From: Juha Yrjola Date: Wed, 21 Dec 2005 20:18:45 +0000 (+0200) Subject: ARM: OMAP: Support for new Retu chips X-Git-Tag: v2.6.15-omap2~41 X-Git-Url: http://pilppa.com/gitweb/?a=commitdiff_plain;h=93cb1e87df6ac03d315c0408634831e7db898a77;p=linux-2.6-omap-h63xx.git ARM: OMAP: Support for new Retu chips Signed-off-by: Juha Yrjölä --- diff --git a/drivers/cbus/retu.c b/drivers/cbus/retu.c index 73b7a5170cb..87ab216c4ae 100644 --- a/drivers/cbus/retu.c +++ b/drivers/cbus/retu.c @@ -50,6 +50,7 @@ static int retu_initialized; static int retu_irq_pin; +static int retu_is_vilma; static struct tasklet_struct retu_tasklet; spinlock_t retu_lock = SPIN_LOCK_UNLOCKED; @@ -295,7 +296,7 @@ static void retu_power_off(void) static int __devinit retu_probe(struct device *dev) { const struct omap_em_asic_bb5_config * em_asic_config; - int ret; + int rev, ret; /* Prepare tasklet */ tasklet_init(&retu_tasklet, retu_tasklet_handler, 0); @@ -321,6 +322,14 @@ static int __devinit retu_probe(struct device *dev) set_irq_type(OMAP_GPIO_IRQ(retu_irq_pin), IRQT_RISING); retu_initialized = 1; + + rev = retu_read_reg(RETU_REG_ASICR) & 0xff; + if (rev & (1 << 7)) + retu_is_vilma = 1; + + printk(KERN_INFO "%s v%d.%d found\n", retu_is_vilma ? "Vilma" : "Retu", + (rev >> 4) & 0x07, rev & 0x0f); + /* Mask all RETU interrupts */ retu_write_reg(RETU_REG_IMR, 0xffff); @@ -392,7 +401,7 @@ static int __init retu_init(void) { int ret = 0; - printk(KERN_INFO "Retu driver initialising\n"); + printk(KERN_INFO "Retu/Vilma driver initialising\n"); init_completion(&device_release); diff --git a/drivers/cbus/retu.h b/drivers/cbus/retu.h index c116160d2c1..db20afc13d2 100644 --- a/drivers/cbus/retu.h +++ b/drivers/cbus/retu.h @@ -26,7 +26,7 @@ #include /* Registers */ -#define RETU_REG_ASICID 0x00 /* ASIC ID & revision */ +#define RETU_REG_ASICR 0x00 /* ASIC ID & revision */ #define RETU_REG_IDR 0x01 /* Interrupt ID */ #define RETU_REG_IMR 0x02 /* Interrupt mask */ #define RETU_REG_RTCDSR 0x03 /* RTC seconds register */