]> git.baikalelectronics.ru Git - arm-tf.git/log
arm-tf.git
5 years agoMerge "doc: Fix plat_sdei_validate_entry_point() documentation" into integration
Mark Dykes [Tue, 26 May 2020 15:34:23 +0000 (15:34 +0000)]
Merge "doc: Fix plat_sdei_validate_entry_point() documentation" into integration

5 years agoMerge "doc: Fixes in PSA FF-A binding document" into integration
Olivier Deprez [Tue, 26 May 2020 09:12:32 +0000 (09:12 +0000)]
Merge "doc: Fixes in PSA FF-A binding document" into integration

5 years agoMerge "SPCI is now called PSA FF-A" into integration
Olivier Deprez [Tue, 26 May 2020 09:11:44 +0000 (09:11 +0000)]
Merge "SPCI is now called PSA FF-A" into integration

5 years agodoc: Fix plat_sdei_validate_entry_point() documentation
Sandrine Bailleux [Fri, 15 May 2020 10:05:51 +0000 (12:05 +0200)]
doc: Fix plat_sdei_validate_entry_point() documentation

Document the second argument of the function.
Minor rewording.

Change-Id: I190794b8cc74c99db4cfe6efc225217c32dd0774
Signed-off-by: Sandrine Bailleux <sandrine.bailleux@arm.com>
5 years agodoc: Fixes in PSA FF-A binding document
Louis Mayencourt [Wed, 8 Apr 2020 12:04:33 +0000 (13:04 +0100)]
doc: Fixes in PSA FF-A binding document

- Fix possible run-time ELs value and xlat-granule size.
- Remove mandatory field for stream-ids.
- Define interrupts attributes to <u32>.
- Remove mem-manage field.
- Add description for memory/device region attributes.

Co-authored-by: Manish Pandey <manish.pandey2@arm.com>
Signed-off-by: Louis Mayencourt <louis.mayencourt@arm.com>
Signed-off-by: Manish Pandey <manish.pandey2@arm.com>
Change-Id: I71cf4406c78eaf894fa6532f83467a6f4110b344

5 years agoSPCI is now called PSA FF-A
J-Alves [Thu, 7 May 2020 17:42:25 +0000 (18:42 +0100)]
SPCI is now called PSA FF-A

SPCI is renamed as PSA FF-A which stands for Platform Security
Architecture Firmware Framework for A class processors.
This patch replaces the occurrence of SPCI with PSA FF-A(in documents)
or simply FFA(in code).

Change-Id: I4ab10adb9ffeef1ff784641dfafd99f515133760
Signed-off-by: J-Alves <joao.alves@arm.com>
5 years agoMerge "plat/arm/fvp: populate runtime console parameters dynamically" into integration
Mark Dykes [Fri, 22 May 2020 17:45:46 +0000 (17:45 +0000)]
Merge "plat/arm/fvp: populate runtime console parameters dynamically" into integration

5 years agoMerge "Tegra: enable SDEI handling" into integration
Mark Dykes [Thu, 21 May 2020 21:24:22 +0000 (21:24 +0000)]
Merge "Tegra: enable SDEI handling" into integration

5 years agoMerge "Tegra194: validate C6 power state type" into integration
Mark Dykes [Thu, 21 May 2020 21:17:25 +0000 (21:17 +0000)]
Merge "Tegra194: validate C6 power state type" into integration

5 years agoMerge "Tegra194: remove support for CPU suspend power down state" into integration
Mark Dykes [Thu, 21 May 2020 21:16:34 +0000 (21:16 +0000)]
Merge "Tegra194: remove support for CPU suspend power down state" into integration

5 years agoMerge "FVP: Add support for passing platform's topology to DTS" into integration
Manish Pandey [Thu, 21 May 2020 20:12:24 +0000 (20:12 +0000)]
Merge "FVP: Add support for passing platform's topology to DTS" into integration

5 years agoMerge "plat/fvp: Support for extracting UART serial node info from DT" into integration
Mark Dykes [Thu, 21 May 2020 19:23:03 +0000 (19:23 +0000)]
Merge "plat/fvp: Support for extracting UART serial node info from DT" into integration

5 years agoplat/arm/fvp: populate runtime console parameters dynamically
Madhukar Pappireddy [Thu, 16 Apr 2020 22:54:25 +0000 (17:54 -0500)]
plat/arm/fvp: populate runtime console parameters dynamically

We query the UART base address and clk frequency in runtime
using fconf getter APIs.

Change-Id: I5f4e84953be5f384472bf90720b706d45cb86260
Signed-off-by: Madhukar Pappireddy <madhukar.pappireddy@arm.com>
5 years agoplat/fvp: Support for extracting UART serial node info from DT
Madhukar Pappireddy [Tue, 24 Mar 2020 15:03:34 +0000 (10:03 -0500)]
plat/fvp: Support for extracting UART serial node info from DT

This patch introduces the populate function which leverages
a new driver to extract base address and clk frequency properties
of the uart serial node from HW_CONFIG device tree.

This patch also introduces fdt helper API fdtw_translate_address()
which helps in performing address translation.

Change-Id: I053628065ebddbde0c9cb3aa93d838619f502ee3
Signed-off-by: Madhukar Pappireddy <madhukar.pappireddy@arm.com>
5 years agoMerge "Enable v8.6 WFE trap delays" into integration
Mark Dykes [Wed, 20 May 2020 22:45:43 +0000 (22:45 +0000)]
Merge "Enable v8.6 WFE trap delays" into integration

5 years agoTegra: enable SDEI handling
Varun Wadekar [Sat, 18 Apr 2020 02:09:21 +0000 (19:09 -0700)]
Tegra: enable SDEI handling

This patch enables SDEI support for all Tegra platforms, with
the following configuration settings.

* SGI 8 as the source IRQ
* Special Private Event 0
* Three private, dynamic events
* Three shared, dynamic events
* Twelve general purpose explicit events

Verified using TFTF SDEI test suite.

******************************* Summary *******************************
 Test suite 'SDEI'                                               Passed
 =================================
 Tests Skipped : 0
 Tests Passed  : 5
 Tests Failed  : 0
 Tests Crashed : 0
 Total tests   : 5
 =================================

Signed-off-by: Varun Wadekar <vwadekar@nvidia.com>
Change-Id: I1922069931a7876a4594e53260ee09f2e4f09390

5 years agoMerge "plat/fvp: Populate GICv3 parameters dynamically" into integration
Mark Dykes [Wed, 20 May 2020 15:41:01 +0000 (15:41 +0000)]
Merge "plat/fvp: Populate GICv3 parameters dynamically" into integration

5 years agoMerge "Tegra: enable stack protection" into integration
Sandrine Bailleux [Wed, 20 May 2020 08:11:13 +0000 (08:11 +0000)]
Merge "Tegra: enable stack protection" into integration

