ARM: bcm283x: Add BCM283x_BASE define
authorMatthias Brugger <mbrugger@suse.com>
Wed, 24 Jul 2019 14:39:05 +0000 (15:39 +0100)
committerMatthias Brugger <mbrugger@suse.com>
Fri, 6 Sep 2019 16:16:59 +0000 (18:16 +0200)
Devices of bcm283x have different base address, depending if they are on
bcm2835 or bcm2836/7. Use BCM283x_BASE depending on the SoC you want to
build and only add the offset in the header files.

Signed-off-by: Matthias Brugger <mbrugger@suse.com>
Signed-off-by: Andrei Gherzan <andrei@balena.io>
arch/arm/mach-bcm283x/Kconfig
arch/arm/mach-bcm283x/include/mach/mbox.h
arch/arm/mach-bcm283x/include/mach/sdhci.h
arch/arm/mach-bcm283x/include/mach/timer.h
arch/arm/mach-bcm283x/include/mach/wdog.h

index 3eb5a9a..8e69914 100644 (file)
@@ -141,4 +141,9 @@ config SYS_SOC
 config SYS_CONFIG_NAME
        default "rpi"
 
+config BCM283x_BASE
+       hex
+       default "0x20000000" if BCM2835
+       default "0x3f000000" if BCM2836 || BCM2837
+
 endmenu
index f892803..1e4718d 100644 (file)
 
 /* Raw mailbox HW */
 
-#ifndef CONFIG_BCM2835
-#define BCM2835_MBOX_PHYSADDR  0x3f00b880
-#else
-#define BCM2835_MBOX_PHYSADDR  0x2000b880
-#endif
+#define BCM2835_MBOX_PHYSADDR  (CONFIG_BCM283x_BASE + 0x0000b880)
 
 struct bcm2835_mbox_regs {
        u32 read;
index 5cb6ec3..b443c37 100644 (file)
@@ -6,11 +6,7 @@
 #ifndef _BCM2835_SDHCI_H_
 #define _BCM2835_SDHCI_H_
 
-#ifndef CONFIG_BCM2835
-#define BCM2835_SDHCI_BASE 0x3f300000
-#else
-#define BCM2835_SDHCI_BASE 0x20300000
-#endif
+#define BCM2835_SDHCI_BASE (CONFIG_BCM283x_BASE + 0x00300000)
 
 int bcm2835_sdhci_init(u32 regbase, u32 emmc_freq);
 
index 56b0c35..014355e 100644 (file)
@@ -6,11 +6,7 @@
 #ifndef _BCM2835_TIMER_H
 #define _BCM2835_TIMER_H
 
-#ifndef CONFIG_BCM2835
-#define BCM2835_TIMER_PHYSADDR 0x3f003000
-#else
-#define BCM2835_TIMER_PHYSADDR 0x20003000
-#endif
+#define BCM2835_TIMER_PHYSADDR (CONFIG_BCM283x_BASE + 0x00003000)
 
 #define BCM2835_TIMER_CS_M3    (1 << 3)
 #define BCM2835_TIMER_CS_M2    (1 << 2)
index 99c88e5..8292b3c 100644 (file)
@@ -6,11 +6,7 @@
 #ifndef _BCM2835_WDOG_H
 #define _BCM2835_WDOG_H
 
-#ifndef CONFIG_BCM2835
-#define BCM2835_WDOG_PHYSADDR                  0x3f100000
-#else
-#define BCM2835_WDOG_PHYSADDR                  0x20100000
-#endif
+#define BCM2835_WDOG_PHYSADDR  (CONFIG_BCM283x_BASE + 0x00100000)
 
 struct bcm2835_wdog_regs {
        u32 unknown0[7];