linux/arch/arm/mach-mv78xx0
Arnd Bergmann 3584be9ec3 ARM: orion/mvebu: unify debug-ll virtual addresses
In a multiplatform configuration, enabling DEBUG_LL breaks booting
on all platforms with incompatible settings. In case of the Marvell
platforms of the Orion/MVEBU family, the physical addresses are
all the same, we just map them at different virtual addresses,
which makes it impossible to run a kernel with DEBUG_LL enabled on
a combination of the merged mvebu and the legacy boardfile based
platforms.

This is easily solved by using the same virtual address everywhere.
I picked the address that is already used by mach-mvebu for UART0:
0xfec12000. All these platforms have a 1MB region with their internal
registers, almost always at physical address 0xf1000000, so I'm
updating the iotable for that entry.

In case of mach-dove, this is slightly trickier, as the existing
mapping is 8MB and a second 8MB mapping is already at the 0xfec00000
address. I have verified from the datasheet that the last 7MB of the
physical mapping are "reserved" and nothing in Linux tries to use
it either. I'm putting this 1MB mapping at the same address as the
others, and the second 8MB register area immediately before that.

Link: https://lore.kernel.org/r/20190731195713.3150463-14-arnd@arndb.de
Link: https://lore.kernel.org/linux-arm-kernel/87si3eb1z8.fsf@free-electrons.com/
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
2019-08-14 19:24:58 +02:00
..
Kconfig treewide: Add SPDX license identifier - Makefile/Kconfig 2019-05-21 10:50:46 +02:00
Makefile License cleanup: add SPDX GPL-2.0 license identifier to files with no license 2017-11-02 11:10:55 +01:00
bridge-regs.h ARM: mv78xx0: clean up mach/*.h headers 2015-12-07 18:17:34 +01:00
buffalo-wxl-setup.c ARM: mv78xx0: clean up mach/*.h headers 2015-12-07 18:17:34 +01:00
common.c clk: Remove io.h from clk-provider.h 2019-05-15 13:21:37 -07:00
common.h reboot: arm: change reboot_mode to use enum reboot_mode 2013-07-09 10:33:29 -07:00
db78x00-bp-setup.c ARM: mv78xx0: clean up mach/*.h headers 2015-12-07 18:17:34 +01:00
irq.c ARM: mv78xx0: clean up mach/*.h headers 2015-12-07 18:17:34 +01:00
irqs.h ARM: mv78xx0: clean up mach/*.h headers 2015-12-07 18:17:34 +01:00
mpp.c ARM: mv78xx0: clean up mach/*.h headers 2015-12-07 18:17:34 +01:00
mpp.h ARM: orion: Fix Orion5x GPIO regression from MPP cleanup 2012-02-09 16:16:31 -08:00
mv78xx0.h ARM: orion/mvebu: unify debug-ll virtual addresses 2019-08-14 19:24:58 +02:00
pcie.c ARM/PCI: Convert PCI scan API to pci_scan_root_bus_bridge() 2017-06-28 15:13:55 -05:00
rd78x00-masa-setup.c ARM: mv78xx0: clean up mach/*.h headers 2015-12-07 18:17:34 +01:00