5 years agoEnable v8.6 WFE trap delays
johpow01 [Wed, 22 Apr 2020 19:05:13 +0000 (14:05 -0500)]
Enable v8.6 WFE trap delays

This patch enables the v8.6 extension to add a delay before WFE traps
are taken. A weak hook plat_arm_set_twedel_scr_el3 has been added in
plat/common/aarch64/plat_common.c that disables this feature by default
but platform-specific code can override it when needed.

The only hook provided sets the TWED fields in SCR_EL3, there are similar
fields in HCR_EL2, SCTLR_EL2, and SCTLR_EL1 to control WFE trap delays in
lower ELs but these should be configured by code running at EL2 and/or EL1
depending on the platform configuration and is outside the scope of TF-A.

Signed-off-by: John Powell <john.powell@arm.com>
Change-Id: I0a9bb814205efeab693a3d0a0623e62144abba2d

5 years agoplat/fvp: Populate GICv3 parameters dynamically
laurenw-arm [Tue, 12 May 2020 15:58:11 +0000 (10:58 -0500)]
plat/fvp: Populate GICv3 parameters dynamically

Query the GICD and GICR base addresses in runtime using fconf getter
APIs.

Signed-off-by: Lauren Wehrmeister <lauren.wehrmeister@arm.com>
Change-Id: I309fb2874f3329ddeb8677ddb53ed4c02199a1e9

5 years agoMerge "Fix exception in save/restore of EL2 registers." into integration
Manish Pandey [Tue, 19 May 2020 15:56:37 +0000 (15:56 +0000)]
Merge "Fix exception in save/restore of EL2 registers." into integration

5 years agoFix exception in save/restore of EL2 registers.
Max Shvetsov [Wed, 13 May 2020 17:15:39 +0000 (18:15 +0100)]
Fix exception in save/restore of EL2 registers.

Removing FPEXC32_EL2 from the register save/restore routine for EL2
registers since it is already a part of save/restore routine for
fpregs.

Signed-off-by: Max Shvetsov <maksims.svecovs@arm.com>
Change-Id: I5ed45fdbf7c8efa8dcfcd96586328d4f6b256bc4

5 years agoFVP: Add support for passing platform's topology to DTS
Alexei Fedorov [Wed, 13 May 2020 20:13:57 +0000 (21:13 +0100)]
FVP: Add support for passing platform's topology to DTS

This patch adds support for passing FVP platform's topology
configuration to DTS files for compilation, which allows to
build DTBs with correct number of clusters and CPUs.
This removes non-existing clusters/CPUs from the compiled
device tree blob and fixes reported Linux errors when trying
to power on absent CPUs/PEs.
If DTS file is passed using FVP_HW_CONFIG_DTS build option from
the platform's makefile, FVP_CLUSTER_COUNT, FVP_MAX_CPUS_PER_CLUSTER
and FVP_MAX_PE_PER_CPU parameters are used, otherwise CI script will
use the default values from the corresponding DTS file.

Change-Id: Idcb45dc6ad5e3eaea18573aff1a01c9344404ab3
Signed-off-by: Alexei Fedorov <Alexei.Fedorov@arm.com>
5 years agoMerge "Fix compilation error when ENABLE_PIE=1" into integration
Sandrine Bailleux [Tue, 19 May 2020 11:27:13 +0000 (11:27 +0000)]
Merge "Fix compilation error when ENABLE_PIE=1" into integration

5 years agoTegra: enable stack protection
Varun Wadekar [Sun, 17 May 2020 05:10:09 +0000 (22:10 -0700)]
Tegra: enable stack protection

This patch sets ENABLE_STACK_PROTECTOR=strong and implements
the platform support to generate a stack protection canary value.

Signed-off-by: Varun Wadekar <vwadekar@nvidia.com>
Change-Id: Ia8afe464b5645917b1c77d49305d19c7cd01866a

5 years agoFix compilation error when ENABLE_PIE=1
Varun Wadekar [Sun, 17 May 2020 03:59:30 +0000 (20:59 -0700)]
Fix compilation error when ENABLE_PIE=1

This patch fixes compilation errors when ENABLE_PIE=1.

