ARM: davinci: da8xx: Add DSP internal RAM memories as IOMEM resources
authorSuman Anna <s-anna@ti.com>
Tue, 16 May 2017 22:13:47 +0000 (17:13 -0500)
committerSekhar Nori <nsekhar@ti.com>
Mon, 22 May 2017 09:17:44 +0000 (14:47 +0530)
The DSP subsystem on DA8xx has various internal RAM memories that can
accessed from the ARM side. These memories can be configured to be
used as either RAM or Cache. Add these memories as IOMEM resources
to the DSP device so that the driver can support loading of images
into internal memories.

Signed-off-by: Suman Anna <s-anna@ti.com>
Signed-off-by: Sekhar Nori <nsekhar@ti.com>
arch/arm/mach-davinci/devices-da8xx.c
arch/arm/mach-davinci/include/mach/da8xx.h

index 74c7653..22440c0 100644 (file)
@@ -800,6 +800,24 @@ static struct resource da8xx_rproc_resources[] = {
                .end            = DA8XX_SYSCFG0_BASE + DA8XX_CHIPSIG_REG + 7,
                .flags          = IORESOURCE_MEM,
        },
+       { /* DSP L2 RAM */
+               .name           = "l2sram",
+               .start          = DA8XX_DSP_L2_RAM_BASE,
+               .end            = DA8XX_DSP_L2_RAM_BASE + SZ_256K - 1,
+               .flags          = IORESOURCE_MEM,
+       },
+       { /* DSP L1P RAM */
+               .name           = "l1pram",
+               .start          = DA8XX_DSP_L1P_RAM_BASE,
+               .end            = DA8XX_DSP_L1P_RAM_BASE + SZ_32K - 1,
+               .flags          = IORESOURCE_MEM,
+       },
+       { /* DSP L1D RAM */
+               .name           = "l1dram",
+               .start          = DA8XX_DSP_L1D_RAM_BASE,
+               .end            = DA8XX_DSP_L1D_RAM_BASE + SZ_32K - 1,
+               .flags          = IORESOURCE_MEM,
+       },
        { /* dsp irq */
                .start          = IRQ_DA8XX_CHIPINT0,
                .end            = IRQ_DA8XX_CHIPINT0,
index 7e46422..93ff156 100644 (file)
@@ -75,6 +75,11 @@ extern unsigned int da850_max_speed;
 #define DA8XX_VPIF_BASE                0x01e17000
 #define DA8XX_GPIO_BASE                0x01e26000
 #define DA8XX_PSC1_BASE                0x01e27000
+
+#define DA8XX_DSP_L2_RAM_BASE  0x11800000
+#define DA8XX_DSP_L1P_RAM_BASE (DA8XX_DSP_L2_RAM_BASE + 0x600000)
+#define DA8XX_DSP_L1D_RAM_BASE (DA8XX_DSP_L2_RAM_BASE + 0x700000)
+
 #define DA8XX_AEMIF_CS2_BASE   0x60000000
 #define DA8XX_AEMIF_CS3_BASE   0x62000000
 #define DA8XX_AEMIF_CTL_BASE   0x68000000