]> Git Repo - linux.git/blame - drivers/scsi/stex.c
Linux 6.14-rc3
[linux.git] / drivers / scsi / stex.c
CommitLineData
2874c5fd 1// SPDX-License-Identifier: GPL-2.0-or-later
5a25ba16
JG
2/*
3 * SuperTrak EX Series Storage Controller driver for Linux
4 *
1ec364e6 5 * Copyright (C) 2005-2015 Promise Technology Inc.
5a25ba16 6 *
5a25ba16
JG
7 * Written By:
8 * Ed Lin <[email protected]>
5a25ba16
JG
9 */
10
11#include <linux/init.h>
12#include <linux/errno.h>
13#include <linux/kernel.h>
14#include <linux/delay.h>
5a0e3ad6 15#include <linux/slab.h>
5a25ba16
JG
16#include <linux/time.h>
17#include <linux/pci.h>
18#include <linux/blkdev.h>
19#include <linux/interrupt.h>
20#include <linux/types.h>
21#include <linux/module.h>
22#include <linux/spinlock.h>
0da39687 23#include <linux/ktime.h>
61b745fa 24#include <linux/reboot.h>
5a25ba16
JG
25#include <asm/io.h>
26#include <asm/irq.h>
27#include <asm/byteorder.h>
28#include <scsi/scsi.h>
29#include <scsi/scsi_device.h>
30#include <scsi/scsi_cmnd.h>
31#include <scsi/scsi_host.h>
cf355883 32#include <scsi/scsi_tcq.h>
c25da0af 33#include <scsi/scsi_dbg.h>
11002fbc 34#include <scsi/scsi_eh.h>
5a25ba16
JG
35
36#define DRV_NAME "stex"
d6570227
C
37#define ST_DRIVER_VERSION "6.02.0000.01"
38#define ST_VER_MAJOR 6
39#define ST_VER_MINOR 02
1ec364e6
C
40#define ST_OEM 0000
41#define ST_BUILD_VER 01
5a25ba16
JG
42
43enum {
44 /* MU register offset */
45 IMR0 = 0x10, /* MU_INBOUND_MESSAGE_REG0 */
46 IMR1 = 0x14, /* MU_INBOUND_MESSAGE_REG1 */
47 OMR0 = 0x18, /* MU_OUTBOUND_MESSAGE_REG0 */
48 OMR1 = 0x1c, /* MU_OUTBOUND_MESSAGE_REG1 */
49 IDBL = 0x20, /* MU_INBOUND_DOORBELL */
50 IIS = 0x24, /* MU_INBOUND_INTERRUPT_STATUS */
51 IIM = 0x28, /* MU_INBOUND_INTERRUPT_MASK */
52 ODBL = 0x2c, /* MU_OUTBOUND_DOORBELL */
53 OIS = 0x30, /* MU_OUTBOUND_INTERRUPT_STATUS */
54 OIM = 0x3c, /* MU_OUTBOUND_INTERRUPT_MASK */
55
69cb4875 56 YIOA_STATUS = 0x00,
0f3f6ee6
EL
57 YH2I_INT = 0x20,
58 YINT_EN = 0x34,
59 YI2H_INT = 0x9c,
60 YI2H_INT_C = 0xa0,
61 YH2I_REQ = 0xc0,
62 YH2I_REQ_HI = 0xc4,
d6570227
C
63 PSCRATCH0 = 0xb0,
64 PSCRATCH1 = 0xb4,
65 PSCRATCH2 = 0xb8,
66 PSCRATCH3 = 0xbc,
67 PSCRATCH4 = 0xc8,
68 MAILBOX_BASE = 0x1000,
69 MAILBOX_HNDSHK_STS = 0x0,
0f3f6ee6 70
5a25ba16 71 /* MU register value */
9eb46d2a
EL
72 MU_INBOUND_DOORBELL_HANDSHAKE = (1 << 0),
73 MU_INBOUND_DOORBELL_REQHEADCHANGED = (1 << 1),
74 MU_INBOUND_DOORBELL_STATUSTAILCHANGED = (1 << 2),
75 MU_INBOUND_DOORBELL_HMUSTOPPED = (1 << 3),
76 MU_INBOUND_DOORBELL_RESET = (1 << 4),
77
78 MU_OUTBOUND_DOORBELL_HANDSHAKE = (1 << 0),
79 MU_OUTBOUND_DOORBELL_REQUESTTAILCHANGED = (1 << 1),
80 MU_OUTBOUND_DOORBELL_STATUSHEADCHANGED = (1 << 2),
81 MU_OUTBOUND_DOORBELL_BUSCHANGE = (1 << 3),
82 MU_OUTBOUND_DOORBELL_HASEVENT = (1 << 4),
83 MU_OUTBOUND_DOORBELL_REQUEST_RESET = (1 << 27),
5a25ba16
JG
84
85 /* MU status code */
86 MU_STATE_STARTING = 1,
9eb46d2a
EL
87 MU_STATE_STARTED = 2,
88 MU_STATE_RESETTING = 3,
89 MU_STATE_FAILED = 4,
45b42adb
C
90 MU_STATE_STOP = 5,
91 MU_STATE_NOCONNECT = 6,
5a25ba16 92
d6570227 93 MU_MAX_DELAY = 50,
5a25ba16 94 MU_HANDSHAKE_SIGNATURE = 0x55aaaa55,
529e7a62 95 MU_HANDSHAKE_SIGNATURE_HALF = 0x5a5a0000,
76fbf96f 96 MU_HARD_RESET_WAIT = 30000,
5a25ba16
JG
97 HMU_PARTNER_TYPE = 2,
98
99 /* firmware returned values */
100 SRB_STATUS_SUCCESS = 0x01,
101 SRB_STATUS_ERROR = 0x04,
102 SRB_STATUS_BUSY = 0x05,
103 SRB_STATUS_INVALID_REQUEST = 0x06,
104 SRB_STATUS_SELECTION_TIMEOUT = 0x0A,
105 SRB_SEE_SENSE = 0x80,
106
107 /* task attribute */
108 TASK_ATTRIBUTE_SIMPLE = 0x0,
109 TASK_ATTRIBUTE_HEADOFQUEUE = 0x1,
110 TASK_ATTRIBUTE_ORDERED = 0x2,
111 TASK_ATTRIBUTE_ACA = 0x4,
6d074ce2 112};
5a25ba16 113
6d074ce2 114enum {
0f3f6ee6
EL
115 SS_STS_NORMAL = 0x80000000,
116 SS_STS_DONE = 0x40000000,
117 SS_STS_HANDSHAKE = 0x20000000,
118
119 SS_HEAD_HANDSHAKE = 0x80,
120
69cb4875
EL
121 SS_H2I_INT_RESET = 0x100,
122
9eb46d2a
EL
123 SS_I2H_REQUEST_RESET = 0x2000,
124
69cb4875 125 SS_MU_OPERATIONAL = 0x80000000,
6d074ce2 126};
69cb4875 127
6d074ce2 128enum {
7cfe99a5 129 STEX_CDB_LENGTH = 16,
5a25ba16 130 STATUS_VAR_LEN = 128,
5a25ba16
JG
131
132 /* sg flags */
133 SG_CF_EOT = 0x80, /* end of table */
134 SG_CF_64B = 0x40, /* 64 bit item */
135 SG_CF_HOST = 0x20, /* sg in host memory */
7cfe99a5
ELP
136 MSG_DATA_DIR_ND = 0,
137 MSG_DATA_DIR_IN = 1,
138 MSG_DATA_DIR_OUT = 2,
5a25ba16 139
5a25ba16
JG
140 st_shasta = 0,
141 st_vsc = 1,
591a3a5f
EL
142 st_yosemite = 2,
143 st_seq = 3,
0f3f6ee6 144 st_yel = 4,
d6570227 145 st_P3 = 5,
5a25ba16
JG
146
147 PASSTHRU_REQ_TYPE = 0x00000001,
148 PASSTHRU_REQ_NO_WAKEUP = 0x00000100,
7cfe99a5 149 ST_INTERNAL_TIMEOUT = 180,
5a25ba16 150
fb4f66be
EL
151 ST_TO_CMD = 0,
152 ST_FROM_CMD = 1,
153
5a25ba16 154 /* vendor specific commands of Promise */
fb4f66be
EL
155 MGT_CMD = 0xd8,
156 SINBAND_MGT_CMD = 0xd9,
5a25ba16
JG
157 ARRAY_CMD = 0xe0,
158 CONTROLLER_CMD = 0xe1,
159 DEBUGGING_CMD = 0xe2,
160 PASSTHRU_CMD = 0xe3,
161
162 PASSTHRU_GET_ADAPTER = 0x05,
163 PASSTHRU_GET_DRVVER = 0x10,
fb4f66be
EL
164
165 CTLR_CONFIG_CMD = 0x03,
166 CTLR_SHUTDOWN = 0x0d,
167
5a25ba16
JG
168 CTLR_POWER_STATE_CHANGE = 0x0e,
169 CTLR_POWER_SAVING = 0x01,
170
171 PASSTHRU_SIGNATURE = 0x4e415041,
fb4f66be 172 MGT_CMD_SIGNATURE = 0xba,
5a25ba16
JG
173
174 INQUIRY_EVPD = 0x01,
94e9108b
EL
175
176 ST_ADDITIONAL_MEM = 0x200000,
cbacfb5f 177 ST_ADDITIONAL_MEM_MIN = 0x80000,
797150b9
C
178 PMIC_SHUTDOWN = 0x0D,
179 PMIC_REUMSE = 0x10,
180 ST_IGNORED = -1,
181 ST_NOTHANDLED = 7,
182 ST_S3 = 3,
183 ST_S4 = 4,
184 ST_S5 = 5,
185 ST_S6 = 6,
5a25ba16
JG
186};
187
188struct st_sgitem {
189 u8 ctrl; /* SG_CF_xxx */
190 u8 reserved[3];
191 __le32 count;
f1498161 192 __le64 addr;
5a25ba16
JG
193};
194
0f3f6ee6
EL
195struct st_ss_sgitem {
196 __le32 addr;
197 __le32 addr_hi;
198 __le32 count;
199};
200
5a25ba16
JG
201struct st_sgtable {
202 __le16 sg_count;
203 __le16 max_sg_count;
204 __le32 sz_in_byte;
5a25ba16
JG
205};
206
0f3f6ee6
EL
207struct st_msg_header {
208 __le64 handle;
209 u8 flag;
210 u8 channel;
211 __le16 timeout;
212 u32 reserved;
213};
214
5a25ba16 215struct handshake_frame {
f1498161 216 __le64 rb_phy; /* request payload queue physical address */
5a25ba16
JG
217 __le16 req_sz; /* size of each request payload */
218 __le16 req_cnt; /* count of reqs the buffer can hold */
219 __le16 status_sz; /* size of each status payload */
220 __le16 status_cnt; /* count of status the buffer can hold */
f1498161 221 __le64 hosttime; /* seconds from Jan 1, 1970 (GMT) */
5a25ba16
JG
222 u8 partner_type; /* who sends this frame */
223 u8 reserved0[7];
224 __le32 partner_ver_major;
225 __le32 partner_ver_minor;
226 __le32 partner_ver_oem;
227 __le32 partner_ver_build;
94e9108b
EL
228 __le32 extra_offset; /* NEW */
229 __le32 extra_size; /* NEW */
0f3f6ee6
EL
230 __le32 scratch_size;
231 u32 reserved1;
5a25ba16
JG
232};
233
234struct req_msg {
235 __le16 tag;
236 u8 lun;
237 u8 target;
238 u8 task_attr;
239 u8 task_manage;
7cfe99a5 240 u8 data_dir;
f903d7b7 241 u8 payload_sz; /* payload size in 4-byte, not used */
5a25ba16 242 u8 cdb[STEX_CDB_LENGTH];
5febf6d6 243 u32 variable[];
5a25ba16
JG
244};
245
246struct status_msg {
247 __le16 tag;
248 u8 lun;
249 u8 target;
250 u8 srb_status;
251 u8 scsi_status;
252 u8 reserved;
253 u8 payload_sz; /* payload size in 4-byte */
254 u8 variable[STATUS_VAR_LEN];
255};
256
257struct ver_info {
258 u32 major;
259 u32 minor;
260 u32 oem;
261 u32 build;
262 u32 reserved[2];
263};
264
265struct st_frame {
266 u32 base[6];
267 u32 rom_addr;
268
269 struct ver_info drv_ver;
270 struct ver_info bios_ver;
271
272 u32 bus;
273 u32 slot;
274 u32 irq_level;
275 u32 irq_vec;
276 u32 id;
277 u32 subid;
278
279 u32 dimm_size;
280 u8 dimm_type;
281 u8 reserved[3];
282
283 u32 channel;
284 u32 reserved1;
285};
286
287struct st_drvver {
288 u32 major;
289 u32 minor;
290 u32 oem;
291 u32 build;
292 u32 signature[2];
293 u8 console_id;
294 u8 host_no;
295 u8 reserved0[2];
296 u32 reserved[3];
297};
298
5a25ba16
JG
299struct st_ccb {
300 struct req_msg *req;
301 struct scsi_cmnd *cmd;
302
303 void *sense_buffer;
304 unsigned int sense_bufflen;
305 int sg_count;
306
307 u32 req_type;
308 u8 srb_status;
309 u8 scsi_status;
f1498161 310 u8 reserved[2];
5a25ba16
JG
311};
312
313struct st_hba {
314 void __iomem *mmio_base; /* iomapped PCI memory space */
315 void *dma_mem;
316 dma_addr_t dma_handle;
94e9108b 317 size_t dma_size;
5a25ba16
JG
318
319 struct Scsi_Host *host;
320 struct pci_dev *pdev;
321
0f3f6ee6
EL
322 struct req_msg * (*alloc_rq) (struct st_hba *);
323 int (*map_sg)(struct st_hba *, struct req_msg *, struct st_ccb *);
324 void (*send) (struct st_hba *, struct req_msg *, u16);
325
5a25ba16
JG
326 u32 req_head;
327 u32 req_tail;
328 u32 status_head;
329 u32 status_tail;
330
331 struct status_msg *status_buffer;
332 void *copy_buffer; /* temp buffer for driver-handled commands */
591a3a5f 333 struct st_ccb *ccb;
5a25ba16 334 struct st_ccb *wait_ccb;
0f3f6ee6 335 __le32 *scratch;
5a25ba16 336
9eb46d2a
EL
337 struct workqueue_struct *work_q;
338 struct work_struct reset_work;
339 wait_queue_head_t reset_waitq;
5a25ba16 340 unsigned int mu_status;
5a25ba16 341 unsigned int cardtype;
99946f81
EL
342 int msi_enabled;
343 int out_req_cnt;
591a3a5f
EL
344 u32 extra_offset;
345 u16 rq_count;
346 u16 rq_size;
347 u16 sts_count;
1ec364e6 348 u8 supports_pm;
d6570227 349 int msi_lock;
591a3a5f
EL
350};
351
352struct st_card_info {
0f3f6ee6
EL
353 struct req_msg * (*alloc_rq) (struct st_hba *);
354 int (*map_sg)(struct st_hba *, struct req_msg *, struct st_ccb *);
355 void (*send) (struct st_hba *, struct req_msg *, u16);
591a3a5f
EL
356 unsigned int max_id;
357 unsigned int max_lun;
358 unsigned int max_channel;
359 u16 rq_count;
360 u16 rq_size;
361 u16 sts_count;
5a25ba16
JG
362};
363
9385c5be 364static int S6flag;
61b745fa
C
365static int stex_halt(struct notifier_block *nb, ulong event, void *buf);
366static struct notifier_block stex_notifier = {
367 stex_halt, NULL, 0
368};
369
99946f81
EL
370static int msi;
371module_param(msi, int, 0);
372MODULE_PARM_DESC(msi, "Enable Message Signaled Interrupts(0=off, 1=on)");
373
5a25ba16
JG
374static const char console_inq_page[] =
375{
376 0x03,0x00,0x03,0x03,0xFA,0x00,0x00,0x30,
377 0x50,0x72,0x6F,0x6D,0x69,0x73,0x65,0x20, /* "Promise " */
378 0x52,0x41,0x49,0x44,0x20,0x43,0x6F,0x6E, /* "RAID Con" */
379 0x73,0x6F,0x6C,0x65,0x20,0x20,0x20,0x20, /* "sole " */
380 0x31,0x2E,0x30,0x30,0x20,0x20,0x20,0x20, /* "1.00 " */
381 0x53,0x58,0x2F,0x52,0x53,0x41,0x46,0x2D, /* "SX/RSAF-" */
382 0x54,0x45,0x31,0x2E,0x30,0x30,0x20,0x20, /* "TE1.00 " */
383 0x0C,0x20,0x20,0x20,0x20,0x20,0x20,0x20
384};
385
386MODULE_AUTHOR("Ed Lin");
387MODULE_DESCRIPTION("Promise Technology SuperTrak EX Controllers");
388MODULE_LICENSE("GPL");
389MODULE_VERSION(ST_DRIVER_VERSION);
390
5a25ba16
JG
391static struct status_msg *stex_get_status(struct st_hba *hba)
392{
f1498161 393 struct status_msg *status = hba->status_buffer + hba->status_tail;
5a25ba16
JG
394
395 ++hba->status_tail;
591a3a5f 396 hba->status_tail %= hba->sts_count+1;
5a25ba16
JG
397
398 return status;
399}
400
5a25ba16
JG
401static void stex_invalid_field(struct scsi_cmnd *cmd,
402 void (*done)(struct scsi_cmnd *))
403{
7cfe99a5 404 /* "Invalid field in cdb" */
f2b1e9c6 405 scsi_build_sense(cmd, 0, ILLEGAL_REQUEST, 0x24, 0x0);
5a25ba16
JG
406 done(cmd);
407}
408
409static struct req_msg *stex_alloc_req(struct st_hba *hba)
410{
591a3a5f 411 struct req_msg *req = hba->dma_mem + hba->req_head * hba->rq_size;
5a25ba16
JG
412
413 ++hba->req_head;
591a3a5f 414 hba->req_head %= hba->rq_count+1;
5a25ba16
JG
415
416 return req;
417}
418
0f3f6ee6
EL
419static struct req_msg *stex_ss_alloc_req(struct st_hba *hba)
420{
421 return (struct req_msg *)(hba->dma_mem +
422 hba->req_head * hba->rq_size + sizeof(struct st_msg_header));
423}
424
5a25ba16
JG
425static int stex_map_sg(struct st_hba *hba,
426 struct req_msg *req, struct st_ccb *ccb)
427{
5a25ba16 428 struct scsi_cmnd *cmd;
d5587d5d 429 struct scatterlist *sg;
5a25ba16 430 struct st_sgtable *dst;
f1498161 431 struct st_sgitem *table;
d5587d5d 432 int i, nseg;
5a25ba16
JG
433
434 cmd = ccb->cmd;
d5587d5d 435 nseg = scsi_dma_map(cmd);
f1498161 436 BUG_ON(nseg < 0);
d5587d5d 437 if (nseg) {
f1498161
EL
438 dst = (struct st_sgtable *)req->variable;
439
d5587d5d
FT
440 ccb->sg_count = nseg;
441 dst->sg_count = cpu_to_le16((u16)nseg);
f1498161
EL
442 dst->max_sg_count = cpu_to_le16(hba->host->sg_tablesize);
443 dst->sz_in_byte = cpu_to_le32(scsi_bufflen(cmd));
5a25ba16 444
f1498161 445 table = (struct st_sgitem *)(dst + 1);
d5587d5d 446 scsi_for_each_sg(cmd, sg, nseg, i) {
f1498161
EL
447 table[i].count = cpu_to_le32((u32)sg_dma_len(sg));
448 table[i].addr = cpu_to_le64(sg_dma_address(sg));
449 table[i].ctrl = SG_CF_64B | SG_CF_HOST;
5a25ba16 450 }
f1498161 451 table[--i].ctrl |= SG_CF_EOT;
5a25ba16
JG
452 }
453
f1498161 454 return nseg;
5a25ba16
JG
455}
456
0f3f6ee6
EL
457static int stex_ss_map_sg(struct st_hba *hba,
458 struct req_msg *req, struct st_ccb *ccb)
459{
460 struct scsi_cmnd *cmd;
461 struct scatterlist *sg;
462 struct st_sgtable *dst;
463 struct st_ss_sgitem *table;
464 int i, nseg;
465
466 cmd = ccb->cmd;
467 nseg = scsi_dma_map(cmd);
468 BUG_ON(nseg < 0);
469 if (nseg) {
470 dst = (struct st_sgtable *)req->variable;
471
472 ccb->sg_count = nseg;
473 dst->sg_count = cpu_to_le16((u16)nseg);
474 dst->max_sg_count = cpu_to_le16(hba->host->sg_tablesize);
475 dst->sz_in_byte = cpu_to_le32(scsi_bufflen(cmd));
476
477 table = (struct st_ss_sgitem *)(dst + 1);
478 scsi_for_each_sg(cmd, sg, nseg, i) {
479 table[i].count = cpu_to_le32((u32)sg_dma_len(sg));
480 table[i].addr =
481 cpu_to_le32(sg_dma_address(sg) & 0xffffffff);
482 table[i].addr_hi =
483 cpu_to_le32((sg_dma_address(sg) >> 16) >> 16);
484 }
485 }
486
487 return nseg;
488}
489
5a25ba16
JG
490static void stex_controller_info(struct st_hba *hba, struct st_ccb *ccb)
491{
492 struct st_frame *p;
493 size_t count = sizeof(struct st_frame);
494
495 p = hba->copy_buffer;
f1498161 496 scsi_sg_copy_to_buffer(ccb->cmd, p, count);
5a25ba16
JG
497 memset(p->base, 0, sizeof(u32)*6);
498 *(unsigned long *)(p->base) = pci_resource_start(hba->pdev, 0);
499 p->rom_addr = 0;
500
501 p->drv_ver.major = ST_VER_MAJOR;
502 p->drv_ver.minor = ST_VER_MINOR;
503 p->drv_ver.oem = ST_OEM;
504 p->drv_ver.build = ST_BUILD_VER;
505
506 p->bus = hba->pdev->bus->number;
507 p->slot = hba->pdev->devfn;
508 p->irq_level = 0;
509 p->irq_vec = hba->pdev->irq;
510 p->id = hba->pdev->vendor << 16 | hba->pdev->device;
511 p->subid =
512 hba->pdev->subsystem_vendor << 16 | hba->pdev->subsystem_device;
513
f1498161 514 scsi_sg_copy_from_buffer(ccb->cmd, p, count);
5a25ba16
JG
515}
516
517static void
518stex_send_cmd(struct st_hba *hba, struct req_msg *req, u16 tag)
519{
520 req->tag = cpu_to_le16(tag);
5a25ba16
JG
521
522 hba->ccb[tag].req = req;
523 hba->out_req_cnt++;
524
525 writel(hba->req_head, hba->mmio_base + IMR0);
526 writel(MU_INBOUND_DOORBELL_REQHEADCHANGED, hba->mmio_base + IDBL);
527 readl(hba->mmio_base + IDBL); /* flush */
528}
529
0f3f6ee6
EL
530static void
531stex_ss_send_cmd(struct st_hba *hba, struct req_msg *req, u16 tag)
532{
533 struct scsi_cmnd *cmd;
534 struct st_msg_header *msg_h;
535 dma_addr_t addr;
536
537 req->tag = cpu_to_le16(tag);
538
539 hba->ccb[tag].req = req;
540 hba->out_req_cnt++;
541
542 cmd = hba->ccb[tag].cmd;
543 msg_h = (struct st_msg_header *)req - 1;
544 if (likely(cmd)) {
545 msg_h->channel = (u8)cmd->device->channel;
bbfa8d7d 546 msg_h->timeout = cpu_to_le16(scsi_cmd_to_rq(cmd)->timeout / HZ);
0f3f6ee6
EL
547 }
548 addr = hba->dma_handle + hba->req_head * hba->rq_size;
549 addr += (hba->ccb[tag].sg_count+4)/11;
550 msg_h->handle = cpu_to_le64(addr);
551
552 ++hba->req_head;
553 hba->req_head %= hba->rq_count+1;
d6570227
C
554 if (hba->cardtype == st_P3) {
555 writel((addr >> 16) >> 16, hba->mmio_base + YH2I_REQ_HI);
556 writel(addr, hba->mmio_base + YH2I_REQ);
557 } else {
558 writel((addr >> 16) >> 16, hba->mmio_base + YH2I_REQ_HI);
559 readl(hba->mmio_base + YH2I_REQ_HI); /* flush */
560 writel(addr, hba->mmio_base + YH2I_REQ);
561 readl(hba->mmio_base + YH2I_REQ); /* flush */
562 }
0f3f6ee6
EL
563}
564
45b42adb
C
565static void return_abnormal_state(struct st_hba *hba, int status)
566{
567 struct st_ccb *ccb;
568 unsigned long flags;
569 u16 tag;
570
571 spin_lock_irqsave(hba->host->host_lock, flags);
572 for (tag = 0; tag < hba->host->can_queue; tag++) {
573 ccb = &hba->ccb[tag];
574 if (ccb->req == NULL)
575 continue;
576 ccb->req = NULL;
577 if (ccb->cmd) {
578 scsi_dma_unmap(ccb->cmd);
579 ccb->cmd->result = status << 16;
4acf838e 580 scsi_done(ccb->cmd);
45b42adb
C
581 ccb->cmd = NULL;
582 }
583 }
584 spin_unlock_irqrestore(hba->host->host_lock, flags);
585}
5a25ba16 586static int
49515b7f 587stex_sdev_configure(struct scsi_device *sdev, struct queue_limits *lim)
5a25ba16
JG
588{
589 sdev->use_10_for_rw = 1;
590 sdev->use_10_for_ms = 1;
dc5c49bf 591 blk_queue_rq_timeout(sdev->request_queue, 60 * HZ);
cf355883 592
5a25ba16
JG
593 return 0;
594}
595
af049dfd 596static int stex_queuecommand_lck(struct scsi_cmnd *cmd)
5a25ba16 597{
af049dfd 598 void (*done)(struct scsi_cmnd *) = scsi_done;
5a25ba16
JG
599 struct st_hba *hba;
600 struct Scsi_Host *host;
f1498161 601 unsigned int id, lun;
5a25ba16
JG
602 struct req_msg *req;
603 u16 tag;
7cfe99a5 604
5a25ba16
JG
605 host = cmd->device->host;
606 id = cmd->device->id;
e0b2e597 607 lun = cmd->device->lun;
5a25ba16 608 hba = (struct st_hba *) &host->hostdata[0];
45b42adb
C
609 if (hba->mu_status == MU_STATE_NOCONNECT) {
610 cmd->result = DID_NO_CONNECT;
611 done(cmd);
612 return 0;
613 }
614 if (unlikely(hba->mu_status != MU_STATE_STARTED))
9eb46d2a
EL
615 return SCSI_MLQUEUE_HOST_BUSY;
616
5a25ba16
JG
617 switch (cmd->cmnd[0]) {
618 case MODE_SENSE_10:
619 {
620 static char ms10_caching_page[12] =
621 { 0, 0x12, 0, 0, 0, 0, 0, 0, 0x8, 0xa, 0x4, 0 };
622 unsigned char page;
7cfe99a5 623
5a25ba16
JG
624 page = cmd->cmnd[2] & 0x3f;
625 if (page == 0x8 || page == 0x3f) {
31fe47d4
FT
626 scsi_sg_copy_from_buffer(cmd, ms10_caching_page,
627 sizeof(ms10_caching_page));
8959e81c 628 cmd->result = DID_OK << 16;
5a25ba16
JG
629 done(cmd);
630 } else
631 stex_invalid_field(cmd, done);
632 return 0;
633 }
e0b2e597
EL
634 case REPORT_LUNS:
635 /*
636 * The shasta firmware does not report actual luns in the
637 * target, so fail the command to force sequential lun scan.
638 * Also, the console device does not support this command.
639 */
640 if (hba->cardtype == st_shasta || id == host->max_id - 1) {
641 stex_invalid_field(cmd, done);
642 return 0;
643 }
644 break;
d116a7bc
EL
645 case TEST_UNIT_READY:
646 if (id == host->max_id - 1) {
8959e81c 647 cmd->result = DID_OK << 16;
d116a7bc
EL
648 done(cmd);
649 return 0;
650 }
651 break;
5a25ba16 652 case INQUIRY:
91e6ecad
EL
653 if (lun >= host->max_lun) {
654 cmd->result = DID_NO_CONNECT << 16;
655 done(cmd);
656 return 0;
657 }
e0b2e597 658 if (id != host->max_id - 1)
5a25ba16 659 break;
0f3f6ee6
EL
660 if (!lun && !cmd->device->channel &&
661 (cmd->cmnd[1] & INQUIRY_EVPD) == 0) {
31fe47d4
FT
662 scsi_sg_copy_from_buffer(cmd, (void *)console_inq_page,
663 sizeof(console_inq_page));
8959e81c 664 cmd->result = DID_OK << 16;
5a25ba16
JG
665 done(cmd);
666 } else
667 stex_invalid_field(cmd, done);
668 return 0;
669 case PASSTHRU_CMD:
670 if (cmd->cmnd[1] == PASSTHRU_GET_DRVVER) {
6022f210
LT
671 const struct st_drvver ver = {
672 .major = ST_VER_MAJOR,
673 .minor = ST_VER_MINOR,
674 .oem = ST_OEM,
675 .build = ST_BUILD_VER,
676 .signature[0] = PASSTHRU_SIGNATURE,
677 .console_id = host->max_id - 1,
678 .host_no = hba->host->host_no,
679 };
26106e3c 680 size_t cp_len = sizeof(ver);
7cfe99a5 681
31fe47d4 682 cp_len = scsi_sg_copy_from_buffer(cmd, &ver, cp_len);
8959e81c
HR
683 if (sizeof(ver) == cp_len)
684 cmd->result = DID_OK << 16;
685 else
686 cmd->result = DID_ERROR << 16;
5a25ba16
JG
687 done(cmd);
688 return 0;
689 }
8b185fc6 690 break;
5a25ba16
JG
691 default:
692 break;
693 }
694
bbfa8d7d 695 tag = scsi_cmd_to_rq(cmd)->tag;
cf355883
EL
696
697 if (unlikely(tag >= host->can_queue))
5a25ba16
JG
698 return SCSI_MLQUEUE_HOST_BUSY;
699
0f3f6ee6 700 req = hba->alloc_rq(hba);
fb4f66be 701
e0b2e597
EL
702 req->lun = lun;
703 req->target = id;
5a25ba16
JG
704
705 /* cdb */
706 memcpy(req->cdb, cmd->cmnd, STEX_CDB_LENGTH);
707
7cfe99a5
ELP
708 if (cmd->sc_data_direction == DMA_FROM_DEVICE)
709 req->data_dir = MSG_DATA_DIR_IN;
710 else if (cmd->sc_data_direction == DMA_TO_DEVICE)
711 req->data_dir = MSG_DATA_DIR_OUT;
712 else
713 req->data_dir = MSG_DATA_DIR_ND;
714
5a25ba16
JG
715 hba->ccb[tag].cmd = cmd;
716 hba->ccb[tag].sense_bufflen = SCSI_SENSE_BUFFERSIZE;
717 hba->ccb[tag].sense_buffer = cmd->sense_buffer;
5a25ba16 718
0f3f6ee6
EL
719 if (!hba->map_sg(hba, req, &hba->ccb[tag])) {
720 hba->ccb[tag].sg_count = 0;
721 memset(&req->variable[0], 0, 8);
722 }
5a25ba16 723
0f3f6ee6 724 hba->send(hba, req, tag);
5a25ba16
JG
725 return 0;
726}
727
f281233d
JG
728static DEF_SCSI_QCMD(stex_queuecommand)
729
5a25ba16
JG
730static void stex_scsi_done(struct st_ccb *ccb)
731{
732 struct scsi_cmnd *cmd = ccb->cmd;
733 int result;
734
f1498161 735 if (ccb->srb_status == SRB_STATUS_SUCCESS || ccb->srb_status == 0) {
5a25ba16
JG
736 result = ccb->scsi_status;
737 switch (ccb->scsi_status) {
738 case SAM_STAT_GOOD:
8959e81c 739 result |= DID_OK << 16;
5a25ba16
JG
740 break;
741 case SAM_STAT_CHECK_CONDITION:
464a00c9 742 result |= DID_OK << 16;
5a25ba16
JG
743 break;
744 case SAM_STAT_BUSY:
8959e81c 745 result |= DID_BUS_BUSY << 16;
5a25ba16
JG
746 break;
747 default:
8959e81c 748 result |= DID_ERROR << 16;
5a25ba16
JG
749 break;
750 }
751 }
752 else if (ccb->srb_status & SRB_SEE_SENSE)
464a00c9 753 result = SAM_STAT_CHECK_CONDITION;
5a25ba16
JG
754 else switch (ccb->srb_status) {
755 case SRB_STATUS_SELECTION_TIMEOUT:
8959e81c 756 result = DID_NO_CONNECT << 16;
5a25ba16
JG
757 break;
758 case SRB_STATUS_BUSY:
8959e81c 759 result = DID_BUS_BUSY << 16;
5a25ba16
JG
760 break;
761 case SRB_STATUS_INVALID_REQUEST:
762 case SRB_STATUS_ERROR:
763 default:
8959e81c 764 result = DID_ERROR << 16;
5a25ba16
JG
765 break;
766 }
767
768 cmd->result = result;
4acf838e 769 scsi_done(cmd);
5a25ba16
JG
770}
771
772static void stex_copy_data(struct st_ccb *ccb,
773 struct status_msg *resp, unsigned int variable)
774{
5a25ba16
JG
775 if (resp->scsi_status != SAM_STAT_GOOD) {
776 if (ccb->sense_buffer != NULL)
777 memcpy(ccb->sense_buffer, resp->variable,
778 min(variable, ccb->sense_bufflen));
779 return;
780 }
781
782 if (ccb->cmd == NULL)
783 return;
f1498161 784 scsi_sg_copy_from_buffer(ccb->cmd, resp->variable, variable);
fb4f66be
EL
785}
786
f1498161 787static void stex_check_cmd(struct st_hba *hba,
fb4f66be
EL
788 struct st_ccb *ccb, struct status_msg *resp)
789{
fb4f66be 790 if (ccb->cmd->cmnd[0] == MGT_CMD &&
f1498161 791 resp->scsi_status != SAM_STAT_CHECK_CONDITION)
968a5763
EL
792 scsi_set_resid(ccb->cmd, scsi_bufflen(ccb->cmd) -
793 le32_to_cpu(*(__le32 *)&resp->variable[0]));
5a25ba16
JG
794}
795
796static void stex_mu_intr(struct st_hba *hba, u32 doorbell)
797{
798 void __iomem *base = hba->mmio_base;
799 struct status_msg *resp;
800 struct st_ccb *ccb;
801 unsigned int size;
802 u16 tag;
803
f1498161 804 if (unlikely(!(doorbell & MU_OUTBOUND_DOORBELL_STATUSHEADCHANGED)))
5a25ba16
JG
805 return;
806
807 /* status payloads */
808 hba->status_head = readl(base + OMR1);
591a3a5f 809 if (unlikely(hba->status_head > hba->sts_count)) {
5a25ba16
JG
810 printk(KERN_WARNING DRV_NAME "(%s): invalid status head\n",
811 pci_name(hba->pdev));
812 return;
813 }
814
fb4f66be
EL
815 /*
816 * it's not a valid status payload if:
817 * 1. there are no pending requests(e.g. during init stage)
818 * 2. there are some pending requests, but the controller is in
819 * reset status, and its type is not st_yosemite
820 * firmware of st_yosemite in reset status will return pending requests
821 * to driver, so we allow it to pass
822 */
823 if (unlikely(hba->out_req_cnt <= 0 ||
824 (hba->mu_status == MU_STATE_RESETTING &&
825 hba->cardtype != st_yosemite))) {
5a25ba16
JG
826 hba->status_tail = hba->status_head;
827 goto update_status;
828 }
829
830 while (hba->status_tail != hba->status_head) {
831 resp = stex_get_status(hba);
832 tag = le16_to_cpu(resp->tag);
cf355883 833 if (unlikely(tag >= hba->host->can_queue)) {
5a25ba16
JG
834 printk(KERN_WARNING DRV_NAME
835 "(%s): invalid tag\n", pci_name(hba->pdev));
836 continue;
837 }
5a25ba16 838
f1498161 839 hba->out_req_cnt--;
5a25ba16 840 ccb = &hba->ccb[tag];
f1498161 841 if (unlikely(hba->wait_ccb == ccb))
5a25ba16
JG
842 hba->wait_ccb = NULL;
843 if (unlikely(ccb->req == NULL)) {
844 printk(KERN_WARNING DRV_NAME
845 "(%s): lagging req\n", pci_name(hba->pdev));
5a25ba16
JG
846 continue;
847 }
848
849 size = resp->payload_sz * sizeof(u32); /* payload size */
850 if (unlikely(size < sizeof(*resp) - STATUS_VAR_LEN ||
851 size > sizeof(*resp))) {
852 printk(KERN_WARNING DRV_NAME "(%s): bad status size\n",
853 pci_name(hba->pdev));
854 } else {
855 size -= sizeof(*resp) - STATUS_VAR_LEN; /* copy size */
856 if (size)
857 stex_copy_data(ccb, resp, size);
858 }
859
dd48ebf7 860 ccb->req = NULL;
5a25ba16
JG
861 ccb->srb_status = resp->srb_status;
862 ccb->scsi_status = resp->scsi_status;
863
cf355883 864 if (likely(ccb->cmd != NULL)) {
fb4f66be 865 if (hba->cardtype == st_yosemite)
f1498161 866 stex_check_cmd(hba, ccb, resp);
fb4f66be 867
cf355883
EL
868 if (unlikely(ccb->cmd->cmnd[0] == PASSTHRU_CMD &&
869 ccb->cmd->cmnd[1] == PASSTHRU_GET_ADAPTER))
870 stex_controller_info(hba, ccb);
fb4f66be 871
d5587d5d 872 scsi_dma_unmap(ccb->cmd);
cf355883 873 stex_scsi_done(ccb);
f1498161 874 } else
5a25ba16 875 ccb->req_type = 0;
5a25ba16
JG
876 }
877
878update_status:
879 writel(hba->status_head, base + IMR1);
880 readl(base + IMR1); /* flush */
881}
882
7d12e780 883static irqreturn_t stex_intr(int irq, void *__hba)
5a25ba16
JG
884{
885 struct st_hba *hba = __hba;
886 void __iomem *base = hba->mmio_base;
887 u32 data;
888 unsigned long flags;
5a25ba16
JG
889
890 spin_lock_irqsave(hba->host->host_lock, flags);
891
892 data = readl(base + ODBL);
893
894 if (data && data != 0xffffffff) {
895 /* clear the interrupt */
896 writel(data, base + ODBL);
897 readl(base + ODBL); /* flush */
898 stex_mu_intr(hba, data);
9eb46d2a
EL
899 spin_unlock_irqrestore(hba->host->host_lock, flags);
900 if (unlikely(data & MU_OUTBOUND_DOORBELL_REQUEST_RESET &&
901 hba->cardtype == st_shasta))
902 queue_work(hba->work_q, &hba->reset_work);
903 return IRQ_HANDLED;
5a25ba16
JG
904 }
905
906 spin_unlock_irqrestore(hba->host->host_lock, flags);
907
9eb46d2a 908 return IRQ_NONE;
5a25ba16
JG
909}
910
0f3f6ee6
EL
911static void stex_ss_mu_intr(struct st_hba *hba)
912{
913 struct status_msg *resp;
914 struct st_ccb *ccb;
915 __le32 *scratch;
916 unsigned int size;
917 int count = 0;
918 u32 value;
919 u16 tag;
920
921 if (unlikely(hba->out_req_cnt <= 0 ||
922 hba->mu_status == MU_STATE_RESETTING))
923 return;
924
925 while (count < hba->sts_count) {
926 scratch = hba->scratch + hba->status_tail;
927 value = le32_to_cpu(*scratch);
928 if (unlikely(!(value & SS_STS_NORMAL)))
929 return;
930
931 resp = hba->status_buffer + hba->status_tail;
932 *scratch = 0;
933 ++count;
934 ++hba->status_tail;
935 hba->status_tail %= hba->sts_count+1;
936
937 tag = (u16)value;
938 if (unlikely(tag >= hba->host->can_queue)) {
939 printk(KERN_WARNING DRV_NAME
69cb4875 940 "(%s): invalid tag\n", pci_name(hba->pdev));
0f3f6ee6
EL
941 continue;
942 }
943
944 hba->out_req_cnt--;
945 ccb = &hba->ccb[tag];
946 if (unlikely(hba->wait_ccb == ccb))
947 hba->wait_ccb = NULL;
948 if (unlikely(ccb->req == NULL)) {
949 printk(KERN_WARNING DRV_NAME
950 "(%s): lagging req\n", pci_name(hba->pdev));
951 continue;
952 }
953
954 ccb->req = NULL;
955 if (likely(value & SS_STS_DONE)) { /* normal case */
956 ccb->srb_status = SRB_STATUS_SUCCESS;
957 ccb->scsi_status = SAM_STAT_GOOD;
958 } else {
959 ccb->srb_status = resp->srb_status;
960 ccb->scsi_status = resp->scsi_status;
961 size = resp->payload_sz * sizeof(u32);
962 if (unlikely(size < sizeof(*resp) - STATUS_VAR_LEN ||
963 size > sizeof(*resp))) {
964 printk(KERN_WARNING DRV_NAME
965 "(%s): bad status size\n",
966 pci_name(hba->pdev));
967 } else {
968 size -= sizeof(*resp) - STATUS_VAR_LEN;
969 if (size)
970 stex_copy_data(ccb, resp, size);
971 }
972 if (likely(ccb->cmd != NULL))
973 stex_check_cmd(hba, ccb, resp);
974 }
975
976 if (likely(ccb->cmd != NULL)) {
977 scsi_dma_unmap(ccb->cmd);
978 stex_scsi_done(ccb);
979 } else
980 ccb->req_type = 0;
981 }
982}
983
984static irqreturn_t stex_ss_intr(int irq, void *__hba)
985{
986 struct st_hba *hba = __hba;
987 void __iomem *base = hba->mmio_base;
988 u32 data;
989 unsigned long flags;
0f3f6ee6
EL
990
991 spin_lock_irqsave(hba->host->host_lock, flags);
992
d6570227
C
993 if (hba->cardtype == st_yel) {
994 data = readl(base + YI2H_INT);
995 if (data && data != 0xffffffff) {
996 /* clear the interrupt */
997 writel(data, base + YI2H_INT_C);
998 stex_ss_mu_intr(hba);
999 spin_unlock_irqrestore(hba->host->host_lock, flags);
1000 if (unlikely(data & SS_I2H_REQUEST_RESET))
1001 queue_work(hba->work_q, &hba->reset_work);
1002 return IRQ_HANDLED;
1003 }
1004 } else {
1005 data = readl(base + PSCRATCH4);
1006 if (data != 0xffffffff) {
1007 if (data != 0) {
1008 /* clear the interrupt */
1009 writel(data, base + PSCRATCH1);
1010 writel((1 << 22), base + YH2I_INT);
1011 }
1012 stex_ss_mu_intr(hba);
1013 spin_unlock_irqrestore(hba->host->host_lock, flags);
1014 if (unlikely(data & SS_I2H_REQUEST_RESET))
1015 queue_work(hba->work_q, &hba->reset_work);
1016 return IRQ_HANDLED;
1017 }
0f3f6ee6
EL
1018 }
1019
1020 spin_unlock_irqrestore(hba->host->host_lock, flags);
1021
9eb46d2a 1022 return IRQ_NONE;
0f3f6ee6
EL
1023}
1024
1025static int stex_common_handshake(struct st_hba *hba)
5a25ba16
JG
1026{
1027 void __iomem *base = hba->mmio_base;
1028 struct handshake_frame *h;
1029 dma_addr_t status_phys;
529e7a62 1030 u32 data;
76fbf96f 1031 unsigned long before;
5a25ba16
JG
1032
1033 if (readl(base + OMR0) != MU_HANDSHAKE_SIGNATURE) {
1034 writel(MU_INBOUND_DOORBELL_HANDSHAKE, base + IDBL);
1035 readl(base + IDBL);
76fbf96f
EL
1036 before = jiffies;
1037 while (readl(base + OMR0) != MU_HANDSHAKE_SIGNATURE) {
1038 if (time_after(jiffies, before + MU_MAX_DELAY * HZ)) {
1039 printk(KERN_ERR DRV_NAME
1040 "(%s): no handshake signature\n",
1041 pci_name(hba->pdev));
1042 return -1;
1043 }
5a25ba16
JG
1044 rmb();
1045 msleep(1);
1046 }
5a25ba16
JG
1047 }
1048
1049 udelay(10);
1050
529e7a62
EL
1051 data = readl(base + OMR1);
1052 if ((data & 0xffff0000) == MU_HANDSHAKE_SIGNATURE_HALF) {
1053 data &= 0x0000ffff;
f1498161 1054 if (hba->host->can_queue > data) {
529e7a62 1055 hba->host->can_queue = data;
f1498161
EL
1056 hba->host->cmd_per_lun = data;
1057 }
529e7a62
EL
1058 }
1059
f1498161
EL
1060 h = (struct handshake_frame *)hba->status_buffer;
1061 h->rb_phy = cpu_to_le64(hba->dma_handle);
591a3a5f
EL
1062 h->req_sz = cpu_to_le16(hba->rq_size);
1063 h->req_cnt = cpu_to_le16(hba->rq_count+1);
5a25ba16 1064 h->status_sz = cpu_to_le16(sizeof(struct status_msg));
591a3a5f 1065 h->status_cnt = cpu_to_le16(hba->sts_count+1);
0da39687 1066 h->hosttime = cpu_to_le64(ktime_get_real_seconds());
5a25ba16 1067 h->partner_type = HMU_PARTNER_TYPE;
591a3a5f
EL
1068 if (hba->extra_offset) {
1069 h->extra_offset = cpu_to_le32(hba->extra_offset);
cbacfb5f 1070 h->extra_size = cpu_to_le32(hba->dma_size - hba->extra_offset);
94e9108b
EL
1071 } else
1072 h->extra_offset = h->extra_size = 0;
5a25ba16 1073
591a3a5f 1074 status_phys = hba->dma_handle + (hba->rq_count+1) * hba->rq_size;
5a25ba16
JG
1075 writel(status_phys, base + IMR0);
1076 readl(base + IMR0);
1077 writel((status_phys >> 16) >> 16, base + IMR1);
1078 readl(base + IMR1);
1079
1080 writel((status_phys >> 16) >> 16, base + OMR0); /* old fw compatible */
1081 readl(base + OMR0);
1082 writel(MU_INBOUND_DOORBELL_HANDSHAKE, base + IDBL);
1083 readl(base + IDBL); /* flush */
1084
1085 udelay(10);
76fbf96f
EL
1086 before = jiffies;
1087 while (readl(base + OMR0) != MU_HANDSHAKE_SIGNATURE) {
1088 if (time_after(jiffies, before + MU_MAX_DELAY * HZ)) {
1089 printk(KERN_ERR DRV_NAME
1090 "(%s): no signature after handshake frame\n",
1091 pci_name(hba->pdev));
1092 return -1;
1093 }
5a25ba16
JG
1094 rmb();
1095 msleep(1);
1096 }
1097
5a25ba16
JG
1098 writel(0, base + IMR0);
1099 readl(base + IMR0);
1100 writel(0, base + OMR0);
1101 readl(base + OMR0);
1102 writel(0, base + IMR1);
1103 readl(base + IMR1);
1104 writel(0, base + OMR1);
1105 readl(base + OMR1); /* flush */
5a25ba16
JG
1106 return 0;
1107}
1108
0f3f6ee6
EL
1109static int stex_ss_handshake(struct st_hba *hba)
1110{
1111 void __iomem *base = hba->mmio_base;
1112 struct st_msg_header *msg_h;
1113 struct handshake_frame *h;
69cb4875 1114 __le32 *scratch;
d6570227 1115 u32 data, scratch_size, mailboxdata, operationaldata;
0f3f6ee6
EL
1116 unsigned long before;
1117 int ret = 0;
1118
69cb4875 1119 before = jiffies;
d6570227
C
1120
1121 if (hba->cardtype == st_yel) {
1122 operationaldata = readl(base + YIOA_STATUS);
1123 while (operationaldata != SS_MU_OPERATIONAL) {
1124 if (time_after(jiffies, before + MU_MAX_DELAY * HZ)) {
1125 printk(KERN_ERR DRV_NAME
1126 "(%s): firmware not operational\n",
1127 pci_name(hba->pdev));
1128 return -1;
1129 }
1130 msleep(1);
1131 operationaldata = readl(base + YIOA_STATUS);
1132 }
1133 } else {
1134 operationaldata = readl(base + PSCRATCH3);
1135 while (operationaldata != SS_MU_OPERATIONAL) {
1136 if (time_after(jiffies, before + MU_MAX_DELAY * HZ)) {
1137 printk(KERN_ERR DRV_NAME
1138 "(%s): firmware not operational\n",
1139 pci_name(hba->pdev));
1140 return -1;
1141 }
1142 msleep(1);
1143 operationaldata = readl(base + PSCRATCH3);
69cb4875 1144 }
69cb4875
EL
1145 }
1146
1147 msg_h = (struct st_msg_header *)hba->dma_mem;
0f3f6ee6
EL
1148 msg_h->handle = cpu_to_le64(hba->dma_handle);
1149 msg_h->flag = SS_HEAD_HANDSHAKE;
1150
69cb4875 1151 h = (struct handshake_frame *)(msg_h + 1);
0f3f6ee6
EL
1152 h->rb_phy = cpu_to_le64(hba->dma_handle);
1153 h->req_sz = cpu_to_le16(hba->rq_size);
1154 h->req_cnt = cpu_to_le16(hba->rq_count+1);
1155 h->status_sz = cpu_to_le16(sizeof(struct status_msg));
1156 h->status_cnt = cpu_to_le16(hba->sts_count+1);
0da39687 1157 h->hosttime = cpu_to_le64(ktime_get_real_seconds());
0f3f6ee6
EL
1158 h->partner_type = HMU_PARTNER_TYPE;
1159 h->extra_offset = h->extra_size = 0;
9eb46d2a
EL
1160 scratch_size = (hba->sts_count+1)*sizeof(u32);
1161 h->scratch_size = cpu_to_le32(scratch_size);
0f3f6ee6 1162
d6570227
C
1163 if (hba->cardtype == st_yel) {
1164 data = readl(base + YINT_EN);
1165 data &= ~4;
1166 writel(data, base + YINT_EN);
1167 writel((hba->dma_handle >> 16) >> 16, base + YH2I_REQ_HI);
1168 readl(base + YH2I_REQ_HI);
1169 writel(hba->dma_handle, base + YH2I_REQ);
1170 readl(base + YH2I_REQ); /* flush */
1171 } else {
1172 data = readl(base + YINT_EN);
1173 data &= ~(1 << 0);
1174 data &= ~(1 << 2);
1175 writel(data, base + YINT_EN);
1176 if (hba->msi_lock == 0) {
1177 /* P3 MSI Register cannot access twice */
1178 writel((1 << 6), base + YH2I_INT);
1179 hba->msi_lock = 1;
1180 }
1181 writel((hba->dma_handle >> 16) >> 16, base + YH2I_REQ_HI);
1182 writel(hba->dma_handle, base + YH2I_REQ);
1183 }
0f3f6ee6 1184
0f3f6ee6 1185 before = jiffies;
d6570227
C
1186 scratch = hba->scratch;
1187 if (hba->cardtype == st_yel) {
1188 while (!(le32_to_cpu(*scratch) & SS_STS_HANDSHAKE)) {
1189 if (time_after(jiffies, before + MU_MAX_DELAY * HZ)) {
1190 printk(KERN_ERR DRV_NAME
1191 "(%s): no signature after handshake frame\n",
1192 pci_name(hba->pdev));
1193 ret = -1;
1194 break;
1195 }
1196 rmb();
1197 msleep(1);
1198 }
1199 } else {
1200 mailboxdata = readl(base + MAILBOX_BASE + MAILBOX_HNDSHK_STS);
1201 while (mailboxdata != SS_STS_HANDSHAKE) {
1202 if (time_after(jiffies, before + MU_MAX_DELAY * HZ)) {
1203 printk(KERN_ERR DRV_NAME
1204 "(%s): no signature after handshake frame\n",
1205 pci_name(hba->pdev));
1206 ret = -1;
1207 break;
1208 }
1209 rmb();
1210 msleep(1);
1211 mailboxdata = readl(base + MAILBOX_BASE + MAILBOX_HNDSHK_STS);
0f3f6ee6 1212 }
0f3f6ee6 1213 }
9eb46d2a 1214 memset(scratch, 0, scratch_size);
0f3f6ee6 1215 msg_h->flag = 0;
d6570227 1216
0f3f6ee6
EL
1217 return ret;
1218}
1219
1220static int stex_handshake(struct st_hba *hba)
1221{
1222 int err;
1223 unsigned long flags;
9eb46d2a 1224 unsigned int mu_status;
0f3f6ee6 1225
d6570227
C
1226 if (hba->cardtype == st_yel || hba->cardtype == st_P3)
1227 err = stex_ss_handshake(hba);
1228 else
1229 err = stex_common_handshake(hba);
9eb46d2a
EL
1230 spin_lock_irqsave(hba->host->host_lock, flags);
1231 mu_status = hba->mu_status;
0f3f6ee6 1232 if (err == 0) {
0f3f6ee6
EL
1233 hba->req_head = 0;
1234 hba->req_tail = 0;
1235 hba->status_head = 0;
1236 hba->status_tail = 0;
1237 hba->out_req_cnt = 0;
1238 hba->mu_status = MU_STATE_STARTED;
9eb46d2a
EL
1239 } else
1240 hba->mu_status = MU_STATE_FAILED;
1241 if (mu_status == MU_STATE_RESETTING)
1242 wake_up_all(&hba->reset_waitq);
1243 spin_unlock_irqrestore(hba->host->host_lock, flags);
0f3f6ee6
EL
1244 return err;
1245}
1246
5a25ba16
JG
1247static int stex_abort(struct scsi_cmnd *cmd)
1248{
1249 struct Scsi_Host *host = cmd->device->host;
1250 struct st_hba *hba = (struct st_hba *)host->hostdata;
bbfa8d7d 1251 u16 tag = scsi_cmd_to_rq(cmd)->tag;
5a25ba16
JG
1252 void __iomem *base;
1253 u32 data;
1254 int result = SUCCESS;
1255 unsigned long flags;
c25da0af 1256
1fa6b5fb 1257 scmd_printk(KERN_INFO, cmd, "aborting command\n");
c25da0af 1258
5a25ba16
JG
1259 base = hba->mmio_base;
1260 spin_lock_irqsave(host->host_lock, flags);
9eb46d2a
EL
1261 if (tag < host->can_queue &&
1262 hba->ccb[tag].req && hba->ccb[tag].cmd == cmd)
cf355883 1263 hba->wait_ccb = &hba->ccb[tag];
9eb46d2a
EL
1264 else
1265 goto out;
5a25ba16 1266
0f3f6ee6
EL
1267 if (hba->cardtype == st_yel) {
1268 data = readl(base + YI2H_INT);
1269 if (data == 0 || data == 0xffffffff)
1270 goto fail_out;
5a25ba16 1271
0f3f6ee6
EL
1272 writel(data, base + YI2H_INT_C);
1273 stex_ss_mu_intr(hba);
d6570227
C
1274 } else if (hba->cardtype == st_P3) {
1275 data = readl(base + PSCRATCH4);
1276 if (data == 0xffffffff)
1277 goto fail_out;
1278 if (data != 0) {
1279 writel(data, base + PSCRATCH1);
1280 writel((1 << 22), base + YH2I_INT);
1281 }
1282 stex_ss_mu_intr(hba);
0f3f6ee6
EL
1283 } else {
1284 data = readl(base + ODBL);
1285 if (data == 0 || data == 0xffffffff)
1286 goto fail_out;
5a25ba16 1287
0f3f6ee6
EL
1288 writel(data, base + ODBL);
1289 readl(base + ODBL); /* flush */
0f3f6ee6
EL
1290 stex_mu_intr(hba, data);
1291 }
5a25ba16
JG
1292 if (hba->wait_ccb == NULL) {
1293 printk(KERN_WARNING DRV_NAME
1294 "(%s): lost interrupt\n", pci_name(hba->pdev));
1295 goto out;
1296 }
1297
1298fail_out:
d5587d5d 1299 scsi_dma_unmap(cmd);
5a25ba16
JG
1300 hba->wait_ccb->req = NULL; /* nullify the req's future return */
1301 hba->wait_ccb = NULL;
1302 result = FAILED;
1303out:
1304 spin_unlock_irqrestore(host->host_lock, flags);
1305 return result;
1306}
1307
1308static void stex_hard_reset(struct st_hba *hba)
1309{
1310 struct pci_bus *bus;
1311 int i;
1312 u16 pci_cmd;
1313 u8 pci_bctl;
1314
1315 for (i = 0; i < 16; i++)
1316 pci_read_config_dword(hba->pdev, i * 4,
1317 &hba->pdev->saved_config_space[i]);
1318
1319 /* Reset secondary bus. Our controller(MU/ATU) is the only device on
1320 secondary bus. Consult Intel 80331/3 developer's manual for detail */
1321 bus = hba->pdev->bus;
1322 pci_read_config_byte(bus->self, PCI_BRIDGE_CONTROL, &pci_bctl);
1323 pci_bctl |= PCI_BRIDGE_CTL_BUS_RESET;
1324 pci_write_config_byte(bus->self, PCI_BRIDGE_CONTROL, pci_bctl);
69f4a513
EL
1325
1326 /*
1327 * 1 ms may be enough for 8-port controllers. But 16-port controllers
1328 * require more time to finish bus reset. Use 100 ms here for safety
1329 */
1330 msleep(100);
5a25ba16
JG
1331 pci_bctl &= ~PCI_BRIDGE_CTL_BUS_RESET;
1332 pci_write_config_byte(bus->self, PCI_BRIDGE_CONTROL, pci_bctl);
1333
76fbf96f 1334 for (i = 0; i < MU_HARD_RESET_WAIT; i++) {
5a25ba16 1335 pci_read_config_word(hba->pdev, PCI_COMMAND, &pci_cmd);
47c4f997 1336 if (pci_cmd != 0xffff && (pci_cmd & PCI_COMMAND_MASTER))
5a25ba16
JG
1337 break;
1338 msleep(1);
1339 }
1340
1341 ssleep(5);
1342 for (i = 0; i < 16; i++)
1343 pci_write_config_dword(hba->pdev, i * 4,
1344 hba->pdev->saved_config_space[i]);
1345}
1346
9eb46d2a
EL
1347static int stex_yos_reset(struct st_hba *hba)
1348{
1349 void __iomem *base;
1350 unsigned long flags, before;
1351 int ret = 0;
1352
1353 base = hba->mmio_base;
1354 writel(MU_INBOUND_DOORBELL_RESET, base + IDBL);
1355 readl(base + IDBL); /* flush */
1356 before = jiffies;
1357 while (hba->out_req_cnt > 0) {
1358 if (time_after(jiffies, before + ST_INTERNAL_TIMEOUT * HZ)) {
1359 printk(KERN_WARNING DRV_NAME
1360 "(%s): reset timeout\n", pci_name(hba->pdev));
1361 ret = -1;
1362 break;
1363 }
1364 msleep(1);
1365 }
1366
1367 spin_lock_irqsave(hba->host->host_lock, flags);
1368 if (ret == -1)
1369 hba->mu_status = MU_STATE_FAILED;
1370 else
1371 hba->mu_status = MU_STATE_STARTED;
1372 wake_up_all(&hba->reset_waitq);
1373 spin_unlock_irqrestore(hba->host->host_lock, flags);
1374
1375 return ret;
1376}
1377
69cb4875
EL
1378static void stex_ss_reset(struct st_hba *hba)
1379{
1380 writel(SS_H2I_INT_RESET, hba->mmio_base + YH2I_INT);
1381 readl(hba->mmio_base + YH2I_INT);
1382 ssleep(5);
1383}
1384
d6570227
C
1385static void stex_p3_reset(struct st_hba *hba)
1386{
1387 writel(SS_H2I_INT_RESET, hba->mmio_base + YH2I_INT);
1388 ssleep(5);
1389}
1390
9eb46d2a 1391static int stex_do_reset(struct st_hba *hba)
5a25ba16 1392{
9eb46d2a
EL
1393 unsigned long flags;
1394 unsigned int mu_status = MU_STATE_RESETTING;
7cfe99a5 1395
9eb46d2a
EL
1396 spin_lock_irqsave(hba->host->host_lock, flags);
1397 if (hba->mu_status == MU_STATE_STARTING) {
1398 spin_unlock_irqrestore(hba->host->host_lock, flags);
1399 printk(KERN_INFO DRV_NAME "(%s): request reset during init\n",
1400 pci_name(hba->pdev));
1401 return 0;
1402 }
1403 while (hba->mu_status == MU_STATE_RESETTING) {
1404 spin_unlock_irqrestore(hba->host->host_lock, flags);
1405 wait_event_timeout(hba->reset_waitq,
1406 hba->mu_status != MU_STATE_RESETTING,
1407 MU_MAX_DELAY * HZ);
1408 spin_lock_irqsave(hba->host->host_lock, flags);
1409 mu_status = hba->mu_status;
1410 }
5a25ba16 1411
9eb46d2a
EL
1412 if (mu_status != MU_STATE_RESETTING) {
1413 spin_unlock_irqrestore(hba->host->host_lock, flags);
1414 return (mu_status == MU_STATE_STARTED) ? 0 : -1;
1415 }
c25da0af 1416
5a25ba16 1417 hba->mu_status = MU_STATE_RESETTING;
9eb46d2a
EL
1418 spin_unlock_irqrestore(hba->host->host_lock, flags);
1419
1420 if (hba->cardtype == st_yosemite)
1421 return stex_yos_reset(hba);
5a25ba16
JG
1422
1423 if (hba->cardtype == st_shasta)
1424 stex_hard_reset(hba);
69cb4875
EL
1425 else if (hba->cardtype == st_yel)
1426 stex_ss_reset(hba);
d6570227
C
1427 else if (hba->cardtype == st_P3)
1428 stex_p3_reset(hba);
45b42adb
C
1429
1430 return_abnormal_state(hba, DID_RESET);
5a25ba16 1431
9eb46d2a
EL
1432 if (stex_handshake(hba) == 0)
1433 return 0;
fb4f66be 1434
9eb46d2a
EL
1435 printk(KERN_WARNING DRV_NAME "(%s): resetting: handshake failed\n",
1436 pci_name(hba->pdev));
1437 return -1;
1438}
1439
1440static int stex_reset(struct scsi_cmnd *cmd)
1441{
1442 struct st_hba *hba;
1443
1444 hba = (struct st_hba *) &cmd->device->host->hostdata[0];
1445
1fa6b5fb
HR
1446 shost_printk(KERN_INFO, cmd->device->host,
1447 "resetting host\n");
9eb46d2a
EL
1448
1449 return stex_do_reset(hba) ? FAILED : SUCCESS;
1450}
1451
1452static void stex_reset_work(struct work_struct *work)
1453{
1454 struct st_hba *hba = container_of(work, struct st_hba, reset_work);
1455
1456 stex_do_reset(hba);
5a25ba16
JG
1457}
1458
1459static int stex_biosparam(struct scsi_device *sdev,
1460 struct block_device *bdev, sector_t capacity, int geom[])
1461{
b4b8bed1 1462 int heads = 255, sectors = 63;
5a25ba16
JG
1463
1464 if (capacity < 0x200000) {
1465 heads = 64;
1466 sectors = 32;
1467 }
1468
b4b8bed1 1469 sector_div(capacity, heads * sectors);
5a25ba16
JG
1470
1471 geom[0] = heads;
1472 geom[1] = sectors;
b4b8bed1 1473 geom[2] = capacity;
5a25ba16
JG
1474
1475 return 0;
1476}
1477
08d60751 1478static const struct scsi_host_template driver_template = {
5a25ba16
JG
1479 .module = THIS_MODULE,
1480 .name = DRV_NAME,
1481 .proc_name = DRV_NAME,
1482 .bios_param = stex_biosparam,
1483 .queuecommand = stex_queuecommand,
49515b7f 1484 .sdev_configure = stex_sdev_configure,
5a25ba16
JG
1485 .eh_abort_handler = stex_abort,
1486 .eh_host_reset_handler = stex_reset,
5a25ba16 1487 .this_id = -1,
4af14d11 1488 .dma_boundary = PAGE_SIZE - 1,
591a3a5f
EL
1489};
1490
c9a71ca1 1491static const struct pci_device_id stex_pci_tbl[] = {
591a3a5f
EL
1492 /* st_shasta */
1493 { 0x105a, 0x8350, PCI_ANY_ID, PCI_ANY_ID, 0, 0,
1494 st_shasta }, /* SuperTrak EX8350/8300/16350/16300 */
1495 { 0x105a, 0xc350, PCI_ANY_ID, PCI_ANY_ID, 0, 0,
1496 st_shasta }, /* SuperTrak EX12350 */
1497 { 0x105a, 0x4302, PCI_ANY_ID, PCI_ANY_ID, 0, 0,
1498 st_shasta }, /* SuperTrak EX4350 */
1499 { 0x105a, 0xe350, PCI_ANY_ID, PCI_ANY_ID, 0, 0,
1500 st_shasta }, /* SuperTrak EX24350 */
1501
1502 /* st_vsc */
1503 { 0x105a, 0x7250, PCI_ANY_ID, PCI_ANY_ID, 0, 0, st_vsc },
1504
1505 /* st_yosemite */
0f3f6ee6 1506 { 0x105a, 0x8650, 0x105a, PCI_ANY_ID, 0, 0, st_yosemite },
591a3a5f
EL
1507
1508 /* st_seq */
1509 { 0x105a, 0x3360, PCI_ANY_ID, PCI_ANY_ID, 0, 0, st_seq },
0f3f6ee6
EL
1510
1511 /* st_yel */
1512 { 0x105a, 0x8650, 0x1033, PCI_ANY_ID, 0, 0, st_yel },
1513 { 0x105a, 0x8760, PCI_ANY_ID, PCI_ANY_ID, 0, 0, st_yel },
d6570227
C
1514
1515 /* st_P3, pluto */
1516 { PCI_VENDOR_ID_PROMISE, 0x8870, PCI_VENDOR_ID_PROMISE,
1517 0x8870, 0, 0, st_P3 },
1518 /* st_P3, p3 */
1519 { PCI_VENDOR_ID_PROMISE, 0x8870, PCI_VENDOR_ID_PROMISE,
1520 0x4300, 0, 0, st_P3 },
1521
1522 /* st_P3, SymplyStor4E */
1523 { PCI_VENDOR_ID_PROMISE, 0x8871, PCI_VENDOR_ID_PROMISE,
1524 0x4311, 0, 0, st_P3 },
1525 /* st_P3, SymplyStor8E */
1526 { PCI_VENDOR_ID_PROMISE, 0x8871, PCI_VENDOR_ID_PROMISE,
1527 0x4312, 0, 0, st_P3 },
1528 /* st_P3, SymplyStor4 */
1529 { PCI_VENDOR_ID_PROMISE, 0x8871, PCI_VENDOR_ID_PROMISE,
1530 0x4321, 0, 0, st_P3 },
1531 /* st_P3, SymplyStor8 */
1532 { PCI_VENDOR_ID_PROMISE, 0x8871, PCI_VENDOR_ID_PROMISE,
1533 0x4322, 0, 0, st_P3 },
591a3a5f
EL
1534 { } /* terminate list */
1535};
1536
1537static struct st_card_info stex_card_info[] = {
1538 /* st_shasta */
1539 {
1540 .max_id = 17,
1541 .max_lun = 8,
1542 .max_channel = 0,
1543 .rq_count = 32,
1544 .rq_size = 1048,
1545 .sts_count = 32,
0f3f6ee6
EL
1546 .alloc_rq = stex_alloc_req,
1547 .map_sg = stex_map_sg,
1548 .send = stex_send_cmd,
591a3a5f
EL
1549 },
1550
1551 /* st_vsc */
1552 {
1553 .max_id = 129,
1554 .max_lun = 1,
1555 .max_channel = 0,
1556 .rq_count = 32,
1557 .rq_size = 1048,
1558 .sts_count = 32,
0f3f6ee6
EL
1559 .alloc_rq = stex_alloc_req,
1560 .map_sg = stex_map_sg,
1561 .send = stex_send_cmd,
591a3a5f
EL
1562 },
1563
1564 /* st_yosemite */
1565 {
1566 .max_id = 2,
1567 .max_lun = 256,
1568 .max_channel = 0,
1569 .rq_count = 256,
1570 .rq_size = 1048,
1571 .sts_count = 256,
0f3f6ee6
EL
1572 .alloc_rq = stex_alloc_req,
1573 .map_sg = stex_map_sg,
1574 .send = stex_send_cmd,
591a3a5f
EL
1575 },
1576
1577 /* st_seq */
1578 {
1579 .max_id = 129,
1580 .max_lun = 1,
1581 .max_channel = 0,
1582 .rq_count = 32,
1583 .rq_size = 1048,
1584 .sts_count = 32,
0f3f6ee6
EL
1585 .alloc_rq = stex_alloc_req,
1586 .map_sg = stex_map_sg,
1587 .send = stex_send_cmd,
1588 },
1589
1590 /* st_yel */
1591 {
1592 .max_id = 129,
1593 .max_lun = 256,
1594 .max_channel = 3,
1595 .rq_count = 801,
1596 .rq_size = 512,
1597 .sts_count = 801,
1598 .alloc_rq = stex_ss_alloc_req,
1599 .map_sg = stex_ss_map_sg,
1600 .send = stex_ss_send_cmd,
591a3a5f 1601 },
d6570227
C
1602
1603 /* st_P3 */
1604 {
1605 .max_id = 129,
1606 .max_lun = 256,
1607 .max_channel = 0,
1608 .rq_count = 801,
1609 .rq_size = 512,
1610 .sts_count = 801,
1611 .alloc_rq = stex_ss_alloc_req,
1612 .map_sg = stex_ss_map_sg,
1613 .send = stex_ss_send_cmd,
1614 },
5a25ba16
JG
1615};
1616
99946f81
EL
1617static int stex_request_irq(struct st_hba *hba)
1618{
1619 struct pci_dev *pdev = hba->pdev;
1620 int status;
1621
d6570227 1622 if (msi || hba->cardtype == st_P3) {
99946f81
EL
1623 status = pci_enable_msi(pdev);
1624 if (status != 0)
1625 printk(KERN_ERR DRV_NAME
1626 "(%s): error %d setting up MSI\n",
1627 pci_name(pdev), status);
1628 else
1629 hba->msi_enabled = 1;
1630 } else
1631 hba->msi_enabled = 0;
1632
d6570227
C
1633 status = request_irq(pdev->irq,
1634 (hba->cardtype == st_yel || hba->cardtype == st_P3) ?
0f3f6ee6 1635 stex_ss_intr : stex_intr, IRQF_SHARED, DRV_NAME, hba);
99946f81
EL
1636
1637 if (status != 0) {
1638 if (hba->msi_enabled)
1639 pci_disable_msi(pdev);
1640 }
1641 return status;
1642}
1643
1644static void stex_free_irq(struct st_hba *hba)
1645{
1646 struct pci_dev *pdev = hba->pdev;
1647
1648 free_irq(pdev->irq, hba);
1649 if (hba->msi_enabled)
1650 pci_disable_msi(pdev);
1651}
1652
6f039790 1653static int stex_probe(struct pci_dev *pdev, const struct pci_device_id *id)
5a25ba16
JG
1654{
1655 struct st_hba *hba;
1656 struct Scsi_Host *host;
591a3a5f 1657 const struct st_card_info *ci = NULL;
0f3f6ee6 1658 u32 sts_offset, cp_offset, scratch_offset;
5a25ba16
JG
1659 int err;
1660
1661 err = pci_enable_device(pdev);
1662 if (err)
1663 return err;
1664
1665 pci_set_master(pdev);
1666
61b745fa
C
1667 S6flag = 0;
1668 register_reboot_notifier(&stex_notifier);
1669
5a25ba16
JG
1670 host = scsi_host_alloc(&driver_template, sizeof(struct st_hba));
1671
1672 if (!host) {
1673 printk(KERN_ERR DRV_NAME "(%s): scsi_host_alloc failed\n",
1674 pci_name(pdev));
1675 err = -ENOMEM;
1676 goto out_disable;
1677 }
1678
1679 hba = (struct st_hba *)host->hostdata;
1680 memset(hba, 0, sizeof(struct st_hba));
1681
1682 err = pci_request_regions(pdev, DRV_NAME);
1683 if (err < 0) {
1684 printk(KERN_ERR DRV_NAME "(%s): request regions failed\n",
1685 pci_name(pdev));
1686 goto out_scsi_host_put;
1687 }
1688
25729a7f 1689 hba->mmio_base = pci_ioremap_bar(pdev, 0);
5a25ba16
JG
1690 if ( !hba->mmio_base) {
1691 printk(KERN_ERR DRV_NAME "(%s): memory map failed\n",
1692 pci_name(pdev));
1693 err = -ENOMEM;
1694 goto out_release_regions;
1695 }
1696
b5a4ad1d
CH
1697 err = dma_set_mask_and_coherent(&pdev->dev, DMA_BIT_MASK(64));
1698 if (err)
1699 err = dma_set_mask_and_coherent(&pdev->dev, DMA_BIT_MASK(32));
5a25ba16
JG
1700 if (err) {
1701 printk(KERN_ERR DRV_NAME "(%s): set dma mask failed\n",
1702 pci_name(pdev));
1703 goto out_iounmap;
1704 }
1705
94e9108b 1706 hba->cardtype = (unsigned int) id->driver_data;
591a3a5f 1707 ci = &stex_card_info[hba->cardtype];
1ec364e6
C
1708 switch (id->subdevice) {
1709 case 0x4221:
1710 case 0x4222:
1711 case 0x4223:
1712 case 0x4224:
1713 case 0x4225:
1714 case 0x4226:
1715 case 0x4227:
1716 case 0x4261:
1717 case 0x4262:
1718 case 0x4263:
1719 case 0x4264:
1720 case 0x4265:
1721 break;
1722 default:
d6570227 1723 if (hba->cardtype == st_yel || hba->cardtype == st_P3)
1ec364e6
C
1724 hba->supports_pm = 1;
1725 }
1726
0f3f6ee6 1727 sts_offset = scratch_offset = (ci->rq_count+1) * ci->rq_size;
d6570227 1728 if (hba->cardtype == st_yel || hba->cardtype == st_P3)
0f3f6ee6 1729 sts_offset += (ci->sts_count+1) * sizeof(u32);
591a3a5f
EL
1730 cp_offset = sts_offset + (ci->sts_count+1) * sizeof(struct status_msg);
1731 hba->dma_size = cp_offset + sizeof(struct st_frame);
1732 if (hba->cardtype == st_seq ||
1733 (hba->cardtype == st_vsc && (pdev->subsystem_device & 1))) {
1734 hba->extra_offset = hba->dma_size;
1735 hba->dma_size += ST_ADDITIONAL_MEM;
1736 }
5a25ba16 1737 hba->dma_mem = dma_alloc_coherent(&pdev->dev,
94e9108b 1738 hba->dma_size, &hba->dma_handle, GFP_KERNEL);
5a25ba16 1739 if (!hba->dma_mem) {
cbacfb5f
EL
1740 /* Retry minimum coherent mapping for st_seq and st_vsc */
1741 if (hba->cardtype == st_seq ||
1742 (hba->cardtype == st_vsc && (pdev->subsystem_device & 1))) {
1743 printk(KERN_WARNING DRV_NAME
1744 "(%s): allocating min buffer for controller\n",
1745 pci_name(pdev));
1746 hba->dma_size = hba->extra_offset
1747 + ST_ADDITIONAL_MEM_MIN;
1748 hba->dma_mem = dma_alloc_coherent(&pdev->dev,
1749 hba->dma_size, &hba->dma_handle, GFP_KERNEL);
1750 }
1751
1752 if (!hba->dma_mem) {
1753 err = -ENOMEM;
1754 printk(KERN_ERR DRV_NAME "(%s): dma mem alloc failed\n",
1755 pci_name(pdev));
1756 goto out_iounmap;
1757 }
5a25ba16
JG
1758 }
1759
591a3a5f
EL
1760 hba->ccb = kcalloc(ci->rq_count, sizeof(struct st_ccb), GFP_KERNEL);
1761 if (!hba->ccb) {
1762 err = -ENOMEM;
1763 printk(KERN_ERR DRV_NAME "(%s): ccb alloc failed\n",
1764 pci_name(pdev));
1765 goto out_pci_free;
1766 }
1767
d6570227 1768 if (hba->cardtype == st_yel || hba->cardtype == st_P3)
0f3f6ee6 1769 hba->scratch = (__le32 *)(hba->dma_mem + scratch_offset);
591a3a5f
EL
1770 hba->status_buffer = (struct status_msg *)(hba->dma_mem + sts_offset);
1771 hba->copy_buffer = hba->dma_mem + cp_offset;
1772 hba->rq_count = ci->rq_count;
1773 hba->rq_size = ci->rq_size;
1774 hba->sts_count = ci->sts_count;
0f3f6ee6
EL
1775 hba->alloc_rq = ci->alloc_rq;
1776 hba->map_sg = ci->map_sg;
1777 hba->send = ci->send;
5a25ba16 1778 hba->mu_status = MU_STATE_STARTING;
d6570227 1779 hba->msi_lock = 0;
5a25ba16 1780
d6570227 1781 if (hba->cardtype == st_yel || hba->cardtype == st_P3)
0f3f6ee6
EL
1782 host->sg_tablesize = 38;
1783 else
1784 host->sg_tablesize = 32;
591a3a5f
EL
1785 host->can_queue = ci->rq_count;
1786 host->cmd_per_lun = ci->rq_count;
1787 host->max_id = ci->max_id;
1788 host->max_lun = ci->max_lun;
1789 host->max_channel = ci->max_channel;
5a25ba16
JG
1790 host->unique_id = host->host_no;
1791 host->max_cmd_len = STEX_CDB_LENGTH;
1792
1793 hba->host = host;
1794 hba->pdev = pdev;
9eb46d2a
EL
1795 init_waitqueue_head(&hba->reset_waitq);
1796
0ef9b018
BVA
1797 hba->work_q = alloc_ordered_workqueue("stex_wq_%d", WQ_MEM_RECLAIM,
1798 host->host_no);
9eb46d2a
EL
1799 if (!hba->work_q) {
1800 printk(KERN_ERR DRV_NAME "(%s): create workqueue failed\n",
1801 pci_name(pdev));
1802 err = -ENOMEM;
1803 goto out_ccb_free;
1804 }
1805 INIT_WORK(&hba->reset_work, stex_reset_work);
5a25ba16 1806
99946f81 1807 err = stex_request_irq(hba);
5a25ba16
JG
1808 if (err) {
1809 printk(KERN_ERR DRV_NAME "(%s): request irq failed\n",
1810 pci_name(pdev));
9eb46d2a 1811 goto out_free_wq;
5a25ba16
JG
1812 }
1813
1814 err = stex_handshake(hba);
1815 if (err)
1816 goto out_free_irq;
1817
1818 pci_set_drvdata(pdev, hba);
1819
1820 err = scsi_add_host(host, &pdev->dev);
1821 if (err) {
1822 printk(KERN_ERR DRV_NAME "(%s): scsi_add_host failed\n",
1823 pci_name(pdev));
1824 goto out_free_irq;
1825 }
1826
1827 scsi_scan_host(host);
1828
1829 return 0;
1830
1831out_free_irq:
99946f81 1832 stex_free_irq(hba);
9eb46d2a
EL
1833out_free_wq:
1834 destroy_workqueue(hba->work_q);
591a3a5f
EL
1835out_ccb_free:
1836 kfree(hba->ccb);
5a25ba16 1837out_pci_free:
94e9108b 1838 dma_free_coherent(&pdev->dev, hba->dma_size,
5a25ba16
JG
1839 hba->dma_mem, hba->dma_handle);
1840out_iounmap:
1841 iounmap(hba->mmio_base);
1842out_release_regions:
1843 pci_release_regions(pdev);
1844out_scsi_host_put:
1845 scsi_host_put(host);
1846out_disable:
1847 pci_disable_device(pdev);
1848
1849 return err;
1850}
1851
797150b9 1852static void stex_hba_stop(struct st_hba *hba, int st_sleep_mic)
5a25ba16
JG
1853{
1854 struct req_msg *req;
0f3f6ee6 1855 struct st_msg_header *msg_h;
5a25ba16
JG
1856 unsigned long flags;
1857 unsigned long before;
cf355883 1858 u16 tag = 0;
5a25ba16
JG
1859
1860 spin_lock_irqsave(hba->host->host_lock, flags);
797150b9 1861
d6570227
C
1862 if ((hba->cardtype == st_yel || hba->cardtype == st_P3) &&
1863 hba->supports_pm == 1) {
1864 if (st_sleep_mic == ST_NOTHANDLED) {
797150b9
C
1865 spin_unlock_irqrestore(hba->host->host_lock, flags);
1866 return;
1867 }
1868 }
0f3f6ee6 1869 req = hba->alloc_rq(hba);
d6570227 1870 if (hba->cardtype == st_yel || hba->cardtype == st_P3) {
0f3f6ee6
EL
1871 msg_h = (struct st_msg_header *)req - 1;
1872 memset(msg_h, 0, hba->rq_size);
1873 } else
1874 memset(req, 0, hba->rq_size);
5a25ba16 1875
d6570227
C
1876 if ((hba->cardtype == st_yosemite || hba->cardtype == st_yel
1877 || hba->cardtype == st_P3)
797150b9 1878 && st_sleep_mic == ST_IGNORED) {
fb4f66be
EL
1879 req->cdb[0] = MGT_CMD;
1880 req->cdb[1] = MGT_CMD_SIGNATURE;
1881 req->cdb[2] = CTLR_CONFIG_CMD;
1882 req->cdb[3] = CTLR_SHUTDOWN;
d6570227
C
1883 } else if ((hba->cardtype == st_yel || hba->cardtype == st_P3)
1884 && st_sleep_mic != ST_IGNORED) {
797150b9
C
1885 req->cdb[0] = MGT_CMD;
1886 req->cdb[1] = MGT_CMD_SIGNATURE;
1887 req->cdb[2] = CTLR_CONFIG_CMD;
1888 req->cdb[3] = PMIC_SHUTDOWN;
1889 req->cdb[4] = st_sleep_mic;
fb4f66be
EL
1890 } else {
1891 req->cdb[0] = CONTROLLER_CMD;
1892 req->cdb[1] = CTLR_POWER_STATE_CHANGE;
1893 req->cdb[2] = CTLR_POWER_SAVING;
1894 }
5a25ba16
JG
1895 hba->ccb[tag].cmd = NULL;
1896 hba->ccb[tag].sg_count = 0;
1897 hba->ccb[tag].sense_bufflen = 0;
1898 hba->ccb[tag].sense_buffer = NULL;
f1498161 1899 hba->ccb[tag].req_type = PASSTHRU_REQ_TYPE;
0f3f6ee6 1900 hba->send(hba, req, tag);
5a25ba16 1901 spin_unlock_irqrestore(hba->host->host_lock, flags);
cf355883
EL
1902 before = jiffies;
1903 while (hba->ccb[tag].req_type & PASSTHRU_REQ_TYPE) {
f1498161
EL
1904 if (time_after(jiffies, before + ST_INTERNAL_TIMEOUT * HZ)) {
1905 hba->ccb[tag].req_type = 0;
797150b9 1906 hba->mu_status = MU_STATE_STOP;
cf355883 1907 return;
f1498161
EL
1908 }
1909 msleep(1);
cf355883 1910 }
797150b9 1911 hba->mu_status = MU_STATE_STOP;
5a25ba16
JG
1912}
1913
1914static void stex_hba_free(struct st_hba *hba)
1915{
99946f81 1916 stex_free_irq(hba);
5a25ba16 1917
9eb46d2a
EL
1918 destroy_workqueue(hba->work_q);
1919
5a25ba16
JG
1920 iounmap(hba->mmio_base);
1921
1922 pci_release_regions(hba->pdev);
1923
591a3a5f
EL
1924 kfree(hba->ccb);
1925
94e9108b 1926 dma_free_coherent(&hba->pdev->dev, hba->dma_size,
5a25ba16
JG
1927 hba->dma_mem, hba->dma_handle);
1928}
1929
1930static void stex_remove(struct pci_dev *pdev)
1931{
1932 struct st_hba *hba = pci_get_drvdata(pdev);
1933
45b42adb
C
1934 hba->mu_status = MU_STATE_NOCONNECT;
1935 return_abnormal_state(hba, DID_NO_CONNECT);
5a25ba16
JG
1936 scsi_remove_host(hba->host);
1937
45b42adb 1938 scsi_block_requests(hba->host);
5a25ba16
JG
1939
1940 stex_hba_free(hba);
1941
1942 scsi_host_put(hba->host);
1943
1944 pci_disable_device(pdev);
61b745fa
C
1945
1946 unregister_reboot_notifier(&stex_notifier);
5a25ba16
JG
1947}
1948
1949static void stex_shutdown(struct pci_dev *pdev)
1950{
1951 struct st_hba *hba = pci_get_drvdata(pdev);
1952
61b745fa 1953 if (hba->supports_pm == 0) {
797150b9 1954 stex_hba_stop(hba, ST_IGNORED);
61b745fa
C
1955 } else if (hba->supports_pm == 1 && S6flag) {
1956 unregister_reboot_notifier(&stex_notifier);
1957 stex_hba_stop(hba, ST_S6);
1958 } else
797150b9
C
1959 stex_hba_stop(hba, ST_S5);
1960}
1961
d6570227 1962static int stex_choice_sleep_mic(struct st_hba *hba, pm_message_t state)
797150b9
C
1963{
1964 switch (state.event) {
1965 case PM_EVENT_SUSPEND:
1966 return ST_S3;
1967 case PM_EVENT_HIBERNATE:
d6570227 1968 hba->msi_lock = 0;
797150b9
C
1969 return ST_S4;
1970 default:
1971 return ST_NOTHANDLED;
1972 }
5a25ba16
JG
1973}
1974
797150b9
C
1975static int stex_suspend(struct pci_dev *pdev, pm_message_t state)
1976{
1977 struct st_hba *hba = pci_get_drvdata(pdev);
1978
d6570227
C
1979 if ((hba->cardtype == st_yel || hba->cardtype == st_P3)
1980 && hba->supports_pm == 1)
1981 stex_hba_stop(hba, stex_choice_sleep_mic(hba, state));
797150b9
C
1982 else
1983 stex_hba_stop(hba, ST_IGNORED);
1984 return 0;
1985}
1986
1987static int stex_resume(struct pci_dev *pdev)
1988{
1989 struct st_hba *hba = pci_get_drvdata(pdev);
1990
1991 hba->mu_status = MU_STATE_STARTING;
1992 stex_handshake(hba);
1993 return 0;
1994}
61b745fa
C
1995
1996static int stex_halt(struct notifier_block *nb, unsigned long event, void *buf)
1997{
1998 S6flag = 1;
1999 return NOTIFY_OK;
2000}
5a25ba16
JG
2001MODULE_DEVICE_TABLE(pci, stex_pci_tbl);
2002
2003static struct pci_driver stex_pci_driver = {
2004 .name = DRV_NAME,
2005 .id_table = stex_pci_tbl,
2006 .probe = stex_probe,
6f039790 2007 .remove = stex_remove,
5a25ba16 2008 .shutdown = stex_shutdown,
797150b9
C
2009 .suspend = stex_suspend,
2010 .resume = stex_resume,
5a25ba16
JG
2011};
2012
2013static int __init stex_init(void)
2014{
2015 printk(KERN_INFO DRV_NAME
2016 ": Promise SuperTrak EX Driver version: %s\n",
2017 ST_DRIVER_VERSION);
2018
2019 return pci_register_driver(&stex_pci_driver);
2020}
2021
2022static void __exit stex_exit(void)
2023{
2024 pci_unregister_driver(&stex_pci_driver);
2025}
2026
2027module_init(stex_init);
2028module_exit(stex_exit);
This page took 1.857827 seconds and 5 git commands to generate.