]> git.baikalelectronics.ru Git - arm-tf.git/commit
feat(allwinner): add support for Allwinner T507 SoC
authorMikhail Kalashnikov <iuncuim@gmail.com>
Mon, 27 Mar 2023 15:36:14 +0000 (18:36 +0300)
committerAndre Przywara <andre.przywara@arm.com>
Wed, 26 Apr 2023 16:45:29 +0000 (17:45 +0100)
commit018c1d878fbfd696ebeda52b5188e4658b87bf75
tree6c525fbf5cd6c30ec87757548d14921cc355b09c
parentfbde260b11171f0f67afbc631e22fe26366ff448
feat(allwinner): add support for Allwinner T507 SoC

The Allwinner T507 SoC is using the same die as the H616, but in a
different package. On top of this, there is at least one different die
revision out there, which uses a different CPU cluster control block.
The same die revision has been spotted in some, but not all, H313 SoCs.

Apart from that IP block, the rest of the SoC seems the same, so we can
support them using the existing H616 port. The die revision can be
auto-detected, so there is no extra build option or knowledge needed.

Provide the deviating CPU power up/down sequence for the die variant.
The new IP block uses per-core instead of per-cluster registers, but
follows the same pattern otherwise.

Since the CPU ops code is shared among all Allwinner SoCs, we need to
dummy-define the new register names for the older SoCs. The actual new
code is guarded by a predicate function, that is hard coded to return
true on the other SoCs. Since this is a static inline function in a
header file, the compiler will optimise away the unneeded branch there,
so the generated code for the other SoCs stays the same.

Change-Id: Ib5ade99d34b4ccb161ccde0e34f280ca6bd16ecd
Signed-off-by: Mikhail Kalashnikov <iuncuim@gmail.com>
Signed-off-by: Andre Przywara <andre.przywara@arm.com>
docs/plat/allwinner.rst
plat/allwinner/common/sunxi_cpu_ops.c
plat/allwinner/common/sunxi_pm.c