|
@@ -880,6 +880,12 @@ static struct cardbus_type cardbus_type[] = {
|
|
|
.restore_state = ti_restore_state,
|
|
|
.sock_init = ti_init,
|
|
|
},
|
|
|
+ [CARDBUS_TYPE_ENE] = {
|
|
|
+ .override = ene_override,
|
|
|
+ .save_state = ti_save_state,
|
|
|
+ .restore_state = ti_restore_state,
|
|
|
+ .sock_init = ti_init,
|
|
|
+ },
|
|
|
#endif
|
|
|
#ifdef CONFIG_YENTA_RICOH
|
|
|
[CARDBUS_TYPE_RICOH] = {
|
|
@@ -902,14 +908,6 @@ static struct cardbus_type cardbus_type[] = {
|
|
|
.restore_state = o2micro_restore_state,
|
|
|
},
|
|
|
#endif
|
|
|
-#ifdef CONFIG_YENTA_TI
|
|
|
- [CARDBUS_TYPE_ENE] = {
|
|
|
- .override = ene_override,
|
|
|
- .save_state = ti_save_state,
|
|
|
- .restore_state = ti_restore_state,
|
|
|
- .sock_init = ti_init,
|
|
|
- },
|
|
|
-#endif
|
|
|
};
|
|
|
|
|
|
|
|
@@ -975,7 +973,7 @@ static irqreturn_t yenta_probe_handler(int irq, void *dev_id)
|
|
|
/* probes the PCI interrupt, use only on override functions */
|
|
|
static int yenta_probe_cb_irq(struct yenta_socket *socket)
|
|
|
{
|
|
|
- u8 reg;
|
|
|
+ u8 reg = 0;
|
|
|
|
|
|
if (!socket->cb_irq)
|
|
|
return -1;
|
|
@@ -989,7 +987,8 @@ static int yenta_probe_cb_irq(struct yenta_socket *socket)
|
|
|
}
|
|
|
|
|
|
/* generate interrupt, wait */
|
|
|
- reg = exca_readb(socket, I365_CSCINT);
|
|
|
+ if (!socket->dev->irq)
|
|
|
+ reg = exca_readb(socket, I365_CSCINT);
|
|
|
exca_writeb(socket, I365_CSCINT, reg | I365_CSC_STSCHG);
|
|
|
cb_writel(socket, CB_SOCKET_EVENT, -1);
|
|
|
cb_writel(socket, CB_SOCKET_MASK, CB_CSTSMASK);
|