diff options
Diffstat (limited to 'drivers/scsi')
-rw-r--r-- | drivers/scsi/gdth.c | 177 | ||||
-rw-r--r-- | drivers/scsi/gdth.h | 8 | ||||
-rw-r--r-- | drivers/scsi/gdth_proc.c | 10 |
3 files changed, 104 insertions, 91 deletions
diff --git a/drivers/scsi/gdth.c b/drivers/scsi/gdth.c index e002c391e0d2..a68004b0d90b 100644 --- a/drivers/scsi/gdth.c +++ b/drivers/scsi/gdth.c | |||
@@ -85,15 +85,15 @@ | |||
85 | 85 | ||
86 | /* The meaning of the Scsi_Pointer members in this driver is as follows: | 86 | /* The meaning of the Scsi_Pointer members in this driver is as follows: |
87 | * ptr: Chaining | 87 | * ptr: Chaining |
88 | * this_residual: Command priority | 88 | * this_residual: unused |
89 | * buffer: unused | 89 | * buffer: unused |
90 | * dma_handle: will drop in !use_sg patch. | 90 | * dma_handle: will drop in !use_sg patch. |
91 | * buffers_residual: Timeout value | 91 | * buffers_residual: unused |
92 | * Status: Command status (gdth_do_cmd()), DMA mem. mappings | 92 | * Status: DMA mem. mappings (FIXME: drop in !use_sg patch.) |
93 | * Message: Additional info (gdth_do_cmd()), DMA direction | 93 | * Message: unused |
94 | * have_data_in: Flag for gdth_wait_completion() | 94 | * have_data_in: unused |
95 | * sent_command: Opcode special command | 95 | * sent_command: unused |
96 | * phase: Service/parameter/return code special command | 96 | * phase: unused |
97 | */ | 97 | */ |
98 | 98 | ||
99 | 99 | ||
@@ -468,7 +468,7 @@ int __gdth_execute(struct scsi_device *sdev, gdth_cmd_str *gdtcmd, char *cmnd, | |||
468 | scp->request_buffer = gdtcmd; | 468 | scp->request_buffer = gdtcmd; |
469 | scp->cmd_len = 12; | 469 | scp->cmd_len = 12; |
470 | memcpy(scp->cmnd, cmnd, 12); | 470 | memcpy(scp->cmnd, cmnd, 12); |
471 | scp->SCp.this_residual = IOCTL_PRI; /* priority */ | 471 | cmndinfo.priority = IOCTL_PRI; |
472 | cmndinfo.internal_command = 1; | 472 | cmndinfo.internal_command = 1; |
473 | 473 | ||
474 | TRACE(("__gdth_execute() cmd 0x%x\n", scp->cmnd[0])); | 474 | TRACE(("__gdth_execute() cmd 0x%x\n", scp->cmnd[0])); |
@@ -476,9 +476,9 @@ int __gdth_execute(struct scsi_device *sdev, gdth_cmd_str *gdtcmd, char *cmnd, | |||
476 | 476 | ||
477 | wait_for_completion(&wait); | 477 | wait_for_completion(&wait); |
478 | 478 | ||
479 | rval = scp->SCp.Status; | 479 | rval = cmndinfo.status; |
480 | if (info) | 480 | if (info) |
481 | *info = scp->SCp.Message; | 481 | *info = cmndinfo.info; |
482 | kfree(scp); | 482 | kfree(scp); |
483 | return rval; | 483 | return rval; |
484 | } | 484 | } |
@@ -2016,14 +2016,14 @@ static void gdth_putq(gdth_ha_str *ha, Scsi_Cmnd *scp, unchar priority) | |||
2016 | spin_lock_irqsave(&ha->smp_lock, flags); | 2016 | spin_lock_irqsave(&ha->smp_lock, flags); |
2017 | 2017 | ||
2018 | if (!cmndinfo->internal_command) { | 2018 | if (!cmndinfo->internal_command) { |
2019 | scp->SCp.this_residual = (int)priority; | 2019 | cmndinfo->priority = priority; |
2020 | b = scp->device->channel; | 2020 | b = scp->device->channel; |
2021 | t = scp->device->id; | 2021 | t = scp->device->id; |
2022 | if (priority >= DEFAULT_PRI) { | 2022 | if (priority >= DEFAULT_PRI) { |
2023 | if ((b != ha->virt_bus && ha->raw[BUS_L2P(ha,b)].lock) || | 2023 | if ((b != ha->virt_bus && ha->raw[BUS_L2P(ha,b)].lock) || |
2024 | (b==ha->virt_bus && t<MAX_HDRIVES && ha->hdr[t].lock)) { | 2024 | (b==ha->virt_bus && t<MAX_HDRIVES && ha->hdr[t].lock)) { |
2025 | TRACE2(("gdth_putq(): locked IO ->update_timeout()\n")); | 2025 | TRACE2(("gdth_putq(): locked IO ->update_timeout()\n")); |
2026 | scp->SCp.buffers_residual = gdth_update_timeout(scp, 0); | 2026 | cmndinfo->timeout = gdth_update_timeout(scp, 0); |
2027 | } | 2027 | } |
2028 | } | 2028 | } |
2029 | } | 2029 | } |
@@ -2035,7 +2035,7 @@ static void gdth_putq(gdth_ha_str *ha, Scsi_Cmnd *scp, unchar priority) | |||
2035 | pscp = ha->req_first; | 2035 | pscp = ha->req_first; |
2036 | nscp = (Scsi_Cmnd *)pscp->SCp.ptr; | 2036 | nscp = (Scsi_Cmnd *)pscp->SCp.ptr; |
2037 | /* priority: 0-highest,..,0xff-lowest */ | 2037 | /* priority: 0-highest,..,0xff-lowest */ |
2038 | while (nscp && (unchar)nscp->SCp.this_residual <= priority) { | 2038 | while (nscp && gdth_cmnd_priv(nscp)->priority <= priority) { |
2039 | pscp = nscp; | 2039 | pscp = nscp; |
2040 | nscp = (Scsi_Cmnd *)pscp->SCp.ptr; | 2040 | nscp = (Scsi_Cmnd *)pscp->SCp.ptr; |
2041 | } | 2041 | } |
@@ -2074,13 +2074,14 @@ static void gdth_next(gdth_ha_str *ha) | |||
2074 | cmd_index = 0; | 2074 | cmd_index = 0; |
2075 | 2075 | ||
2076 | for (nscp = pscp = ha->req_first; nscp; nscp = (Scsi_Cmnd *)nscp->SCp.ptr) { | 2076 | for (nscp = pscp = ha->req_first; nscp; nscp = (Scsi_Cmnd *)nscp->SCp.ptr) { |
2077 | struct gdth_cmndinfo *nscp_cmndinfo = gdth_cmnd_priv(nscp); | ||
2077 | if (nscp != pscp && nscp != (Scsi_Cmnd *)pscp->SCp.ptr) | 2078 | if (nscp != pscp && nscp != (Scsi_Cmnd *)pscp->SCp.ptr) |
2078 | pscp = (Scsi_Cmnd *)pscp->SCp.ptr; | 2079 | pscp = (Scsi_Cmnd *)pscp->SCp.ptr; |
2079 | if (!gdth_cmnd_priv(nscp)->internal_command) { | 2080 | if (!nscp_cmndinfo->internal_command) { |
2080 | b = nscp->device->channel; | 2081 | b = nscp->device->channel; |
2081 | t = nscp->device->id; | 2082 | t = nscp->device->id; |
2082 | l = nscp->device->lun; | 2083 | l = nscp->device->lun; |
2083 | if (nscp->SCp.this_residual >= DEFAULT_PRI) { | 2084 | if (nscp_cmndinfo->priority >= DEFAULT_PRI) { |
2084 | if ((b != ha->virt_bus && ha->raw[BUS_L2P(ha,b)].lock) || | 2085 | if ((b != ha->virt_bus && ha->raw[BUS_L2P(ha,b)].lock) || |
2085 | (b == ha->virt_bus && t < MAX_HDRIVES && ha->hdr[t].lock)) | 2086 | (b == ha->virt_bus && t < MAX_HDRIVES && ha->hdr[t].lock)) |
2086 | continue; | 2087 | continue; |
@@ -2101,9 +2102,9 @@ static void gdth_next(gdth_ha_str *ha) | |||
2101 | firsttime = FALSE; | 2102 | firsttime = FALSE; |
2102 | } | 2103 | } |
2103 | 2104 | ||
2104 | if (!gdth_cmnd_priv(nscp)->internal_command) { | 2105 | if (!nscp_cmndinfo->internal_command) { |
2105 | if (nscp->SCp.phase == -1) { | 2106 | if (nscp_cmndinfo->phase == -1) { |
2106 | nscp->SCp.phase = CACHESERVICE; /* default: cache svc. */ | 2107 | nscp_cmndinfo->phase = CACHESERVICE; /* default: cache svc. */ |
2107 | if (nscp->cmnd[0] == TEST_UNIT_READY) { | 2108 | if (nscp->cmnd[0] == TEST_UNIT_READY) { |
2108 | TRACE2(("TEST_UNIT_READY Bus %d Id %d LUN %d\n", | 2109 | TRACE2(("TEST_UNIT_READY Bus %d Id %d LUN %d\n", |
2109 | b, t, l)); | 2110 | b, t, l)); |
@@ -2116,8 +2117,8 @@ static void gdth_next(gdth_ha_str *ha) | |||
2116 | } else if ((ha->scan_mode & 0x0f) == 1) { | 2117 | } else if ((ha->scan_mode & 0x0f) == 1) { |
2117 | if (b == 0 && ((t == 0 && l == 1) || | 2118 | if (b == 0 && ((t == 0 && l == 1) || |
2118 | (t == 1 && l == 0))) { | 2119 | (t == 1 && l == 0))) { |
2119 | nscp->SCp.sent_command = GDT_SCAN_START; | 2120 | nscp_cmndinfo->OpCode = GDT_SCAN_START; |
2120 | nscp->SCp.phase = ((ha->scan_mode & 0x10 ? 1:0) << 8) | 2121 | nscp_cmndinfo->phase = ((ha->scan_mode & 0x10 ? 1:0) << 8) |
2121 | | SCSIRAWSERVICE; | 2122 | | SCSIRAWSERVICE; |
2122 | ha->scan_mode = 0x12; | 2123 | ha->scan_mode = 0x12; |
2123 | TRACE2(("Scan mode: 0x%x (SCAN_START)\n", | 2124 | TRACE2(("Scan mode: 0x%x (SCAN_START)\n", |
@@ -2128,8 +2129,8 @@ static void gdth_next(gdth_ha_str *ha) | |||
2128 | } | 2129 | } |
2129 | } else if (ha->scan_mode == 0x12) { | 2130 | } else if (ha->scan_mode == 0x12) { |
2130 | if (b == ha->bus_cnt && t == ha->tid_cnt-1) { | 2131 | if (b == ha->bus_cnt && t == ha->tid_cnt-1) { |
2131 | nscp->SCp.phase = SCSIRAWSERVICE; | 2132 | nscp_cmndinfo->phase = SCSIRAWSERVICE; |
2132 | nscp->SCp.sent_command = GDT_SCAN_END; | 2133 | nscp_cmndinfo->OpCode = GDT_SCAN_END; |
2133 | ha->scan_mode &= 0x10; | 2134 | ha->scan_mode &= 0x10; |
2134 | TRACE2(("Scan mode: 0x%x (SCAN_END)\n", | 2135 | TRACE2(("Scan mode: 0x%x (SCAN_END)\n", |
2135 | ha->scan_mode)); | 2136 | ha->scan_mode)); |
@@ -2140,17 +2141,17 @@ static void gdth_next(gdth_ha_str *ha) | |||
2140 | nscp->cmnd[0] != READ_CAPACITY && nscp->cmnd[0] != MODE_SENSE && | 2141 | nscp->cmnd[0] != READ_CAPACITY && nscp->cmnd[0] != MODE_SENSE && |
2141 | (ha->hdr[t].cluster_type & CLUSTER_DRIVE)) { | 2142 | (ha->hdr[t].cluster_type & CLUSTER_DRIVE)) { |
2142 | /* always GDT_CLUST_INFO! */ | 2143 | /* always GDT_CLUST_INFO! */ |
2143 | nscp->SCp.sent_command = GDT_CLUST_INFO; | 2144 | nscp_cmndinfo->OpCode = GDT_CLUST_INFO; |
2144 | } | 2145 | } |
2145 | } | 2146 | } |
2146 | } | 2147 | } |
2147 | 2148 | ||
2148 | if (nscp->SCp.sent_command != -1) { | 2149 | if (nscp_cmndinfo->OpCode != -1) { |
2149 | if ((nscp->SCp.phase & 0xff) == CACHESERVICE) { | 2150 | if ((nscp_cmndinfo->phase & 0xff) == CACHESERVICE) { |
2150 | if (!(cmd_index=gdth_fill_cache_cmd(ha, nscp, t))) | 2151 | if (!(cmd_index=gdth_fill_cache_cmd(ha, nscp, t))) |
2151 | this_cmd = FALSE; | 2152 | this_cmd = FALSE; |
2152 | next_cmd = FALSE; | 2153 | next_cmd = FALSE; |
2153 | } else if ((nscp->SCp.phase & 0xff) == SCSIRAWSERVICE) { | 2154 | } else if ((nscp_cmndinfo->phase & 0xff) == SCSIRAWSERVICE) { |
2154 | if (!(cmd_index=gdth_fill_raw_cmd(ha, nscp, BUS_L2P(ha, b)))) | 2155 | if (!(cmd_index=gdth_fill_raw_cmd(ha, nscp, BUS_L2P(ha, b)))) |
2155 | this_cmd = FALSE; | 2156 | this_cmd = FALSE; |
2156 | next_cmd = FALSE; | 2157 | next_cmd = FALSE; |
@@ -2159,8 +2160,8 @@ static void gdth_next(gdth_ha_str *ha) | |||
2159 | nscp->sense_buffer[0] = 0x70; | 2160 | nscp->sense_buffer[0] = 0x70; |
2160 | nscp->sense_buffer[2] = NOT_READY; | 2161 | nscp->sense_buffer[2] = NOT_READY; |
2161 | nscp->result = (DID_OK << 16) | (CHECK_CONDITION << 1); | 2162 | nscp->result = (DID_OK << 16) | (CHECK_CONDITION << 1); |
2162 | if (!nscp->SCp.have_data_in) | 2163 | if (!nscp_cmndinfo->wait_for_completion) |
2163 | nscp->SCp.have_data_in++; | 2164 | nscp_cmndinfo->wait_for_completion++; |
2164 | else | 2165 | else |
2165 | gdth_scsi_done(nscp); | 2166 | gdth_scsi_done(nscp); |
2166 | } | 2167 | } |
@@ -2178,8 +2179,8 @@ static void gdth_next(gdth_ha_str *ha) | |||
2178 | TRACE2(("Command 0x%x to bus %d id %d lun %d -> IGNORE\n", | 2179 | TRACE2(("Command 0x%x to bus %d id %d lun %d -> IGNORE\n", |
2179 | nscp->cmnd[0], b, t, l)); | 2180 | nscp->cmnd[0], b, t, l)); |
2180 | nscp->result = DID_BAD_TARGET << 16; | 2181 | nscp->result = DID_BAD_TARGET << 16; |
2181 | if (!nscp->SCp.have_data_in) | 2182 | if (!nscp_cmndinfo->wait_for_completion) |
2182 | nscp->SCp.have_data_in++; | 2183 | nscp_cmndinfo->wait_for_completion++; |
2183 | else | 2184 | else |
2184 | gdth_scsi_done(nscp); | 2185 | gdth_scsi_done(nscp); |
2185 | } else { | 2186 | } else { |
@@ -2204,8 +2205,8 @@ static void gdth_next(gdth_ha_str *ha) | |||
2204 | nscp->sense_buffer[0] = 0x70; | 2205 | nscp->sense_buffer[0] = 0x70; |
2205 | nscp->sense_buffer[2] = UNIT_ATTENTION; | 2206 | nscp->sense_buffer[2] = UNIT_ATTENTION; |
2206 | nscp->result = (DID_OK << 16) | (CHECK_CONDITION << 1); | 2207 | nscp->result = (DID_OK << 16) | (CHECK_CONDITION << 1); |
2207 | if (!nscp->SCp.have_data_in) | 2208 | if (!nscp_cmndinfo->wait_for_completion) |
2208 | nscp->SCp.have_data_in++; | 2209 | nscp_cmndinfo->wait_for_completion++; |
2209 | else | 2210 | else |
2210 | gdth_scsi_done(nscp); | 2211 | gdth_scsi_done(nscp); |
2211 | } else if (gdth_internal_cache_cmd(ha, nscp)) | 2212 | } else if (gdth_internal_cache_cmd(ha, nscp)) |
@@ -2220,8 +2221,8 @@ static void gdth_next(gdth_ha_str *ha) | |||
2220 | TRACE(("Prevent r. nonremov. drive->do nothing\n")); | 2221 | TRACE(("Prevent r. nonremov. drive->do nothing\n")); |
2221 | nscp->result = DID_OK << 16; | 2222 | nscp->result = DID_OK << 16; |
2222 | nscp->sense_buffer[0] = 0; | 2223 | nscp->sense_buffer[0] = 0; |
2223 | if (!nscp->SCp.have_data_in) | 2224 | if (!nscp_cmndinfo->wait_for_completion) |
2224 | nscp->SCp.have_data_in++; | 2225 | nscp_cmndinfo->wait_for_completion++; |
2225 | else | 2226 | else |
2226 | gdth_scsi_done(nscp); | 2227 | gdth_scsi_done(nscp); |
2227 | } else { | 2228 | } else { |
@@ -2256,8 +2257,8 @@ static void gdth_next(gdth_ha_str *ha) | |||
2256 | nscp->sense_buffer[0] = 0x70; | 2257 | nscp->sense_buffer[0] = 0x70; |
2257 | nscp->sense_buffer[2] = UNIT_ATTENTION; | 2258 | nscp->sense_buffer[2] = UNIT_ATTENTION; |
2258 | nscp->result = (DID_OK << 16) | (CHECK_CONDITION << 1); | 2259 | nscp->result = (DID_OK << 16) | (CHECK_CONDITION << 1); |
2259 | if (!nscp->SCp.have_data_in) | 2260 | if (!nscp_cmndinfo->wait_for_completion) |
2260 | nscp->SCp.have_data_in++; | 2261 | nscp_cmndinfo->wait_for_completion++; |
2261 | else | 2262 | else |
2262 | gdth_scsi_done(nscp); | 2263 | gdth_scsi_done(nscp); |
2263 | } else if (!(cmd_index=gdth_fill_cache_cmd(ha, nscp, t))) | 2264 | } else if (!(cmd_index=gdth_fill_cache_cmd(ha, nscp, t))) |
@@ -2271,8 +2272,8 @@ static void gdth_next(gdth_ha_str *ha) | |||
2271 | printk("GDT-HA %d: Unknown SCSI command 0x%x to cache service !\n", | 2272 | printk("GDT-HA %d: Unknown SCSI command 0x%x to cache service !\n", |
2272 | ha->hanum, nscp->cmnd[0]); | 2273 | ha->hanum, nscp->cmnd[0]); |
2273 | nscp->result = DID_ABORT << 16; | 2274 | nscp->result = DID_ABORT << 16; |
2274 | if (!nscp->SCp.have_data_in) | 2275 | if (!nscp_cmndinfo->wait_for_completion) |
2275 | nscp->SCp.have_data_in++; | 2276 | nscp_cmndinfo->wait_for_completion++; |
2276 | else | 2277 | else |
2277 | gdth_scsi_done(nscp); | 2278 | gdth_scsi_done(nscp); |
2278 | break; | 2279 | break; |
@@ -2351,6 +2352,7 @@ static int gdth_internal_cache_cmd(gdth_ha_str *ha, Scsi_Cmnd *scp) | |||
2351 | gdth_rdcap_data rdc; | 2352 | gdth_rdcap_data rdc; |
2352 | gdth_sense_data sd; | 2353 | gdth_sense_data sd; |
2353 | gdth_modep_data mpd; | 2354 | gdth_modep_data mpd; |
2355 | struct gdth_cmndinfo *cmndinfo = gdth_cmnd_priv(scp); | ||
2354 | 2356 | ||
2355 | t = scp->device->id; | 2357 | t = scp->device->id; |
2356 | TRACE(("gdth_internal_cache_cmd() cmd 0x%x hdrive %d\n", | 2358 | TRACE(("gdth_internal_cache_cmd() cmd 0x%x hdrive %d\n", |
@@ -2437,8 +2439,8 @@ static int gdth_internal_cache_cmd(gdth_ha_str *ha, Scsi_Cmnd *scp) | |||
2437 | break; | 2439 | break; |
2438 | } | 2440 | } |
2439 | 2441 | ||
2440 | if (!scp->SCp.have_data_in) | 2442 | if (!cmndinfo->wait_for_completion) |
2441 | scp->SCp.have_data_in++; | 2443 | cmndinfo->wait_for_completion++; |
2442 | else | 2444 | else |
2443 | return 1; | 2445 | return 1; |
2444 | 2446 | ||
@@ -2448,6 +2450,7 @@ static int gdth_internal_cache_cmd(gdth_ha_str *ha, Scsi_Cmnd *scp) | |||
2448 | static int gdth_fill_cache_cmd(gdth_ha_str *ha, Scsi_Cmnd *scp, ushort hdrive) | 2450 | static int gdth_fill_cache_cmd(gdth_ha_str *ha, Scsi_Cmnd *scp, ushort hdrive) |
2449 | { | 2451 | { |
2450 | register gdth_cmd_str *cmdp; | 2452 | register gdth_cmd_str *cmdp; |
2453 | struct gdth_cmndinfo *cmndinfo = gdth_cmnd_priv(scp); | ||
2451 | struct scatterlist *sl; | 2454 | struct scatterlist *sl; |
2452 | ulong32 cnt, blockcnt; | 2455 | ulong32 cnt, blockcnt; |
2453 | ulong64 no, blockno; | 2456 | ulong64 no, blockno; |
@@ -2481,8 +2484,8 @@ static int gdth_fill_cache_cmd(gdth_ha_str *ha, Scsi_Cmnd *scp, ushort hdrive) | |||
2481 | 2484 | ||
2482 | /* fill command */ | 2485 | /* fill command */ |
2483 | read_write = 0; | 2486 | read_write = 0; |
2484 | if (scp->SCp.sent_command != -1) | 2487 | if (cmndinfo->OpCode != -1) |
2485 | cmdp->OpCode = scp->SCp.sent_command; /* special cache cmd. */ | 2488 | cmdp->OpCode = cmndinfo->OpCode; /* special cache cmd. */ |
2486 | else if (scp->cmnd[0] == RESERVE) | 2489 | else if (scp->cmnd[0] == RESERVE) |
2487 | cmdp->OpCode = GDT_RESERVE_DRV; | 2490 | cmdp->OpCode = GDT_RESERVE_DRV; |
2488 | else if (scp->cmnd[0] == RELEASE) | 2491 | else if (scp->cmnd[0] == RELEASE) |
@@ -2547,9 +2550,9 @@ static int gdth_fill_cache_cmd(gdth_ha_str *ha, Scsi_Cmnd *scp, ushort hdrive) | |||
2547 | sl = (struct scatterlist *)scp->request_buffer; | 2550 | sl = (struct scatterlist *)scp->request_buffer; |
2548 | sgcnt = scp->use_sg; | 2551 | sgcnt = scp->use_sg; |
2549 | scp->SCp.Status = GDTH_MAP_SG; | 2552 | scp->SCp.Status = GDTH_MAP_SG; |
2550 | scp->SCp.Message = (read_write == 1 ? | 2553 | cmndinfo->dma_dir = (read_write == 1 ? |
2551 | PCI_DMA_TODEVICE : PCI_DMA_FROMDEVICE); | 2554 | PCI_DMA_TODEVICE : PCI_DMA_FROMDEVICE); |
2552 | sgcnt = pci_map_sg(ha->pdev,sl,scp->use_sg,scp->SCp.Message); | 2555 | sgcnt = pci_map_sg(ha->pdev, sl, scp->use_sg, cmndinfo->dma_dir); |
2553 | if (mode64) { | 2556 | if (mode64) { |
2554 | cmdp->u.cache64.DestAddr= (ulong64)-1; | 2557 | cmdp->u.cache64.DestAddr= (ulong64)-1; |
2555 | cmdp->u.cache64.sg_canz = sgcnt; | 2558 | cmdp->u.cache64.sg_canz = sgcnt; |
@@ -2584,12 +2587,12 @@ static int gdth_fill_cache_cmd(gdth_ha_str *ha, Scsi_Cmnd *scp, ushort hdrive) | |||
2584 | 2587 | ||
2585 | } else if (scp->request_bufflen) { | 2588 | } else if (scp->request_bufflen) { |
2586 | scp->SCp.Status = GDTH_MAP_SINGLE; | 2589 | scp->SCp.Status = GDTH_MAP_SINGLE; |
2587 | scp->SCp.Message = (read_write == 1 ? | 2590 | cmndinfo->dma_dir = (read_write == 1 ? |
2588 | PCI_DMA_TODEVICE : PCI_DMA_FROMDEVICE); | 2591 | PCI_DMA_TODEVICE : PCI_DMA_FROMDEVICE); |
2589 | page = virt_to_page(scp->request_buffer); | 2592 | page = virt_to_page(scp->request_buffer); |
2590 | offset = (ulong)scp->request_buffer & ~PAGE_MASK; | 2593 | offset = (ulong)scp->request_buffer & ~PAGE_MASK; |
2591 | phys_addr = pci_map_page(ha->pdev,page,offset, | 2594 | phys_addr = pci_map_page(ha->pdev,page,offset, |
2592 | scp->request_bufflen,scp->SCp.Message); | 2595 | scp->request_bufflen, cmndinfo->dma_dir); |
2593 | scp->SCp.dma_handle = phys_addr; | 2596 | scp->SCp.dma_handle = phys_addr; |
2594 | if (mode64) { | 2597 | if (mode64) { |
2595 | if (ha->cache_feat & SCATTER_GATHER) { | 2598 | if (ha->cache_feat & SCATTER_GATHER) { |
@@ -2689,17 +2692,17 @@ static int gdth_fill_raw_cmd(gdth_ha_str *ha, Scsi_Cmnd *scp, unchar b) | |||
2689 | 2692 | ||
2690 | cmndinfo = gdth_cmnd_priv(scp); | 2693 | cmndinfo = gdth_cmnd_priv(scp); |
2691 | /* fill command */ | 2694 | /* fill command */ |
2692 | if (scp->SCp.sent_command != -1) { | 2695 | if (cmndinfo->OpCode != -1) { |
2693 | cmdp->OpCode = scp->SCp.sent_command; /* special raw cmd. */ | 2696 | cmdp->OpCode = cmndinfo->OpCode; /* special raw cmd. */ |
2694 | cmdp->BoardNode = LOCALBOARD; | 2697 | cmdp->BoardNode = LOCALBOARD; |
2695 | if (mode64) { | 2698 | if (mode64) { |
2696 | cmdp->u.raw64.direction = (scp->SCp.phase >> 8); | 2699 | cmdp->u.raw64.direction = (cmndinfo->phase >> 8); |
2697 | TRACE2(("special raw cmd 0x%x param 0x%x\n", | 2700 | TRACE2(("special raw cmd 0x%x param 0x%x\n", |
2698 | cmdp->OpCode, cmdp->u.raw64.direction)); | 2701 | cmdp->OpCode, cmdp->u.raw64.direction)); |
2699 | /* evaluate command size */ | 2702 | /* evaluate command size */ |
2700 | ha->cmd_len = GDTOFFSOF(gdth_cmd_str,u.raw64.sg_lst); | 2703 | ha->cmd_len = GDTOFFSOF(gdth_cmd_str,u.raw64.sg_lst); |
2701 | } else { | 2704 | } else { |
2702 | cmdp->u.raw.direction = (scp->SCp.phase >> 8); | 2705 | cmdp->u.raw.direction = (cmndinfo->phase >> 8); |
2703 | TRACE2(("special raw cmd 0x%x param 0x%x\n", | 2706 | TRACE2(("special raw cmd 0x%x param 0x%x\n", |
2704 | cmdp->OpCode, cmdp->u.raw.direction)); | 2707 | cmdp->OpCode, cmdp->u.raw.direction)); |
2705 | /* evaluate command size */ | 2708 | /* evaluate command size */ |
@@ -2754,8 +2757,8 @@ static int gdth_fill_raw_cmd(gdth_ha_str *ha, Scsi_Cmnd *scp, unchar b) | |||
2754 | sl = (struct scatterlist *)scp->request_buffer; | 2757 | sl = (struct scatterlist *)scp->request_buffer; |
2755 | sgcnt = scp->use_sg; | 2758 | sgcnt = scp->use_sg; |
2756 | scp->SCp.Status = GDTH_MAP_SG; | 2759 | scp->SCp.Status = GDTH_MAP_SG; |
2757 | scp->SCp.Message = PCI_DMA_BIDIRECTIONAL; | 2760 | cmndinfo->dma_dir = PCI_DMA_BIDIRECTIONAL; |
2758 | sgcnt = pci_map_sg(ha->pdev,sl,scp->use_sg,scp->SCp.Message); | 2761 | sgcnt = pci_map_sg(ha->pdev,sl, scp->use_sg, cmndinfo->dma_dir); |
2759 | if (mode64) { | 2762 | if (mode64) { |
2760 | cmdp->u.raw64.sdata = (ulong64)-1; | 2763 | cmdp->u.raw64.sdata = (ulong64)-1; |
2761 | cmdp->u.raw64.sg_ranz = sgcnt; | 2764 | cmdp->u.raw64.sg_ranz = sgcnt; |
@@ -2790,11 +2793,11 @@ static int gdth_fill_raw_cmd(gdth_ha_str *ha, Scsi_Cmnd *scp, unchar b) | |||
2790 | 2793 | ||
2791 | } else if (scp->request_bufflen) { | 2794 | } else if (scp->request_bufflen) { |
2792 | scp->SCp.Status = GDTH_MAP_SINGLE; | 2795 | scp->SCp.Status = GDTH_MAP_SINGLE; |
2793 | scp->SCp.Message = PCI_DMA_BIDIRECTIONAL; | 2796 | cmndinfo->dma_dir = PCI_DMA_BIDIRECTIONAL; |
2794 | page = virt_to_page(scp->request_buffer); | 2797 | page = virt_to_page(scp->request_buffer); |
2795 | offset = (ulong)scp->request_buffer & ~PAGE_MASK; | 2798 | offset = (ulong)scp->request_buffer & ~PAGE_MASK; |
2796 | phys_addr = pci_map_page(ha->pdev,page,offset, | 2799 | phys_addr = pci_map_page(ha->pdev,page,offset, |
2797 | scp->request_bufflen,scp->SCp.Message); | 2800 | scp->request_bufflen, cmndinfo->dma_dir); |
2798 | scp->SCp.dma_handle = phys_addr; | 2801 | scp->SCp.dma_handle = phys_addr; |
2799 | 2802 | ||
2800 | if (mode64) { | 2803 | if (mode64) { |
@@ -3266,7 +3269,7 @@ static irqreturn_t __gdth_interrupt(gdth_ha_str *ha, int irq, | |||
3266 | if (!gdth_polling) | 3269 | if (!gdth_polling) |
3267 | spin_unlock_irqrestore(&ha->smp_lock, flags); | 3270 | spin_unlock_irqrestore(&ha->smp_lock, flags); |
3268 | if (rval == 2) { | 3271 | if (rval == 2) { |
3269 | gdth_putq(ha, scp,scp->SCp.this_residual); | 3272 | gdth_putq(ha, scp, gdth_cmnd_priv(scp)->priority); |
3270 | } else if (rval == 1) { | 3273 | } else if (rval == 1) { |
3271 | gdth_scsi_done(scp); | 3274 | gdth_scsi_done(scp); |
3272 | } | 3275 | } |
@@ -3390,60 +3393,60 @@ static int gdth_sync_event(gdth_ha_str *ha, int service, unchar index, | |||
3390 | } else { | 3393 | } else { |
3391 | b = scp->device->channel; | 3394 | b = scp->device->channel; |
3392 | t = scp->device->id; | 3395 | t = scp->device->id; |
3393 | if (scp->SCp.sent_command == -1 && b != ha->virt_bus) { | 3396 | if (cmndinfo->OpCode == -1 && b != ha->virt_bus) { |
3394 | ha->raw[BUS_L2P(ha,b)].io_cnt[t]--; | 3397 | ha->raw[BUS_L2P(ha,b)].io_cnt[t]--; |
3395 | } | 3398 | } |
3396 | /* cache or raw service */ | 3399 | /* cache or raw service */ |
3397 | if (ha->status == S_BSY) { | 3400 | if (ha->status == S_BSY) { |
3398 | TRACE2(("Controller busy -> retry !\n")); | 3401 | TRACE2(("Controller busy -> retry !\n")); |
3399 | if (scp->SCp.sent_command == GDT_MOUNT) | 3402 | if (cmndinfo->OpCode == GDT_MOUNT) |
3400 | scp->SCp.sent_command = GDT_CLUST_INFO; | 3403 | cmndinfo->OpCode = GDT_CLUST_INFO; |
3401 | /* retry */ | 3404 | /* retry */ |
3402 | return 2; | 3405 | return 2; |
3403 | } | 3406 | } |
3404 | if (scp->SCp.Status == GDTH_MAP_SG) | 3407 | if (scp->SCp.Status == GDTH_MAP_SG) |
3405 | pci_unmap_sg(ha->pdev,scp->request_buffer, | 3408 | pci_unmap_sg(ha->pdev,scp->request_buffer, |
3406 | scp->use_sg,scp->SCp.Message); | 3409 | scp->use_sg, cmndinfo->dma_dir); |
3407 | else if (scp->SCp.Status == GDTH_MAP_SINGLE) | 3410 | else if (scp->SCp.Status == GDTH_MAP_SINGLE) |
3408 | pci_unmap_page(ha->pdev,scp->SCp.dma_handle, | 3411 | pci_unmap_page(ha->pdev,scp->SCp.dma_handle, |
3409 | scp->request_bufflen,scp->SCp.Message); | 3412 | scp->request_bufflen, cmndinfo->dma_dir); |
3410 | if (cmndinfo->sense_paddr) | 3413 | if (cmndinfo->sense_paddr) |
3411 | pci_unmap_page(ha->pdev, cmndinfo->sense_paddr, 16, | 3414 | pci_unmap_page(ha->pdev, cmndinfo->sense_paddr, 16, |
3412 | PCI_DMA_FROMDEVICE); | 3415 | PCI_DMA_FROMDEVICE); |
3413 | 3416 | ||
3414 | if (ha->status == S_OK) { | 3417 | if (ha->status == S_OK) { |
3415 | scp->SCp.Status = S_OK; | 3418 | cmndinfo->status = S_OK; |
3416 | scp->SCp.Message = ha->info; | 3419 | cmndinfo->info = ha->info; |
3417 | if (scp->SCp.sent_command != -1) { | 3420 | if (cmndinfo->OpCode != -1) { |
3418 | TRACE2(("gdth_sync_event(): special cmd 0x%x OK\n", | 3421 | TRACE2(("gdth_sync_event(): special cmd 0x%x OK\n", |
3419 | scp->SCp.sent_command)); | 3422 | cmndinfo->OpCode)); |
3420 | /* special commands GDT_CLUST_INFO/GDT_MOUNT ? */ | 3423 | /* special commands GDT_CLUST_INFO/GDT_MOUNT ? */ |
3421 | if (scp->SCp.sent_command == GDT_CLUST_INFO) { | 3424 | if (cmndinfo->OpCode == GDT_CLUST_INFO) { |
3422 | ha->hdr[t].cluster_type = (unchar)ha->info; | 3425 | ha->hdr[t].cluster_type = (unchar)ha->info; |
3423 | if (!(ha->hdr[t].cluster_type & | 3426 | if (!(ha->hdr[t].cluster_type & |
3424 | CLUSTER_MOUNTED)) { | 3427 | CLUSTER_MOUNTED)) { |
3425 | /* NOT MOUNTED -> MOUNT */ | 3428 | /* NOT MOUNTED -> MOUNT */ |
3426 | scp->SCp.sent_command = GDT_MOUNT; | 3429 | cmndinfo->OpCode = GDT_MOUNT; |
3427 | if (ha->hdr[t].cluster_type & | 3430 | if (ha->hdr[t].cluster_type & |
3428 | CLUSTER_RESERVED) { | 3431 | CLUSTER_RESERVED) { |
3429 | /* cluster drive RESERVED (on the other node) */ | 3432 | /* cluster drive RESERVED (on the other node) */ |
3430 | scp->SCp.phase = -2; /* reservation conflict */ | 3433 | cmndinfo->phase = -2; /* reservation conflict */ |
3431 | } | 3434 | } |
3432 | } else { | 3435 | } else { |
3433 | scp->SCp.sent_command = -1; | 3436 | cmndinfo->OpCode = -1; |
3434 | } | 3437 | } |
3435 | } else { | 3438 | } else { |
3436 | if (scp->SCp.sent_command == GDT_MOUNT) { | 3439 | if (cmndinfo->OpCode == GDT_MOUNT) { |
3437 | ha->hdr[t].cluster_type |= CLUSTER_MOUNTED; | 3440 | ha->hdr[t].cluster_type |= CLUSTER_MOUNTED; |
3438 | ha->hdr[t].media_changed = TRUE; | 3441 | ha->hdr[t].media_changed = TRUE; |
3439 | } else if (scp->SCp.sent_command == GDT_UNMOUNT) { | 3442 | } else if (cmndinfo->OpCode == GDT_UNMOUNT) { |
3440 | ha->hdr[t].cluster_type &= ~CLUSTER_MOUNTED; | 3443 | ha->hdr[t].cluster_type &= ~CLUSTER_MOUNTED; |
3441 | ha->hdr[t].media_changed = TRUE; | 3444 | ha->hdr[t].media_changed = TRUE; |
3442 | } | 3445 | } |
3443 | scp->SCp.sent_command = -1; | 3446 | cmndinfo->OpCode = -1; |
3444 | } | 3447 | } |
3445 | /* retry */ | 3448 | /* retry */ |
3446 | scp->SCp.this_residual = HIGH_PRI; | 3449 | cmndinfo->priority = HIGH_PRI; |
3447 | return 2; | 3450 | return 2; |
3448 | } else { | 3451 | } else { |
3449 | /* RESERVE/RELEASE ? */ | 3452 | /* RESERVE/RELEASE ? */ |
@@ -3456,17 +3459,17 @@ static int gdth_sync_event(gdth_ha_str *ha, int service, unchar index, | |||
3456 | scp->sense_buffer[0] = 0; | 3459 | scp->sense_buffer[0] = 0; |
3457 | } | 3460 | } |
3458 | } else { | 3461 | } else { |
3459 | scp->SCp.Status = ha->status; | 3462 | cmndinfo->status = ha->status; |
3460 | scp->SCp.Message = ha->info; | 3463 | cmndinfo->info = ha->info; |
3461 | 3464 | ||
3462 | if (scp->SCp.sent_command != -1) { | 3465 | if (cmndinfo->OpCode != -1) { |
3463 | TRACE2(("gdth_sync_event(): special cmd 0x%x error 0x%x\n", | 3466 | TRACE2(("gdth_sync_event(): special cmd 0x%x error 0x%x\n", |
3464 | scp->SCp.sent_command, ha->status)); | 3467 | cmndinfo->OpCode, ha->status)); |
3465 | if (scp->SCp.sent_command == GDT_SCAN_START || | 3468 | if (cmndinfo->OpCode == GDT_SCAN_START || |
3466 | scp->SCp.sent_command == GDT_SCAN_END) { | 3469 | cmndinfo->OpCode == GDT_SCAN_END) { |
3467 | scp->SCp.sent_command = -1; | 3470 | cmndinfo->OpCode = -1; |
3468 | /* retry */ | 3471 | /* retry */ |
3469 | scp->SCp.this_residual = HIGH_PRI; | 3472 | cmndinfo->priority = HIGH_PRI; |
3470 | return 2; | 3473 | return 2; |
3471 | } | 3474 | } |
3472 | memset((char*)scp->sense_buffer,0,16); | 3475 | memset((char*)scp->sense_buffer,0,16); |
@@ -3509,8 +3512,8 @@ static int gdth_sync_event(gdth_ha_str *ha, int service, unchar index, | |||
3509 | } | 3512 | } |
3510 | } | 3513 | } |
3511 | } | 3514 | } |
3512 | if (!scp->SCp.have_data_in) | 3515 | if (!cmndinfo->wait_for_completion) |
3513 | scp->SCp.have_data_in++; | 3516 | cmndinfo->wait_for_completion++; |
3514 | else | 3517 | else |
3515 | return 1; | 3518 | return 1; |
3516 | } | 3519 | } |
@@ -4042,7 +4045,7 @@ static int gdth_queuecommand(struct scsi_cmnd *scp, | |||
4042 | 4045 | ||
4043 | scp->scsi_done = done; | 4046 | scp->scsi_done = done; |
4044 | gdth_update_timeout(scp, scp->timeout_per_command * 6); | 4047 | gdth_update_timeout(scp, scp->timeout_per_command * 6); |
4045 | scp->SCp.this_residual = DEFAULT_PRI; | 4048 | cmndinfo->priority = DEFAULT_PRI; |
4046 | return __gdth_queuecommand(ha, scp, cmndinfo); | 4049 | return __gdth_queuecommand(ha, scp, cmndinfo); |
4047 | } | 4050 | } |
4048 | 4051 | ||
@@ -4050,16 +4053,16 @@ static int __gdth_queuecommand(gdth_ha_str *ha, struct scsi_cmnd *scp, | |||
4050 | struct gdth_cmndinfo *cmndinfo) | 4053 | struct gdth_cmndinfo *cmndinfo) |
4051 | { | 4054 | { |
4052 | scp->host_scribble = (unsigned char *)cmndinfo; | 4055 | scp->host_scribble = (unsigned char *)cmndinfo; |
4053 | scp->SCp.have_data_in = 1; | 4056 | cmndinfo->wait_for_completion = 1; |
4054 | scp->SCp.phase = -1; | 4057 | cmndinfo->phase = -1; |
4055 | scp->SCp.sent_command = -1; | 4058 | cmndinfo->OpCode = -1; |
4056 | scp->SCp.Status = GDTH_MAP_NONE; | 4059 | scp->SCp.Status = GDTH_MAP_NONE; |
4057 | 4060 | ||
4058 | #ifdef GDTH_STATISTICS | 4061 | #ifdef GDTH_STATISTICS |
4059 | ++act_ios; | 4062 | ++act_ios; |
4060 | #endif | 4063 | #endif |
4061 | 4064 | ||
4062 | gdth_putq(ha, scp, scp->SCp.this_residual); | 4065 | gdth_putq(ha, scp, cmndinfo->priority); |
4063 | gdth_next(ha); | 4066 | gdth_next(ha); |
4064 | return 0; | 4067 | return 0; |
4065 | } | 4068 | } |
diff --git a/drivers/scsi/gdth.h b/drivers/scsi/gdth.h index be4ae5abd5c3..25803a8f31de 100644 --- a/drivers/scsi/gdth.h +++ b/drivers/scsi/gdth.h | |||
@@ -923,6 +923,14 @@ typedef struct { | |||
923 | int index; | 923 | int index; |
924 | int internal_command; /* don't call scsi_done */ | 924 | int internal_command; /* don't call scsi_done */ |
925 | dma_addr_t sense_paddr; /* sense dma-addr */ | 925 | dma_addr_t sense_paddr; /* sense dma-addr */ |
926 | unchar priority; | ||
927 | int timeout; | ||
928 | volatile int wait_for_completion; | ||
929 | ushort status; | ||
930 | ulong32 info; | ||
931 | enum dma_data_direction dma_dir; | ||
932 | int phase; /* ???? */ | ||
933 | int OpCode; | ||
926 | } cmndinfo[GDTH_MAXCMDS]; /* index==0 is free */ | 934 | } cmndinfo[GDTH_MAXCMDS]; /* index==0 is free */ |
927 | unchar bus_cnt; /* SCSI bus count */ | 935 | unchar bus_cnt; /* SCSI bus count */ |
928 | unchar tid_cnt; /* Target ID count */ | 936 | unchar tid_cnt; /* Target ID count */ |
diff --git a/drivers/scsi/gdth_proc.c b/drivers/scsi/gdth_proc.c index ad1b60dbcf9c..de5773443c62 100644 --- a/drivers/scsi/gdth_proc.c +++ b/drivers/scsi/gdth_proc.c | |||
@@ -728,20 +728,22 @@ static void gdth_wait_completion(gdth_ha_str *ha, int busnum, int id) | |||
728 | ulong flags; | 728 | ulong flags; |
729 | int i; | 729 | int i; |
730 | Scsi_Cmnd *scp; | 730 | Scsi_Cmnd *scp; |
731 | struct gdth_cmndinfo *cmndinfo; | ||
731 | unchar b, t; | 732 | unchar b, t; |
732 | 733 | ||
733 | spin_lock_irqsave(&ha->smp_lock, flags); | 734 | spin_lock_irqsave(&ha->smp_lock, flags); |
734 | 735 | ||
735 | for (i = 0; i < GDTH_MAXCMDS; ++i) { | 736 | for (i = 0; i < GDTH_MAXCMDS; ++i) { |
736 | scp = ha->cmd_tab[i].cmnd; | 737 | scp = ha->cmd_tab[i].cmnd; |
738 | cmndinfo = gdth_cmnd_priv(scp); | ||
737 | 739 | ||
738 | b = scp->device->channel; | 740 | b = scp->device->channel; |
739 | t = scp->device->id; | 741 | t = scp->device->id; |
740 | if (!SPECIAL_SCP(scp) && t == (unchar)id && | 742 | if (!SPECIAL_SCP(scp) && t == (unchar)id && |
741 | b == (unchar)busnum) { | 743 | b == (unchar)busnum) { |
742 | scp->SCp.have_data_in = 0; | 744 | cmndinfo->wait_for_completion = 0; |
743 | spin_unlock_irqrestore(&ha->smp_lock, flags); | 745 | spin_unlock_irqrestore(&ha->smp_lock, flags); |
744 | while (!scp->SCp.have_data_in) | 746 | while (!cmndinfo->wait_for_completion) |
745 | barrier(); | 747 | barrier(); |
746 | spin_lock_irqsave(&ha->smp_lock, flags); | 748 | spin_lock_irqsave(&ha->smp_lock, flags); |
747 | } | 749 | } |
@@ -764,7 +766,7 @@ static void gdth_stop_timeout(gdth_ha_str *ha, int busnum, int id) | |||
764 | t = scp->device->id; | 766 | t = scp->device->id; |
765 | if (t == (unchar)id && b == (unchar)busnum) { | 767 | if (t == (unchar)id && b == (unchar)busnum) { |
766 | TRACE2(("gdth_stop_timeout(): update_timeout()\n")); | 768 | TRACE2(("gdth_stop_timeout(): update_timeout()\n")); |
767 | scp->SCp.buffers_residual = gdth_update_timeout(scp, 0); | 769 | cmndinfo->timeout = gdth_update_timeout(scp, 0); |
768 | } | 770 | } |
769 | } | 771 | } |
770 | } | 772 | } |
@@ -786,7 +788,7 @@ static void gdth_start_timeout(gdth_ha_str *ha, int busnum, int id) | |||
786 | t = scp->device->id; | 788 | t = scp->device->id; |
787 | if (t == (unchar)id && b == (unchar)busnum) { | 789 | if (t == (unchar)id && b == (unchar)busnum) { |
788 | TRACE2(("gdth_start_timeout(): update_timeout()\n")); | 790 | TRACE2(("gdth_start_timeout(): update_timeout()\n")); |
789 | gdth_update_timeout(scp, scp->SCp.buffers_residual); | 791 | gdth_update_timeout(scp, cmndinfo->timeout); |
790 | } | 792 | } |
791 | } | 793 | } |
792 | } | 794 | } |