Commit 1e27dbe7 authored by Ben Dooks's avatar Ben Dooks Committed by Linus Torvalds

SM501: Check SM501 ID register on initialisation

When binding the driver, check the ID register for a valid identity, in case
the SM501 is not functioning correctly.
Signed-off-by: default avatarBen Dooks <ben-linux@fluff.org>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent ffd65af0
...@@ -893,6 +893,7 @@ static int sm501_init_dev(struct sm501_devdata *sm) ...@@ -893,6 +893,7 @@ static int sm501_init_dev(struct sm501_devdata *sm)
{ {
resource_size_t mem_avail; resource_size_t mem_avail;
unsigned long dramctrl; unsigned long dramctrl;
unsigned long devid;
int ret; int ret;
mutex_init(&sm->clock_lock); mutex_init(&sm->clock_lock);
...@@ -900,13 +901,18 @@ static int sm501_init_dev(struct sm501_devdata *sm) ...@@ -900,13 +901,18 @@ static int sm501_init_dev(struct sm501_devdata *sm)
INIT_LIST_HEAD(&sm->devices); INIT_LIST_HEAD(&sm->devices);
dramctrl = readl(sm->regs + SM501_DRAM_CONTROL); devid = readl(sm->regs + SM501_DEVICEID);
if ((devid & SM501_DEVICEID_IDMASK) != SM501_DEVICEID_SM501) {
dev_err(sm->dev, "incorrect device id %08lx\n", devid);
return -EINVAL;
}
dramctrl = readl(sm->regs + SM501_DRAM_CONTROL);
mem_avail = sm501_mem_local[(dramctrl >> 13) & 0x7]; mem_avail = sm501_mem_local[(dramctrl >> 13) & 0x7];
dev_info(sm->dev, "SM501 At %p: Version %08x, %ld Mb, IRQ %d\n", dev_info(sm->dev, "SM501 At %p: Version %08lx, %ld Mb, IRQ %d\n",
sm->regs, readl(sm->regs + SM501_DEVICEID), sm->regs, devid, (unsigned long)mem_avail >> 20, sm->irq);
(unsigned long)mem_avail >> 20, sm->irq);
sm501_dump_gate(sm); sm501_dump_gate(sm);
......
...@@ -109,6 +109,9 @@ ...@@ -109,6 +109,9 @@
#define SM501_DEVICEID (0x000060) #define SM501_DEVICEID (0x000060)
/* 0x050100A0 */ /* 0x050100A0 */
#define SM501_DEVICEID_SM501 (0x05010000)
#define SM501_DEVICEID_IDMASK (0xffff0000)
#define SM501_PLLCLOCK_COUNT (0x000064) #define SM501_PLLCLOCK_COUNT (0x000064)
#define SM501_MISC_TIMING (0x000068) #define SM501_MISC_TIMING (0x000068)
#define SM501_CURRENT_SDRAM_CLOCK (0x00006C) #define SM501_CURRENT_SDRAM_CLOCK (0x00006C)
......
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