diff options
Diffstat (limited to 'drivers/scsi/ncr53c8xx.c')
-rw-r--r-- | drivers/scsi/ncr53c8xx.c | 127 |
1 files changed, 55 insertions, 72 deletions
diff --git a/drivers/scsi/ncr53c8xx.c b/drivers/scsi/ncr53c8xx.c index 32350707b94..22f913127f0 100644 --- a/drivers/scsi/ncr53c8xx.c +++ b/drivers/scsi/ncr53c8xx.c | |||
@@ -69,6 +69,10 @@ | |||
69 | ** Low PCI traffic for command handling when on-chip RAM is present. | 69 | ** Low PCI traffic for command handling when on-chip RAM is present. |
70 | ** Aggressive SCSI SCRIPTS optimizations. | 70 | ** Aggressive SCSI SCRIPTS optimizations. |
71 | ** | 71 | ** |
72 | ** 2005 by Matthew Wilcox and James Bottomley | ||
73 | ** PCI-ectomy. This driver now supports only the 720 chip (see the | ||
74 | ** NCR_Q720 and zalon drivers for the bus probe logic). | ||
75 | ** | ||
72 | ******************************************************************************* | 76 | ******************************************************************************* |
73 | */ | 77 | */ |
74 | 78 | ||
@@ -90,13 +94,6 @@ | |||
90 | 94 | ||
91 | #define SCSI_NCR_DEBUG_FLAGS (0) | 95 | #define SCSI_NCR_DEBUG_FLAGS (0) |
92 | 96 | ||
93 | /*========================================================== | ||
94 | ** | ||
95 | ** Include files | ||
96 | ** | ||
97 | **========================================================== | ||
98 | */ | ||
99 | |||
100 | #include <linux/blkdev.h> | 97 | #include <linux/blkdev.h> |
101 | #include <linux/delay.h> | 98 | #include <linux/delay.h> |
102 | #include <linux/dma-mapping.h> | 99 | #include <linux/dma-mapping.h> |
@@ -121,6 +118,7 @@ | |||
121 | 118 | ||
122 | #include <scsi/scsi.h> | 119 | #include <scsi/scsi.h> |
123 | #include <scsi/scsi_cmnd.h> | 120 | #include <scsi/scsi_cmnd.h> |
121 | #include <scsi/scsi_dbg.h> | ||
124 | #include <scsi/scsi_device.h> | 122 | #include <scsi/scsi_device.h> |
125 | #include <scsi/scsi_tcq.h> | 123 | #include <scsi/scsi_tcq.h> |
126 | #include <scsi/scsi_transport.h> | 124 | #include <scsi/scsi_transport.h> |
@@ -128,10 +126,8 @@ | |||
128 | 126 | ||
129 | #include "ncr53c8xx.h" | 127 | #include "ncr53c8xx.h" |
130 | 128 | ||
131 | #define NAME53C "ncr53c" | ||
132 | #define NAME53C8XX "ncr53c8xx" | 129 | #define NAME53C8XX "ncr53c8xx" |
133 | 130 | ||
134 | |||
135 | /*========================================================== | 131 | /*========================================================== |
136 | ** | 132 | ** |
137 | ** Debugging tags | 133 | ** Debugging tags |
@@ -2111,7 +2107,7 @@ static struct script script0 __initdata = { | |||
2111 | */ | 2107 | */ |
2112 | 2108 | ||
2113 | /* | 2109 | /* |
2114 | ** The M_REJECT problem seems to be due to a selection | 2110 | ** The MESSAGE_REJECT problem seems to be due to a selection |
2115 | ** timing problem. | 2111 | ** timing problem. |
2116 | ** Wait immediately for the selection to complete. | 2112 | ** Wait immediately for the selection to complete. |
2117 | ** (2.5x behaves so) | 2113 | ** (2.5x behaves so) |
@@ -2162,7 +2158,7 @@ static struct script script0 __initdata = { | |||
2162 | /* | 2158 | /* |
2163 | ** Selection complete. | 2159 | ** Selection complete. |
2164 | ** Send the IDENTIFY and SIMPLE_TAG messages | 2160 | ** Send the IDENTIFY and SIMPLE_TAG messages |
2165 | ** (and the M_X_SYNC_REQ message) | 2161 | ** (and the EXTENDED_SDTR message) |
2166 | */ | 2162 | */ |
2167 | SCR_MOVE_TBL ^ SCR_MSG_OUT, | 2163 | SCR_MOVE_TBL ^ SCR_MSG_OUT, |
2168 | offsetof (struct dsb, smsg), | 2164 | offsetof (struct dsb, smsg), |
@@ -2191,7 +2187,7 @@ static struct script script0 __initdata = { | |||
2191 | /* | 2187 | /* |
2192 | ** Initialize the msgout buffer with a NOOP message. | 2188 | ** Initialize the msgout buffer with a NOOP message. |
2193 | */ | 2189 | */ |
2194 | SCR_LOAD_REG (scratcha, M_NOOP), | 2190 | SCR_LOAD_REG (scratcha, NOP), |
2195 | 0, | 2191 | 0, |
2196 | SCR_COPY (1), | 2192 | SCR_COPY (1), |
2197 | RADDR (scratcha), | 2193 | RADDR (scratcha), |
@@ -2343,21 +2339,21 @@ static struct script script0 __initdata = { | |||
2343 | /* | 2339 | /* |
2344 | ** Handle this message. | 2340 | ** Handle this message. |
2345 | */ | 2341 | */ |
2346 | SCR_JUMP ^ IFTRUE (DATA (M_COMPLETE)), | 2342 | SCR_JUMP ^ IFTRUE (DATA (COMMAND_COMPLETE)), |
2347 | PADDR (complete), | 2343 | PADDR (complete), |
2348 | SCR_JUMP ^ IFTRUE (DATA (M_DISCONNECT)), | 2344 | SCR_JUMP ^ IFTRUE (DATA (DISCONNECT)), |
2349 | PADDR (disconnect), | 2345 | PADDR (disconnect), |
2350 | SCR_JUMP ^ IFTRUE (DATA (M_SAVE_DP)), | 2346 | SCR_JUMP ^ IFTRUE (DATA (SAVE_POINTERS)), |
2351 | PADDR (save_dp), | 2347 | PADDR (save_dp), |
2352 | SCR_JUMP ^ IFTRUE (DATA (M_RESTORE_DP)), | 2348 | SCR_JUMP ^ IFTRUE (DATA (RESTORE_POINTERS)), |
2353 | PADDR (restore_dp), | 2349 | PADDR (restore_dp), |
2354 | SCR_JUMP ^ IFTRUE (DATA (M_EXTENDED)), | 2350 | SCR_JUMP ^ IFTRUE (DATA (EXTENDED_MESSAGE)), |
2355 | PADDRH (msg_extended), | 2351 | PADDRH (msg_extended), |
2356 | SCR_JUMP ^ IFTRUE (DATA (M_NOOP)), | 2352 | SCR_JUMP ^ IFTRUE (DATA (NOP)), |
2357 | PADDR (clrack), | 2353 | PADDR (clrack), |
2358 | SCR_JUMP ^ IFTRUE (DATA (M_REJECT)), | 2354 | SCR_JUMP ^ IFTRUE (DATA (MESSAGE_REJECT)), |
2359 | PADDRH (msg_reject), | 2355 | PADDRH (msg_reject), |
2360 | SCR_JUMP ^ IFTRUE (DATA (M_IGN_RESIDUE)), | 2356 | SCR_JUMP ^ IFTRUE (DATA (IGNORE_WIDE_RESIDUE)), |
2361 | PADDRH (msg_ign_residue), | 2357 | PADDRH (msg_ign_residue), |
2362 | /* | 2358 | /* |
2363 | ** Rest of the messages left as | 2359 | ** Rest of the messages left as |
@@ -2372,7 +2368,7 @@ static struct script script0 __initdata = { | |||
2372 | */ | 2368 | */ |
2373 | SCR_INT, | 2369 | SCR_INT, |
2374 | SIR_REJECT_SENT, | 2370 | SIR_REJECT_SENT, |
2375 | SCR_LOAD_REG (scratcha, M_REJECT), | 2371 | SCR_LOAD_REG (scratcha, MESSAGE_REJECT), |
2376 | 0, | 2372 | 0, |
2377 | }/*-------------------------< SETMSG >----------------------*/,{ | 2373 | }/*-------------------------< SETMSG >----------------------*/,{ |
2378 | SCR_COPY (1), | 2374 | SCR_COPY (1), |
@@ -2564,7 +2560,7 @@ static struct script script0 __initdata = { | |||
2564 | /* | 2560 | /* |
2565 | ** If it was no ABORT message ... | 2561 | ** If it was no ABORT message ... |
2566 | */ | 2562 | */ |
2567 | SCR_JUMP ^ IFTRUE (DATA (M_ABORT)), | 2563 | SCR_JUMP ^ IFTRUE (DATA (ABORT_TASK_SET)), |
2568 | PADDRH (msg_out_abort), | 2564 | PADDRH (msg_out_abort), |
2569 | /* | 2565 | /* |
2570 | ** ... wait for the next phase | 2566 | ** ... wait for the next phase |
@@ -2576,7 +2572,7 @@ static struct script script0 __initdata = { | |||
2576 | /* | 2572 | /* |
2577 | ** ... else clear the message ... | 2573 | ** ... else clear the message ... |
2578 | */ | 2574 | */ |
2579 | SCR_LOAD_REG (scratcha, M_NOOP), | 2575 | SCR_LOAD_REG (scratcha, NOP), |
2580 | 0, | 2576 | 0, |
2581 | SCR_COPY (4), | 2577 | SCR_COPY (4), |
2582 | RADDR (scratcha), | 2578 | RADDR (scratcha), |
@@ -3035,7 +3031,7 @@ static struct scripth scripth0 __initdata = { | |||
3035 | */ | 3031 | */ |
3036 | SCR_MOVE_ABS (1) ^ SCR_MSG_IN, | 3032 | SCR_MOVE_ABS (1) ^ SCR_MSG_IN, |
3037 | NADDR (msgin[2]), | 3033 | NADDR (msgin[2]), |
3038 | SCR_JUMP ^ IFTRUE (DATA (M_X_WIDE_REQ)), | 3034 | SCR_JUMP ^ IFTRUE (DATA (EXTENDED_WDTR)), |
3039 | PADDRH (msg_wdtr), | 3035 | PADDRH (msg_wdtr), |
3040 | /* | 3036 | /* |
3041 | ** unknown extended message | 3037 | ** unknown extended message |
@@ -3069,7 +3065,7 @@ static struct scripth scripth0 __initdata = { | |||
3069 | 3065 | ||
3070 | }/*-------------------------< SEND_WDTR >----------------*/,{ | 3066 | }/*-------------------------< SEND_WDTR >----------------*/,{ |
3071 | /* | 3067 | /* |
3072 | ** Send the M_X_WIDE_REQ | 3068 | ** Send the EXTENDED_WDTR |
3073 | */ | 3069 | */ |
3074 | SCR_MOVE_ABS (4) ^ SCR_MSG_OUT, | 3070 | SCR_MOVE_ABS (4) ^ SCR_MSG_OUT, |
3075 | NADDR (msgout), | 3071 | NADDR (msgout), |
@@ -3089,7 +3085,7 @@ static struct scripth scripth0 __initdata = { | |||
3089 | */ | 3085 | */ |
3090 | SCR_MOVE_ABS (1) ^ SCR_MSG_IN, | 3086 | SCR_MOVE_ABS (1) ^ SCR_MSG_IN, |
3091 | NADDR (msgin[2]), | 3087 | NADDR (msgin[2]), |
3092 | SCR_JUMP ^ IFTRUE (DATA (M_X_SYNC_REQ)), | 3088 | SCR_JUMP ^ IFTRUE (DATA (EXTENDED_SDTR)), |
3093 | PADDRH (msg_sdtr), | 3089 | PADDRH (msg_sdtr), |
3094 | /* | 3090 | /* |
3095 | ** unknown extended message | 3091 | ** unknown extended message |
@@ -3124,7 +3120,7 @@ static struct scripth scripth0 __initdata = { | |||
3124 | 3120 | ||
3125 | }/*-------------------------< SEND_SDTR >-------------*/,{ | 3121 | }/*-------------------------< SEND_SDTR >-------------*/,{ |
3126 | /* | 3122 | /* |
3127 | ** Send the M_X_SYNC_REQ | 3123 | ** Send the EXTENDED_SDTR |
3128 | */ | 3124 | */ |
3129 | SCR_MOVE_ABS (5) ^ SCR_MSG_OUT, | 3125 | SCR_MOVE_ABS (5) ^ SCR_MSG_OUT, |
3130 | NADDR (msgout), | 3126 | NADDR (msgout), |
@@ -3202,10 +3198,10 @@ static struct scripth scripth0 __initdata = { | |||
3202 | 3198 | ||
3203 | }/*-------------------------< RESET >----------------------*/,{ | 3199 | }/*-------------------------< RESET >----------------------*/,{ |
3204 | /* | 3200 | /* |
3205 | ** Send a M_RESET message if bad IDENTIFY | 3201 | ** Send a TARGET_RESET message if bad IDENTIFY |
3206 | ** received on reselection. | 3202 | ** received on reselection. |
3207 | */ | 3203 | */ |
3208 | SCR_LOAD_REG (scratcha, M_ABORT_TAG), | 3204 | SCR_LOAD_REG (scratcha, ABORT_TASK), |
3209 | 0, | 3205 | 0, |
3210 | SCR_JUMP, | 3206 | SCR_JUMP, |
3211 | PADDRH (abort_resel), | 3207 | PADDRH (abort_resel), |
@@ -3213,7 +3209,7 @@ static struct scripth scripth0 __initdata = { | |||
3213 | /* | 3209 | /* |
3214 | ** Abort a wrong tag received on reselection. | 3210 | ** Abort a wrong tag received on reselection. |
3215 | */ | 3211 | */ |
3216 | SCR_LOAD_REG (scratcha, M_ABORT_TAG), | 3212 | SCR_LOAD_REG (scratcha, ABORT_TASK), |
3217 | 0, | 3213 | 0, |
3218 | SCR_JUMP, | 3214 | SCR_JUMP, |
3219 | PADDRH (abort_resel), | 3215 | PADDRH (abort_resel), |
@@ -3221,7 +3217,7 @@ static struct scripth scripth0 __initdata = { | |||
3221 | /* | 3217 | /* |
3222 | ** Abort a reselection when no active CCB. | 3218 | ** Abort a reselection when no active CCB. |
3223 | */ | 3219 | */ |
3224 | SCR_LOAD_REG (scratcha, M_ABORT), | 3220 | SCR_LOAD_REG (scratcha, ABORT_TASK_SET), |
3225 | 0, | 3221 | 0, |
3226 | }/*-------------------------< ABORT_RESEL >----------------*/,{ | 3222 | }/*-------------------------< ABORT_RESEL >----------------*/,{ |
3227 | SCR_COPY (1), | 3223 | SCR_COPY (1), |
@@ -3333,7 +3329,7 @@ static struct scripth scripth0 __initdata = { | |||
3333 | ** Read the message, since we got it directly | 3329 | ** Read the message, since we got it directly |
3334 | ** from the SCSI BUS data lines. | 3330 | ** from the SCSI BUS data lines. |
3335 | ** Signal problem to C code for logging the event. | 3331 | ** Signal problem to C code for logging the event. |
3336 | ** Send a M_ABORT to clear all pending tasks. | 3332 | ** Send an ABORT_TASK_SET to clear all pending tasks. |
3337 | */ | 3333 | */ |
3338 | SCR_INT, | 3334 | SCR_INT, |
3339 | SIR_RESEL_BAD_LUN, | 3335 | SIR_RESEL_BAD_LUN, |
@@ -3345,7 +3341,7 @@ static struct scripth scripth0 __initdata = { | |||
3345 | /* | 3341 | /* |
3346 | ** We donnot have a task for that I_T_L. | 3342 | ** We donnot have a task for that I_T_L. |
3347 | ** Signal problem to C code for logging the event. | 3343 | ** Signal problem to C code for logging the event. |
3348 | ** Send a M_ABORT message. | 3344 | ** Send an ABORT_TASK_SET message. |
3349 | */ | 3345 | */ |
3350 | SCR_INT, | 3346 | SCR_INT, |
3351 | SIR_RESEL_BAD_I_T_L, | 3347 | SIR_RESEL_BAD_I_T_L, |
@@ -3355,7 +3351,7 @@ static struct scripth scripth0 __initdata = { | |||
3355 | /* | 3351 | /* |
3356 | ** We donnot have a task that matches the tag. | 3352 | ** We donnot have a task that matches the tag. |
3357 | ** Signal problem to C code for logging the event. | 3353 | ** Signal problem to C code for logging the event. |
3358 | ** Send a M_ABORTTAG message. | 3354 | ** Send an ABORT_TASK message. |
3359 | */ | 3355 | */ |
3360 | SCR_INT, | 3356 | SCR_INT, |
3361 | SIR_RESEL_BAD_I_T_L_Q, | 3357 | SIR_RESEL_BAD_I_T_L_Q, |
@@ -3366,7 +3362,7 @@ static struct scripth scripth0 __initdata = { | |||
3366 | ** We donnot know the target that reselected us. | 3362 | ** We donnot know the target that reselected us. |
3367 | ** Grab the first message if any (IDENTIFY). | 3363 | ** Grab the first message if any (IDENTIFY). |
3368 | ** Signal problem to C code for logging the event. | 3364 | ** Signal problem to C code for logging the event. |
3369 | ** M_RESET message. | 3365 | ** TARGET_RESET message. |
3370 | */ | 3366 | */ |
3371 | SCR_INT, | 3367 | SCR_INT, |
3372 | SIR_RESEL_BAD_TARGET, | 3368 | SIR_RESEL_BAD_TARGET, |
@@ -4109,17 +4105,11 @@ static int ncr_prepare_nego(struct ncb *np, struct ccb *cp, u_char *msgptr) | |||
4109 | 4105 | ||
4110 | switch (nego) { | 4106 | switch (nego) { |
4111 | case NS_SYNC: | 4107 | case NS_SYNC: |
4112 | msgptr[msglen++] = M_EXTENDED; | 4108 | msglen += spi_populate_sync_msg(msgptr + msglen, |
4113 | msgptr[msglen++] = 3; | 4109 | tp->maxoffs ? tp->minsync : 0, tp->maxoffs); |
4114 | msgptr[msglen++] = M_X_SYNC_REQ; | ||
4115 | msgptr[msglen++] = tp->maxoffs ? tp->minsync : 0; | ||
4116 | msgptr[msglen++] = tp->maxoffs; | ||
4117 | break; | 4110 | break; |
4118 | case NS_WIDE: | 4111 | case NS_WIDE: |
4119 | msgptr[msglen++] = M_EXTENDED; | 4112 | msglen += spi_populate_width_msg(msgptr + msglen, tp->usrwide); |
4120 | msgptr[msglen++] = 2; | ||
4121 | msgptr[msglen++] = M_X_WIDE_REQ; | ||
4122 | msgptr[msglen++] = tp->usrwide; | ||
4123 | break; | 4113 | break; |
4124 | } | 4114 | } |
4125 | 4115 | ||
@@ -4220,7 +4210,7 @@ static int ncr_queue_command (struct ncb *np, struct scsi_cmnd *cmd) | |||
4220 | **---------------------------------------------------- | 4210 | **---------------------------------------------------- |
4221 | */ | 4211 | */ |
4222 | 4212 | ||
4223 | idmsg = M_IDENTIFY | sdev->lun; | 4213 | idmsg = IDENTIFY(0, sdev->lun); |
4224 | 4214 | ||
4225 | if (cp ->tag != NO_TAG || | 4215 | if (cp ->tag != NO_TAG || |
4226 | (cp != np->ccb && np->disc && !(tp->usrflag & UF_NODISC))) | 4216 | (cp != np->ccb && np->disc && !(tp->usrflag & UF_NODISC))) |
@@ -4239,7 +4229,7 @@ static int ncr_queue_command (struct ncb *np, struct scsi_cmnd *cmd) | |||
4239 | */ | 4229 | */ |
4240 | if (lp && time_after(jiffies, lp->tags_stime)) { | 4230 | if (lp && time_after(jiffies, lp->tags_stime)) { |
4241 | if (lp->tags_smap) { | 4231 | if (lp->tags_smap) { |
4242 | order = M_ORDERED_TAG; | 4232 | order = ORDERED_QUEUE_TAG; |
4243 | if ((DEBUG_FLAGS & DEBUG_TAGS)||bootverbose>2){ | 4233 | if ((DEBUG_FLAGS & DEBUG_TAGS)||bootverbose>2){ |
4244 | PRINT_ADDR(cmd, | 4234 | PRINT_ADDR(cmd, |
4245 | "ordered tag forced.\n"); | 4235 | "ordered tag forced.\n"); |
@@ -4257,10 +4247,10 @@ static int ncr_queue_command (struct ncb *np, struct scsi_cmnd *cmd) | |||
4257 | case 0x08: /* READ_SMALL (6) */ | 4247 | case 0x08: /* READ_SMALL (6) */ |
4258 | case 0x28: /* READ_BIG (10) */ | 4248 | case 0x28: /* READ_BIG (10) */ |
4259 | case 0xa8: /* READ_HUGE (12) */ | 4249 | case 0xa8: /* READ_HUGE (12) */ |
4260 | order = M_SIMPLE_TAG; | 4250 | order = SIMPLE_QUEUE_TAG; |
4261 | break; | 4251 | break; |
4262 | default: | 4252 | default: |
4263 | order = M_ORDERED_TAG; | 4253 | order = ORDERED_QUEUE_TAG; |
4264 | } | 4254 | } |
4265 | } | 4255 | } |
4266 | msgptr[msglen++] = order; | 4256 | msgptr[msglen++] = order; |
@@ -6229,9 +6219,9 @@ static int ncr_int_par (struct ncb *np) | |||
6229 | if (!(dbc & 0xc0000000)) | 6219 | if (!(dbc & 0xc0000000)) |
6230 | phase = (dbc >> 24) & 7; | 6220 | phase = (dbc >> 24) & 7; |
6231 | if (phase == 7) | 6221 | if (phase == 7) |
6232 | msg = M_PARITY; | 6222 | msg = MSG_PARITY_ERROR; |
6233 | else | 6223 | else |
6234 | msg = M_ID_ERROR; | 6224 | msg = INITIATOR_ERROR; |
6235 | 6225 | ||
6236 | 6226 | ||
6237 | /* | 6227 | /* |
@@ -6795,6 +6785,8 @@ void ncr_int_sir (struct ncb *np) | |||
6795 | /*----------------------------------------------------------------------------- | 6785 | /*----------------------------------------------------------------------------- |
6796 | ** | 6786 | ** |
6797 | ** Was Sie schon immer ueber transfermode negotiation wissen wollten ... | 6787 | ** Was Sie schon immer ueber transfermode negotiation wissen wollten ... |
6788 | ** ("Everything you've always wanted to know about transfer mode | ||
6789 | ** negotiation") | ||
6798 | ** | 6790 | ** |
6799 | ** We try to negotiate sync and wide transfer only after | 6791 | ** We try to negotiate sync and wide transfer only after |
6800 | ** a successful inquire command. We look at byte 7 of the | 6792 | ** a successful inquire command. We look at byte 7 of the |
@@ -6896,8 +6888,8 @@ void ncr_int_sir (struct ncb *np) | |||
6896 | break; | 6888 | break; |
6897 | 6889 | ||
6898 | } | 6890 | } |
6899 | np->msgin [0] = M_NOOP; | 6891 | np->msgin [0] = NOP; |
6900 | np->msgout[0] = M_NOOP; | 6892 | np->msgout[0] = NOP; |
6901 | cp->nego_status = 0; | 6893 | cp->nego_status = 0; |
6902 | break; | 6894 | break; |
6903 | 6895 | ||
@@ -6991,12 +6983,7 @@ void ncr_int_sir (struct ncb *np) | |||
6991 | spi_offset(starget) = ofs; | 6983 | spi_offset(starget) = ofs; |
6992 | ncr_setsync(np, cp, scntl3, (fak<<5)|ofs); | 6984 | ncr_setsync(np, cp, scntl3, (fak<<5)|ofs); |
6993 | 6985 | ||
6994 | np->msgout[0] = M_EXTENDED; | 6986 | spi_populate_sync_msg(np->msgout, per, ofs); |
6995 | np->msgout[1] = 3; | ||
6996 | np->msgout[2] = M_X_SYNC_REQ; | ||
6997 | np->msgout[3] = per; | ||
6998 | np->msgout[4] = ofs; | ||
6999 | |||
7000 | cp->nego_status = NS_SYNC; | 6987 | cp->nego_status = NS_SYNC; |
7001 | 6988 | ||
7002 | if (DEBUG_FLAGS & DEBUG_NEGO) { | 6989 | if (DEBUG_FLAGS & DEBUG_NEGO) { |
@@ -7007,7 +6994,7 @@ void ncr_int_sir (struct ncb *np) | |||
7007 | OUTL_DSP (NCB_SCRIPT_PHYS (np, msg_bad)); | 6994 | OUTL_DSP (NCB_SCRIPT_PHYS (np, msg_bad)); |
7008 | return; | 6995 | return; |
7009 | } | 6996 | } |
7010 | np->msgin [0] = M_NOOP; | 6997 | np->msgin [0] = NOP; |
7011 | 6998 | ||
7012 | break; | 6999 | break; |
7013 | 7000 | ||
@@ -7082,13 +7069,9 @@ void ncr_int_sir (struct ncb *np) | |||
7082 | 7069 | ||
7083 | spi_width(starget) = wide; | 7070 | spi_width(starget) = wide; |
7084 | ncr_setwide(np, cp, wide, 1); | 7071 | ncr_setwide(np, cp, wide, 1); |
7072 | spi_populate_width_msg(np->msgout, wide); | ||
7085 | 7073 | ||
7086 | np->msgout[0] = M_EXTENDED; | 7074 | np->msgin [0] = NOP; |
7087 | np->msgout[1] = 2; | ||
7088 | np->msgout[2] = M_X_WIDE_REQ; | ||
7089 | np->msgout[3] = wide; | ||
7090 | |||
7091 | np->msgin [0] = M_NOOP; | ||
7092 | 7075 | ||
7093 | cp->nego_status = NS_WIDE; | 7076 | cp->nego_status = NS_WIDE; |
7094 | 7077 | ||
@@ -7107,12 +7090,12 @@ void ncr_int_sir (struct ncb *np) | |||
7107 | case SIR_REJECT_RECEIVED: | 7090 | case SIR_REJECT_RECEIVED: |
7108 | /*----------------------------------------------- | 7091 | /*----------------------------------------------- |
7109 | ** | 7092 | ** |
7110 | ** We received a M_REJECT message. | 7093 | ** We received a MESSAGE_REJECT. |
7111 | ** | 7094 | ** |
7112 | **----------------------------------------------- | 7095 | **----------------------------------------------- |
7113 | */ | 7096 | */ |
7114 | 7097 | ||
7115 | PRINT_ADDR(cp->cmd, "M_REJECT received (%x:%x).\n", | 7098 | PRINT_ADDR(cp->cmd, "MESSAGE_REJECT received (%x:%x).\n", |
7116 | (unsigned)scr_to_cpu(np->lastmsg), np->msgout[0]); | 7099 | (unsigned)scr_to_cpu(np->lastmsg), np->msgout[0]); |
7117 | break; | 7100 | break; |
7118 | 7101 | ||
@@ -7124,7 +7107,7 @@ void ncr_int_sir (struct ncb *np) | |||
7124 | **----------------------------------------------- | 7107 | **----------------------------------------------- |
7125 | */ | 7108 | */ |
7126 | 7109 | ||
7127 | ncr_print_msg(cp, "M_REJECT sent for", np->msgin); | 7110 | ncr_print_msg(cp, "MESSAGE_REJECT sent for", np->msgin); |
7128 | break; | 7111 | break; |
7129 | 7112 | ||
7130 | /*-------------------------------------------------------------------- | 7113 | /*-------------------------------------------------------------------- |
@@ -7143,7 +7126,7 @@ void ncr_int_sir (struct ncb *np) | |||
7143 | **----------------------------------------------- | 7126 | **----------------------------------------------- |
7144 | */ | 7127 | */ |
7145 | 7128 | ||
7146 | PRINT_ADDR(cp->cmd, "M_IGN_RESIDUE received, but not yet " | 7129 | PRINT_ADDR(cp->cmd, "IGNORE_WIDE_RESIDUE received, but not yet " |
7147 | "implemented.\n"); | 7130 | "implemented.\n"); |
7148 | break; | 7131 | break; |
7149 | #if 0 | 7132 | #if 0 |
@@ -7156,7 +7139,7 @@ void ncr_int_sir (struct ncb *np) | |||
7156 | **----------------------------------------------- | 7139 | **----------------------------------------------- |
7157 | */ | 7140 | */ |
7158 | 7141 | ||
7159 | PRINT_ADDR(cp->cmd, "M_DISCONNECT received, but datapointer " | 7142 | PRINT_ADDR(cp->cmd, "DISCONNECT received, but datapointer " |
7160 | "not saved: data=%x save=%x goal=%x.\n", | 7143 | "not saved: data=%x save=%x goal=%x.\n", |
7161 | (unsigned) INL (nc_temp), | 7144 | (unsigned) INL (nc_temp), |
7162 | (unsigned) scr_to_cpu(np->header.savep), | 7145 | (unsigned) scr_to_cpu(np->header.savep), |
@@ -7862,7 +7845,7 @@ static int __init ncr_snooptest (struct ncb* np) | |||
7862 | **========================================================== | 7845 | **========================================================== |
7863 | ** | 7846 | ** |
7864 | ** Note: we have to return the correct value. | 7847 | ** Note: we have to return the correct value. |
7865 | ** THERE IS NO SAVE DEFAULT VALUE. | 7848 | ** THERE IS NO SAFE DEFAULT VALUE. |
7866 | ** | 7849 | ** |
7867 | ** Most NCR/SYMBIOS boards are delivered with a 40 Mhz clock. | 7850 | ** Most NCR/SYMBIOS boards are delivered with a 40 Mhz clock. |
7868 | ** 53C860 and 53C875 rev. 1 support fast20 transfers but | 7851 | ** 53C860 and 53C875 rev. 1 support fast20 transfers but |
@@ -8562,7 +8545,7 @@ struct Scsi_Host * __init ncr_attach(struct scsi_host_template *tpnt, | |||
8562 | 8545 | ||
8563 | /* use SIMPLE TAG messages by default */ | 8546 | /* use SIMPLE TAG messages by default */ |
8564 | #ifdef SCSI_NCR_ALWAYS_SIMPLE_TAG | 8547 | #ifdef SCSI_NCR_ALWAYS_SIMPLE_TAG |
8565 | np->order = M_SIMPLE_TAG; | 8548 | np->order = SIMPLE_QUEUE_TAG; |
8566 | #endif | 8549 | #endif |
8567 | 8550 | ||
8568 | spin_unlock_irqrestore(&np->smp_lock, flags); | 8551 | spin_unlock_irqrestore(&np->smp_lock, flags); |