This commit was manufactured by cvs2svn to create tag
[linux-2.6.git] / drivers / scsi / pcmcia / qlogic_stub.c
index 4766bcd..abb755f 100644 (file)
@@ -93,6 +93,17 @@ static Scsi_Host_Template qlogicfas_driver_template = {
 
 /*====================================================================*/
 
+/* Parameters that can be set with 'insmod' */
+
+/* Bit map of interrupts to choose from */
+static unsigned int irq_mask = 0xdeb8;
+static int irq_list[4] = { -1 };
+
+MODULE_PARM(irq_mask, "i");
+MODULE_PARM(irq_list, "1-4i");
+
+/*====================================================================*/
+
 typedef struct scsi_info_t {
        dev_link_t link;
        dev_node_t node;
@@ -171,7 +182,7 @@ static dev_link_t *qlogic_attach(void)
        scsi_info_t *info;
        client_reg_t client_reg;
        dev_link_t *link;
-       int ret;
+       int i, ret;
 
        DEBUG(0, "qlogic_attach()\n");
 
@@ -186,7 +197,12 @@ static dev_link_t *qlogic_attach(void)
        link->io.Attributes1 = IO_DATA_PATH_WIDTH_AUTO;
        link->io.IOAddrLines = 10;
        link->irq.Attributes = IRQ_TYPE_EXCLUSIVE;
-       link->irq.IRQInfo1 = IRQ_LEVEL_ID;
+       link->irq.IRQInfo1 = IRQ_INFO2_VALID | IRQ_LEVEL_ID;
+       if (irq_list[0] == -1)
+               link->irq.IRQInfo2 = irq_mask;
+       else
+               for (i = 0; i < 4; i++)
+                       link->irq.IRQInfo2 |= 1 << irq_list[i];
        link->conf.Attributes = CONF_ENABLE_IRQ;
        link->conf.Vcc = 50;
        link->conf.IntType = INT_MEMORY_AND_IO;
@@ -196,6 +212,7 @@ static dev_link_t *qlogic_attach(void)
        link->next = dev_list;
        dev_list = link;
        client_reg.dev_info = &dev_info;
+       client_reg.Attributes = INFO_IO_CLIENT | INFO_CARD_SHARE;
        client_reg.event_handler = &qlogic_event;
        client_reg.EventMask = CS_EVENT_RESET_REQUEST | CS_EVENT_CARD_RESET | CS_EVENT_CARD_INSERTION | CS_EVENT_CARD_REMOVAL | CS_EVENT_PM_SUSPEND | CS_EVENT_PM_RESUME;
        client_reg.Version = 0x0210;
@@ -415,7 +432,10 @@ static int __init init_qlogic_cs(void)
 static void __exit exit_qlogic_cs(void)
 {
        pcmcia_unregister_driver(&qlogic_cs_driver);
-       BUG_ON(dev_list != NULL);
+
+       /* XXX: this really needs to move into generic code.. */
+       while (dev_list != NULL)
+               qlogic_detach(dev_list);
 }
 
 MODULE_AUTHOR("Tom Zerucha, Michael Griffith");