2 * SuperTrak EX Series Storage Controller driver for Linux
4 * Copyright (C) 2005-2009 Promise Technology Inc.
6 * This program is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU General Public License
8 * as published by the Free Software Foundation; either version
9 * 2 of the License, or (at your option) any later version.
12 * Ed Lin <promise_linux@promise.com>
16 #include <linux/init.h>
17 #include <linux/errno.h>
18 #include <linux/kernel.h>
19 #include <linux/delay.h>
20 #include <linux/time.h>
21 #include <linux/pci.h>
22 #include <linux/blkdev.h>
23 #include <linux/interrupt.h>
24 #include <linux/types.h>
25 #include <linux/module.h>
26 #include <linux/spinlock.h>
29 #include <asm/byteorder.h>
30 #include <scsi/scsi.h>
31 #include <scsi/scsi_device.h>
32 #include <scsi/scsi_cmnd.h>
33 #include <scsi/scsi_host.h>
34 #include <scsi/scsi_tcq.h>
35 #include <scsi/scsi_dbg.h>
36 #include <scsi/scsi_eh.h>
38 #define DRV_NAME "stex"
39 #define ST_DRIVER_VERSION "4.6.0000.1"
40 #define ST_VER_MAJOR 4
41 #define ST_VER_MINOR 6
43 #define ST_BUILD_VER 1
46 /* MU register offset */
47 IMR0
= 0x10, /* MU_INBOUND_MESSAGE_REG0 */
48 IMR1
= 0x14, /* MU_INBOUND_MESSAGE_REG1 */
49 OMR0
= 0x18, /* MU_OUTBOUND_MESSAGE_REG0 */
50 OMR1
= 0x1c, /* MU_OUTBOUND_MESSAGE_REG1 */
51 IDBL
= 0x20, /* MU_INBOUND_DOORBELL */
52 IIS
= 0x24, /* MU_INBOUND_INTERRUPT_STATUS */
53 IIM
= 0x28, /* MU_INBOUND_INTERRUPT_MASK */
54 ODBL
= 0x2c, /* MU_OUTBOUND_DOORBELL */
55 OIS
= 0x30, /* MU_OUTBOUND_INTERRUPT_STATUS */
56 OIM
= 0x3c, /* MU_OUTBOUND_INTERRUPT_MASK */
58 /* MU register value */
59 MU_INBOUND_DOORBELL_HANDSHAKE
= 1,
60 MU_INBOUND_DOORBELL_REQHEADCHANGED
= 2,
61 MU_INBOUND_DOORBELL_STATUSTAILCHANGED
= 4,
62 MU_INBOUND_DOORBELL_HMUSTOPPED
= 8,
63 MU_INBOUND_DOORBELL_RESET
= 16,
65 MU_OUTBOUND_DOORBELL_HANDSHAKE
= 1,
66 MU_OUTBOUND_DOORBELL_REQUESTTAILCHANGED
= 2,
67 MU_OUTBOUND_DOORBELL_STATUSHEADCHANGED
= 4,
68 MU_OUTBOUND_DOORBELL_BUSCHANGE
= 8,
69 MU_OUTBOUND_DOORBELL_HASEVENT
= 16,
72 MU_STATE_STARTING
= 1,
73 MU_STATE_FMU_READY_FOR_HANDSHAKE
= 2,
74 MU_STATE_SEND_HANDSHAKE_FRAME
= 3,
76 MU_STATE_RESETTING
= 5,
79 MU_HANDSHAKE_SIGNATURE
= 0x55aaaa55,
80 MU_HANDSHAKE_SIGNATURE_HALF
= 0x5a5a0000,
81 MU_HARD_RESET_WAIT
= 30000,
84 /* firmware returned values */
85 SRB_STATUS_SUCCESS
= 0x01,
86 SRB_STATUS_ERROR
= 0x04,
87 SRB_STATUS_BUSY
= 0x05,
88 SRB_STATUS_INVALID_REQUEST
= 0x06,
89 SRB_STATUS_SELECTION_TIMEOUT
= 0x0A,
93 TASK_ATTRIBUTE_SIMPLE
= 0x0,
94 TASK_ATTRIBUTE_HEADOFQUEUE
= 0x1,
95 TASK_ATTRIBUTE_ORDERED
= 0x2,
96 TASK_ATTRIBUTE_ACA
= 0x4,
98 /* request count, etc. */
101 /* one message wasted, use MU_MAX_REQUEST+1
102 to handle MU_MAX_REQUEST messages */
103 MU_REQ_COUNT
= (MU_MAX_REQUEST
+ 1),
104 MU_STATUS_COUNT
= (MU_MAX_REQUEST
+ 1),
106 STEX_CDB_LENGTH
= 16,
107 REQ_VARIABLE_LEN
= 1024,
108 STATUS_VAR_LEN
= 128,
109 ST_CAN_QUEUE
= MU_MAX_REQUEST
,
110 ST_CMD_PER_LUN
= MU_MAX_REQUEST
,
114 SG_CF_EOT
= 0x80, /* end of table */
115 SG_CF_64B
= 0x40, /* 64 bit item */
116 SG_CF_HOST
= 0x20, /* sg in host memory */
119 MSG_DATA_DIR_OUT
= 2,
127 PASSTHRU_REQ_TYPE
= 0x00000001,
128 PASSTHRU_REQ_NO_WAKEUP
= 0x00000100,
129 ST_INTERNAL_TIMEOUT
= 180,
134 /* vendor specific commands of Promise */
136 SINBAND_MGT_CMD
= 0xd9,
138 CONTROLLER_CMD
= 0xe1,
139 DEBUGGING_CMD
= 0xe2,
142 PASSTHRU_GET_ADAPTER
= 0x05,
143 PASSTHRU_GET_DRVVER
= 0x10,
145 CTLR_CONFIG_CMD
= 0x03,
146 CTLR_SHUTDOWN
= 0x0d,
148 CTLR_POWER_STATE_CHANGE
= 0x0e,
149 CTLR_POWER_SAVING
= 0x01,
151 PASSTHRU_SIGNATURE
= 0x4e415041,
152 MGT_CMD_SIGNATURE
= 0xba,
156 ST_ADDITIONAL_MEM
= 0x200000,
160 u8 ctrl
; /* SG_CF_xxx */
171 struct st_sgitem table
[ST_MAX_SG
];
174 struct handshake_frame
{
175 __le32 rb_phy
; /* request payload queue physical address */
177 __le16 req_sz
; /* size of each request payload */
178 __le16 req_cnt
; /* count of reqs the buffer can hold */
179 __le16 status_sz
; /* size of each status payload */
180 __le16 status_cnt
; /* count of status the buffer can hold */
181 __le32 hosttime
; /* seconds from Jan 1, 1970 (GMT) */
183 u8 partner_type
; /* who sends this frame */
185 __le32 partner_ver_major
;
186 __le32 partner_ver_minor
;
187 __le32 partner_ver_oem
;
188 __le32 partner_ver_build
;
189 __le32 extra_offset
; /* NEW */
190 __le32 extra_size
; /* NEW */
201 u8 payload_sz
; /* payload size in 4-byte, not used */
202 u8 cdb
[STEX_CDB_LENGTH
];
203 u8 variable
[REQ_VARIABLE_LEN
];
213 u8 payload_sz
; /* payload size in 4-byte */
214 u8 variable
[STATUS_VAR_LEN
];
229 struct ver_info drv_ver
;
230 struct ver_info bios_ver
;
259 #define MU_REQ_BUFFER_SIZE (MU_REQ_COUNT * sizeof(struct req_msg))
260 #define MU_STATUS_BUFFER_SIZE (MU_STATUS_COUNT * sizeof(struct status_msg))
261 #define MU_BUFFER_SIZE (MU_REQ_BUFFER_SIZE + MU_STATUS_BUFFER_SIZE)
262 #define STEX_EXTRA_SIZE sizeof(struct st_frame)
263 #define STEX_BUFFER_SIZE (MU_BUFFER_SIZE + STEX_EXTRA_SIZE)
267 struct scsi_cmnd
*cmd
;
270 unsigned int sense_bufflen
;
279 void __iomem
*mmio_base
; /* iomapped PCI memory space */
281 dma_addr_t dma_handle
;
284 struct Scsi_Host
*host
;
285 struct pci_dev
*pdev
;
292 struct status_msg
*status_buffer
;
293 void *copy_buffer
; /* temp buffer for driver-handled commands */
294 struct st_ccb ccb
[MU_MAX_REQUEST
];
295 struct st_ccb
*wait_ccb
;
296 wait_queue_head_t waitq
;
298 unsigned int mu_status
;
301 unsigned int cardtype
;
304 static const char console_inq_page
[] =
306 0x03,0x00,0x03,0x03,0xFA,0x00,0x00,0x30,
307 0x50,0x72,0x6F,0x6D,0x69,0x73,0x65,0x20, /* "Promise " */
308 0x52,0x41,0x49,0x44,0x20,0x43,0x6F,0x6E, /* "RAID Con" */
309 0x73,0x6F,0x6C,0x65,0x20,0x20,0x20,0x20, /* "sole " */
310 0x31,0x2E,0x30,0x30,0x20,0x20,0x20,0x20, /* "1.00 " */
311 0x53,0x58,0x2F,0x52,0x53,0x41,0x46,0x2D, /* "SX/RSAF-" */
312 0x54,0x45,0x31,0x2E,0x30,0x30,0x20,0x20, /* "TE1.00 " */
313 0x0C,0x20,0x20,0x20,0x20,0x20,0x20,0x20
316 MODULE_AUTHOR("Ed Lin");
317 MODULE_DESCRIPTION("Promise Technology SuperTrak EX Controllers");
318 MODULE_LICENSE("GPL");
319 MODULE_VERSION(ST_DRIVER_VERSION
);
321 static void stex_gettime(__le32
*time
)
325 do_gettimeofday(&tv
);
326 *time
= cpu_to_le32(tv
.tv_sec
& 0xffffffff);
327 *(time
+ 1) = cpu_to_le32((tv
.tv_sec
>> 16) >> 16);
330 static struct status_msg
*stex_get_status(struct st_hba
*hba
)
332 struct status_msg
*status
=
333 hba
->status_buffer
+ hba
->status_tail
;
336 hba
->status_tail
%= MU_STATUS_COUNT
;
341 static void stex_invalid_field(struct scsi_cmnd
*cmd
,
342 void (*done
)(struct scsi_cmnd
*))
344 cmd
->result
= (DRIVER_SENSE
<< 24) | SAM_STAT_CHECK_CONDITION
;
346 /* "Invalid field in cdb" */
347 scsi_build_sense_buffer(0, cmd
->sense_buffer
, ILLEGAL_REQUEST
, 0x24,
352 static struct req_msg
*stex_alloc_req(struct st_hba
*hba
)
354 struct req_msg
*req
= ((struct req_msg
*)hba
->dma_mem
) +
358 hba
->req_head
%= MU_REQ_COUNT
;
363 static int stex_map_sg(struct st_hba
*hba
,
364 struct req_msg
*req
, struct st_ccb
*ccb
)
366 struct scsi_cmnd
*cmd
;
367 struct scatterlist
*sg
;
368 struct st_sgtable
*dst
;
372 dst
= (struct st_sgtable
*)req
->variable
;
373 dst
->max_sg_count
= cpu_to_le16(ST_MAX_SG
);
374 dst
->sz_in_byte
= cpu_to_le32(scsi_bufflen(cmd
));
376 nseg
= scsi_dma_map(cmd
);
380 ccb
->sg_count
= nseg
;
381 dst
->sg_count
= cpu_to_le16((u16
)nseg
);
383 scsi_for_each_sg(cmd
, sg
, nseg
, i
) {
384 dst
->table
[i
].count
= cpu_to_le32((u32
)sg_dma_len(sg
));
386 cpu_to_le32(sg_dma_address(sg
) & 0xffffffff);
387 dst
->table
[i
].addr_hi
=
388 cpu_to_le32((sg_dma_address(sg
) >> 16) >> 16);
389 dst
->table
[i
].ctrl
= SG_CF_64B
| SG_CF_HOST
;
391 dst
->table
[--i
].ctrl
|= SG_CF_EOT
;
397 static void stex_controller_info(struct st_hba
*hba
, struct st_ccb
*ccb
)
400 size_t count
= sizeof(struct st_frame
);
402 p
= hba
->copy_buffer
;
403 count
= scsi_sg_copy_to_buffer(ccb
->cmd
, p
, count
);
404 memset(p
->base
, 0, sizeof(u32
)*6);
405 *(unsigned long *)(p
->base
) = pci_resource_start(hba
->pdev
, 0);
408 p
->drv_ver
.major
= ST_VER_MAJOR
;
409 p
->drv_ver
.minor
= ST_VER_MINOR
;
410 p
->drv_ver
.oem
= ST_OEM
;
411 p
->drv_ver
.build
= ST_BUILD_VER
;
413 p
->bus
= hba
->pdev
->bus
->number
;
414 p
->slot
= hba
->pdev
->devfn
;
416 p
->irq_vec
= hba
->pdev
->irq
;
417 p
->id
= hba
->pdev
->vendor
<< 16 | hba
->pdev
->device
;
419 hba
->pdev
->subsystem_vendor
<< 16 | hba
->pdev
->subsystem_device
;
421 count
= scsi_sg_copy_from_buffer(ccb
->cmd
, p
, count
);
425 stex_send_cmd(struct st_hba
*hba
, struct req_msg
*req
, u16 tag
)
427 req
->tag
= cpu_to_le16(tag
);
428 req
->task_attr
= TASK_ATTRIBUTE_SIMPLE
;
429 req
->task_manage
= 0; /* not supported yet */
431 hba
->ccb
[tag
].req
= req
;
434 writel(hba
->req_head
, hba
->mmio_base
+ IMR0
);
435 writel(MU_INBOUND_DOORBELL_REQHEADCHANGED
, hba
->mmio_base
+ IDBL
);
436 readl(hba
->mmio_base
+ IDBL
); /* flush */
440 stex_slave_alloc(struct scsi_device
*sdev
)
442 /* Cheat: usually extracted from Inquiry data */
443 sdev
->tagged_supported
= 1;
445 scsi_activate_tcq(sdev
, ST_CMD_PER_LUN
);
451 stex_slave_config(struct scsi_device
*sdev
)
453 sdev
->use_10_for_rw
= 1;
454 sdev
->use_10_for_ms
= 1;
455 blk_queue_rq_timeout(sdev
->request_queue
, 60 * HZ
);
456 sdev
->tagged_supported
= 1;
462 stex_slave_destroy(struct scsi_device
*sdev
)
464 scsi_deactivate_tcq(sdev
, 1);
468 stex_queuecommand(struct scsi_cmnd
*cmd
, void (* done
)(struct scsi_cmnd
*))
471 struct Scsi_Host
*host
;
476 host
= cmd
->device
->host
;
477 id
= cmd
->device
->id
;
478 lun
= cmd
->device
->lun
;
479 hba
= (struct st_hba
*) &host
->hostdata
[0];
481 switch (cmd
->cmnd
[0]) {
484 static char ms10_caching_page
[12] =
485 { 0, 0x12, 0, 0, 0, 0, 0, 0, 0x8, 0xa, 0x4, 0 };
488 page
= cmd
->cmnd
[2] & 0x3f;
489 if (page
== 0x8 || page
== 0x3f) {
490 scsi_sg_copy_from_buffer(cmd
, ms10_caching_page
,
491 sizeof(ms10_caching_page
));
492 cmd
->result
= DID_OK
<< 16 | COMMAND_COMPLETE
<< 8;
495 stex_invalid_field(cmd
, done
);
500 * The shasta firmware does not report actual luns in the
501 * target, so fail the command to force sequential lun scan.
502 * Also, the console device does not support this command.
504 if (hba
->cardtype
== st_shasta
|| id
== host
->max_id
- 1) {
505 stex_invalid_field(cmd
, done
);
509 case TEST_UNIT_READY
:
510 if (id
== host
->max_id
- 1) {
511 cmd
->result
= DID_OK
<< 16 | COMMAND_COMPLETE
<< 8;
517 if (id
!= host
->max_id
- 1)
519 if (lun
== 0 && (cmd
->cmnd
[1] & INQUIRY_EVPD
) == 0) {
520 scsi_sg_copy_from_buffer(cmd
, (void *)console_inq_page
,
521 sizeof(console_inq_page
));
522 cmd
->result
= DID_OK
<< 16 | COMMAND_COMPLETE
<< 8;
525 stex_invalid_field(cmd
, done
);
528 if (cmd
->cmnd
[1] == PASSTHRU_GET_DRVVER
) {
529 struct st_drvver ver
;
530 size_t cp_len
= sizeof(ver
);
532 ver
.major
= ST_VER_MAJOR
;
533 ver
.minor
= ST_VER_MINOR
;
535 ver
.build
= ST_BUILD_VER
;
536 ver
.signature
[0] = PASSTHRU_SIGNATURE
;
537 ver
.console_id
= host
->max_id
- 1;
538 ver
.host_no
= hba
->host
->host_no
;
539 cp_len
= scsi_sg_copy_from_buffer(cmd
, &ver
, cp_len
);
540 cmd
->result
= sizeof(ver
) == cp_len
?
541 DID_OK
<< 16 | COMMAND_COMPLETE
<< 8 :
542 DID_ERROR
<< 16 | COMMAND_COMPLETE
<< 8;
550 cmd
->scsi_done
= done
;
552 tag
= cmd
->request
->tag
;
554 if (unlikely(tag
>= host
->can_queue
))
555 return SCSI_MLQUEUE_HOST_BUSY
;
557 req
= stex_alloc_req(hba
);
563 memcpy(req
->cdb
, cmd
->cmnd
, STEX_CDB_LENGTH
);
565 if (cmd
->sc_data_direction
== DMA_FROM_DEVICE
)
566 req
->data_dir
= MSG_DATA_DIR_IN
;
567 else if (cmd
->sc_data_direction
== DMA_TO_DEVICE
)
568 req
->data_dir
= MSG_DATA_DIR_OUT
;
570 req
->data_dir
= MSG_DATA_DIR_ND
;
572 hba
->ccb
[tag
].cmd
= cmd
;
573 hba
->ccb
[tag
].sense_bufflen
= SCSI_SENSE_BUFFERSIZE
;
574 hba
->ccb
[tag
].sense_buffer
= cmd
->sense_buffer
;
575 hba
->ccb
[tag
].req_type
= 0;
577 if (cmd
->sc_data_direction
!= DMA_NONE
)
578 stex_map_sg(hba
, req
, &hba
->ccb
[tag
]);
580 stex_send_cmd(hba
, req
, tag
);
584 static void stex_scsi_done(struct st_ccb
*ccb
)
586 struct scsi_cmnd
*cmd
= ccb
->cmd
;
589 if (ccb
->srb_status
== SRB_STATUS_SUCCESS
|| ccb
->srb_status
== 0) {
590 result
= ccb
->scsi_status
;
591 switch (ccb
->scsi_status
) {
593 result
|= DID_OK
<< 16 | COMMAND_COMPLETE
<< 8;
595 case SAM_STAT_CHECK_CONDITION
:
596 result
|= DRIVER_SENSE
<< 24;
599 result
|= DID_BUS_BUSY
<< 16 | COMMAND_COMPLETE
<< 8;
602 result
|= DID_ERROR
<< 16 | COMMAND_COMPLETE
<< 8;
606 else if (ccb
->srb_status
& SRB_SEE_SENSE
)
607 result
= DRIVER_SENSE
<< 24 | SAM_STAT_CHECK_CONDITION
;
608 else switch (ccb
->srb_status
) {
609 case SRB_STATUS_SELECTION_TIMEOUT
:
610 result
= DID_NO_CONNECT
<< 16 | COMMAND_COMPLETE
<< 8;
612 case SRB_STATUS_BUSY
:
613 result
= DID_BUS_BUSY
<< 16 | COMMAND_COMPLETE
<< 8;
615 case SRB_STATUS_INVALID_REQUEST
:
616 case SRB_STATUS_ERROR
:
618 result
= DID_ERROR
<< 16 | COMMAND_COMPLETE
<< 8;
622 cmd
->result
= result
;
626 static void stex_copy_data(struct st_ccb
*ccb
,
627 struct status_msg
*resp
, unsigned int variable
)
629 size_t count
= variable
;
631 if (resp
->scsi_status
!= SAM_STAT_GOOD
) {
632 if (ccb
->sense_buffer
!= NULL
)
633 memcpy(ccb
->sense_buffer
, resp
->variable
,
634 min(variable
, ccb
->sense_bufflen
));
638 if (ccb
->cmd
== NULL
)
640 count
= scsi_sg_copy_from_buffer(ccb
->cmd
, resp
->variable
, count
);
643 static void stex_ys_commands(struct st_hba
*hba
,
644 struct st_ccb
*ccb
, struct status_msg
*resp
)
646 if (ccb
->cmd
->cmnd
[0] == MGT_CMD
&&
647 resp
->scsi_status
!= SAM_STAT_CHECK_CONDITION
) {
648 scsi_set_resid(ccb
->cmd
, scsi_bufflen(ccb
->cmd
) -
649 le32_to_cpu(*(__le32
*)&resp
->variable
[0]));
653 static void stex_mu_intr(struct st_hba
*hba
, u32 doorbell
)
655 void __iomem
*base
= hba
->mmio_base
;
656 struct status_msg
*resp
;
661 if (!(doorbell
& MU_OUTBOUND_DOORBELL_STATUSHEADCHANGED
))
664 /* status payloads */
665 hba
->status_head
= readl(base
+ OMR1
);
666 if (unlikely(hba
->status_head
>= MU_STATUS_COUNT
)) {
667 printk(KERN_WARNING DRV_NAME
"(%s): invalid status head\n",
668 pci_name(hba
->pdev
));
673 * it's not a valid status payload if:
674 * 1. there are no pending requests(e.g. during init stage)
675 * 2. there are some pending requests, but the controller is in
676 * reset status, and its type is not st_yosemite
677 * firmware of st_yosemite in reset status will return pending requests
678 * to driver, so we allow it to pass
680 if (unlikely(hba
->out_req_cnt
<= 0 ||
681 (hba
->mu_status
== MU_STATE_RESETTING
&&
682 hba
->cardtype
!= st_yosemite
))) {
683 hba
->status_tail
= hba
->status_head
;
687 while (hba
->status_tail
!= hba
->status_head
) {
688 resp
= stex_get_status(hba
);
689 tag
= le16_to_cpu(resp
->tag
);
690 if (unlikely(tag
>= hba
->host
->can_queue
)) {
691 printk(KERN_WARNING DRV_NAME
692 "(%s): invalid tag\n", pci_name(hba
->pdev
));
696 ccb
= &hba
->ccb
[tag
];
697 if (hba
->wait_ccb
== ccb
)
698 hba
->wait_ccb
= NULL
;
699 if (unlikely(ccb
->req
== NULL
)) {
700 printk(KERN_WARNING DRV_NAME
701 "(%s): lagging req\n", pci_name(hba
->pdev
));
706 size
= resp
->payload_sz
* sizeof(u32
); /* payload size */
707 if (unlikely(size
< sizeof(*resp
) - STATUS_VAR_LEN
||
708 size
> sizeof(*resp
))) {
709 printk(KERN_WARNING DRV_NAME
"(%s): bad status size\n",
710 pci_name(hba
->pdev
));
712 size
-= sizeof(*resp
) - STATUS_VAR_LEN
; /* copy size */
714 stex_copy_data(ccb
, resp
, size
);
718 ccb
->srb_status
= resp
->srb_status
;
719 ccb
->scsi_status
= resp
->scsi_status
;
721 if (likely(ccb
->cmd
!= NULL
)) {
722 if (hba
->cardtype
== st_yosemite
)
723 stex_ys_commands(hba
, ccb
, resp
);
725 if (unlikely(ccb
->cmd
->cmnd
[0] == PASSTHRU_CMD
&&
726 ccb
->cmd
->cmnd
[1] == PASSTHRU_GET_ADAPTER
))
727 stex_controller_info(hba
, ccb
);
729 scsi_dma_unmap(ccb
->cmd
);
732 } else if (ccb
->req_type
& PASSTHRU_REQ_TYPE
) {
734 if (ccb
->req_type
& PASSTHRU_REQ_NO_WAKEUP
) {
739 if (waitqueue_active(&hba
->waitq
))
740 wake_up(&hba
->waitq
);
745 writel(hba
->status_head
, base
+ IMR1
);
746 readl(base
+ IMR1
); /* flush */
749 static irqreturn_t
stex_intr(int irq
, void *__hba
)
751 struct st_hba
*hba
= __hba
;
752 void __iomem
*base
= hba
->mmio_base
;
757 spin_lock_irqsave(hba
->host
->host_lock
, flags
);
759 data
= readl(base
+ ODBL
);
761 if (data
&& data
!= 0xffffffff) {
762 /* clear the interrupt */
763 writel(data
, base
+ ODBL
);
764 readl(base
+ ODBL
); /* flush */
765 stex_mu_intr(hba
, data
);
769 spin_unlock_irqrestore(hba
->host
->host_lock
, flags
);
771 return IRQ_RETVAL(handled
);
774 static int stex_handshake(struct st_hba
*hba
)
776 void __iomem
*base
= hba
->mmio_base
;
777 struct handshake_frame
*h
;
778 dma_addr_t status_phys
;
780 unsigned long before
;
782 if (readl(base
+ OMR0
) != MU_HANDSHAKE_SIGNATURE
) {
783 writel(MU_INBOUND_DOORBELL_HANDSHAKE
, base
+ IDBL
);
786 while (readl(base
+ OMR0
) != MU_HANDSHAKE_SIGNATURE
) {
787 if (time_after(jiffies
, before
+ MU_MAX_DELAY
* HZ
)) {
788 printk(KERN_ERR DRV_NAME
789 "(%s): no handshake signature\n",
790 pci_name(hba
->pdev
));
800 data
= readl(base
+ OMR1
);
801 if ((data
& 0xffff0000) == MU_HANDSHAKE_SIGNATURE_HALF
) {
803 if (hba
->host
->can_queue
> data
)
804 hba
->host
->can_queue
= data
;
807 h
= (struct handshake_frame
*)(hba
->dma_mem
+ MU_REQ_BUFFER_SIZE
);
808 h
->rb_phy
= cpu_to_le32(hba
->dma_handle
);
809 h
->rb_phy_hi
= cpu_to_le32((hba
->dma_handle
>> 16) >> 16);
810 h
->req_sz
= cpu_to_le16(sizeof(struct req_msg
));
811 h
->req_cnt
= cpu_to_le16(MU_REQ_COUNT
);
812 h
->status_sz
= cpu_to_le16(sizeof(struct status_msg
));
813 h
->status_cnt
= cpu_to_le16(MU_STATUS_COUNT
);
814 stex_gettime(&h
->hosttime
);
815 h
->partner_type
= HMU_PARTNER_TYPE
;
816 if (hba
->dma_size
> STEX_BUFFER_SIZE
) {
817 h
->extra_offset
= cpu_to_le32(STEX_BUFFER_SIZE
);
818 h
->extra_size
= cpu_to_le32(ST_ADDITIONAL_MEM
);
820 h
->extra_offset
= h
->extra_size
= 0;
822 status_phys
= hba
->dma_handle
+ MU_REQ_BUFFER_SIZE
;
823 writel(status_phys
, base
+ IMR0
);
825 writel((status_phys
>> 16) >> 16, base
+ IMR1
);
828 writel((status_phys
>> 16) >> 16, base
+ OMR0
); /* old fw compatible */
830 writel(MU_INBOUND_DOORBELL_HANDSHAKE
, base
+ IDBL
);
831 readl(base
+ IDBL
); /* flush */
835 while (readl(base
+ OMR0
) != MU_HANDSHAKE_SIGNATURE
) {
836 if (time_after(jiffies
, before
+ MU_MAX_DELAY
* HZ
)) {
837 printk(KERN_ERR DRV_NAME
838 "(%s): no signature after handshake frame\n",
839 pci_name(hba
->pdev
));
846 writel(0, base
+ IMR0
);
848 writel(0, base
+ OMR0
);
850 writel(0, base
+ IMR1
);
852 writel(0, base
+ OMR1
);
853 readl(base
+ OMR1
); /* flush */
854 hba
->mu_status
= MU_STATE_STARTED
;
858 static int stex_abort(struct scsi_cmnd
*cmd
)
860 struct Scsi_Host
*host
= cmd
->device
->host
;
861 struct st_hba
*hba
= (struct st_hba
*)host
->hostdata
;
862 u16 tag
= cmd
->request
->tag
;
865 int result
= SUCCESS
;
868 printk(KERN_INFO DRV_NAME
869 "(%s): aborting command\n", pci_name(hba
->pdev
));
870 scsi_print_command(cmd
);
872 base
= hba
->mmio_base
;
873 spin_lock_irqsave(host
->host_lock
, flags
);
874 if (tag
< host
->can_queue
&& hba
->ccb
[tag
].cmd
== cmd
)
875 hba
->wait_ccb
= &hba
->ccb
[tag
];
877 for (tag
= 0; tag
< host
->can_queue
; tag
++)
878 if (hba
->ccb
[tag
].cmd
== cmd
) {
879 hba
->wait_ccb
= &hba
->ccb
[tag
];
882 if (tag
>= host
->can_queue
)
886 data
= readl(base
+ ODBL
);
887 if (data
== 0 || data
== 0xffffffff)
890 writel(data
, base
+ ODBL
);
891 readl(base
+ ODBL
); /* flush */
893 stex_mu_intr(hba
, data
);
895 if (hba
->wait_ccb
== NULL
) {
896 printk(KERN_WARNING DRV_NAME
897 "(%s): lost interrupt\n", pci_name(hba
->pdev
));
903 hba
->wait_ccb
->req
= NULL
; /* nullify the req's future return */
904 hba
->wait_ccb
= NULL
;
907 spin_unlock_irqrestore(host
->host_lock
, flags
);
911 static void stex_hard_reset(struct st_hba
*hba
)
918 for (i
= 0; i
< 16; i
++)
919 pci_read_config_dword(hba
->pdev
, i
* 4,
920 &hba
->pdev
->saved_config_space
[i
]);
922 /* Reset secondary bus. Our controller(MU/ATU) is the only device on
923 secondary bus. Consult Intel 80331/3 developer's manual for detail */
924 bus
= hba
->pdev
->bus
;
925 pci_read_config_byte(bus
->self
, PCI_BRIDGE_CONTROL
, &pci_bctl
);
926 pci_bctl
|= PCI_BRIDGE_CTL_BUS_RESET
;
927 pci_write_config_byte(bus
->self
, PCI_BRIDGE_CONTROL
, pci_bctl
);
930 * 1 ms may be enough for 8-port controllers. But 16-port controllers
931 * require more time to finish bus reset. Use 100 ms here for safety
934 pci_bctl
&= ~PCI_BRIDGE_CTL_BUS_RESET
;
935 pci_write_config_byte(bus
->self
, PCI_BRIDGE_CONTROL
, pci_bctl
);
937 for (i
= 0; i
< MU_HARD_RESET_WAIT
; i
++) {
938 pci_read_config_word(hba
->pdev
, PCI_COMMAND
, &pci_cmd
);
939 if (pci_cmd
!= 0xffff && (pci_cmd
& PCI_COMMAND_MASTER
))
945 for (i
= 0; i
< 16; i
++)
946 pci_write_config_dword(hba
->pdev
, i
* 4,
947 hba
->pdev
->saved_config_space
[i
]);
950 static int stex_reset(struct scsi_cmnd
*cmd
)
954 unsigned long before
;
956 hba
= (struct st_hba
*) &cmd
->device
->host
->hostdata
[0];
958 printk(KERN_INFO DRV_NAME
959 "(%s): resetting host\n", pci_name(hba
->pdev
));
960 scsi_print_command(cmd
);
962 hba
->mu_status
= MU_STATE_RESETTING
;
964 if (hba
->cardtype
== st_shasta
)
965 stex_hard_reset(hba
);
967 if (hba
->cardtype
!= st_yosemite
) {
968 if (stex_handshake(hba
)) {
969 printk(KERN_WARNING DRV_NAME
970 "(%s): resetting: handshake failed\n",
971 pci_name(hba
->pdev
));
974 spin_lock_irqsave(hba
->host
->host_lock
, flags
);
977 hba
->status_head
= 0;
978 hba
->status_tail
= 0;
979 hba
->out_req_cnt
= 0;
980 spin_unlock_irqrestore(hba
->host
->host_lock
, flags
);
985 writel(MU_INBOUND_DOORBELL_RESET
, hba
->mmio_base
+ IDBL
);
986 readl(hba
->mmio_base
+ IDBL
); /* flush */
988 while (hba
->out_req_cnt
> 0) {
989 if (time_after(jiffies
, before
+ ST_INTERNAL_TIMEOUT
* HZ
)) {
990 printk(KERN_WARNING DRV_NAME
991 "(%s): reset timeout\n", pci_name(hba
->pdev
));
997 hba
->mu_status
= MU_STATE_STARTED
;
1001 static int stex_biosparam(struct scsi_device
*sdev
,
1002 struct block_device
*bdev
, sector_t capacity
, int geom
[])
1004 int heads
= 255, sectors
= 63;
1006 if (capacity
< 0x200000) {
1011 sector_div(capacity
, heads
* sectors
);
1020 static struct scsi_host_template driver_template
= {
1021 .module
= THIS_MODULE
,
1023 .proc_name
= DRV_NAME
,
1024 .bios_param
= stex_biosparam
,
1025 .queuecommand
= stex_queuecommand
,
1026 .slave_alloc
= stex_slave_alloc
,
1027 .slave_configure
= stex_slave_config
,
1028 .slave_destroy
= stex_slave_destroy
,
1029 .eh_abort_handler
= stex_abort
,
1030 .eh_host_reset_handler
= stex_reset
,
1031 .can_queue
= ST_CAN_QUEUE
,
1033 .sg_tablesize
= ST_MAX_SG
,
1034 .cmd_per_lun
= ST_CMD_PER_LUN
,
1037 static int stex_set_dma_mask(struct pci_dev
* pdev
)
1041 if (!pci_set_dma_mask(pdev
, DMA_64BIT_MASK
)
1042 && !pci_set_consistent_dma_mask(pdev
, DMA_64BIT_MASK
))
1044 ret
= pci_set_dma_mask(pdev
, DMA_32BIT_MASK
);
1046 ret
= pci_set_consistent_dma_mask(pdev
, DMA_32BIT_MASK
);
1050 static int __devinit
1051 stex_probe(struct pci_dev
*pdev
, const struct pci_device_id
*id
)
1054 struct Scsi_Host
*host
;
1057 err
= pci_enable_device(pdev
);
1061 pci_set_master(pdev
);
1063 host
= scsi_host_alloc(&driver_template
, sizeof(struct st_hba
));
1066 printk(KERN_ERR DRV_NAME
"(%s): scsi_host_alloc failed\n",
1072 hba
= (struct st_hba
*)host
->hostdata
;
1073 memset(hba
, 0, sizeof(struct st_hba
));
1075 err
= pci_request_regions(pdev
, DRV_NAME
);
1077 printk(KERN_ERR DRV_NAME
"(%s): request regions failed\n",
1079 goto out_scsi_host_put
;
1082 hba
->mmio_base
= pci_ioremap_bar(pdev
, 0);
1083 if ( !hba
->mmio_base
) {
1084 printk(KERN_ERR DRV_NAME
"(%s): memory map failed\n",
1087 goto out_release_regions
;
1090 err
= stex_set_dma_mask(pdev
);
1092 printk(KERN_ERR DRV_NAME
"(%s): set dma mask failed\n",
1097 hba
->cardtype
= (unsigned int) id
->driver_data
;
1098 if (hba
->cardtype
== st_vsc
&& (pdev
->subsystem_device
& 1))
1099 hba
->cardtype
= st_vsc1
;
1100 hba
->dma_size
= (hba
->cardtype
== st_vsc1
|| hba
->cardtype
== st_seq
) ?
1101 (STEX_BUFFER_SIZE
+ ST_ADDITIONAL_MEM
) : (STEX_BUFFER_SIZE
);
1102 hba
->dma_mem
= dma_alloc_coherent(&pdev
->dev
,
1103 hba
->dma_size
, &hba
->dma_handle
, GFP_KERNEL
);
1104 if (!hba
->dma_mem
) {
1106 printk(KERN_ERR DRV_NAME
"(%s): dma mem alloc failed\n",
1111 hba
->status_buffer
=
1112 (struct status_msg
*)(hba
->dma_mem
+ MU_REQ_BUFFER_SIZE
);
1113 hba
->copy_buffer
= hba
->dma_mem
+ MU_BUFFER_SIZE
;
1114 hba
->mu_status
= MU_STATE_STARTING
;
1116 if (hba
->cardtype
== st_shasta
) {
1118 host
->max_id
= 16 + 1;
1119 } else if (hba
->cardtype
== st_yosemite
) {
1120 host
->max_lun
= 256;
1121 host
->max_id
= 1 + 1;
1123 /* st_vsc , st_vsc1 and st_seq */
1125 host
->max_id
= 128 + 1;
1127 host
->max_channel
= 0;
1128 host
->unique_id
= host
->host_no
;
1129 host
->max_cmd_len
= STEX_CDB_LENGTH
;
1133 init_waitqueue_head(&hba
->waitq
);
1135 err
= request_irq(pdev
->irq
, stex_intr
, IRQF_SHARED
, DRV_NAME
, hba
);
1137 printk(KERN_ERR DRV_NAME
"(%s): request irq failed\n",
1142 err
= stex_handshake(hba
);
1146 err
= scsi_init_shared_tag_map(host
, host
->can_queue
);
1148 printk(KERN_ERR DRV_NAME
"(%s): init shared queue failed\n",
1153 pci_set_drvdata(pdev
, hba
);
1155 err
= scsi_add_host(host
, &pdev
->dev
);
1157 printk(KERN_ERR DRV_NAME
"(%s): scsi_add_host failed\n",
1162 scsi_scan_host(host
);
1167 free_irq(pdev
->irq
, hba
);
1169 dma_free_coherent(&pdev
->dev
, hba
->dma_size
,
1170 hba
->dma_mem
, hba
->dma_handle
);
1172 iounmap(hba
->mmio_base
);
1173 out_release_regions
:
1174 pci_release_regions(pdev
);
1176 scsi_host_put(host
);
1178 pci_disable_device(pdev
);
1183 static void stex_hba_stop(struct st_hba
*hba
)
1185 struct req_msg
*req
;
1186 unsigned long flags
;
1187 unsigned long before
;
1190 spin_lock_irqsave(hba
->host
->host_lock
, flags
);
1191 req
= stex_alloc_req(hba
);
1192 memset(req
->cdb
, 0, STEX_CDB_LENGTH
);
1194 if (hba
->cardtype
== st_yosemite
) {
1195 req
->cdb
[0] = MGT_CMD
;
1196 req
->cdb
[1] = MGT_CMD_SIGNATURE
;
1197 req
->cdb
[2] = CTLR_CONFIG_CMD
;
1198 req
->cdb
[3] = CTLR_SHUTDOWN
;
1200 req
->cdb
[0] = CONTROLLER_CMD
;
1201 req
->cdb
[1] = CTLR_POWER_STATE_CHANGE
;
1202 req
->cdb
[2] = CTLR_POWER_SAVING
;
1205 hba
->ccb
[tag
].cmd
= NULL
;
1206 hba
->ccb
[tag
].sg_count
= 0;
1207 hba
->ccb
[tag
].sense_bufflen
= 0;
1208 hba
->ccb
[tag
].sense_buffer
= NULL
;
1209 hba
->ccb
[tag
].req_type
|= PASSTHRU_REQ_TYPE
;
1211 stex_send_cmd(hba
, req
, tag
);
1212 spin_unlock_irqrestore(hba
->host
->host_lock
, flags
);
1215 while (hba
->ccb
[tag
].req_type
& PASSTHRU_REQ_TYPE
) {
1216 if (time_after(jiffies
, before
+ ST_INTERNAL_TIMEOUT
* HZ
))
1222 static void stex_hba_free(struct st_hba
*hba
)
1224 free_irq(hba
->pdev
->irq
, hba
);
1226 iounmap(hba
->mmio_base
);
1228 pci_release_regions(hba
->pdev
);
1230 dma_free_coherent(&hba
->pdev
->dev
, hba
->dma_size
,
1231 hba
->dma_mem
, hba
->dma_handle
);
1234 static void stex_remove(struct pci_dev
*pdev
)
1236 struct st_hba
*hba
= pci_get_drvdata(pdev
);
1238 scsi_remove_host(hba
->host
);
1240 pci_set_drvdata(pdev
, NULL
);
1246 scsi_host_put(hba
->host
);
1248 pci_disable_device(pdev
);
1251 static void stex_shutdown(struct pci_dev
*pdev
)
1253 struct st_hba
*hba
= pci_get_drvdata(pdev
);
1258 static struct pci_device_id stex_pci_tbl
[] = {
1260 { 0x105a, 0x8350, PCI_ANY_ID
, PCI_ANY_ID
, 0, 0,
1261 st_shasta
}, /* SuperTrak EX8350/8300/16350/16300 */
1262 { 0x105a, 0xc350, PCI_ANY_ID
, PCI_ANY_ID
, 0, 0,
1263 st_shasta
}, /* SuperTrak EX12350 */
1264 { 0x105a, 0x4302, PCI_ANY_ID
, PCI_ANY_ID
, 0, 0,
1265 st_shasta
}, /* SuperTrak EX4350 */
1266 { 0x105a, 0xe350, PCI_ANY_ID
, PCI_ANY_ID
, 0, 0,
1267 st_shasta
}, /* SuperTrak EX24350 */
1270 { 0x105a, 0x7250, PCI_ANY_ID
, PCI_ANY_ID
, 0, 0, st_vsc
},
1273 { 0x105a, 0x8650, PCI_ANY_ID
, PCI_ANY_ID
, 0, 0, st_yosemite
},
1276 { 0x105a, 0x3360, PCI_ANY_ID
, PCI_ANY_ID
, 0, 0, st_seq
},
1277 { } /* terminate list */
1279 MODULE_DEVICE_TABLE(pci
, stex_pci_tbl
);
1281 static struct pci_driver stex_pci_driver
= {
1283 .id_table
= stex_pci_tbl
,
1284 .probe
= stex_probe
,
1285 .remove
= __devexit_p(stex_remove
),
1286 .shutdown
= stex_shutdown
,
1289 static int __init
stex_init(void)
1291 printk(KERN_INFO DRV_NAME
1292 ": Promise SuperTrak EX Driver version: %s\n",
1295 return pci_register_driver(&stex_pci_driver
);
1298 static void __exit
stex_exit(void)
1300 pci_unregister_driver(&stex_pci_driver
);
1303 module_init(stex_init
);
1304 module_exit(stex_exit
);