<snip>
bl31/aarch64/bl31_entrypoint.S: Assembler messages:
bl31/aarch64/bl31_entrypoint.S:61: Error: invalid operand (*UND* section) for `~'
bl31/aarch64/bl31_entrypoint.S:61: Error: invalid immediate
Makefile:1079: recipe for target 'build/tegra/t194/debug/bl31/bl31_entrypoint.o' failed
<snip>

Verified by setting 'ENABLE_PIE=1' for Tegra platform builds.

Signed-off-by: Varun Wadekar <vwadekar@nvidia.com>
Change-Id: Ifd184f89b86b4360fda86a6ce83fd8495f930bbc

5 years agoMerge "plat/arm/fvp: Support performing SDEI platform setup in runtime" into integration
Mark Dykes [Fri, 15 May 2020 18:32:50 +0000 (18:32 +0000)]
Merge "plat/arm/fvp: Support performing SDEI platform setup in runtime" into integration

5 years agoplat/arm/fvp: Support performing SDEI platform setup in runtime
Balint Dobszay [Wed, 18 Dec 2019 14:28:00 +0000 (15:28 +0100)]
plat/arm/fvp: Support performing SDEI platform setup in runtime

This patch introduces dynamic configuration for SDEI setup and is supported
when the new build flag SDEI_IN_FCONF is enabled. Instead of using C arrays
and processing the configuration at compile time, the config is moved to
dts files. It will be retrieved at runtime during SDEI init, using the fconf
layer.

Change-Id: If5c35a7517ba00a9f258d7f3e7c8c20cee169a31
Signed-off-by: Balint Dobszay <balint.dobszay@arm.com>
Co-authored-by: Madhukar Pappireddy <madhukar.pappireddy@arm.com>
5 years agoMerge "Tegra: introduce support for SMCCC_ARCH_SOC_ID" into integration
Manish Pandey [Fri, 15 May 2020 08:57:42 +0000 (08:57 +0000)]
Merge "Tegra: introduce support for SMCCC_ARCH_SOC_ID" into integration

5 years agoMerge "Implement workaround for AT speculative behaviour" into integration
Mark Dykes [Thu, 14 May 2020 14:53:55 +0000 (14:53 +0000)]
Merge "Implement workaround for AT speculative behaviour" into integration

5 years agoImplement workaround for AT speculative behaviour
Manish V Badarkhe [Tue, 28 Apr 2020 03:53:32 +0000 (04:53 +0100)]
Implement workaround for AT speculative behaviour

During context switching from higher EL (EL2 or higher)
to lower EL can cause incorrect translation in TLB due to
speculative execution of AT instruction using out-of-context
translation regime.

Workaround is implemented as below during EL's (EL1 or EL2)
"context_restore" operation:
1. Disable page table walk using SCTLR.M and TCR.EPD0 & EPD1
   bits for EL1 or EL2 (stage1 and stage2 disabled)
2. Save all system registers except TCR and SCTLR (for EL1 and EL2)
3. Do memory barrier operation (isb) to ensure all
   system register writes are done.
4. Restore TCR and SCTLR registers (for EL1 and EL2)

Errata details are available for various CPUs as below:
Cortex-A76: 1165522
Cortex-A72: 1319367
Cortex-A57: 1319537
Cortex-A55: 1530923
Cortex-A53: 1530924

More details can be found in mail-chain:
https://lists.trustedfirmware.org/pipermail/tf-a/2020-April/000445.html

Currently, Workaround is implemented as build option which is default
disabled.

Signed-off-by: Manish V Badarkhe <Manish.Badarkhe@arm.com>
Change-Id: If8545e61f782cb0c2dda7ffbaf50681c825bd2f0

5 years agoMerge changes I35c5abd9,I99e64245 into integration
Manish Pandey [Wed, 13 May 2020 16:06:42 +0000 (16:06 +0000)]
Merge changes I35c5abd9,I99e64245 into integration

* changes:
  SPMD: extract SPMC DTB header size from SPMD
  SPMD: code/comments cleanup

5 years agoMerge "doc: Reorganize maintainers.rst file" into integration
joanna.farley [Wed, 13 May 2020 09:27:41 +0000 (09:27 +0000)]
Merge "doc: Reorganize maintainers.rst file" into integration

5 years agoMerge "doc: Update various process documents" into integration
joanna.farley [Wed, 13 May 2020 09:21:19 +0000 (09:21 +0000)]
Merge "doc: Update various process documents" into integration

5 years agodoc: Reorganize maintainers.rst file
Sandrine Bailleux [Wed, 13 May 2020 06:57:41 +0000 (08:57 +0200)]
doc: Reorganize maintainers.rst file

The maintainers.rst file provides the list of all TF-A modules and their
code owners. As there are quite a lot of modules (and more to come) in
TF-A, it is sometimes hard to find the information.

Introduce categories (core code, drivers/libraries/framework, ...) and
classify each module in the right one.

Note that the core code category is pretty much empty right now but the
plan would be to expand it with further modules (e.g. PSCI, SDEI, TBBR,
...) in a future patch.

Change-Id: Id68a2dd79a8f6b68af5364bbf1c59b20c05f8fe7
Signed-off-by: Sandrine Bailleux <sandrine.bailleux@arm.com>
5 years agodoc: Update various process documents
Sandrine Bailleux [Tue, 12 May 2020 08:36:05 +0000 (10:36 +0200)]
doc: Update various process documents

Most of the changes consist in using the new code owners terminology
(from [1]).

[1] https://developer.trustedfirmware.org/w/collaboration/project-maintenance-process/

Change-Id: Icead20e9335af12aa47d3f1ac5d04ca157b20c82
Signed-off-by: Sandrine Bailleux <sandrine.bailleux@arm.com>
5 years agoSPMD: extract SPMC DTB header size from SPMD
Olivier Deprez [Fri, 7 Feb 2020 14:44:43 +0000 (15:44 +0100)]
SPMD: extract SPMC DTB header size from SPMD

Currently BL2 passes TOS_FW_CONFIG address and size through registers to
BL31. This corresponds to SPMC manifest load address and size. The SPMC
manifest is mapped in BL31 by dynamic mapping. This patch removes BL2
changes from generic code (which were enclosed by SPD=spmd) and retrieves
SPMC manifest size directly from within SPMD. The SPMC manifest load
address is still passed through a register by generic code.

Signed-off-by: Olivier Deprez <olivier.deprez@arm.com>
Change-Id: I35c5abd95c616ae25677302f0b1d0c45c51c042f

5 years agoSPMD: code/comments cleanup
Olivier Deprez [Thu, 16 Apr 2020 11:39:06 +0000 (13:39 +0200)]
SPMD: code/comments cleanup

As a follow-up to bdd2596d4, and related to SPM Dispatcher
EL3 component and SPM Core S-EL2/S-EL1 component: update
with cosmetic and coding rules changes. In addition:
-Add Armv8.4-SecEL2 arch detection helper.
-Add an SPMC context (on current core) get helper.
-Return more meaningful error return codes.
-Remove complexity in few spmd_smc_handler switch-cases.
-Remove unused defines and structures from spmd_private.h

Signed-off-by: Olivier Deprez <olivier.deprez@arm.com>
Change-Id: I99e642450b0dafb19d3218a2f0e2d3107e8ca3fe

5 years agoTegra: introduce support for SMCCC_ARCH_SOC_ID
Varun Wadekar [Tue, 12 May 2020 21:04:10 +0000 (14:04 -0700)]
Tegra: introduce support for SMCCC_ARCH_SOC_ID

This patch returns the SOC version and revision values from
the 'plat_get_soc_version' and 'plat_get_soc_revision' handlers.

Verified using TFTF SMCCC_ARCH_SOC_ID test.

<snip>
> Executing 'SMCCC_ARCH_SOC_ID test'
  TEST COMPLETE                                                 Passed
SOC Rev = 0x102
SOC Ver = 0x36b0019
<snip>

Signed-off-by: Varun Wadekar <vwadekar@nvidia.com>
Change-Id: Ibd7101619143b74f6f6660732daeac1a8bca3e44

5 years agoMerge "Fix SMCCC_ARCH_SOC_ID implementation" into integration
Mark Dykes [Fri, 8 May 2020 18:18:34 +0000 (18:18 +0000)]
Merge "Fix SMCCC_ARCH_SOC_ID implementation" into integration

5 years agoMerge changes from topic "fdt_wrappers_rework" into integration
Sandrine Bailleux [Thu, 7 May 2020 11:51:31 +0000 (11:51 +0000)]
Merge changes from topic "fdt_wrappers_rework" into integration

* changes:
  arm_fpga: Read UART address from DT
  arm_fpga: Read GICD and GICR base addresses from DT
  arm_fpga: Read generic timer counter frequency from DT
  arm_fpga: Use Generic UART

5 years agoMerge changes from topic "fdt_wrappers_rework" into integration
Sandrine Bailleux [Thu, 7 May 2020 08:59:33 +0000 (08:59 +0000)]
Merge changes from topic "fdt_wrappers_rework" into integration

* changes:
  plat/stm32: Use generic fdt_get_stdout_node_offset()
  fdt/wrappers: Introduce code to find UART DT node
  plat/stm32: Use generic fdt_get_reg_props_by_name()

5 years agoTegra194: validate C6 power state type
Varun Wadekar [Wed, 6 May 2020 05:44:20 +0000 (22:44 -0700)]
Tegra194: validate C6 power state type

This patch validates that PSTATE_STANDBY is set as the C6 power state type.

Signed-off-by: Varun Wadekar <vwadekar@nvidia.com>
Change-Id: I26a4a61bcb4ee0d1846ab61c007eeba3c180e5aa

5 years agoTegra194: remove support for CPU suspend power down state
Varun Wadekar [Thu, 23 Apr 2020 16:56:06 +0000 (09:56 -0700)]
Tegra194: remove support for CPU suspend power down state

Tegra194 platforms removed support to power down CPUs during CPU suspend. This
patch removes the support for CPU suspend power down as a result.

Signed-off-by: Varun Wadekar <vwadekar@nvidia.com>
Change-Id: Ifde72c90c194582a79fb80904154b9886413f16e

5 years agoarm_fpga: Read UART address from DT
Andre Przywara [Thu, 9 Apr 2020 09:25:43 +0000 (10:25 +0100)]
arm_fpga: Read UART address from DT

The arm_fpga port requires a DTB, to launch a BL33 payload.
To make this port more flexible, we can also use the information in the
DT to configure the console driver.
For a start, find the DT node pointed to by the stdout-path property, and
read the base address from there.
This assumes for now that the stdout-path points to a PL011 UART.

This allows to remove platform specific addresses from the image. We
keep the original base address for the crash console.

Change-Id: I46a990de2315f81cae4d7913ae99a07b0bec5cb1
Signed-off-by: Andre Przywara <andre.przywara@arm.com>
5 years agoplat/stm32: Use generic fdt_get_stdout_node_offset()
Andre Przywara [Thu, 9 Apr 2020 10:27:21 +0000 (11:27 +0100)]
plat/stm32: Use generic fdt_get_stdout_node_offset()

Now that we have an implementation for getting the node offset of the
stdout-path property in the generic fdt_wrappers code, use that to
replace the current ST platform specific implementation.

Change-Id: I5dd05684e7ca3cb563b5f71c885e1066393e057e
Signed-off-by: Andre Przywara <andre.przywara@arm.com>
5 years agoarm_fpga: Read GICD and GICR base addresses from DT
Andre Przywara [Fri, 24 Jan 2020 15:46:05 +0000 (15:46 +0000)]
arm_fpga: Read GICD and GICR base addresses from DT

Since we use a DTB with all platform information to pass this on to a
kernel loaded as BL33, we can as well make use of it for our own
purposes.

Every DT would contain a node for the GIC(v3) interrupt controller, so
we can read the base address for the distributor and redistributors from
there.

This avoids hard coding this information in the code and allows for a more
flexible binary.

Change-Id: Ic530e223a21a45bc30a07a21048116d5af69e972
Signed-off-by: Andre Przywara <andre.przywara@arm.com>
5 years agofdt/wrappers: Introduce code to find UART DT node
Andre Przywara [Thu, 26 Mar 2020 12:52:06 +0000 (12:52 +0000)]
fdt/wrappers: Introduce code to find UART DT node

The stdout-path property in the /chosen node of a DTB points to a device
node, which is used for boot console output.
On most (if not all) ARM based platforms this is the debug UART.
The ST platform code contains a function to parse this property and
chase down eventual aliases to learn the node offset of this UART node.

Introduce a slightly more generalised version of this ST platform function
in the generic fdt_wrappers code. This will be useful for other platforms
as well.

Change-Id: Ie6da47ace7833861b5e35fe8cba49835db3659a5
Signed-off-by: Andre Przywara <andre.przywara@arm.com>
5 years agoarm_fpga: Read generic timer counter frequency from DT
Andre Przywara [Fri, 24 Jan 2020 15:02:27 +0000 (15:02 +0000)]
arm_fpga: Read generic timer counter frequency from DT

The ARM Generic Timer DT binding describes an (optional) property to
declare the counter frequency. Its usage is normally discouraged, as the
value should be read from the CNTFRQ_EL0 system register.

However in our case we can use it to program this register in the first
place, which avoids us to hard code a counter frequency into the code.
We keep some default value in, if the DT lacks that property for
whatever reason.

Change-Id: I5b71176db413f904f21eb16f3302fbb799cb0305
Signed-off-by: Andre Przywara <andre.przywara@arm.com>
5 years agoplat/stm32: Use generic fdt_get_reg_props_by_name()
Andre Przywara [Thu, 26 Mar 2020 12:11:34 +0000 (12:11 +0000)]
plat/stm32: Use generic fdt_get_reg_props_by_name()

The STM32 platform port parse DT nodes to find base address to
peripherals. It does this by using its own implementation, even though
this functionality is generic and actually widely useful outside of the
STM32 code.

Re-implement fdt_get_reg_props_by_name() on top of the newly introduced
fdt_get_reg_props_by_index() function, and move it to fdt_wrapper.c.
This is removes the assumption that #address-cells and #size-cells are
always one.

Change-Id: I6d584930262c732b6e0356d98aea50b2654f789d
Signed-off-by: Andre Przywara <andre.przywara@arm.com>
5 years agoarm_fpga: Use Generic UART
Andre Przywara [Thu, 9 Apr 2020 09:10:09 +0000 (10:10 +0100)]
arm_fpga: Use Generic UART

The SCP firmware on the ARM FPGA initialises the UART already. This allows
us to treat the PL011 as an SBSA Generic UART, which does not require
any further setup.

This in particular removes the need for any baudrate and base clock related
settings to be hard coded into the BL31 image.

Change-Id: I16fc943526267356b97166a7068459e06ff77f0f
Signed-off-by: Andre Przywara <andre.przywara@arm.com>
5 years agoMerge "rcar_gen3: plat: Zero-terminate the string in unsigned_num_print()" into integ...
Sandrine Bailleux [Tue, 5 May 2020 13:12:33 +0000 (13:12 +0000)]
Merge "rcar_gen3: plat: Zero-terminate the string in unsigned_num_print()" into integration

5 years agoMerge changes I85eb75cf,Ic6d9f927 into integration
Sandrine Bailleux [Tue, 5 May 2020 12:01:48 +0000 (12:01 +0000)]
Merge changes I85eb75cf,Ic6d9f927 into integration

* changes:
  fconf: Update dyn_config compatible string
  doc: Add binding document for fconf.

5 years agoMerge "Fix build type is empty in version string" into integration
Sandrine Bailleux [Tue, 5 May 2020 08:37:47 +0000 (08:37 +0000)]
Merge "Fix build type is empty in version string" into integration

5 years agoFix SMCCC_ARCH_SOC_ID implementation
Manish V Badarkhe [Tue, 28 Apr 2020 12:25:56 +0000 (13:25 +0100)]
Fix SMCCC_ARCH_SOC_ID implementation

Commit 0e753437e75b ("Implement SMCCC_ARCH_SOC_ID SMC call") executes
and return the result of SMCCC_ARCH_SOC_ID(soc_id_type) to the
SMCCC_ARCH_FEATURES(SMCCC_ARCH_SOC_ID) itself. Moreover it expect to
pass soc_id_type for SMCCC_ARCH_FEATURES(SMCCC_ARCH_SOC_ID) which is
incorrect.

Fix the implementation by returning SMC_OK for
SMCCC_ARCH_FEATURES(SMCCC_ARCH_SOC_ID) always and move the current
implementation under "smccc_arch_id" function which gets called from
SMC handler on receiving "SMCCC_ARCH_SOC_ID" command.

This change is tested over linux operating system

Change-Id: I61a980045081eae786b907d408767ba9ecec3468
Signed-off-by: Sudeep Holla <sudeep.holla@arm.com>
Signed-off-by: Manish V Badarkhe <Manish.Badarkhe@arm.com>
5 years agoMerge changes from topic "fdt_wrappers_rework" into integration
Manish Pandey [Mon, 4 May 2020 16:03:54 +0000 (16:03 +0000)]
Merge changes from topic "fdt_wrappers_rework" into integration

* changes:
  arm: fconf: Fix GICv3 dynamic configuration
  plat/stm32: Implement fdt_read_uint32_default() as a wrapper
  fdt/wrappers: Replace fdtw_read_cells() implementation
  plat/stm32: Use generic fdt_read_uint32_array() implementation
  fdt/wrappers: Generalise fdtw_read_array()

5 years agoarm: fconf: Fix GICv3 dynamic configuration
Andre Przywara [Thu, 26 Mar 2020 11:57:43 +0000 (11:57 +0000)]
arm: fconf: Fix GICv3 dynamic configuration

At the moment the fconf_populate_gicv3_config() implementation is
somewhat incomplete: First it actually fails to store the retrieved
information (the local addr[] array is going nowhere), but also it makes
quite some assumptions about the device tree passed to it: it needs to
use two address-cells and two size-cells, and also requires all five
register regions to be specified, where actually only the first two
are mandatory according to the binding (and needed by our code).

Fix this by introducing a proper generic function to retrieve "reg"
property information from a DT node:
We retrieve the #address-cells and #size-cells properties from the
parent node, then use those to extract the right values from the "reg"
property. The function takes an index to select one region of a reg
property.

This is loosely based on the STM32 implementation using "reg-names",
which we will subsume in a follow-up patch.

Change-Id: Ia59bfdf80aea4e36876c7b6ed4d153e303f482e8
Signed-off-by: Andre Przywara <andre.przywara@arm.com>
5 years agofconf: Update dyn_config compatible string
Louis Mayencourt [Mon, 20 Apr 2020 13:17:21 +0000 (14:17 +0100)]
fconf: Update dyn_config compatible string

Dynamic configuration properties are fconf properties. Modify the
compatible string from "arm,.." to "fconf,.." to reflect this.

Signed-off-by: Louis Mayencourt <louis.mayencourt@arm.com>
Change-Id: I85eb75cf877c5f4d3feea3936d4c348ca843bc6c

5 years agodoc: Add binding document for fconf.
Louis Mayencourt [Mon, 20 Apr 2020 13:14:10 +0000 (14:14 +0100)]
doc: Add binding document for fconf.

Complete the documentation with information on how to write a DTS for
fconf. This patch adds the bindings information for dynamic
configuration properties.

Signed-off-by: Louis Mayencourt <louis.mayencourt@arm.com>
Change-Id: Ic6d9f927df53bb87315c23ec5a8943d0c3258d45

5 years agoplat/stm32: Implement fdt_read_uint32_default() as a wrapper
Andre Przywara [Thu, 26 Mar 2020 11:50:33 +0000 (11:50 +0000)]
plat/stm32: Implement fdt_read_uint32_default() as a wrapper

The STM32 platform code uses its own set of FDT helper functions,
although some of them are fairly generic.

Remove the implementation of fdt_read_uint32_default() and implement it
on top of the newly introduced fdt_read_uint32() function, then convert
all users over.

This also fixes two callers, which were slightly abusing the "default"
semantic.

Change-Id: I570533362b4846e58dd797a92347de3e0e5abb75
Signed-off-by: Andre Przywara <andre.przywara@arm.com>
5 years agofdt/wrappers: Replace fdtw_read_cells() implementation
Andre Przywara [Thu, 26 Mar 2020 11:22:37 +0000 (11:22 +0000)]
fdt/wrappers: Replace fdtw_read_cells() implementation

Our fdtw_read_cells() implementation goes to great lengths to
sanity-check every parameter and result, but leaves a big hole open:
The size of the storage the value pointer points at needs to match the
number of cells given. This can't be easily checked at compile time,
since we lose the size information by using a void pointer.
Regardless the current usage of this function is somewhat wrong anyways,
since we use it on single-element, fixed-length properties only, for
which the DT binding specifies the size.
Typically we use those functions dealing with a number of cells in DT
context to deal with *dynamically* sized properties, which depend on
other properties (#size-cells, #clock-cells, ...), to specify the number
of cells needed.

Another problem with the current implementation is the use of
ambiguously sized types (uintptr_t, size_t) together with a certain
expectation about their size. In general there is no relation between
the length of a DT property and the bitness of the code that parses the
DTB: AArch64 code could encounter 32-bit addresses (where the physical
address space is limited to 4GB [1]), while AArch32 code could read
64-bit sized properties (/memory nodes on LPAE systems, [2]).

To make this more clear, fix the potential issues and also align more
with other DT users (Linux and U-Boot), introduce functions to explicitly
read uint32 and uint64 properties. As the other DT consumers, we do this
based on the generic "read array" function.
Convert all users to use either of those two new functions, and make
sure we never use a pointer to anything other than uint32_t or uint64_t
variables directly.

This reveals (and fixes) a bug in plat_spmd_manifest.c, where we write
4 bytes into a uint16_t variable (passed via a void pointer).

Also we change the implementation of the function to better align with
other libfdt users, by using the right types (fdt32_t) and common
variable names (*prop, prop_names).

[1] https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/arch/arm64/boot/dts/allwinner/sun50i-a64.dtsi#n874
[2] https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/arch/arm/boot/dts/ecx-2000.dts

Change-Id: I718de960515117ac7a3331a1b177d2ec224a3890
Signed-off-by: Andre Przywara <andre.przywara@arm.com>
5 years agoplat/stm32: Use generic fdt_read_uint32_array() implementation
Andre Przywara [Thu, 26 Mar 2020 12:51:21 +0000 (12:51 +0000)]
plat/stm32: Use generic fdt_read_uint32_array() implementation

The device tree parsing code for the STM32 platform is using its own FDT
helper functions, some of them being rather generic.
In particular the existing fdt_read_uint32_array() implementation is now
almost identical to the new generic code in fdt_wrappers.c, so we can
remove the ST specific version and adjust the existing callers.

Compared to the original ST implementation the new version takes a
pointer to the DTB as the first argument, and also swaps the order of
the number of cells and the pointer.

Change-Id: Id06b0f1ba4db1ad1f733be40e82c34f46638551a
Signed-off-by: Andre Przywara <andre.przywara@arm.com>
5 years agofdt/wrappers: Generalise fdtw_read_array()
Andre Przywara [Mon, 30 Mar 2020 22:21:13 +0000 (23:21 +0100)]
fdt/wrappers: Generalise fdtw_read_array()

Currently our fdtw_read_array() implementation requires the length of
the property to exactly match the requested size, which makes it less
flexible for parsing generic device trees.
Also the name is slightly misleading, since we treat the cells of the
array as 32 bit unsigned integers, performing the endianess conversion.

To fix those issues and align the code more with other DT users (Linux
kernel or U-Boot), rename the function to "fdt_read_uint32_array", and
relax the length check to only check if the property covers at least the
number of cells we request.
This also changes the variable names to be more in-line with other DT
users, and switches to the proper data types.

This makes this function more useful in later patches.

Change-Id: Id86f4f588ffcb5106d4476763ecdfe35a735fa6c
Signed-off-by: Andre Przywara <andre.przywara@arm.com>
5 years agorcar_gen3: plat: Zero-terminate the string in unsigned_num_print()
Marek Vasut [Sat, 11 Apr 2020 17:02:29 +0000 (19:02 +0200)]
rcar_gen3: plat: Zero-terminate the string in unsigned_num_print()

Make sure the string generated in unsigned_num_print() is zero-terminated.

Signed-off-by: Marek Vasut <marek.vasut+renesas@gmail.com>
Change-Id: Ic0ac1ebca255002522159a9152ab41991f043d05

5 years agoMerge changes from topic "linker-script" into integration
Sandrine Bailleux [Mon, 27 Apr 2020 08:45:34 +0000 (08:45 +0000)]
Merge changes from topic "linker-script" into integration

* changes:
  linker_script: move .data section to bl_common.ld.h
  linker_script: move stacks section to bl_common.ld.h
  bl1: remove '.' from stacks section in linker script

5 years agolinker_script: move .data section to bl_common.ld.h
Masahiro Yamada [Wed, 22 Apr 2020 01:50:12 +0000 (10:50 +0900)]
linker_script: move .data section to bl_common.ld.h

Move the data section to the common header.

I slightly tweaked some scripts as follows:

[1] bl1.ld.S has ALIGN(16). I added DATA_ALIGN macro, which is 1
    by default, but overridden by bl1.ld.S. Currently, ALIGN(16)
    of the .data section is redundant because commit 412865907699
    ("Fix boot failures on some builds linked with ld.lld.") padded
    out the previous section to work around the issue of LLD version
    <= 10.0. This will be fixed in the future release of LLVM, so
    I am keeping the proper way to align LMA.

[2] bl1.ld.S and bl2_el3.ld.S define __DATA_RAM_{START,END}__ instead
    of __DATA_{START,END}__. I put them out of the .data section.

[3] SORT_BY_ALIGNMENT() is missing tsp.ld.S, sp_min.ld.S, and
    mediatek/mt6795/bl31.ld.S. This commit adds SORT_BY_ALIGNMENT()
    for all images, so the symbol order in those three will change,
    but I do not think it is a big deal.

Change-Id: I215bb23c319f045cd88e6f4e8ee2518c67f03692
Signed-off-by: Masahiro Yamada <yamada.masahiro@socionext.com>
5 years agoFix build type is empty in version string
Peiyuan Song [Sat, 25 Apr 2020 08:53:43 +0000 (16:53 +0800)]
Fix build type is empty in version string

Signed-off-by: Peiyuan Song <squallatf@gmail.com>
Change-Id: I97c2e6f8c12ecf828605811019d47a24293c1ebb

5 years agolinker_script: move stacks section to bl_common.ld.h
Masahiro Yamada [Tue, 7 Apr 2020 04:04:24 +0000 (13:04 +0900)]
linker_script: move stacks section to bl_common.ld.h

The stacks section is the same for all BL linker scripts.

Move it to the common header file.

Change-Id: Ibd253488667ab4f69702d56ff9e9929376704f6c
Signed-off-by: Masahiro Yamada <yamada.masahiro@socionext.com>
5 years agobl1: remove '.' from stacks section in linker script
Masahiro Yamada [Tue, 7 Apr 2020 02:17:38 +0000 (11:17 +0900)]
bl1: remove '.' from stacks section in linker script

Only BL1 specifies '.' in the address field of the stacks section.

Commit 4f59d8359f97 ("Make BL1 RO and RW base addresses configurable")
added '.' on purpose but the commit message does not help to understand
why.

This commit gets rid of it in order to factor out the stacks section
into include/common/bl_common.ld.h

I compared the build result for PLAT=qemu.

'aarch64-linux-gnu-nm -n build/qemu/release/bl1/bl1.elf' will change
as follows:

@@ -336,8 +336,8 @@
 000000000e04e0e0 d max_log_level
 000000000e04e0e4 D console_state
 000000000e04e0e5 D __DATA_RAM_END__
-000000000e04e0e5 B __STACKS_START__
 000000000e04e100 b platform_normal_stacks
+000000000e04e100 B __STACKS_START__
 000000000e04f100 b bl1_cpu_context
 000000000e04f100 B __BSS_START__
 000000000e04f100 B __STACKS_END__

After this change, __STACKS_START__ will match to platform_normal_stacks,
and I think it makes more sense.

'aarch64-linux-gnu-objdump -h build/qemu/release/bl1/bl1.elf' will change
as follows:

@@ -9,11 +9,11 @@
                   CONTENTS, ALLOC, LOAD, READONLY, DATA
   2 .data         000000e5  000000000e04e000  0000000000004a60  0001e000  2**4
                   CONTENTS, ALLOC, LOAD, DATA
-  3 stacks        0000101b  000000000e04e0e5  000000000e04e0e5  0001e0e5  2**6
+  3 stacks        00001000  000000000e04e100  0000000000004b45  0001e100  2**6
                   ALLOC
-  4 .bss          000007e0  000000000e04f100  000000000e04f100  0001e0e5  2**5
+  4 .bss          000007e0  000000000e04f100  0000000000004b50  0001f100  2**5
                   ALLOC
-  5 xlat_table    00006000  000000000e050000  000000000e050000  0001e0e5  2**12
+  5 xlat_table    00006000  000000000e050000  0000000000004b45  00020000  2**12
                   ALLOC
   6 coherent_ram  00000000  000000000e056000  000000000e056000  0001f000  2**12
                   CONTENTS

Sandrine pointed me to a useful document [1] to understand why LMAs of
stacks, .bss, and xlat_table section have changed.

Before this patch, they fell into this scenario:
 "If the section has a specific VMA address, then this is used as the
  LMA address as well."

With this commit, the following applies:
 "Otherwise if a memory region can be found that is compatible with the
  current section, and this region contains at least one section, then
  the LMA is set so the difference between the VMA and LMA is the same
  as the difference between the VMA and LMA of the last section in the
  located region."

Anyway, those three sections are not loaded, so the LMA changes will not
be a problem. The size of bl1.bin is still the same.

QEMU still boots successfully with this change.

A good thing is, this fixes the error for the latest LLD. If I use the
mainline LLVM, I see the following error. The alignment check will probably
be included in the LLVM 11 release, so it is better to fix it now.

$ PLAT=qemu CC=clang CROSS_COMPILE=aarch64-linux-gnu-
  [ snip ]
ld.lld: error: address (0xe04e0e5) of section stacks is not a multiple of alignment (64)
make: *** [Makefile:1050: build/qemu/release/bl1/bl1.elf] Error 1

[1]: https://sourceware.org/binutils/docs/ld/Output-Section-LMA.html#Output-Section-LMA

Change-Id: I3d2f3cc2858be8b3ce2eab3812a76d1e0b5f3a32
Signed-off-by: Masahiro Yamada <yamada.masahiro@socionext.com>
5 years agoMerge "Provide a hint to power controller for DSU cluster power down" into integration
Sandrine Bailleux [Fri, 24 Apr 2020 09:08:33 +0000 (09:08 +0000)]
Merge "Provide a hint to power controller for DSU cluster power down" into integration

5 years agoMerge "board/rddanielxlr: add support for rd-daniel config-xlr platform" into integration
Manish Pandey [Thu, 23 Apr 2020 20:35:48 +0000 (20:35 +0000)]
Merge "board/rddanielxlr: add support for rd-daniel config-xlr platform" into integration

5 years agoMerge "spm: Normalize the style of spm core manifest" into integration
Manish Pandey [Thu, 23 Apr 2020 11:33:55 +0000 (11:33 +0000)]
Merge "spm: Normalize the style of spm core manifest" into integration

5 years agospm: Normalize the style of spm core manifest
Louis Mayencourt [Tue, 31 Mar 2020 09:51:46 +0000 (10:51 +0100)]
spm: Normalize the style of spm core manifest

Signed-off-by: Louis Mayencourt <louis.mayencourt@arm.com>
Change-Id: Ib39e53eb53521b8651fb30b7bf0058f7669569d5

5 years agoboard/rddanielxlr: add support for rd-daniel config-xlr platform
Aditya Angadi [Mon, 6 Apr 2020 11:41:23 +0000 (17:11 +0530)]
board/rddanielxlr: add support for rd-daniel config-xlr platform

RD-Daniel Config-XLR platform has four identical chips connected via a
high speed coherent CCIX link. Each chip has four Neoverse cores
connected via coherent CMN interconnect.

Change-Id: I37d1b91f2b6ba08f61c64d0288bc16a429836c08
Signed-off-by: Aditya Angadi <aditya.angadi@arm.com>
5 years agoMerge "fdts: a5ds: Fix for the system timer issue." into integration
Sandrine Bailleux [Wed, 22 Apr 2020 06:35:15 +0000 (06:35 +0000)]
Merge "fdts: a5ds: Fix for the system timer issue." into integration

5 years agoMerge "doc: Treat Sphinx warnings as errors" into integration
Sandrine Bailleux [Tue, 21 Apr 2020 09:38:01 +0000 (09:38 +0000)]
Merge "doc: Treat Sphinx warnings as errors" into integration

5 years agodoc: Treat Sphinx warnings as errors
Sandrine Bailleux [Fri, 17 Apr 2020 12:19:20 +0000 (14:19 +0200)]
doc: Treat Sphinx warnings as errors

'make doc' will now fail if Sphinx outputs any warning messages during
documentation generation.

Change-Id: I3e466af58ccf29b14a7e61037539b79ab6fc6037
Signed-off-by: Sandrine Bailleux <sandrine.bailleux@arm.com>
5 years agoMerge "Incrementing the minor version to reflect upcoming v2.3 release" into integration
Mark Dykes [Mon, 20 Apr 2020 15:56:43 +0000 (15:56 +0000)]
Merge "Incrementing the minor version to reflect upcoming v2.3 release" into integration

5 years agoIncrementing the minor version to reflect upcoming v2.3 release
Madhukar Pappireddy [Mon, 20 Apr 2020 05:01:09 +0000 (00:01 -0500)]
Incrementing the minor version to reflect upcoming v2.3 release

Change-Id: I27f7d92988fc16f68041c2ddaa8dd3a60362ddd1
Signed-off-by: Madhukar Pappireddy <madhukar.pappireddy@arm.com>
5 years agofdts: a5ds: Fix for the system timer issue.
lakshmi Kailasanathan [Fri, 17 Apr 2020 11:52:19 +0000 (12:52 +0100)]
fdts: a5ds: Fix for the system timer issue.

A5DS FPGA system timer clock frequency is 7.5Mhz.
The dt is file updated inline with the hardware
clock frequency.

Change-Id: I3f6c2e0d4a7b293175a42cf398a8730448504af9
Signed-off-by: lakshmi Kailasanathan <lakshmi.Kailasanathan@arm.com>
5 years agoMerge "juno/sgm: Align SCP_BL2 to page boundary" into integration
Mark Dykes [Fri, 17 Apr 2020 15:25:21 +0000 (15:25 +0000)]
Merge "juno/sgm: Align SCP_BL2 to page boundary" into integration

5 years agoMerge "doc: Fixup some SMCCC links" into integration
Mark Dykes [Fri, 17 Apr 2020 15:23:47 +0000 (15:23 +0000)]
Merge "doc: Fixup some SMCCC links" into integration

5 years agojuno/sgm: Align SCP_BL2 to page boundary
Chris Kay [Fri, 17 Apr 2020 09:36:34 +0000 (10:36 +0100)]
juno/sgm: Align SCP_BL2 to page boundary

This commit fixes an assertion that was triggering in certain contexts:

    ERROR: mmap_add_region_check() failed. error -22
    ASSERT: lib/xlat_tables_v2/xlat_tables_core.c:790

Change-Id: Ia55b3fb4f496c8cd791ea6093d122edae0a7e92a
Signed-off-by: Chris Kay <chris.kay@arm.com>
Signed-off-by: Sandrine Bailleux <sandrine.bailleux@arm.com>
5 years agodoc: Fixup some SMCCC links
Sandrine Bailleux [Fri, 17 Apr 2020 12:06:52 +0000 (14:06 +0200)]
doc: Fixup some SMCCC links

This is a fixup for patch 3ba55a3c5fa260c9218be1adff8f39fc2a568d68
("docs: Update SMCCC doc, other changes for release"), where some
links names got changed but their references didn't.

Change-Id: I980d04dde338f3539a2ec1ae2e807440587b1cf5
Signed-off-by: Sandrine Bailleux <sandrine.bailleux@arm.com>
5 years agoMerge "doc: Set fconf as experimental feature" into integration
Sandrine Bailleux [Fri, 17 Apr 2020 08:35:33 +0000 (08:35 +0000)]
Merge "doc: Set fconf as experimental feature" into integration

5 years agoMerge "docs: Update SMCCC doc, other changes for release" into integration
Mark Dykes [Thu, 16 Apr 2020 21:04:44 +0000 (21:04 +0000)]
Merge "docs: Update SMCCC doc, other changes for release" into integration

5 years agoMerge "docs: Updating Change log for v2.3 Release" into integration
Mark Dykes [Thu, 16 Apr 2020 21:04:17 +0000 (21:04 +0000)]
Merge "docs: Updating Change log for v2.3 Release" into integration

5 years agodoc: Set fconf as experimental feature
Louis Mayencourt [Thu, 9 Apr 2020 15:32:20 +0000 (16:32 +0100)]
doc: Set fconf as experimental feature

Following the messages on the mailing list regarding the possible issue around
reading DTB's information, we decided to flag the fconf feature as experimental.
A uniform approach should be used to handle properties miss and DTB validation.

Signed-off-by: Louis Mayencourt <louis.mayencourt@arm.com>
Change-Id: Ib3c86e81fb2e89452c593f68d825d3d8f505e1fb

5 years agodocs: Updating Change log for v2.3 Release
laurenw-arm [Tue, 14 Apr 2020 21:44:52 +0000 (16:44 -0500)]
docs: Updating Change log for v2.3 Release

Updating the change log for the v2.3 release and the upcoming change log
template for v2.4 release.

Signed-off-by: Lauren Wehrmeister <lauren.wehrmeister@arm.com>
Change-Id: Ice875d3c93227069738a429d4b945512af8470e9

5 years agodocs: Update SMCCC doc, other changes for release
laurenw-arm [Thu, 16 Apr 2020 15:02:17 +0000 (10:02 -0500)]
docs: Update SMCCC doc, other changes for release

Signed-off-by: Lauren Wehrmeister <lauren.wehrmeister@arm.com>
Change-Id: Ie842d6a9919776de151a4e9304f870aede07c47a

5 years agoMerge "docs: Fixes and updates for the v2.3 release" into integration
Sandrine Bailleux [Thu, 16 Apr 2020 07:42:55 +0000 (07:42 +0000)]
Merge "docs: Fixes and updates for the v2.3 release" into integration

5 years agoMerge "docs: Updating Release information for v2.4" into integration
joanna.farley [Thu, 16 Apr 2020 07:12:39 +0000 (07:12 +0000)]
Merge "docs: Updating Release information for v2.4" into integration

5 years agodocs: Fixes and updates for the v2.3 release
laurenw-arm [Wed, 15 Apr 2020 22:48:36 +0000 (17:48 -0500)]
docs: Fixes and updates for the v2.3 release

A small set of misc changes to ensure correctness before the v2.3
release.

Signed-off-by: Lauren Wehrmeister <lauren.wehrmeister@arm.com>
Change-Id: I5b4e35b3b46616df0453cecff61f5a414951cd62

5 years agodocs: Updating Release information for v2.4
laurenw-arm [Wed, 15 Apr 2020 20:19:50 +0000 (15:19 -0500)]
docs: Updating Release information for v2.4

Signed-off-by: Lauren Wehrmeister <lauren.wehrmeister@arm.com>
Change-Id: I5a7ae778999295f3453b7ab0bfc26351e545fb8f

5 years agoProvide a hint to power controller for DSU cluster power down
Madhukar Pappireddy [Wed, 30 Oct 2019 19:24:39 +0000 (14:24 -0500)]
Provide a hint to power controller for DSU cluster power down

By writing 0 to CLUSTERPWRDN DSU register bit 0, we send an
advisory to the power controller that cluster power is not required
when all cores are powered down.

The AArch32 CLUSTERPWRDN register is architecturally mapped to the
AArch64 CLUSTERPWRDN_EL1 register

Change-Id: Ie6e67c1c7d811fa25c51e2e405ca7f59bd20c81b
Signed-off-by: Madhukar Pappireddy <madhukar.pappireddy@arm.com>
5 years agoMerge "plat/arm/sgi: update mmap and xlat count" into integration
Manish Pandey [Wed, 15 Apr 2020 11:25:08 +0000 (11:25 +0000)]
Merge "plat/arm/sgi: update mmap and xlat count" into integration

5 years agoMerge "Fix Broadcom Stingray platform documentation" into integration
Sandrine Bailleux [Wed, 15 Apr 2020 10:29:27 +0000 (10:29 +0000)]
Merge "Fix Broadcom Stingray platform documentation" into integration

5 years agoFix Broadcom Stingray platform documentation
Sandrine Bailleux [Wed, 15 Apr 2020 09:13:38 +0000 (11:13 +0200)]
Fix Broadcom Stingray platform documentation

 - Include the platform documentation in the table of contents.

 - Add a title for the document. Without this, the platform
   documentation was listed under a 'Description' title on page
   https://trustedfirmware-a.readthedocs.io/en/latest/plat/index.html

 - Change TF-A git repository URL to point to tf.org (rather than the
   deprecated read-only mirror on Github).

 - Fix the restructuredText syntax for the FIP command line. It was
   not displayed at all on the rendered version.

Change-Id: I7a0f062bcf8e0dfc65e8f8bdd6775c497a47e619
Signed-off-by: Sandrine Bailleux <sandrine.bailleux@arm.com>
5 years agoplat/arm/sgi: update mmap and xlat count
Aditya Angadi [Wed, 8 Apr 2020 08:47:08 +0000 (14:17 +0530)]
plat/arm/sgi: update mmap and xlat count

A single chip platform requires five mmap entries and a corresponding
number of translation tables. For every additional chip in the system,
three additional mmap entries are required to map the shared SRAM and
the IO regions. A corresponding number of additional translation
tables are required as well.

Change-Id: I1332a1305f2af62181387cf36954f6fb0e6f11ed
Signed-off-by: Aditya Angadi <aditya.angadi@arm.com>
5 years agoMerge "stingray: fix coverity reported issues on brcm platform" into integration
Sandrine Bailleux [Tue, 14 Apr 2020 07:54:26 +0000 (07:54 +0000)]
Merge "stingray: fix coverity reported issues on brcm platform" into integration