Commit 9e181b63 authored by Jamie Lenehan's avatar Jamie Lenehan Committed by James Bottomley

[PATCH] dc395x [3/5] - remove old debugging stuff

Remove the special versions of kmalloc and kfree and remove the trace
related stuff from the code. None of this is really needed and it is
not really a nice implementation. This also removes all non 7-bit
clean characters to help with David Eger's work to remove and/or
convert them all to UTF8.
parent b056db71
...@@ -87,16 +87,13 @@ ...@@ -87,16 +87,13 @@
#define DBG_SGPARANOIA 0x0020 #define DBG_SGPARANOIA 0x0020
#define DBG_FIFO 0x0040 #define DBG_FIFO 0x0040
#define DBG_PIO 0x0080 #define DBG_PIO 0x0080
#define DBG_MALLOC 0x0200 /* report on memory allocations */
#define DBG_TRACE 0x0400
#define DBG_TRACEALL 0x0800
/* /*
* Set set of things to output debugging for. * Set set of things to output debugging for.
* Undefine to remove all debugging * Undefine to remove all debugging
*/ */
/*#define DEBUG_MASK (DBG_0|DBG_1|DBG_DCB|DBG_PARSE|DBG_SGPARANOIA|DBG_FIFO|DBG_PIO|DBG_TRACE|DBG_TRACEALL)*/ /*#define DEBUG_MASK (DBG_0|DBG_1|DBG_DCB|DBG_PARSE|DBG_SGPARANOIA|DBG_FIFO|DBG_PIO)*/
/*#define DEBUG_MASK DBG_0*/ /*#define DEBUG_MASK DBG_0*/
...@@ -137,61 +134,6 @@ ...@@ -137,61 +134,6 @@
#endif #endif
/*
* Memory allocation debugging
* Just reports when memory is allocated and/or released.
*/
#if debug_enabled(DBG_MALLOC)
inline void *dc395x_kmalloc(size_t sz, int fl)
{
void *ptr = kmalloc(sz, fl);
dprintkl(KERN_DEBUG, "Alloc %i bytes @ %p w/ fl %08x\n", sz, ptr, fl);
return ptr;
}
inline void dc395x_kfree(const void *adr)
{
dprintkl(KERN_DEBUG, "Free mem @ %p\n", adr);
kfree(adr);
}
#else
#define dc395x_kmalloc(sz, fl) kmalloc(sz, fl)
#define dc395x_kfree(adr) kfree(adr)
#endif
/*
* Debug/trace stuff
*/
#if debug_enabled(DBG_TRACEALL)
# define TRACEOUTALL(x...) printk ( x)
#else
# define TRACEOUTALL(x...) do {} while (0)
#endif
#if debug_enabled(DBG_TRACE|DBG_TRACEALL)
# define DEBUGTRACEBUFSZ 512
static char tracebuf[64];
# define TRACEPRINTF(x...) \
do { \
int ln = sprintf(tracebuf, x); \
if (srb->debugpos + ln >= DEBUGTRACEBUFSZ) { \
srb->debugtrace[srb->debugpos] = 0; \
srb->debugpos = DEBUGTRACEBUFSZ/5; \
srb->debugtrace[srb->debugpos++] = '>'; \
} \
sprintf(srb->debugtrace + srb->debugpos, "%s", tracebuf); \
srb->debugpos += ln - 1; \
} while (0)
# define TRACEOUT(x...) printk (x)
#else
# define TRACEPRINTF(x...) do {} while (0)
# define TRACEOUT(x...) do {} while (0)
#endif
/*---------------------------------------------------------------------------
---------------------------------------------------------------------------*/
#ifndef PCI_VENDOR_ID_TEKRAM #ifndef PCI_VENDOR_ID_TEKRAM
#define PCI_VENDOR_ID_TEKRAM 0x1DE1 /* Vendor ID */ #define PCI_VENDOR_ID_TEKRAM 0x1DE1 /* Vendor ID */
#endif #endif
...@@ -315,11 +257,6 @@ struct ScsiReqBlk { ...@@ -315,11 +257,6 @@ struct ScsiReqBlk {
u8 flag; u8 flag;
u8 scsi_phase; u8 scsi_phase;
#if debug_enabled(DBG_TRACE|DBG_TRACEALL)
u16 debugpos;
char *debugtrace;
#endif
}; };
struct DeviceCtlBlk { struct DeviceCtlBlk {
...@@ -899,7 +836,6 @@ static void srb_waiting_to_going_move(struct DeviceCtlBlk *dcb, ...@@ -899,7 +836,6 @@ static void srb_waiting_to_going_move(struct DeviceCtlBlk *dcb,
struct ScsiReqBlk *srb) struct ScsiReqBlk *srb)
{ {
dprintkdbg(DBG_0, "srb_waiting_to_going_move: srb %p\n", srb); dprintkdbg(DBG_0, "srb_waiting_to_going_move: srb %p\n", srb);
TRACEPRINTF("WtG *");
list_move(&srb->list, &dcb->srb_going_list); list_move(&srb->list, &dcb->srb_going_list);
} }
...@@ -1119,10 +1055,6 @@ static void build_srb(Scsi_Cmnd *cmd, struct DeviceCtlBlk *dcb, ...@@ -1119,10 +1055,6 @@ static void build_srb(Scsi_Cmnd *cmd, struct DeviceCtlBlk *dcb,
srb->total_xfer_length, cmd->request_buffer, srb->total_xfer_length, cmd->request_buffer,
cmd->use_sg, srb->segment_x[0].address); cmd->use_sg, srb->segment_x[0].address);
} }
#if debug_enabled(DBG_TRACE|DBG_TRACEALL)
srb->debugpos = 0;
srb->debugtrace = 0;
#endif
} }
...@@ -1284,7 +1216,6 @@ static void dump_register_info(struct AdapterCtlBlk *acb, ...@@ -1284,7 +1216,6 @@ static void dump_register_info(struct AdapterCtlBlk *acb,
(" State %04x Status %02x Phase %02x (%sconn.)\n", (" State %04x Status %02x Phase %02x (%sconn.)\n",
srb->state, srb->status, srb->scsi_phase, srb->state, srb->status, srb->scsi_phase,
(acb->active_dcb) ? "" : "not"); (acb->active_dcb) ? "" : "not");
TRACEOUT(" %s\n", srb->debugtrace);
} }
dprintkl(KERN_INFO, "dump: SCSI block\n"); dprintkl(KERN_INFO, "dump: SCSI block\n");
printk printk
...@@ -1337,12 +1268,6 @@ static inline void clear_fifo(struct AdapterCtlBlk *acb, char *txt) ...@@ -1337,12 +1268,6 @@ static inline void clear_fifo(struct AdapterCtlBlk *acb, char *txt)
dprintkdbg(DBG_FIFO, dprintkdbg(DBG_FIFO,
"Clr FIFO (%i bytes) on phase %02x in %s\n", "Clr FIFO (%i bytes) on phase %02x in %s\n",
fifocnt & 0x3f, lines, txt); fifocnt & 0x3f, lines, txt);
#endif
#if debug_enabled(DBG_TRACE)
if (acb->active_dcb && acb->active_dcb->active_srb) {
struct ScsiReqBlk *srb = acb->active_dcb->active_srb;
TRACEPRINTF("#*");
}
#endif #endif
DC395x_write16(acb, TRM_S1040_SCSI_CONTROL, DO_CLRFIFO); DC395x_write16(acb, TRM_S1040_SCSI_CONTROL, DO_CLRFIFO);
} }
...@@ -1497,7 +1422,6 @@ static void build_sdtr(struct AdapterCtlBlk *acb, struct DeviceCtlBlk *dcb, ...@@ -1497,7 +1422,6 @@ static void build_sdtr(struct AdapterCtlBlk *acb, struct DeviceCtlBlk *dcb,
*ptr++ = dcb->sync_offset; /* Transfer period (max. REQ/ACK dist) */ *ptr++ = dcb->sync_offset; /* Transfer period (max. REQ/ACK dist) */
srb->msg_count += 5; srb->msg_count += 5;
srb->state |= SRB_DO_SYNC_NEGO; srb->state |= SRB_DO_SYNC_NEGO;
TRACEPRINTF("S *");
} }
...@@ -1521,7 +1445,6 @@ static void build_wdtr(struct AdapterCtlBlk *acb, struct DeviceCtlBlk *dcb, ...@@ -1521,7 +1445,6 @@ static void build_wdtr(struct AdapterCtlBlk *acb, struct DeviceCtlBlk *dcb,
*ptr++ = wide; *ptr++ = wide;
srb->msg_count += 4; srb->msg_count += 4;
srb->state |= SRB_DO_WIDE_NEGO; srb->state |= SRB_DO_WIDE_NEGO;
TRACEPRINTF("W *");
} }
...@@ -1558,7 +1481,6 @@ void selection_timeout_missed(unsigned long ptr) ...@@ -1558,7 +1481,6 @@ void selection_timeout_missed(unsigned long ptr)
} }
DC395x_LOCK_IO(acb->scsi_host, flags); DC395x_LOCK_IO(acb->scsi_host, flags);
srb = acb->active_dcb->active_srb; srb = acb->active_dcb->active_srb;
TRACEPRINTF("N/TO *");
disconnect(acb); disconnect(acb);
DC395x_UNLOCK_IO(acb->scsi_host, flags); DC395x_UNLOCK_IO(acb->scsi_host, flags);
} }
...@@ -1578,7 +1500,6 @@ static u8 start_scsi(struct AdapterCtlBlk * acb, struct DeviceCtlBlk * dcb, ...@@ -1578,7 +1500,6 @@ static u8 start_scsi(struct AdapterCtlBlk * acb, struct DeviceCtlBlk * dcb,
s_stat = DC395x_read8(acb, TRM_S1040_SCSI_SIGNAL); s_stat = DC395x_read8(acb, TRM_S1040_SCSI_SIGNAL);
s_stat2 = 0; s_stat2 = 0;
s_stat2 = DC395x_read16(acb, TRM_S1040_SCSI_STATUS); s_stat2 = DC395x_read16(acb, TRM_S1040_SCSI_STATUS);
TRACEPRINTF("Start %02x *", s_stat);
#if 1 #if 1
if (s_stat & 0x20 /* s_stat2 & 0x02000 */ ) { if (s_stat & 0x20 /* s_stat2 & 0x02000 */ ) {
dprintkdbg(DBG_KG, dprintkdbg(DBG_KG,
...@@ -1595,7 +1516,6 @@ static u8 start_scsi(struct AdapterCtlBlk * acb, struct DeviceCtlBlk * dcb, ...@@ -1595,7 +1516,6 @@ static u8 start_scsi(struct AdapterCtlBlk * acb, struct DeviceCtlBlk * dcb,
* Instead let this fail and have the timer make sure the command is * Instead let this fail and have the timer make sure the command is
* tried again after a short time * tried again after a short time
*/ */
TRACEPRINTF("^*");
/*selto_timer (acb); */ /*selto_timer (acb); */
/*monitor_next_irq = 1; */ /*monitor_next_irq = 1; */
return 1; return 1;
...@@ -1607,17 +1527,12 @@ static u8 start_scsi(struct AdapterCtlBlk * acb, struct DeviceCtlBlk * dcb, ...@@ -1607,17 +1527,12 @@ static u8 start_scsi(struct AdapterCtlBlk * acb, struct DeviceCtlBlk * dcb,
dprintkl(KERN_DEBUG, "While another one (%li) is active!!\n", dprintkl(KERN_DEBUG, "While another one (%li) is active!!\n",
(acb->active_dcb->active_srb ? acb->active_dcb-> (acb->active_dcb->active_srb ? acb->active_dcb->
active_srb->cmd->pid : 0)); active_srb->cmd->pid : 0));
TRACEOUT(" %s\n", srb->debugtrace);
if (acb->active_dcb->active_srb)
TRACEOUT(" %s\n",
acb->active_dcb->active_srb->debugtrace);
return 1; return 1;
} }
if (DC395x_read16(acb, TRM_S1040_SCSI_STATUS) & SCSIINTERRUPT) { if (DC395x_read16(acb, TRM_S1040_SCSI_STATUS) & SCSIINTERRUPT) {
dprintkdbg(DBG_KG, dprintkdbg(DBG_KG,
"StartSCSI failed (busy) for pid %li(%02i-%i)\n", "StartSCSI failed (busy) for pid %li(%02i-%i)\n",
srb->cmd->pid, dcb->target_id, dcb->target_lun); srb->cmd->pid, dcb->target_id, dcb->target_lun);
TRACEPRINTF("*");
return 1; return 1;
} }
/* Allow starting of SCSI commands half a second before we allow the mid-level /* Allow starting of SCSI commands half a second before we allow the mid-level
...@@ -1704,8 +1619,6 @@ static u8 start_scsi(struct AdapterCtlBlk * acb, struct DeviceCtlBlk * dcb, ...@@ -1704,8 +1619,6 @@ static u8 start_scsi(struct AdapterCtlBlk * acb, struct DeviceCtlBlk * dcb,
DC395x_write8(acb, TRM_S1040_SCSI_FIFO, tag_number); DC395x_write8(acb, TRM_S1040_SCSI_FIFO, tag_number);
dcb->tag_mask |= tag_mask; dcb->tag_mask |= tag_mask;
srb->tag_number = tag_number; srb->tag_number = tag_number;
TRACEPRINTF("Tag %i *", tag_number);
scsicommand = SCMD_SEL_ATN3; scsicommand = SCMD_SEL_ATN3;
srb->state = SRB_START_; srb->state = SRB_START_;
} }
...@@ -1761,7 +1674,6 @@ static u8 start_scsi(struct AdapterCtlBlk * acb, struct DeviceCtlBlk * dcb, ...@@ -1761,7 +1674,6 @@ static u8 start_scsi(struct AdapterCtlBlk * acb, struct DeviceCtlBlk * dcb,
DC395x_write16(acb, TRM_S1040_SCSI_CONTROL, DC395x_write16(acb, TRM_S1040_SCSI_CONTROL,
DO_DATALATCH | DO_HWRESELECT); DO_DATALATCH | DO_HWRESELECT);
/* SCSI command */ /* SCSI command */
TRACEPRINTF("%02x *", scsicommand);
DC395x_write8(acb, TRM_S1040_SCSI_COMMAND, scsicommand); DC395x_write8(acb, TRM_S1040_SCSI_COMMAND, scsicommand);
} }
return return_code; return return_code;
...@@ -1938,7 +1850,6 @@ static void msgout_phase0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb, ...@@ -1938,7 +1850,6 @@ static void msgout_phase0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb,
DC395x_write16(acb, TRM_S1040_SCSI_CONTROL, DO_DATALATCH); /* it's important for atn stop */ DC395x_write16(acb, TRM_S1040_SCSI_CONTROL, DO_DATALATCH); /* it's important for atn stop */
srb->state &= ~SRB_MSGOUT; srb->state &= ~SRB_MSGOUT;
TRACEPRINTF("MOP0 *");
} }
...@@ -1949,7 +1860,6 @@ static void msgout_phase1(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb, ...@@ -1949,7 +1860,6 @@ static void msgout_phase1(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb,
u8 *ptr; u8 *ptr;
dprintkdbg(DBG_0, "msgout_phase1 (#%li)\n", srb->cmd->pid); dprintkdbg(DBG_0, "msgout_phase1 (#%li)\n", srb->cmd->pid);
TRACEPRINTF("MOP1*");
clear_fifo(acb, "MOP1"); clear_fifo(acb, "MOP1");
if (!(srb->state & SRB_MSGOUT)) { if (!(srb->state & SRB_MSGOUT)) {
srb->state |= SRB_MSGOUT; srb->state |= SRB_MSGOUT;
...@@ -1961,17 +1871,11 @@ static void msgout_phase1(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb, ...@@ -1961,17 +1871,11 @@ static void msgout_phase1(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb,
DC395x_write8(acb, TRM_S1040_SCSI_FIFO, MSG_NOP); DC395x_write8(acb, TRM_S1040_SCSI_FIFO, MSG_NOP);
DC395x_write16(acb, TRM_S1040_SCSI_CONTROL, DO_DATALATCH); /* it's important for atn stop */ DC395x_write16(acb, TRM_S1040_SCSI_CONTROL, DO_DATALATCH); /* it's important for atn stop */
DC395x_write8(acb, TRM_S1040_SCSI_COMMAND, SCMD_FIFO_OUT); DC395x_write8(acb, TRM_S1040_SCSI_COMMAND, SCMD_FIFO_OUT);
TRACEPRINTF("\\*");
TRACEOUT(" %s\n", srb->debugtrace);
return; return;
} }
ptr = (u8 *)srb->msgout_buf; ptr = (u8 *)srb->msgout_buf;
TRACEPRINTF("(*"); for (i = 0; i < srb->msg_count; i++)
for (i = 0; i < srb->msg_count; i++) {
TRACEPRINTF("%02x *", *ptr);
DC395x_write8(acb, TRM_S1040_SCSI_FIFO, *ptr++); DC395x_write8(acb, TRM_S1040_SCSI_FIFO, *ptr++);
}
TRACEPRINTF(")*");
srb->msg_count = 0; srb->msg_count = 0;
if (/*(dcb->flag & ABORT_DEV_) && */ if (/*(dcb->flag & ABORT_DEV_) && */
(srb->msgout_buf[0] == MSG_ABORT)) (srb->msgout_buf[0] == MSG_ABORT))
...@@ -1980,7 +1884,6 @@ static void msgout_phase1(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb, ...@@ -1980,7 +1884,6 @@ static void msgout_phase1(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb,
/*1.25 */ /*1.25 */
/*DC395x_write16 (TRM_S1040_SCSI_CONTROL, DO_DATALATCH); *//* it's important for atn stop */ /*DC395x_write16 (TRM_S1040_SCSI_CONTROL, DO_DATALATCH); *//* it's important for atn stop */
/* SCSI command */ /* SCSI command */
/*TRACEPRINTF (".*"); */
DC395x_write8(acb, TRM_S1040_SCSI_COMMAND, SCMD_FIFO_OUT); DC395x_write8(acb, TRM_S1040_SCSI_COMMAND, SCMD_FIFO_OUT);
} }
...@@ -1989,7 +1892,6 @@ static void command_phase0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb, ...@@ -1989,7 +1892,6 @@ static void command_phase0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb,
u16 *pscsi_status) u16 *pscsi_status)
{ {
dprintkdbg(DBG_0, "command_phase0 (#%li)\n", srb->cmd->pid); dprintkdbg(DBG_0, "command_phase0 (#%li)\n", srb->cmd->pid);
TRACEPRINTF("COP0 *");
/*1.25 */ /*1.25 */
/*clear_fifo(acb, COP0); */ /*clear_fifo(acb, COP0); */
DC395x_write16(acb, TRM_S1040_SCSI_CONTROL, DO_DATALATCH); DC395x_write16(acb, TRM_S1040_SCSI_CONTROL, DO_DATALATCH);
...@@ -2004,7 +1906,6 @@ static void command_phase1(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb, ...@@ -2004,7 +1906,6 @@ static void command_phase1(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb,
u16 i; u16 i;
dprintkdbg(DBG_0, "command_phase1 (#%li)\n", srb->cmd->pid); dprintkdbg(DBG_0, "command_phase1 (#%li)\n", srb->cmd->pid);
TRACEPRINTF("COP1*");
clear_fifo(acb, "COP1"); clear_fifo(acb, "COP1");
DC395x_write16(acb, TRM_S1040_SCSI_CONTROL, DO_CLRATN); DC395x_write16(acb, TRM_S1040_SCSI_CONTROL, DO_CLRATN);
if (!(srb->flag & AUTO_REQSENSE)) { if (!(srb->flag & AUTO_REQSENSE)) {
...@@ -2028,7 +1929,6 @@ static void command_phase1(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb, ...@@ -2028,7 +1929,6 @@ static void command_phase1(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb,
/* it's important for atn stop */ /* it's important for atn stop */
DC395x_write16(acb, TRM_S1040_SCSI_CONTROL, DO_DATALATCH); DC395x_write16(acb, TRM_S1040_SCSI_CONTROL, DO_DATALATCH);
/* SCSI command */ /* SCSI command */
TRACEPRINTF(".*");
DC395x_write8(acb, TRM_S1040_SCSI_COMMAND, SCMD_FIFO_OUT); DC395x_write8(acb, TRM_S1040_SCSI_COMMAND, SCMD_FIFO_OUT);
} }
...@@ -2152,7 +2052,6 @@ static void sg_subtract_one(struct ScsiReqBlk *srb) ...@@ -2152,7 +2052,6 @@ static void sg_subtract_one(struct ScsiReqBlk *srb)
static void cleanup_after_transfer(struct AdapterCtlBlk *acb, static void cleanup_after_transfer(struct AdapterCtlBlk *acb,
struct ScsiReqBlk *srb) struct ScsiReqBlk *srb)
{ {
TRACEPRINTF(" Cln*");
/*DC395x_write8 (TRM_S1040_DMA_STATUS, FORCEDMACOMP); */ /*DC395x_write8 (TRM_S1040_DMA_STATUS, FORCEDMACOMP); */
if (DC395x_read16(acb, TRM_S1040_DMA_COMMAND) & 0x0001) { /* read */ if (DC395x_read16(acb, TRM_S1040_DMA_COMMAND) & 0x0001) { /* read */
if (!(DC395x_read8(acb, TRM_S1040_SCSI_FIFOCNT) & 0x40)) if (!(DC395x_read8(acb, TRM_S1040_SCSI_FIFOCNT) & 0x40))
...@@ -2184,7 +2083,6 @@ static void data_out_phase0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb, ...@@ -2184,7 +2083,6 @@ static void data_out_phase0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb,
u32 d_left_counter = 0; u32 d_left_counter = 0;
dprintkdbg(DBG_0, "data_out_phase0 (#%li)\n", srb->cmd->pid); dprintkdbg(DBG_0, "data_out_phase0 (#%li)\n", srb->cmd->pid);
TRACEPRINTF("DOP0*");
/* /*
* KG: We need to drain the buffers before we draw any conclusions! * KG: We need to drain the buffers before we draw any conclusions!
...@@ -2260,7 +2158,6 @@ static void data_out_phase0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb, ...@@ -2260,7 +2158,6 @@ static void data_out_phase0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb,
if (srb->total_xfer_length > DC395x_LASTPIO) if (srb->total_xfer_length > DC395x_LASTPIO)
d_left_counter += d_left_counter +=
DC395x_read32(acb, TRM_S1040_SCSI_COUNTER); DC395x_read32(acb, TRM_S1040_SCSI_COUNTER);
TRACEPRINTF("%06x *", d_left_counter);
/* Is this a good idea? */ /* Is this a good idea? */
/*clear_fifo(acb, "DOP1"); */ /*clear_fifo(acb, "DOP1"); */
...@@ -2337,7 +2234,6 @@ static void data_out_phase0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb, ...@@ -2337,7 +2234,6 @@ static void data_out_phase0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb,
cleanup_after_transfer(acb, srb); cleanup_after_transfer(acb, srb);
} }
#endif #endif
TRACEPRINTF(".*");
} }
...@@ -2346,11 +2242,9 @@ static void data_out_phase1(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb, ...@@ -2346,11 +2242,9 @@ static void data_out_phase1(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb,
{ {
dprintkdbg(DBG_0, "data_out_phase1 (#%li)\n", srb->cmd->pid); dprintkdbg(DBG_0, "data_out_phase1 (#%li)\n", srb->cmd->pid);
/*1.25 */ /*1.25 */
TRACEPRINTF("DOP1*");
clear_fifo(acb, "DOP1"); clear_fifo(acb, "DOP1");
/* do prepare befor transfer when data out phase */ /* do prepare befor transfer when data out phase */
data_io_transfer(acb, srb, XFERDATAOUT); data_io_transfer(acb, srb, XFERDATAOUT);
TRACEPRINTF(".*");
} }
...@@ -2362,7 +2256,6 @@ static void data_in_phase0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb, ...@@ -2362,7 +2256,6 @@ static void data_in_phase0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb,
u32 d_left_counter = 0; u32 d_left_counter = 0;
dprintkdbg(DBG_0, "data_in_phase0 (#%li)\n", srb->cmd->pid); dprintkdbg(DBG_0, "data_in_phase0 (#%li)\n", srb->cmd->pid);
TRACEPRINTF("DIP0*");
/* /*
* KG: DataIn is much more tricky than DataOut. When the device is finished * KG: DataIn is much more tricky than DataOut. When the device is finished
...@@ -2570,7 +2463,6 @@ static void data_in_phase0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb, ...@@ -2570,7 +2463,6 @@ static void data_in_phase0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb,
/*DC395x_write8 (TRM_S1040_DMA_CONTROL, CLRXFIFO | ABORTXFER); */ /*DC395x_write8 (TRM_S1040_DMA_CONTROL, CLRXFIFO | ABORTXFER); */
/*clear_fifo(acb, "DIP0"); */ /*clear_fifo(acb, "DIP0"); */
/*DC395x_write16(TRM_S1040_SCSI_CONTROL, DO_DATALATCH); */ /*DC395x_write16(TRM_S1040_SCSI_CONTROL, DO_DATALATCH); */
TRACEPRINTF(".*");
} }
...@@ -2582,10 +2474,8 @@ static void data_in_phase1(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb, ...@@ -2582,10 +2474,8 @@ static void data_in_phase1(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb,
/*clear_fifo(acb, "DIP1"); */ /*clear_fifo(acb, "DIP1"); */
/* Allow data in! */ /* Allow data in! */
/*DC395x_write16(TRM_S1040_SCSI_CONTROL, DO_DATALATCH); */ /*DC395x_write16(TRM_S1040_SCSI_CONTROL, DO_DATALATCH); */
TRACEPRINTF("DIP1:*");
/* do prepare before transfer when data in phase */ /* do prepare before transfer when data in phase */
data_io_transfer(acb, srb, XFERDATAIN); data_io_transfer(acb, srb, XFERDATAIN);
TRACEPRINTF(".*");
} }
...@@ -2599,8 +2489,6 @@ static void data_io_transfer(struct AdapterCtlBlk *acb, ...@@ -2599,8 +2489,6 @@ static void data_io_transfer(struct AdapterCtlBlk *acb,
((io_dir & DMACMD_DIR) ? 'r' : 'w'), srb->cmd->pid, ((io_dir & DMACMD_DIR) ? 'r' : 'w'), srb->cmd->pid,
srb->total_xfer_length, srb->sg_index, srb->total_xfer_length, srb->sg_index,
srb->sg_count); srb->sg_count);
TRACEPRINTF("%05x(%i/%i)*", srb->total_xfer_length,
srb->sg_index, srb->sg_count);
if (srb == acb->tmp_srb) if (srb == acb->tmp_srb)
dprintkl(KERN_ERR, "Using tmp_srb in DataPhase!\n"); dprintkl(KERN_ERR, "Using tmp_srb in DataPhase!\n");
...@@ -2756,7 +2644,6 @@ static void status_phase0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb, ...@@ -2756,7 +2644,6 @@ static void status_phase0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb,
u16 *pscsi_status) u16 *pscsi_status)
{ {
dprintkdbg(DBG_0, "status_phase0 (#%li)\n", srb->cmd->pid); dprintkdbg(DBG_0, "status_phase0 (#%li)\n", srb->cmd->pid);
TRACEPRINTF("STP0 *");
srb->target_status = DC395x_read8(acb, TRM_S1040_SCSI_FIFO); srb->target_status = DC395x_read8(acb, TRM_S1040_SCSI_FIFO);
srb->end_message = DC395x_read8(acb, TRM_S1040_SCSI_FIFO); /* get message */ srb->end_message = DC395x_read8(acb, TRM_S1040_SCSI_FIFO); /* get message */
srb->state = SRB_COMPLETED; srb->state = SRB_COMPLETED;
...@@ -2773,8 +2660,6 @@ static void status_phase1(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb, ...@@ -2773,8 +2660,6 @@ static void status_phase1(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb,
u16 *pscsi_status) u16 *pscsi_status)
{ {
dprintkdbg(DBG_0, "status_phase1 (#%li)\n", srb->cmd->pid); dprintkdbg(DBG_0, "status_phase1 (#%li)\n", srb->cmd->pid);
TRACEPRINTF("STP1 *");
srb->state = SRB_STATUS; srb->state = SRB_STATUS;
DC395x_write16(acb, TRM_S1040_SCSI_CONTROL, DO_DATALATCH); /* it's important for atn stop */ DC395x_write16(acb, TRM_S1040_SCSI_CONTROL, DO_DATALATCH); /* it's important for atn stop */
/* SCSI command */ /* SCSI command */
...@@ -2826,7 +2711,6 @@ static inline void msgin_reject(struct AdapterCtlBlk *acb, ...@@ -2826,7 +2711,6 @@ static inline void msgin_reject(struct AdapterCtlBlk *acb,
dprintkl(KERN_INFO, dprintkl(KERN_INFO,
"Reject message %02x from %02i-%i\n", srb->msgin_buf[0], "Reject message %02x from %02i-%i\n", srb->msgin_buf[0],
srb->dcb->target_id, srb->dcb->target_lun); srb->dcb->target_id, srb->dcb->target_lun);
TRACEPRINTF("\\*");
} }
...@@ -2843,7 +2727,6 @@ static inline void enable_msgout_abort(struct AdapterCtlBlk *acb, ...@@ -2843,7 +2727,6 @@ static inline void enable_msgout_abort(struct AdapterCtlBlk *acb,
if (srb->dcb) if (srb->dcb)
srb->dcb->flag &= ~ABORT_DEV_; srb->dcb->flag &= ~ABORT_DEV_;
*/ */
TRACEPRINTF("#*");
} }
...@@ -2881,20 +2764,6 @@ static struct ScsiReqBlk *msgin_qtag(struct AdapterCtlBlk *acb, ...@@ -2881,20 +2764,6 @@ static struct ScsiReqBlk *msgin_qtag(struct AdapterCtlBlk *acb,
if (!(srb->state & SRB_DISCONNECT)) if (!(srb->state & SRB_DISCONNECT))
goto mingx0; goto mingx0;
/* Tag found */
{
struct ScsiReqBlk *last_srb;
TRACEPRINTF("[%s]*", dcb->active_srb->debugtrace);
TRACEPRINTF("RTag*");
/* Just for debugging ... */
last_srb = srb;
srb = dcb->active_srb;
TRACEPRINTF("Found.*");
srb = last_srb;
}
memcpy(srb->msgin_buf, dcb->active_srb->msgin_buf, acb->msg_len); memcpy(srb->msgin_buf, dcb->active_srb->msgin_buf, acb->msg_len);
srb->state |= dcb->active_srb->state; srb->state |= dcb->active_srb->state;
srb->state |= SRB_DATA_XFER; srb->state |= SRB_DATA_XFER;
...@@ -2909,7 +2778,6 @@ static struct ScsiReqBlk *msgin_qtag(struct AdapterCtlBlk *acb, ...@@ -2909,7 +2778,6 @@ static struct ScsiReqBlk *msgin_qtag(struct AdapterCtlBlk *acb,
srb->msgout_buf[0] = MSG_ABORT_TAG; srb->msgout_buf[0] = MSG_ABORT_TAG;
srb->msg_count = 1; srb->msg_count = 1;
DC395x_ENABLE_MSGOUT; DC395x_ENABLE_MSGOUT;
TRACEPRINTF("?*");
dprintkl(KERN_DEBUG, "Unknown tag received: %i: abort !!\n", tag); dprintkl(KERN_DEBUG, "Unknown tag received: %i: abort !!\n", tag);
return srb; return srb;
} }
...@@ -2931,7 +2799,6 @@ static void msgin_set_async(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb) ...@@ -2931,7 +2799,6 @@ static void msgin_set_async(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb)
struct DeviceCtlBlk *dcb = srb->dcb; struct DeviceCtlBlk *dcb = srb->dcb;
dprintkl(KERN_DEBUG, "Target %02i: No sync transfers\n", dcb->target_id); dprintkl(KERN_DEBUG, "Target %02i: No sync transfers\n", dcb->target_id);
TRACEPRINTF("!S *");
dcb->sync_mode &= ~(SYNC_NEGO_ENABLE); dcb->sync_mode &= ~(SYNC_NEGO_ENABLE);
dcb->sync_mode |= SYNC_NEGO_DONE; dcb->sync_mode |= SYNC_NEGO_DONE;
/*dcb->sync_period &= 0; */ /*dcb->sync_period &= 0; */
...@@ -2998,7 +2865,6 @@ static void msgin_set_sync(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb) ...@@ -2998,7 +2865,6 @@ static void msgin_set_sync(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb)
((fact % dcb->min_nego_period) * 10 + ((fact % dcb->min_nego_period) * 10 +
dcb->min_nego_period / 2) / dcb->min_nego_period); dcb->min_nego_period / 2) / dcb->min_nego_period);
TRACEPRINTF("S%i *", dcb->min_nego_period << 2);
if (!(srb->state & SRB_DO_SYNC_NEGO)) { if (!(srb->state & SRB_DO_SYNC_NEGO)) {
/* Reply with corrected SDTR Message */ /* Reply with corrected SDTR Message */
dprintkl(KERN_DEBUG, " .. answer w/ %ins %i\n", dprintkl(KERN_DEBUG, " .. answer w/ %ins %i\n",
...@@ -3030,7 +2896,6 @@ static inline void msgin_set_nowide(struct AdapterCtlBlk *acb, ...@@ -3030,7 +2896,6 @@ static inline void msgin_set_nowide(struct AdapterCtlBlk *acb,
dprintkdbg(DBG_KG, "WDTR got rejected from target %02i\n", dprintkdbg(DBG_KG, "WDTR got rejected from target %02i\n",
dcb->target_id); dcb->target_id);
TRACEPRINTF("!W *");
dcb->sync_period &= ~WIDE_SYNC; dcb->sync_period &= ~WIDE_SYNC;
dcb->sync_mode &= ~(WIDE_NEGO_ENABLE); dcb->sync_mode &= ~(WIDE_NEGO_ENABLE);
dcb->sync_mode |= WIDE_NEGO_DONE; dcb->sync_mode |= WIDE_NEGO_DONE;
...@@ -3069,7 +2934,6 @@ static void msgin_set_wide(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb) ...@@ -3069,7 +2934,6 @@ static void msgin_set_wide(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb)
else else
dcb->sync_period &= ~WIDE_SYNC; dcb->sync_period &= ~WIDE_SYNC;
srb->state &= ~SRB_DO_WIDE_NEGO; srb->state &= ~SRB_DO_WIDE_NEGO;
TRACEPRINTF("W%i *", (dcb->sync_period & WIDE_SYNC ? 1 : 0));
/*dcb->sync_mode &= ~(WIDE_NEGO_ENABLE+WIDE_NEGO_DONE); */ /*dcb->sync_mode &= ~(WIDE_NEGO_ENABLE+WIDE_NEGO_DONE); */
dprintkdbg(DBG_KG, dprintkdbg(DBG_KG,
"Wide transfers (%i bit) negotiated with target %02i\n", "Wide transfers (%i bit) negotiated with target %02i\n",
...@@ -3102,12 +2966,9 @@ static void msgin_phase0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb, ...@@ -3102,12 +2966,9 @@ static void msgin_phase0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb,
struct DeviceCtlBlk *dcb = acb->active_dcb; struct DeviceCtlBlk *dcb = acb->active_dcb;
dprintkdbg(DBG_0, "msgin_phase0 (#%li)\n", srb->cmd->pid); dprintkdbg(DBG_0, "msgin_phase0 (#%li)\n", srb->cmd->pid);
TRACEPRINTF("MIP0*");
srb->msgin_buf[acb->msg_len++] = DC395x_read8(acb, TRM_S1040_SCSI_FIFO); srb->msgin_buf[acb->msg_len++] = DC395x_read8(acb, TRM_S1040_SCSI_FIFO);
if (msgin_completed(srb->msgin_buf, acb->msg_len)) { if (msgin_completed(srb->msgin_buf, acb->msg_len)) {
TRACEPRINTF("(%02x)*", srb->msgin_buf[0]);
/* Now eval the msg */ /* Now eval the msg */
switch (srb->msgin_buf[0]) { switch (srb->msgin_buf[0]) {
case DISCONNECT: case DISCONNECT:
...@@ -3117,7 +2978,6 @@ static void msgin_phase0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb, ...@@ -3117,7 +2978,6 @@ static void msgin_phase0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb,
case SIMPLE_QUEUE_TAG: case SIMPLE_QUEUE_TAG:
case HEAD_OF_QUEUE_TAG: case HEAD_OF_QUEUE_TAG:
case ORDERED_QUEUE_TAG: case ORDERED_QUEUE_TAG:
TRACEPRINTF("(%02x)*", srb->msgin_buf[1]);
srb = srb =
msgin_qtag(acb, dcb, msgin_qtag(acb, dcb,
srb->msgin_buf[1]); srb->msgin_buf[1]);
...@@ -3141,7 +3001,6 @@ static void msgin_phase0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb, ...@@ -3141,7 +3001,6 @@ static void msgin_phase0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb,
break; break;
case EXTENDED_MESSAGE: case EXTENDED_MESSAGE:
TRACEPRINTF("(%02x)*", srb->msgin_buf[2]);
/* SDTR */ /* SDTR */
if (srb->msgin_buf[1] == 3 if (srb->msgin_buf[1] == 3
&& srb->msgin_buf[2] == EXTENDED_SDTR) { && srb->msgin_buf[2] == EXTENDED_SDTR) {
...@@ -3168,10 +3027,9 @@ static void msgin_phase0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb, ...@@ -3168,10 +3027,9 @@ static void msgin_phase0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb,
/* nothing has to be done */ /* nothing has to be done */
case COMMAND_COMPLETE: case COMMAND_COMPLETE:
break; break;
/* /*
* SAVE POINTER may be ignored as we have the struct ScsiReqBlk* associated with the * SAVE POINTER may be ignored as we have the struct
* scsi command. Thanks, Grard, for pointing it out. * ScsiReqBlk* associated with the scsi command.
*/ */
case SAVE_POINTERS: case SAVE_POINTERS:
dprintkdbg(DBG_0, "SAVE POINTER message received (pid %li: rem.%i) ... ignore :-(\n", dprintkdbg(DBG_0, "SAVE POINTER message received (pid %li: rem.%i) ... ignore :-(\n",
...@@ -3196,7 +3054,6 @@ static void msgin_phase0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb, ...@@ -3196,7 +3054,6 @@ static void msgin_phase0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb,
default: default:
if (srb->msgin_buf[0] & IDENTIFY_BASE) { if (srb->msgin_buf[0] & IDENTIFY_BASE) {
dprintkl(KERN_DEBUG, "Identify Message received?\n"); dprintkl(KERN_DEBUG, "Identify Message received?\n");
/*TRACEOUT (" %s\n", srb->debugtrace); */
srb->msg_count = 1; srb->msg_count = 1;
srb->msgout_buf[0] = dcb->identify_msg; srb->msgout_buf[0] = dcb->identify_msg;
DC395x_ENABLE_MSGOUT; DC395x_ENABLE_MSGOUT;
...@@ -3204,22 +3061,12 @@ static void msgin_phase0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb, ...@@ -3204,22 +3061,12 @@ static void msgin_phase0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb,
/*break; */ /*break; */
} }
msgin_reject(acb, srb); msgin_reject(acb, srb);
TRACEOUT(" %s\n", srb->debugtrace);
} }
TRACEPRINTF(".*");
/* Clear counter and MsgIn state */ /* Clear counter and MsgIn state */
srb->state &= ~SRB_MSGIN; srb->state &= ~SRB_MSGIN;
acb->msg_len = 0; acb->msg_len = 0;
} }
/*1.25 */
if ((*pscsi_status & PHASEMASK) != PH_MSG_IN)
#if 0
clear_fifo(acb, "MIP0_");
#else
TRACEPRINTF("N/Cln *");
#endif
*pscsi_status = PH_BUS_FREE; *pscsi_status = PH_BUS_FREE;
DC395x_write16(acb, TRM_S1040_SCSI_CONTROL, DO_DATALATCH); /* it's important ... you know! */ DC395x_write16(acb, TRM_S1040_SCSI_CONTROL, DO_DATALATCH); /* it's important ... you know! */
DC395x_write8(acb, TRM_S1040_SCSI_COMMAND, SCMD_MSGACCEPT); DC395x_write8(acb, TRM_S1040_SCSI_COMMAND, SCMD_MSGACCEPT);
...@@ -3230,7 +3077,6 @@ static void msgin_phase1(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb, ...@@ -3230,7 +3077,6 @@ static void msgin_phase1(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb,
u16 *pscsi_status) u16 *pscsi_status)
{ {
dprintkdbg(DBG_0, "msgin_phase1 (#%li)\n", srb->cmd->pid); dprintkdbg(DBG_0, "msgin_phase1 (#%li)\n", srb->cmd->pid);
TRACEPRINTF("MIP1 *");
clear_fifo(acb, "MIP1"); clear_fifo(acb, "MIP1");
DC395x_write32(acb, TRM_S1040_SCSI_COUNTER, 1); DC395x_write32(acb, TRM_S1040_SCSI_COUNTER, 1);
if (!(srb->state & SRB_MSGIN)) { if (!(srb->state & SRB_MSGIN)) {
...@@ -3246,14 +3092,12 @@ static void msgin_phase1(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb, ...@@ -3246,14 +3092,12 @@ static void msgin_phase1(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb,
static void nop0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb, static void nop0(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb,
u16 *pscsi_status) u16 *pscsi_status)
{ {
/*TRACEPRINTF("NOP0 *"); */
} }
static void nop1(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb, static void nop1(struct AdapterCtlBlk *acb, struct ScsiReqBlk *srb,
u16 *pscsi_status) u16 *pscsi_status)
{ {
/*TRACEPRINTF("NOP1 *"); */
} }
...@@ -3299,7 +3143,6 @@ static void disconnect(struct AdapterCtlBlk *acb) ...@@ -3299,7 +3143,6 @@ static void disconnect(struct AdapterCtlBlk *acb)
srb = dcb->active_srb; srb = dcb->active_srb;
acb->active_dcb = NULL; acb->active_dcb = NULL;
dprintkdbg(DBG_0, "disconnect (#%li)\n", srb->cmd->pid); dprintkdbg(DBG_0, "disconnect (#%li)\n", srb->cmd->pid);
TRACEPRINTF("DISC *");
srb->scsi_phase = PH_BUS_FREE; /* initial phase */ srb->scsi_phase = PH_BUS_FREE; /* initial phase */
clear_fifo(acb, "Disc"); clear_fifo(acb, "Disc");
...@@ -3330,12 +3173,9 @@ static void disconnect(struct AdapterCtlBlk *acb) ...@@ -3330,12 +3173,9 @@ static void disconnect(struct AdapterCtlBlk *acb)
dprintkl(KERN_DEBUG, "Unexpected Disconnection (pid %li)!\n", dprintkl(KERN_DEBUG, "Unexpected Disconnection (pid %li)!\n",
srb->cmd->pid); srb->cmd->pid);
srb->target_status = SCSI_STAT_SEL_TIMEOUT; srb->target_status = SCSI_STAT_SEL_TIMEOUT;
TRACEPRINTF("UnExpD *");
TRACEOUT("%s\n", srb->debugtrace);
goto disc1; goto disc1;
} else { } else {
/* Normal selection timeout */ /* Normal selection timeout */
TRACEPRINTF("SlTO *");
dprintkdbg(DBG_KG, dprintkdbg(DBG_KG,
"Disc: SelTO (#%li) for dev %02i-%i\n", "Disc: SelTO (#%li) for dev %02i-%i\n",
srb->cmd->pid, dcb->target_id, srb->cmd->pid, dcb->target_id,
...@@ -3358,17 +3198,10 @@ static void disconnect(struct AdapterCtlBlk *acb) ...@@ -3358,17 +3198,10 @@ static void disconnect(struct AdapterCtlBlk *acb)
* SRB_DISCONNECT (This is what we expect!) * SRB_DISCONNECT (This is what we expect!)
*/ */
/* dprintkl(KERN_DEBUG, "DoWaitingSRB (#%li)\n", srb->cmd->pid); */ /* dprintkl(KERN_DEBUG, "DoWaitingSRB (#%li)\n", srb->cmd->pid); */
TRACEPRINTF("+*");
if (bval & 0x40) { if (bval & 0x40) {
dprintkdbg(DBG_0, "Debug: DISC: SCSI bus stat %02x: ACK set! Other controllers?\n", dprintkdbg(DBG_0, "Debug: DISC: SCSI bus stat %02x: ACK set! Other controllers?\n",
bval); bval);
/* It could come from another initiator, therefore don't do much ! */ /* It could come from another initiator, therefore don't do much ! */
TRACEPRINTF("ACK(%02x) *", bval);
/*dump_register_info (acb, dcb, srb); */
/*TRACEOUT (" %s\n", srb->debugtrace); */
/*dcb->flag |= ABORT_DEV_; */
/*enable_msgout_abort (acb, srb); */
/*DC395x_write16 (TRM_S1040_SCSI_CONTROL, DO_CLRFIFO | DO_CLRATN | DO_HWRESELECT); */
} else } else
waiting_process_next(acb); waiting_process_next(acb);
} else if (srb->state & SRB_COMPLETED) { } else if (srb->state & SRB_COMPLETED) {
...@@ -3414,8 +3247,6 @@ static void reselect(struct AdapterCtlBlk *acb) ...@@ -3414,8 +3247,6 @@ static void reselect(struct AdapterCtlBlk *acb)
srb->cmd->pid, dcb->target_id, srb->cmd->pid, dcb->target_id,
dcb->target_lun, rsel_tar_lun_id, dcb->target_lun, rsel_tar_lun_id,
DC395x_read16(acb, TRM_S1040_SCSI_STATUS)); DC395x_read16(acb, TRM_S1040_SCSI_STATUS));
TRACEPRINTF("ArbLResel!*");
/*TRACEOUT (" %s\n", srb->debugtrace); */
arblostflag = 1; arblostflag = 1;
/*srb->state |= SRB_DISCONNECT; */ /*srb->state |= SRB_DISCONNECT; */
...@@ -3448,21 +3279,11 @@ static void reselect(struct AdapterCtlBlk *acb) ...@@ -3448,21 +3279,11 @@ static void reselect(struct AdapterCtlBlk *acb)
dcb->target_id, dcb->target_lun); dcb->target_id, dcb->target_lun);
if (dcb->sync_mode & EN_TAG_QUEUEING /*&& !arblostflag */) { if (dcb->sync_mode & EN_TAG_QUEUEING /*&& !arblostflag */) {
struct ScsiReqBlk *oldSRB = srb;
srb = acb->tmp_srb; srb = acb->tmp_srb;
#if debug_enabled(DBG_TRACE|DBG_TRACEALL)
srb->debugpos = 0;
srb->debugtrace[0] = 0;
#endif
dcb->active_srb = srb; dcb->active_srb = srb;
if (oldSRB)
TRACEPRINTF("ArbLResel(%li):*", oldSRB->cmd->pid);
/*if (arblostflag) dprintkl(KERN_DEBUG, "Reselect: Wait for Tag ... \n"); */
} else { } else {
/* There can be only one! */ /* There can be only one! */
srb = dcb->active_srb; srb = dcb->active_srb;
if (srb)
TRACEPRINTF("RSel *");
if (!srb || !(srb->state & SRB_DISCONNECT)) { if (!srb || !(srb->state & SRB_DISCONNECT)) {
/* /*
* abort command * abort command
...@@ -3482,7 +3303,6 @@ static void reselect(struct AdapterCtlBlk *acb) ...@@ -3482,7 +3303,6 @@ static void reselect(struct AdapterCtlBlk *acb)
srb->state = SRB_DATA_XFER; srb->state = SRB_DATA_XFER;
} }
/*if (arblostflag) TRACEOUT (" %s\n", srb->debugtrace); */
} }
srb->scsi_phase = PH_BUS_FREE; /* initial phase */ srb->scsi_phase = PH_BUS_FREE; /* initial phase */
...@@ -3606,8 +3426,6 @@ static void srb_done(struct AdapterCtlBlk *acb, struct DeviceCtlBlk *dcb, ...@@ -3606,8 +3426,6 @@ static void srb_done(struct AdapterCtlBlk *acb, struct DeviceCtlBlk *dcb,
struct ScsiInqData *ptr; struct ScsiInqData *ptr;
int dir; int dir;
TRACEPRINTF("DONE *");
dir = scsi_to_pci_dma_dir(cmd->sc_data_direction); dir = scsi_to_pci_dma_dir(cmd->sc_data_direction);
if (cmd->use_sg) { if (cmd->use_sg) {
struct scatterlist* sg = (struct scatterlist *)cmd->request_buffer; struct scatterlist* sg = (struct scatterlist *)cmd->request_buffer;
...@@ -3809,12 +3627,10 @@ static void srb_done(struct AdapterCtlBlk *acb, struct DeviceCtlBlk *dcb, ...@@ -3809,12 +3627,10 @@ static void srb_done(struct AdapterCtlBlk *acb, struct DeviceCtlBlk *dcb,
if (debug_enabled(DBG_KG)) { if (debug_enabled(DBG_KG)) {
printk(" 0x%08x\n", cmd->result); printk(" 0x%08x\n", cmd->result);
} }
TRACEPRINTF("%08x(%li)*", cmd->result, jiffies);
pci_unmap_srb(acb, srb); pci_unmap_srb(acb, srb);
/*DC395x_UNLOCK_ACB_NI; */ /*DC395x_UNLOCK_ACB_NI; */
cmd->scsi_done(cmd); cmd->scsi_done(cmd);
/*DC395x_LOCK_ACB_NI; */ /*DC395x_LOCK_ACB_NI; */
TRACEOUTALL(KERN_INFO " %s\n", srb->debugtrace);
waiting_process_next(acb); waiting_process_next(acb);
} }
...@@ -3839,16 +3655,8 @@ static void doing_srb_done(struct AdapterCtlBlk *acb, u8 did_flag, ...@@ -3839,16 +3655,8 @@ static void doing_srb_done(struct AdapterCtlBlk *acb, u8 did_flag,
p = srb->cmd; p = srb->cmd;
dir = scsi_to_pci_dma_dir(p->sc_data_direction); dir = scsi_to_pci_dma_dir(p->sc_data_direction);
result = MK_RES(0, did_flag, 0, 0); result = MK_RES(0, did_flag, 0, 0);
printk("G:%li(%02i-%i) ", p->pid,
/*result = MK_RES(0,DID_RESET,0,0); */
TRACEPRINTF("Reset(%li):%08x*", jiffies, result);
printk(" (G)");
#if 1 /*ndef DC395x_DEBUGTRACE */
printk("%li(%02i-%i) ", p->pid,
p->device->id, p->device->lun); p->device->id, p->device->lun);
#endif
TRACEOUT("%s\n", srb->debugtrace);
srb_going_remove(dcb, srb); srb_going_remove(dcb, srb);
free_tag(dcb, srb); free_tag(dcb, srb);
srb_free_insert(acb, srb); srb_free_insert(acb, srb);
...@@ -3877,16 +3685,10 @@ static void doing_srb_done(struct AdapterCtlBlk *acb, u8 did_flag, ...@@ -3877,16 +3685,10 @@ static void doing_srb_done(struct AdapterCtlBlk *acb, u8 did_flag,
p = srb->cmd; p = srb->cmd;
result = MK_RES(0, did_flag, 0, 0); result = MK_RES(0, did_flag, 0, 0);
TRACEPRINTF("Reset(%li):%08x*", jiffies, result); printk("W:%li(%i-%i)", p->pid, p->device->id,
printk(" (W)");
#if 1 /*ndef DC395x_DEBUGTRACE */
printk("%li(%i-%i)", p->pid, p->device->id,
p->device->lun); p->device->lun);
#endif
TRACEOUT("%s\n", srb->debugtrace);
srb_waiting_remove(dcb, srb); srb_waiting_remove(dcb, srb);
srb_free_insert(acb, srb); srb_free_insert(acb, srb);
p->result = result; p->result = result;
pci_unmap_srb_sense(acb, srb); pci_unmap_srb_sense(acb, srb);
pci_unmap_srb(acb, srb); pci_unmap_srb(acb, srb);
...@@ -3999,7 +3801,6 @@ static void request_sense(struct AdapterCtlBlk *acb, struct DeviceCtlBlk *dcb, ...@@ -3999,7 +3801,6 @@ static void request_sense(struct AdapterCtlBlk *acb, struct DeviceCtlBlk *dcb,
dprintkdbg(DBG_KG, dprintkdbg(DBG_KG,
"request_sense for pid %li, target %02i-%i\n", "request_sense for pid %li, target %02i-%i\n",
cmd->pid, cmd->device->id, cmd->device->lun); cmd->pid, cmd->device->id, cmd->device->lun);
TRACEPRINTF("RqSn*");
srb->flag |= AUTO_REQSENSE; srb->flag |= AUTO_REQSENSE;
srb->adapter_status = 0; srb->adapter_status = 0;
srb->target_status = 0; srb->target_status = 0;
...@@ -4030,11 +3831,9 @@ static void request_sense(struct AdapterCtlBlk *acb, struct DeviceCtlBlk *dcb, ...@@ -4030,11 +3831,9 @@ static void request_sense(struct AdapterCtlBlk *acb, struct DeviceCtlBlk *dcb,
dprintkl(KERN_DEBUG, dprintkl(KERN_DEBUG,
"Request Sense failed for pid %li (%02i-%i)!\n", "Request Sense failed for pid %li (%02i-%i)!\n",
srb->cmd->pid, dcb->target_id, dcb->target_lun); srb->cmd->pid, dcb->target_id, dcb->target_lun);
TRACEPRINTF("?*");
srb_going_to_waiting_move(dcb, srb); srb_going_to_waiting_move(dcb, srb);
waiting_set_timer(acb, HZ / 100); waiting_set_timer(acb, HZ / 100);
} }
TRACEPRINTF(".*");
} }
...@@ -4058,7 +3857,7 @@ static struct DeviceCtlBlk *device_alloc(struct AdapterCtlBlk *acb, ...@@ -4058,7 +3857,7 @@ static struct DeviceCtlBlk *device_alloc(struct AdapterCtlBlk *acb,
u8 period_index = eeprom->target[target].period & 0x07; u8 period_index = eeprom->target[target].period & 0x07;
struct DeviceCtlBlk *dcb; struct DeviceCtlBlk *dcb;
dcb = dc395x_kmalloc(sizeof(struct DeviceCtlBlk), GFP_ATOMIC); dcb = kmalloc(sizeof(struct DeviceCtlBlk), GFP_ATOMIC);
dprintkdbg(DBG_0, "device_alloc: device %p\n", dcb); dprintkdbg(DBG_0, "device_alloc: device %p\n", dcb);
if (!dcb) if (!dcb)
return NULL; return NULL;
...@@ -4193,7 +3992,7 @@ static void adapter_remove_and_free_device(struct AdapterCtlBlk *acb, ...@@ -4193,7 +3992,7 @@ static void adapter_remove_and_free_device(struct AdapterCtlBlk *acb,
return; return;
} }
adapter_remove_device(acb, dcb); adapter_remove_device(acb, dcb);
dc395x_kfree(dcb); kfree(dcb);
} }
...@@ -4570,60 +4369,6 @@ static void __init print_eeprom_settings(struct NvRamType *eeprom) ...@@ -4570,60 +4369,6 @@ static void __init print_eeprom_settings(struct NvRamType *eeprom)
} }
#if debug_enabled(DBG_TRACE|DBG_TRACEALL)
/*
* Memory for trace buffers
*/
static void free_tracebufs(struct AdapterCtlBlk *acb)
{
int i;
const unsigned bufs_per_page = PAGE_SIZE / DEBUGTRACEBUFSZ;
for (i = 0; i < srb_idx; i += bufs_per_page)
if (acb->srb_array[i].debugtrace)
dc395x_kfree(acb->srb_array[i].debugtrace);
}
static int alloc_tracebufs(struct AdapterCtlBlk *acb)
{
const unsigned mem_needed =
(DC395x_MAX_SRB_CNT + 1) * DEBUGTRACEBUFSZ;
int pages = (mem_needed + (PAGE_SIZE - 1)) / PAGE_SIZE;
const unsigned bufs_per_page = PAGE_SIZE / DEBUGTRACEBUFSZ;
int srb_idx = 0;
unsigned i = 0;
unsigned char *ptr;
for (i = 0; i < DC395x_MAX_SRB_CNT; i++)
acb->srb_array[i].debugtrace = NULL;
while (pages--) {
ptr = dc395x_kmalloc(PAGE_SIZE, GFP_KERNEL);
if (!ptr) {
free_tracebufs(acb);
return 1;
}
/*dprintkl(KERN_DEBUG, "Alloc %li bytes at %p for tracebuf %i\n", */
/* PAGE_SIZE, ptr, srb_idx); */
i = 0;
while (i < bufs_per_page && srb_idx < DC395x_MAX_SRB_CNT)
acb->srb_array[srb_idx++].debugtrace =
ptr + (i++ * DEBUGTRACEBUFSZ);
}
if (i < bufs_per_page) {
acb->srb.debugtrace = ptr + (i * DEBUGTRACEBUFSZ);
acb->srb.debugtrace[0] = 0;
} else
dprintkl(KERN_DEBUG, "No space for tmsrb tracebuf reserved?!\n");
return 0;
}
#else
static void free_tracebufs(struct AdapterCtlBlk *acb) {}
static int alloc_tracebufs(struct AdapterCtlBlk *acb) { return 0; }
#endif
/* Free SG tables */ /* Free SG tables */
static void adapter_sg_tables_free(struct AdapterCtlBlk *acb) static void adapter_sg_tables_free(struct AdapterCtlBlk *acb)
{ {
...@@ -4632,7 +4377,7 @@ static void adapter_sg_tables_free(struct AdapterCtlBlk *acb) ...@@ -4632,7 +4377,7 @@ static void adapter_sg_tables_free(struct AdapterCtlBlk *acb)
for (i = 0; i < DC395x_MAX_SRB_CNT; i += srbs_per_page) for (i = 0; i < DC395x_MAX_SRB_CNT; i += srbs_per_page)
if (acb->srb_array[i].segment_x) if (acb->srb_array[i].segment_x)
dc395x_kfree(acb->srb_array[i].segment_x); kfree(acb->srb_array[i].segment_x);
} }
...@@ -4654,7 +4399,7 @@ static int __init adapter_sg_tables_alloc(struct AdapterCtlBlk *acb) ...@@ -4654,7 +4399,7 @@ static int __init adapter_sg_tables_alloc(struct AdapterCtlBlk *acb)
dprintkdbg(DBG_1, "Allocate %i pages for SG tables\n", pages); dprintkdbg(DBG_1, "Allocate %i pages for SG tables\n", pages);
while (pages--) { while (pages--) {
ptr = (struct SGentry *)dc395x_kmalloc(PAGE_SIZE, GFP_KERNEL); ptr = (struct SGentry *)kmalloc(PAGE_SIZE, GFP_KERNEL);
if (!ptr) { if (!ptr) {
adapter_sg_tables_free(acb); adapter_sg_tables_free(acb);
return 1; return 1;
...@@ -4918,10 +4663,6 @@ static int __init adapter_init(struct AdapterCtlBlk *acb, u32 io_port, ...@@ -4918,10 +4663,6 @@ static int __init adapter_init(struct AdapterCtlBlk *acb, u32 io_port,
dprintkl(KERN_DEBUG, "Memory allocation for SG tables failed\n"); dprintkl(KERN_DEBUG, "Memory allocation for SG tables failed\n");
goto failed; goto failed;
} }
if (alloc_tracebufs(acb)) {
dprintkl(KERN_DEBUG, "Memory allocation for trace buffers failed\n");
goto failed;
}
adapter_init_scsi_host(acb->scsi_host); adapter_init_scsi_host(acb->scsi_host);
adapter_init_chip(acb); adapter_init_chip(acb);
set_basic_config(acb); set_basic_config(acb);
...@@ -4939,7 +4680,6 @@ static int __init adapter_init(struct AdapterCtlBlk *acb, u32 io_port, ...@@ -4939,7 +4680,6 @@ static int __init adapter_init(struct AdapterCtlBlk *acb, u32 io_port,
if (acb->io_port_base) if (acb->io_port_base)
release_region(acb->io_port_base, acb->io_port_len); release_region(acb->io_port_base, acb->io_port_len);
adapter_sg_tables_free(acb); adapter_sg_tables_free(acb);
free_tracebufs(acb);
return 1; return 1;
} }
...@@ -4996,7 +4736,6 @@ static void adapter_uninit(struct AdapterCtlBlk *acb) ...@@ -4996,7 +4736,6 @@ static void adapter_uninit(struct AdapterCtlBlk *acb)
release_region(acb->io_port_base, acb->io_port_len); release_region(acb->io_port_base, acb->io_port_len);
adapter_sg_tables_free(acb); adapter_sg_tables_free(acb);
free_tracebufs(acb);
} }
...@@ -5107,11 +4846,7 @@ static int dc395x_proc_info(struct Scsi_Host *host, char *buffer, ...@@ -5107,11 +4846,7 @@ static int dc395x_proc_info(struct Scsi_Host *host, char *buffer,
dcb->target_id, dcb->target_lun, dcb->target_id, dcb->target_lun,
list_size(&dcb->srb_going_list)); list_size(&dcb->srb_going_list));
list_for_each_entry(srb, &dcb->srb_going_list, list) list_for_each_entry(srb, &dcb->srb_going_list, list)
#if debug_enabled(DBG_TRACE|DBG_TRACEALL)
SPRINTF("\n %s", srb->debugtrace);
#else
SPRINTF(" %li", srb->cmd->pid); SPRINTF(" %li", srb->cmd->pid);
#endif
if (!list_empty(&dcb->srb_waiting_list) || !list_empty(&dcb->srb_going_list)) if (!list_empty(&dcb->srb_waiting_list) || !list_empty(&dcb->srb_going_list))
SPRINTF("\n"); SPRINTF("\n");
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment