Commit a73c87bf authored by Vitaly Bordug's avatar Vitaly Bordug Committed by Paul Mackerras

[PATCH] ppc32: odd fixes and improvements in ppc_sys

This consists of offsets fix in ..._devices.c, and update of
ppc_sys_fixup_mem_resource() function to prevent subsequent fixups
Signed-off-by: default avatarVitaly Bordug <vbordug@ru.mvista.com>
Signed-off-by: default avatarPaul Mackerras <paulus@samba.org>
parent 2833c28a
...@@ -170,12 +170,18 @@ struct platform_device ppc_sys_platform_devices[] = { ...@@ -170,12 +170,18 @@ struct platform_device ppc_sys_platform_devices[] = {
[MPC8xx_CPM_SMC1] = { [MPC8xx_CPM_SMC1] = {
.name = "fsl-cpm-smc", .name = "fsl-cpm-smc",
.id = 1, .id = 1,
.num_resources = 2, .num_resources = 3,
.resource = (struct resource[]) { .resource = (struct resource[]) {
{ {
.name = "regs", .name = "regs",
.start = 0xa82, .start = 0xa80,
.end = 0xa91, .end = 0xa8f,
.flags = IORESOURCE_MEM,
},
{
.name = "pram",
.start = 0x3e80,
.end = 0x3ebf,
.flags = IORESOURCE_MEM, .flags = IORESOURCE_MEM,
}, },
{ {
...@@ -189,14 +195,21 @@ struct platform_device ppc_sys_platform_devices[] = { ...@@ -189,14 +195,21 @@ struct platform_device ppc_sys_platform_devices[] = {
[MPC8xx_CPM_SMC2] = { [MPC8xx_CPM_SMC2] = {
.name = "fsl-cpm-smc", .name = "fsl-cpm-smc",
.id = 2, .id = 2,
.num_resources = 2, .num_resources = 3,
.resource = (struct resource[]) { .resource = (struct resource[]) {
{ {
.name = "regs", .name = "regs",
.start = 0xa92, .start = 0xa90,
.end = 0xaa1, .end = 0xa9f,
.flags = IORESOURCE_MEM, .flags = IORESOURCE_MEM,
}, },
{
.name = "pram",
.start = 0x3f80,
.end = 0x3fbf,
.flags = IORESOURCE_MEM,
},
{ {
.name = "interrupt", .name = "interrupt",
.start = MPC8xx_INT_SMC2, .start = MPC8xx_INT_SMC2,
......
...@@ -109,9 +109,11 @@ ppc_sys_fixup_mem_resource(struct platform_device *pdev, phys_addr_t paddr) ...@@ -109,9 +109,11 @@ ppc_sys_fixup_mem_resource(struct platform_device *pdev, phys_addr_t paddr)
int i; int i;
for (i = 0; i < pdev->num_resources; i++) { for (i = 0; i < pdev->num_resources; i++) {
struct resource *r = &pdev->resource[i]; struct resource *r = &pdev->resource[i];
if ((r->flags & IORESOURCE_MEM) == IORESOURCE_MEM) { if (((r->flags & IORESOURCE_MEM) == IORESOURCE_MEM) &&
((r->flags & PPC_SYS_IORESOURCE_FIXUPPED) != PPC_SYS_IORESOURCE_FIXUPPED)) {
r->start += paddr; r->start += paddr;
r->end += paddr; r->end += paddr;
r->flags |= PPC_SYS_IORESOURCE_FIXUPPED;
} }
} }
} }
......
...@@ -113,13 +113,13 @@ struct ppc_sys_spec ppc_sys_specs[] = { ...@@ -113,13 +113,13 @@ struct ppc_sys_spec ppc_sys_specs[] = {
.ppc_sys_name = "8248", .ppc_sys_name = "8248",
.mask = 0x0000ff00, .mask = 0x0000ff00,
.value = 0x00000c00, .value = 0x00000c00,
.num_devices = 11, .num_devices = 12,
.device_list = (enum ppc_sys_devices[]) .device_list = (enum ppc_sys_devices[])
{ {
MPC82xx_CPM_FCC1, MPC82xx_CPM_FCC2, MPC82xx_CPM_SCC1, MPC82xx_CPM_FCC1, MPC82xx_CPM_FCC2, MPC82xx_CPM_SCC1,
MPC82xx_CPM_SCC2, MPC82xx_CPM_SCC3, MPC82xx_CPM_SMC1, MPC82xx_CPM_SCC2, MPC82xx_CPM_SCC3, MPC82xx_CPM_SCC4,
MPC82xx_CPM_SMC2, MPC82xx_CPM_SPI, MPC82xx_CPM_I2C, MPC82xx_CPM_SMC1, MPC82xx_CPM_SMC2, MPC82xx_CPM_SPI,
MPC82xx_CPM_USB, MPC82xx_SEC1, MPC82xx_CPM_I2C, MPC82xx_CPM_USB, MPC82xx_SEC1,
}, },
}, },
{ {
......
...@@ -39,6 +39,8 @@ ...@@ -39,6 +39,8 @@
#error "need definition of ppc_sys_devices" #error "need definition of ppc_sys_devices"
#endif #endif
#define PPC_SYS_IORESOURCE_FIXUPPED 0x00000001
struct ppc_sys_spec { struct ppc_sys_spec {
/* PPC sys is matched via (ID & mask) == value, id could be /* PPC sys is matched via (ID & mask) == value, id could be
* PVR, SVR, IMMR, * etc. */ * PVR, SVR, IMMR, * etc. */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment