taglinefilesource code
scb140drivers/net/apricot.cstruct i596_scb *scb;
scb152drivers/net/apricot.cstruct i596_scb scb;
scb201drivers/net/apricot.clp->scb.rfd = (struct i596_rfd *)I596_NULL;
scb222drivers/net/apricot.crfd->next = lp->scb.rfd;
scb223drivers/net/apricot.clp->scb.rfd = rfd;
scb227drivers/net/apricot.clp->rx_tail->next = lp->scb.rfd;
scb236drivers/net/apricot.cstruct i596_rfd *rfd = lp->scb.rfd;
scb242drivers/net/apricot.clp->scb.rfd = rfd->next;
scb244drivers/net/apricot.crfd = lp->scb.rfd;
scb267drivers/net/apricot.clp->iscp.scb = &(lp->scb);
scb271drivers/net/apricot.clp->cmd_head = lp->scb.cmd = (struct i596_cmd *) I596_NULL;
scb283drivers/net/apricot.cdev->name, lp->scb.status, lp->scb.command);
scb287drivers/net/apricot.clp->scb.command = 0;
scb301drivers/net/apricot.cwhile (lp->scb.status, lp->scb.command)
scb305drivers/net/apricot.cdev->name, lp->scb.status, lp->scb.command);
scb309drivers/net/apricot.clp->scb.command = RX_START;
scb313drivers/net/apricot.cwhile (lp->scb.status, lp->scb.command)
scb317drivers/net/apricot.clp->scb.status, lp->scb.command);
scb332drivers/net/apricot.cwhile ((lp->scb.rfd->stat) & STAT_C)
scb334drivers/net/apricot.cif (i596_debug >2) print_eth(lp->scb.rfd->data);
scb336drivers/net/apricot.cif ((lp->scb.rfd->stat) & STAT_OK)
scb339drivers/net/apricot.cint pkt_len = lp->scb.rfd->count & 0x3fff;
scb352drivers/net/apricot.cmemcpy(skb_put(skb,pkt_len), lp->scb.rfd->data, pkt_len);
scb363drivers/net/apricot.cif ((lp->scb.rfd->stat) & 0x0001) lp->stats.collisions++;
scb364drivers/net/apricot.cif ((lp->scb.rfd->stat) & 0x0080) lp->stats.rx_length_errors++;
scb365drivers/net/apricot.cif ((lp->scb.rfd->stat) & 0x0100) lp->stats.rx_over_errors++;
scb366drivers/net/apricot.cif ((lp->scb.rfd->stat) & 0x0200) lp->stats.rx_fifo_errors++;
scb367drivers/net/apricot.cif ((lp->scb.rfd->stat) & 0x0400) lp->stats.rx_frame_errors++;
scb368drivers/net/apricot.cif ((lp->scb.rfd->stat) & 0x0800) lp->stats.rx_crc_errors++;
scb369drivers/net/apricot.cif ((lp->scb.rfd->stat) & 0x1000) lp->stats.rx_length_errors++;
scb372drivers/net/apricot.clp->scb.rfd->stat = 0;
scb374drivers/net/apricot.clp->rx_tail = lp->scb.rfd;
scb375drivers/net/apricot.clp->scb.rfd = lp->scb.rfd->next;
scb430drivers/net/apricot.cwhile (lp->scb.status, lp->scb.command)
scb434drivers/net/apricot.clp->scb.status, lp->scb.command);
scb438drivers/net/apricot.clp->scb.cmd = lp->cmd_head;
scb448drivers/net/apricot.cwhile (lp->scb.status, lp->scb.command)
scb452drivers/net/apricot.clp->scb.status, lp->scb.command);
scb459drivers/net/apricot.clp->scb.command = CUC_ABORT|RX_ABORT;
scb465drivers/net/apricot.cwhile ((lp->scb.status, lp->scb.command) || lp->scb.command)
scb469drivers/net/apricot.clp->scb.status, lp->scb.command);
scb502drivers/net/apricot.cwhile (lp->scb.status, lp->scb.command)
scb506drivers/net/apricot.clp->scb.status, lp->scb.command);
scb510drivers/net/apricot.clp->scb.cmd = cmd;
scb511drivers/net/apricot.clp->scb.command = CUC_START;
scb517drivers/net/apricot.clp->cmd_head = lp->scb.cmd;
scb595drivers/net/apricot.clp->scb.command = CUC_START|RX_START;
scb738drivers/net/apricot.clp->scb.command = 0;
scb739drivers/net/apricot.clp->scb.cmd = (struct i596_cmd *) I596_NULL;
scb740drivers/net/apricot.clp->scb.rfd = (struct i596_rfd *)I596_NULL;
scb770drivers/net/apricot.cwhile (lp->scb.status, lp->scb.command)
scb773drivers/net/apricot.cprintk("%s: i596 interrupt, timeout status %4.4x command %4.4x.\n", dev->name, lp->scb.status, lp->scb.command);
scb776drivers/net/apricot.cstatus = lp->scb.status;
scb871drivers/net/apricot.clp->scb.cmd = lp->cmd_head;
scb892drivers/net/apricot.cwhile (lp->scb.status, lp->scb.command)
scb895drivers/net/apricot.cprintk("%s: i596 interrupt, timeout status %4.4x command %4.4x.\n", dev->name, lp->scb.status, lp->scb.command);
scb898drivers/net/apricot.clp->scb.command = ack_cmd;
scb923drivers/net/apricot.cdev->name, lp->scb.status);
scb925drivers/net/apricot.clp->scb.command = CUC_ABORT|RX_ABORT;
scb930drivers/net/apricot.cwhile (lp->scb.status, lp->scb.command)
scb934drivers/net/apricot.cdev->name, lp->scb.status, lp->scb.command);
scb145drivers/net/ni52.cif(!p->scb->cmd) break; \
scb188drivers/net/ni52.cvolatile struct scb_struct  *scb;  /* volatile is important */
scb292drivers/net/ni52.cp->scb  = (struct scb_struct *)  (dev->mem_start);
scb300drivers/net/ni52.cp->iscp->scb_offset = make16(p->scb);
scb311drivers/net/ni52.cmemset((char *)p->scb,0,sizeof(struct scb_struct));
scb464drivers/net/ni52.cptr = (void *) ((char *)p->scb + sizeof(struct scb_struct));
scb487drivers/net/ni52.cp->scb->cbl_offset = make16(cfg_cmd);
scb489drivers/net/ni52.cp->scb->cmd = CUC_START; /* cmd.-unit start */
scb513drivers/net/ni52.cp->scb->cbl_offset = make16(ias_cmd);
scb515drivers/net/ni52.cp->scb->cmd = CUC_START; /* cmd.-unit start */
scb537drivers/net/ni52.cp->scb->cbl_offset = make16(tdr_cmd);
scb539drivers/net/ni52.cp->scb->cmd = CUC_START; /* cmd.-unit start */
scb554drivers/net/ni52.cp->scb->cmd = p->scb->status & STAT_MASK;
scb574drivers/net/ni52.cp->scb->cmd = p->scb->status & STAT_MASK;
scb635drivers/net/ni52.cp->scb->cbl_offset = make16(mc_cmd);
scb636drivers/net/ni52.cp->scb->cmd = CUC_START;
scb680drivers/net/ni52.cp->scb->cbl_offset = make16(p->nop_cmds[0]);
scb681drivers/net/ni52.cp->scb->cmd = CUC_START;
scb730drivers/net/ni52.cp->scb->rfa_offset    = make16(p->rfd_first);
scb755drivers/net/ni52.cwhile((stat=p->scb->status & STAT_MASK))
scb757drivers/net/ni52.cp->scb->cmd = stat;
scb770drivers/net/ni52.cprintk("%s: oops! CU has left active state. stat: %04x/%04x.\n",dev->name,(int) stat,(int) p->scb->status);
scb776drivers/net/ni52.cif(p->scb->status & RU_SUSPEND) /* special case: RU_SUSPEND */
scb779drivers/net/ni52.cp->scb->cmd = RUC_RESUME;
scb784drivers/net/ni52.cprintk("%s: Receiver-Unit went 'NOT READY': %04x/%04x.\n",dev->name,(int) stat,(int) p->scb->status);
scb789drivers/net/ni52.cif(p->scb->cmd)   /* timed out? */
scb861drivers/net/ni52.cp->scb->cmd = RUC_ABORT; /* usually the RU is in the 'no resource'-state .. abort it now. */
scb868drivers/net/ni52.cprintk("%s: Receive-Unit restarted. Status: %04x\n",dev->name,p->scb->status);
scb930drivers/net/ni52.cp->scb->rfa_offset = make16(p->rfd_first);
scb931drivers/net/ni52.cp->scb->cmd = RUC_START;
scb954drivers/net/ni52.cif(p->scb->status & CU_ACTIVE) /* COMMAND-UNIT active? */
scb961drivers/net/ni52.cp->scb->cmd = CUC_ABORT;
scb964drivers/net/ni52.cp->scb->cbl_offset = make16(p->nop_cmds[p->nop_point]);
scb965drivers/net/ni52.cp->scb->cmd = CUC_START;
scb974drivers/net/ni52.cprintk("%s: xmitter timed out, try to restart! stat: %04x\n",dev->name,p->scb->status);
scb1010drivers/net/ni52.cp->scb->cbl_offset = make16(p->xmit_cmds[0]);
scb1011drivers/net/ni52.cp->scb->cmd = CUC_START;
scb1019drivers/net/ni52.cif( (p->scb->status & CU_ACTIVE)) /* test it, because CU sometimes doesn't start immediately */
scb1072drivers/net/ni52.ccrc = p->scb->crc_errs; /* get error-statistic from the ni82586 */
scb1073drivers/net/ni52.cp->scb->crc_errs -= crc;
scb1074drivers/net/ni52.caln = p->scb->aln_errs;
scb1075drivers/net/ni52.cp->scb->aln_errs -= aln;
scb1076drivers/net/ni52.crsc = p->scb->rsc_errs;
scb1077drivers/net/ni52.cp->scb->rsc_errs -= rsc;
scb1078drivers/net/ni52.covrn = p->scb->ovrn_errs;
scb1079drivers/net/ni52.cp->scb->ovrn_errs -= ovrn;
scb541drivers/net/wavelan.cscb_t    scb;
scb588drivers/net/wavelan.cmemset(&scb, 0x00, sizeof(scb));
scb589drivers/net/wavelan.cscb.scb_command = SCB_CMD_RESET;
scb590drivers/net/wavelan.cscb.scb_cbl_offset = OFFSET_CU;
scb591drivers/net/wavelan.cscb.scb_rfa_offset = OFFSET_RU;
scb592drivers/net/wavelan.cobram_write(ioaddr, OFFSET_SCB, (unsigned char *)&scb, sizeof(scb));
scb616drivers/net/wavelan.cobram_read(ioaddr, OFFSET_SCB, (unsigned char *)&scb, sizeof(scb));
scb618drivers/net/wavelan.cif (scb.scb_status == (SCB_ST_CX | SCB_ST_CNA))
scb626drivers/net/wavelan.cprintk("%s: wavelan_hardware_reset(): status: expected 0x%02x, got 0x%02x.\n", dev->name, SCB_ST_CX | SCB_ST_CNA, scb.scb_status);
scb2337drivers/net/wavelan.cscb_t  scb;
scb2339drivers/net/wavelan.cobram_read(ioaddr, OFFSET_SCB, (unsigned char *)&scb, sizeof(scb));   
scb2347drivers/net/wavelan.c(scb.scb_status & (SCB_ST_CX | SCB_ST_FR | SCB_ST_CNA | SCB_ST_RNR)) >> 12,
scb2348drivers/net/wavelan.c(scb.scb_status & SCB_ST_CX) ? "cmd completion interrupt," : "",
scb2349drivers/net/wavelan.c(scb.scb_status & SCB_ST_FR) ? "frame received," : "",
scb2350drivers/net/wavelan.c(scb.scb_status & SCB_ST_CNA) ? "cmd unit not active," : "",
scb2351drivers/net/wavelan.c(scb.scb_status & SCB_ST_RNR) ? "rcv unit not ready," : ""
scb2356drivers/net/wavelan.c(scb.scb_status & SCB_ST_CUS) >> 8,
scb2357drivers/net/wavelan.c((scb.scb_status & SCB_ST_CUS) == SCB_ST_CUS_IDLE) ? "idle" : "",
scb2358drivers/net/wavelan.c((scb.scb_status & SCB_ST_CUS) == SCB_ST_CUS_SUSP) ? "suspended" : "",
scb2359drivers/net/wavelan.c((scb.scb_status & SCB_ST_CUS) == SCB_ST_CUS_ACTV) ? "active" : ""
scb2364drivers/net/wavelan.c(scb.scb_status & SCB_ST_RUS) >> 4,
scb2365drivers/net/wavelan.c((scb.scb_status & SCB_ST_RUS) == SCB_ST_RUS_IDLE) ? "idle" : "",
scb2366drivers/net/wavelan.c((scb.scb_status & SCB_ST_RUS) == SCB_ST_RUS_SUSP) ? "suspended" : "",
scb2367drivers/net/wavelan.c((scb.scb_status & SCB_ST_RUS) == SCB_ST_RUS_NRES) ? "no resources" : "",
scb2368drivers/net/wavelan.c((scb.scb_status & SCB_ST_RUS) == SCB_ST_RUS_RDY) ? "ready" : ""
scb2375drivers/net/wavelan.c(scb.scb_command & (SCB_CMD_ACK_CX | SCB_CMD_ACK_FR | SCB_CMD_ACK_CNA | SCB_CMD_ACK_RNR)) >> 12,
scb2376drivers/net/wavelan.c(scb.scb_command & SCB_CMD_ACK_CX) ? "ack cmd completion," : "",
scb2377drivers/net/wavelan.c(scb.scb_command & SCB_CMD_ACK_FR) ? "ack frame received," : "",
scb2378drivers/net/wavelan.c(scb.scb_command & SCB_CMD_ACK_CNA) ? "ack CU not active," : "",
scb2379drivers/net/wavelan.c(scb.scb_command & SCB_CMD_ACK_RNR) ? "ack RU not ready," : ""
scb2384drivers/net/wavelan.c(scb.scb_command & SCB_CMD_CUC) >> 8,
scb2385drivers/net/wavelan.c((scb.scb_command & SCB_CMD_CUC) == SCB_CMD_CUC_NOP) ? "nop" : "",
scb2386drivers/net/wavelan.c((scb.scb_command & SCB_CMD_CUC) == SCB_CMD_CUC_GO) ? "start cbl_offset" : "",
scb2387drivers/net/wavelan.c((scb.scb_command & SCB_CMD_CUC) == SCB_CMD_CUC_RES) ? "resume execution" : "",
scb2388drivers/net/wavelan.c((scb.scb_command & SCB_CMD_CUC) == SCB_CMD_CUC_SUS) ? "suspend execution" : "",
scb2389drivers/net/wavelan.c((scb.scb_command & SCB_CMD_CUC) == SCB_CMD_CUC_ABT) ? "abort execution" : ""
scb2394drivers/net/wavelan.c(scb.scb_command & SCB_CMD_RUC) >> 4,
scb2395drivers/net/wavelan.c((scb.scb_command & SCB_CMD_RUC) == SCB_CMD_RUC_NOP) ? "nop" : "",
scb2396drivers/net/wavelan.c((scb.scb_command & SCB_CMD_RUC) == SCB_CMD_RUC_GO) ? "start rfa_offset" : "",
scb2397drivers/net/wavelan.c((scb.scb_command & SCB_CMD_RUC) == SCB_CMD_RUC_RES) ? "resume reception" : "",
scb2398drivers/net/wavelan.c((scb.scb_command & SCB_CMD_RUC) == SCB_CMD_RUC_SUS) ? "suspend reception" : "",
scb2399drivers/net/wavelan.c((scb.scb_command & SCB_CMD_RUC) == SCB_CMD_RUC_ABT) ? "abort reception" : ""
scb2402drivers/net/wavelan.cprintk(" cbl_offset 0x%x", scb.scb_cbl_offset);
scb2403drivers/net/wavelan.cprintk(" rfa_offset 0x%x", scb.scb_rfa_offset);
scb2405drivers/net/wavelan.cprintk(" crcerrs %d", scb.scb_crcerrs);
scb2406drivers/net/wavelan.cprintk(" alnerrs %d", scb.scb_alnerrs);
scb2407drivers/net/wavelan.cprintk(" rscerrs %d", scb.scb_rscerrs);
scb2408drivers/net/wavelan.cprintk(" ovrnerrs %d", scb.scb_ovrnerrs);
scb1274drivers/scsi/aic7xxx.cdebug_scb(struct aic7xxx_scb *scb)
scb1277drivers/scsi/aic7xxx.cscb->control, scb->target_channel_lun, scb->SG_segment_count,
scb1278drivers/scsi/aic7xxx.c(scb->SG_list_pointer[3] << 24) | (scb->SG_list_pointer[2] << 16) |
scb1279drivers/scsi/aic7xxx.c(scb->SG_list_pointer[1] << 8) | scb->SG_list_pointer[0],
scb1280drivers/scsi/aic7xxx.c(scb->SCSI_cmd_pointer[3] << 24) | (scb->SCSI_cmd_pointer[2] << 16) |
scb1281drivers/scsi/aic7xxx.c(scb->SCSI_cmd_pointer[1] << 8) | scb->SCSI_cmd_pointer[0],
scb1282drivers/scsi/aic7xxx.cscb->SCSI_cmd_length);
scb1284drivers/scsi/aic7xxx.c(scb->RESERVED[1] << 8) | scb->RESERVED[0], scb->target_status,
scb1285drivers/scsi/aic7xxx.cscb->residual_SG_segment_count, (scb->residual_data_count[2] << 16) |
scb1286drivers/scsi/aic7xxx.c(scb->residual_data_count[1] << 8) | scb->residual_data_count[0]);
scb1288drivers/scsi/aic7xxx.c(scb->data_pointer[3] << 24) | (scb->data_pointer[2] << 16) |
scb1289drivers/scsi/aic7xxx.c(scb->data_pointer[1] << 8) | scb->data_pointer[0],
scb1290drivers/scsi/aic7xxx.c(scb->data_count[2] << 16) | (scb->data_count[1] << 8) | scb->data_count[0],
scb1291drivers/scsi/aic7xxx.c(unsigned int) scb->host_scb, scb->next_waiting);
scb1293drivers/scsi/aic7xxx.c(unsigned long) scb->next, (unsigned long) scb->cmd, scb->state,
scb1294drivers/scsi/aic7xxx.cscb->position);
scb1617drivers/scsi/aic7xxx.caic7xxx_putscb(int base, struct aic7xxx_scb *scb)
scb1624drivers/scsi/aic7xxx.coutb(scb->position, QINFIFO(base));
scb1635drivers/scsi/aic7xxx.caic7xxx_putscb_dma(int base, struct aic7xxx_scb *scb)
scb1649drivers/scsi/aic7xxx.c:"S" (scb), "c" (31), "d" (SCBARRAY(base))
scb1663drivers/scsi/aic7xxx.caic7xxx_getscb(int base, struct aic7xxx_scb *scb)
scb1674drivers/scsi/aic7xxx.c:"D" (scb), "c" (SCB_UPLOAD_SIZE), "d" (SCBARRAY(base))
scb1691drivers/scsi/aic7xxx.caic7xxx_match_scb(struct aic7xxx_scb *scb, int target, char channel)
scb1693drivers/scsi/aic7xxx.cint targ = (scb->target_channel_lun >> 4) & 0x0F;
scb1694drivers/scsi/aic7xxx.cchar chan = (scb->target_channel_lun & SELBUSB) ? 'B' : 'A';
scb1748drivers/scsi/aic7xxx.caic7xxx_done(struct aic7xxx_host *p, struct aic7xxx_scb *scb)
scb1751drivers/scsi/aic7xxx.cScsi_Cmnd *cmd = scb->cmd;
scb1768drivers/scsi/aic7xxx.cscb->state = SCB_FREE;
scb1769drivers/scsi/aic7xxx.cscb->next = p->free_scb;
scb1770drivers/scsi/aic7xxx.cp->free_scb = &(p->scb_array[scb->position]);
scb1771drivers/scsi/aic7xxx.cscb->cmd = NULL;
scb1787drivers/scsi/aic7xxx.cstruct aic7xxx_scb *scb,
scb1801drivers/scsi/aic7xxx.chead = scb->position;
scb1808drivers/scsi/aic7xxx.coutb(scb->position, SCBPTR(base));
scb1810drivers/scsi/aic7xxx.chead = scb->position;
scb1819drivers/scsi/aic7xxx.ctail = scb->position;
scb1831drivers/scsi/aic7xxx.coutb(scb->position, SCBARRAY(base) + 30);
scb1832drivers/scsi/aic7xxx.coutb(scb->position, SCBPTR(base));
scb1838drivers/scsi/aic7xxx.ctail = scb->position;
scb1858drivers/scsi/aic7xxx.caic7xxx_abort_waiting_scb(struct aic7xxx_host *p, struct aic7xxx_scb *scb,
scb1862drivers/scsi/aic7xxx.cint target = (scb->target_channel_lun >> 4) & 0x0F;
scb1863drivers/scsi/aic7xxx.cchar channel = (scb->target_channel_lun & SELBUSB) ? 'B' : 'A';
scb1871drivers/scsi/aic7xxx.coutb(scb->position, SCBPTR(base));
scb1902drivers/scsi/aic7xxx.cif (inb(WAITING_SCBT(base)) == scb->position)
scb1913drivers/scsi/aic7xxx.cscb->state |= SCB_ABORTED;
scb1914drivers/scsi/aic7xxx.cscb->cmd->result = (DID_RESET << 16);
scb1915drivers/scsi/aic7xxx.caic7xxx_done(p, scb);
scb1937drivers/scsi/aic7xxx.cstruct aic7xxx_scb *scb;
scb1961drivers/scsi/aic7xxx.cscb = &(p->scb_array[saved_queue[i]]);
scb1962drivers/scsi/aic7xxx.cif (aic7xxx_match_scb(scb, target, channel))
scb1967drivers/scsi/aic7xxx.cscb->state |= SCB_ABORTED;
scb1968drivers/scsi/aic7xxx.cscb->cmd->result = (DID_RESET << 16);
scb1969drivers/scsi/aic7xxx.caic7xxx_done(p, scb);
scb1970drivers/scsi/aic7xxx.coutb(scb->position, SCBPTR(base));
scb1996drivers/scsi/aic7xxx.cscb = &(p->scb_array[next]);
scb2000drivers/scsi/aic7xxx.cif (aic7xxx_match_scb(scb, target, channel))
scb2002drivers/scsi/aic7xxx.cnext = aic7xxx_abort_waiting_scb(p, scb, prev, timedout_scb);
scb2007drivers/scsi/aic7xxx.coutb(scb->position, SCBPTR(base));
scb2022drivers/scsi/aic7xxx.cscb = &(p->scb_array[i]);
scb2023drivers/scsi/aic7xxx.cif ((scb->state & SCB_ACTIVE) && aic7xxx_match_scb(scb, target, channel))
scb2029drivers/scsi/aic7xxx.coutb(scb->position, SCBPTR(base));
scb2031drivers/scsi/aic7xxx.cscb->state |= SCB_ABORTED;
scb2032drivers/scsi/aic7xxx.cscb->cmd->result = (DID_RESET << 16);
scb2033drivers/scsi/aic7xxx.caic7xxx_done(p, scb);
scb2185drivers/scsi/aic7xxx.cstruct aic7xxx_scb *scb;
scb2310drivers/scsi/aic7xxx.cscb = &(p->scb_array[scb_index]);
scb2313drivers/scsi/aic7xxx.cscb->cmd->device->tagged_supported = 0;
scb2314drivers/scsi/aic7xxx.cscb->cmd->device->tagged_queue = 0;
scb2401drivers/scsi/aic7xxx.cscb = &(p->scb_array[scb_index]);
scb2402drivers/scsi/aic7xxx.cdebug_scb(scb);
scb2516drivers/scsi/aic7xxx.cscb = &(p->scb_array[scb_index]);
scb2518drivers/scsi/aic7xxx.cif ((scb->state != SCB_ACTIVE) || (scb->cmd == NULL))
scb2522drivers/scsi/aic7xxx.cintstat, scb_index, scb->state, (unsigned int) scb->cmd);
scb2526drivers/scsi/aic7xxx.ccmd = scb->cmd;
scb2527drivers/scsi/aic7xxx.caic7xxx_getscb(base, scb);
scb2528drivers/scsi/aic7xxx.caic7xxx_status(cmd) = scb->target_status;
scb2530drivers/scsi/aic7xxx.ccmd->result |= scb->target_status;
scb2532drivers/scsi/aic7xxx.cswitch (status_byte(scb->target_status))
scb2545drivers/scsi/aic7xxx.ctcl = scb->target_channel_lun;
scb2550drivers/scsi/aic7xxx.cmemcpy((void *) scb->sense_cmd, (void *) generic_sense,
scb2553drivers/scsi/aic7xxx.cscb->sense_cmd[1] = (cmd->lun << 5);
scb2554drivers/scsi/aic7xxx.cscb->sense_cmd[4] = sizeof(cmd->sense_buffer);
scb2556drivers/scsi/aic7xxx.cscb->sense_sg.address = (char *) &cmd->sense_buffer;
scb2557drivers/scsi/aic7xxx.cscb->sense_sg.length = sizeof(cmd->sense_buffer);
scb2558drivers/scsi/aic7xxx.creq_buf = &scb->sense_sg;
scb2560drivers/scsi/aic7xxx.ccontrol = scb->control;
scb2561drivers/scsi/aic7xxx.cmemset(scb, 0, SCB_DOWNLOAD_SIZE);
scb2562drivers/scsi/aic7xxx.cscb->control = control & SCB_DISCENB;
scb2563drivers/scsi/aic7xxx.cscb->target_channel_lun = tcl;
scb2564drivers/scsi/aic7xxx.caddr = scb->sense_cmd;
scb2565drivers/scsi/aic7xxx.cscb->SCSI_cmd_length = COMMAND_SIZE(scb->sense_cmd[0]);
scb2566drivers/scsi/aic7xxx.cmemcpy(scb->SCSI_cmd_pointer, &addr,
scb2567drivers/scsi/aic7xxx.csizeof(scb->SCSI_cmd_pointer));
scb2568drivers/scsi/aic7xxx.cscb->SG_segment_count = 1;
scb2569drivers/scsi/aic7xxx.cmemcpy(scb->SG_list_pointer, &req_buf,
scb2570drivers/scsi/aic7xxx.csizeof(scb->SG_list_pointer));
scb2571drivers/scsi/aic7xxx.cscb->data_count[0] = scb->sense_sg.length & 0xFF;
scb2572drivers/scsi/aic7xxx.cscb->data_count[1] = (scb->sense_sg.length >> 8) & 0xFF;
scb2573drivers/scsi/aic7xxx.cscb->data_count[2] = (scb->sense_sg.length >> 16) & 0xFF;
scb2574drivers/scsi/aic7xxx.cmemcpy(scb->data_pointer, &(scb->sense_sg.address), 4);
scb2581drivers/scsi/aic7xxx.c:"S" (scb), "c" (SCB_DOWNLOAD_SIZE), "d" (SCBARRAY(base))
scb2594drivers/scsi/aic7xxx.caic7xxx_add_waiting_scb(base, scb, LIST_HEAD);
scb2626drivers/scsi/aic7xxx.cscb->target_status);
scb2638drivers/scsi/aic7xxx.cscb = &(p->scb_array[scb_index]);
scb2639drivers/scsi/aic7xxx.cif ((scb->state != SCB_ACTIVE) || (scb->cmd == NULL))
scb2643drivers/scsi/aic7xxx.cintstat, scb_index, scb->state, (unsigned int) scb->cmd);
scb2647drivers/scsi/aic7xxx.ccmd = scb->cmd;
scb2660drivers/scsi/aic7xxx.cactual = aic7xxx_length(cmd, scb->residual_SG_segment_count);
scb2673drivers/scsi/aic7xxx.caic7xxx_status(cmd) = scb->target_status;
scb2681drivers/scsi/aic7xxx.cscb = &(p->scb_array[scb_index]);
scb2682drivers/scsi/aic7xxx.cif ((scb->state != SCB_ACTIVE) || (scb->cmd == NULL))
scb2686drivers/scsi/aic7xxx.cintstat, scb_index, scb->state, (unsigned int) scb->cmd);
scb2690drivers/scsi/aic7xxx.ccmd = scb->cmd;
scb2700drivers/scsi/aic7xxx.caic7xxx_done(p, scb);
scb2706drivers/scsi/aic7xxx.cscb = &(p->scb_array[scb_index]);
scb2707drivers/scsi/aic7xxx.cif ((scb->state != SCB_ACTIVE) || (scb->cmd == NULL))
scb2711drivers/scsi/aic7xxx.cintstat, scb_index, scb->state, (unsigned int) scb->cmd);
scb2720drivers/scsi/aic7xxx.cif (scb->state & SCB_DEVICE_RESET)
scb2739drivers/scsi/aic7xxx.cscb = &(p->scb_array[scb_index]);
scb2742drivers/scsi/aic7xxx.cscsi_id, scb_index, scb->state);
scb2744drivers/scsi/aic7xxx.cif (scb->state & SCB_DEVICE_RESET)
scb2781drivers/scsi/aic7xxx.cscb = &(p->scb_array[scb_index]);
scb2782drivers/scsi/aic7xxx.cif ((scb->state != SCB_ACTIVE) || (scb->cmd == NULL))
scb2794drivers/scsi/aic7xxx.cscb = NULL;
scb2798drivers/scsi/aic7xxx.ccmd = scb->cmd;
scb2825drivers/scsi/aic7xxx.cif (scb->target_channel_lun & 0x88)
scb2868drivers/scsi/aic7xxx.caic7xxx_done(p, scb);
scb2871drivers/scsi/aic7xxx.cscb->position, scb->state, (unsigned int) scb->cmd);
scb2893drivers/scsi/aic7xxx.cscb = NULL;
scb2907drivers/scsi/aic7xxx.cscb = NULL;
scb2926drivers/scsi/aic7xxx.cscb = &(p->scb_array[complete]);
scb2927drivers/scsi/aic7xxx.cif ((scb->state != SCB_ACTIVE) || (scb->cmd == NULL))
scb2932drivers/scsi/aic7xxx.cscb->state, (unsigned int) scb->cmd, scb->position);
scb2936drivers/scsi/aic7xxx.ccmd = scb->cmd;
scb2948drivers/scsi/aic7xxx.cscb->state, (unsigned int) scb->cmd, (unsigned int) p->free_scb);
scb2961drivers/scsi/aic7xxx.caic7xxx_done(p, scb);
scb2963drivers/scsi/aic7xxx.cif (scb != &p->scb_array[scb->position])
scb2965drivers/scsi/aic7xxx.cprintk("aic7xxx: (complete) Address mismatch, pos(%d).\n", scb->position);
scb2968drivers/scsi/aic7xxx.cscb->state, (unsigned int) scb->cmd, (unsigned int) p->free_scb);
scb4421drivers/scsi/aic7xxx.cstruct aic7xxx_scb *scb)
scb4443drivers/scsi/aic7xxx.cscb->control |= SCB_TE;
scb4449drivers/scsi/aic7xxx.cscb->control |= SCB_DISCENB;
scb4454drivers/scsi/aic7xxx.cscb->control |= SCB_NEEDWDTR;
scb4464drivers/scsi/aic7xxx.cscb->control |= SCB_NEEDSDTR;
scb4476drivers/scsi/aic7xxx.cscb->target_channel_lun = ((cmd->target << 4) & 0xF0) |
scb4491drivers/scsi/aic7xxx.cscb->SCSI_cmd_length = cmd->cmd_len;
scb4492drivers/scsi/aic7xxx.cmemcpy(scb->SCSI_cmd_pointer, &addr, sizeof(scb->SCSI_cmd_pointer));
scb4500drivers/scsi/aic7xxx.cscb->SG_segment_count = cmd->use_sg;
scb4501drivers/scsi/aic7xxx.cmemcpy(scb->SG_list_pointer, &cmd->request_buffer,
scb4502drivers/scsi/aic7xxx.csizeof(scb->SG_list_pointer));
scb4504drivers/scsi/aic7xxx.cmemcpy(scb->data_pointer, &(sg[0].address), sizeof(scb->data_pointer));
scb4505drivers/scsi/aic7xxx.cscb->data_count[0] = sg[0].length & 0xFF;
scb4506drivers/scsi/aic7xxx.cscb->data_count[1] = (sg[0].length >> 8) & 0xFF;
scb4507drivers/scsi/aic7xxx.cscb->data_count[2] = (sg[0].length >> 16) & 0xFF;
scb4522drivers/scsi/aic7xxx.cscb->SG_segment_count = 0;
scb4523drivers/scsi/aic7xxx.cmemset(scb->SG_list_pointer, 0, sizeof(scb->SG_list_pointer));
scb4524drivers/scsi/aic7xxx.cmemset(scb->data_pointer, 0, sizeof(scb->data_pointer));
scb4525drivers/scsi/aic7xxx.cmemset(scb->data_count, 0, sizeof(scb->data_count));
scb4529drivers/scsi/aic7xxx.cscb->SG_segment_count = 1;
scb4530drivers/scsi/aic7xxx.cscb->sg.address = (char *) cmd->request_buffer;
scb4531drivers/scsi/aic7xxx.cscb->sg.length = cmd->request_bufflen;
scb4532drivers/scsi/aic7xxx.caddr = &scb->sg;
scb4533drivers/scsi/aic7xxx.cmemcpy(scb->SG_list_pointer, &addr, sizeof(scb->SG_list_pointer));
scb4534drivers/scsi/aic7xxx.cscb->data_count[0] = scb->sg.length & 0xFF;
scb4535drivers/scsi/aic7xxx.cscb->data_count[1] = (scb->sg.length >> 8) & 0xFF;
scb4536drivers/scsi/aic7xxx.cscb->data_count[2] = (scb->sg.length >> 16) & 0xFF;
scb4537drivers/scsi/aic7xxx.cmemcpy(scb->data_pointer, &cmd->request_buffer, sizeof(scb->data_pointer));
scb4554drivers/scsi/aic7xxx.cstruct aic7xxx_scb *scb;
scb4601drivers/scsi/aic7xxx.cscb = p->free_scb;
scb4602drivers/scsi/aic7xxx.cif (scb != NULL)
scb4604drivers/scsi/aic7xxx.cp->free_scb = scb->next;   /* remove and update head of list */
scb4612drivers/scsi/aic7xxx.cscb = &(p->scb_array[scb->position]);
scb4613drivers/scsi/aic7xxx.cscb->control = 0;
scb4614drivers/scsi/aic7xxx.cscb->state = SCB_ACTIVE;
scb4629drivers/scsi/aic7xxx.cscb = &(p->scb_array[p->numscb]);
scb4630drivers/scsi/aic7xxx.cmemset(scb, 0, sizeof(*scb));
scb4632drivers/scsi/aic7xxx.cscb->position = p->numscb;
scb4634drivers/scsi/aic7xxx.cscb->state = SCB_ACTIVE;
scb4635drivers/scsi/aic7xxx.cscb->next_waiting = SCB_LIST_NULL;
scb4636drivers/scsi/aic7xxx.cmemcpy(scb->host_scb, &scb, sizeof(scb));
scb4637drivers/scsi/aic7xxx.cscb->control = SCB_NEEDDMA;
scb4640drivers/scsi/aic7xxx.coutb(scb->position, SCBPTR(p->base));
scb4641drivers/scsi/aic7xxx.caic7xxx_putscb_dma(p->base, scb);
scb4644drivers/scsi/aic7xxx.cscb->control = 0;
scb4648drivers/scsi/aic7xxx.cscb->cmd = cmd;
scb4649drivers/scsi/aic7xxx.caic7xxx_position(cmd) = scb->position;
scb4651drivers/scsi/aic7xxx.cdebug_scb(scb);
scb4658drivers/scsi/aic7xxx.caic7xxx_buildscb(p, cmd, scb);
scb4661drivers/scsi/aic7xxx.cif (scb != &p->scb_array[scb->position])
scb4667drivers/scsi/aic7xxx.cscb->position, (unsigned int) scb->cmd,
scb4668drivers/scsi/aic7xxx.cscb->state, (unsigned int) p->free_scb);
scb4684drivers/scsi/aic7xxx.caic7xxx_putscb(p->base, scb);
scb4701drivers/scsi/aic7xxx.c(long) cmd, (long) scb->cmd, scb->position);
scb4719drivers/scsi/aic7xxx.caic7xxx_abort_scb(struct aic7xxx_host *p, struct aic7xxx_scb *scb,
scb4725drivers/scsi/aic7xxx.cchar channel = scb->target_channel_lun & SELBUSB ? 'B': 'A';
scb4735drivers/scsi/aic7xxx.cscb->position, (scb->state & SCB_ABORTED));
scb4743drivers/scsi/aic7xxx.cif (scb->state & SCB_ABORTED)
scb4748drivers/scsi/aic7xxx.cfound = aic7xxx_reset_channel(p, channel, scb->position);
scb4775drivers/scsi/aic7xxx.coutb(scb->position, SCBPTR(base));
scb4779drivers/scsi/aic7xxx.cprintk ("aic7xxx: (abort_scb) scb %d is disconnected.\n", scb->position);
scb4781drivers/scsi/aic7xxx.cscb->state |= (SCB_DEVICE_RESET | SCB_ABORTED);
scb4782drivers/scsi/aic7xxx.cscb->SG_segment_count = 0;
scb4783drivers/scsi/aic7xxx.cmemset(scb->SG_list_pointer, 0, sizeof(scb->SG_list_pointer));
scb4784drivers/scsi/aic7xxx.cmemset(scb->data_pointer, 0, sizeof(scb->data_pointer));
scb4785drivers/scsi/aic7xxx.cmemset(scb->data_count, 0, sizeof(scb->data_count));
scb4791drivers/scsi/aic7xxx.c:"S" (scb), "c" (SCB_DOWNLOAD_SIZE), "d" (SCBARRAY(base))
scb4794drivers/scsi/aic7xxx.caic7xxx_error(scb->cmd) = errcode;
scb4796drivers/scsi/aic7xxx.caic7xxx_add_waiting_scb(base, scb, LIST_SECOND);
scb4819drivers/scsi/aic7xxx.caic7xxx_reset_channel(p, channel, scb->position);
scb4834drivers/scsi/aic7xxx.cif (active_scbp->target_channel_lun != scb->target_channel_lun)
scb4844drivers/scsi/aic7xxx.caic7xxx_error(scb->cmd) = errcode;
scb4858drivers/scsi/aic7xxx.caic7xxx_reset_channel(p, channel, scb->position);
scb4876drivers/scsi/aic7xxx.cstruct aic7xxx_scb  *scb;
scb4882drivers/scsi/aic7xxx.cscb = &(p->scb_array[aic7xxx_position(cmd)]);
scb4888drivers/scsi/aic7xxx.cprintk ("aic7xxx: (abort_reset) scb state 0x%x\n", scb->state);
scb4891drivers/scsi/aic7xxx.cif (scb->state & SCB_ACTIVE)
scb4893drivers/scsi/aic7xxx.cif (scb->state & SCB_IMMED)
scb4900drivers/scsi/aic7xxx.caic7xxx_done (p, scb);
scb4907drivers/scsi/aic7xxx.cscb_status = aic7xxx_abort_scb(p, scb, errcode);
scb354drivers/scsi/wd7000.cstruct scb *next;             /* for lists of scbs */
scb608drivers/scsi/wd7000.cregister Scb *scb, *p;
scb644drivers/scsi/wd7000.cscb = scbfree;  freescbs -= needed;
scb652drivers/scsi/wd7000.creturn scb;
scb656drivers/scsi/wd7000.cstatic inline void free_scb( Scb *scb )
scb663drivers/scsi/wd7000.cmemset(scb, 0, sizeof(Scb));
scb664drivers/scsi/wd7000.cscb->next = scbfree;  scbfree = scb;
scb815drivers/scsi/wd7000.cregister Scb *scb;             /* for SCSI commands */
scb871drivers/scsi/wd7000.cscb = (struct scb *) scsi2int((unchar *)icmbs[icmb].scbptr);
scb873drivers/scsi/wd7000.cif (!(scb->op & ICB_OP_MASK))  {   /* an SCB is done */
scb874drivers/scsi/wd7000.cSCpnt = scb->SCpnt;
scb876drivers/scsi/wd7000.chost_error = scb->vue | (icmb_status << 8);
scb877drivers/scsi/wd7000.cscsi_error = scb->status;
scb881drivers/scsi/wd7000.cfree_scb(scb);
scb886drivers/scsi/wd7000.cicb = (IcbAny *) scb;
scb900drivers/scsi/wd7000.cregister Scb *scb;
scb911drivers/scsi/wd7000.cscb = alloc_scbs(1);
scb912drivers/scsi/wd7000.cscb->idlun = idlun;
scb913drivers/scsi/wd7000.cmemcpy(scb->cdb, cdb, cdblen);
scb914drivers/scsi/wd7000.cscb->direc = 0x40;    /* Disable direction check */
scb916drivers/scsi/wd7000.cscb->SCpnt = SCpnt;         /* so we can find stuff later */
scb917drivers/scsi/wd7000.cSCpnt->host_scribble = (unchar *) scb;
scb918drivers/scsi/wd7000.cscb->host = host;
scb931drivers/scsi/wd7000.csgb = scb->sgb;
scb932drivers/scsi/wd7000.cscb->op = 1;
scb933drivers/scsi/wd7000.cany2scsi(scb->dataptr, (int) sgb);
scb934drivers/scsi/wd7000.cany2scsi(scb->maxlen, SCpnt->use_sg * sizeof (Sgb) );
scb941drivers/scsi/wd7000.cscb->op = 0;
scb942drivers/scsi/wd7000.cany2scsi(scb->dataptr, (int) SCpnt->request_buffer);
scb943drivers/scsi/wd7000.cany2scsi(scb->maxlen, SCpnt->request_bufflen);
scb945drivers/scsi/wd7000.cwhile (!mail_out(host, scb)) /* keep trying */;
scb976drivers/scsi/wd7000.cmail_out(host, (struct scb *) &icb);
scb1088drivers/scsi/wd7000.cmail_out(host, (struct scb *) &icb);