taglinefilesource code
scb143drivers/net/apricot.cstruct i596_scb *scb;
scb155drivers/net/apricot.cstruct i596_scb scb;
scb206drivers/net/apricot.clp->scb.rfd = (struct i596_rfd *)I596_NULL;
scb227drivers/net/apricot.crfd->next = lp->scb.rfd;
scb228drivers/net/apricot.clp->scb.rfd = rfd;
scb232drivers/net/apricot.clp->rx_tail->next = lp->scb.rfd;
scb241drivers/net/apricot.cstruct i596_rfd *rfd = lp->scb.rfd;
scb247drivers/net/apricot.clp->scb.rfd = rfd->next;
scb249drivers/net/apricot.crfd = lp->scb.rfd;
scb272drivers/net/apricot.clp->iscp.scb = &(lp->scb);
scb276drivers/net/apricot.clp->cmd_head = lp->scb.cmd = (struct i596_cmd *) I596_NULL;
scb288drivers/net/apricot.cdev->name, lp->scb.status, lp->scb.command);
scb292drivers/net/apricot.clp->scb.command = 0;
scb306drivers/net/apricot.cwhile (lp->scb.status, lp->scb.command)
scb310drivers/net/apricot.cdev->name, lp->scb.status, lp->scb.command);
scb314drivers/net/apricot.clp->scb.command = RX_START;
scb318drivers/net/apricot.cwhile (lp->scb.status, lp->scb.command)
scb322drivers/net/apricot.clp->scb.status, lp->scb.command);
scb337drivers/net/apricot.cwhile ((lp->scb.rfd->stat) & STAT_C)
scb339drivers/net/apricot.cif (i596_debug >2) print_eth(lp->scb.rfd->data);
scb341drivers/net/apricot.cif ((lp->scb.rfd->stat) & STAT_OK)
scb344drivers/net/apricot.cint pkt_len = lp->scb.rfd->count & 0x3fff;
scb358drivers/net/apricot.cmemcpy(skb->data, lp->scb.rfd->data, pkt_len);
scb369drivers/net/apricot.cif ((lp->scb.rfd->stat) & 0x0001) lp->stats.collisions++;
scb370drivers/net/apricot.cif ((lp->scb.rfd->stat) & 0x0080) lp->stats.rx_length_errors++;
scb371drivers/net/apricot.cif ((lp->scb.rfd->stat) & 0x0100) lp->stats.rx_over_errors++;
scb372drivers/net/apricot.cif ((lp->scb.rfd->stat) & 0x0200) lp->stats.rx_fifo_errors++;
scb373drivers/net/apricot.cif ((lp->scb.rfd->stat) & 0x0400) lp->stats.rx_frame_errors++;
scb374drivers/net/apricot.cif ((lp->scb.rfd->stat) & 0x0800) lp->stats.rx_crc_errors++;
scb375drivers/net/apricot.cif ((lp->scb.rfd->stat) & 0x1000) lp->stats.rx_length_errors++;
scb378drivers/net/apricot.clp->scb.rfd->stat = 0;
scb380drivers/net/apricot.clp->rx_tail = lp->scb.rfd;
scb381drivers/net/apricot.clp->scb.rfd = lp->scb.rfd->next;
scb436drivers/net/apricot.cwhile (lp->scb.status, lp->scb.command)
scb440drivers/net/apricot.clp->scb.status, lp->scb.command);
scb444drivers/net/apricot.clp->scb.cmd = lp->cmd_head;
scb454drivers/net/apricot.cwhile (lp->scb.status, lp->scb.command)
scb458drivers/net/apricot.clp->scb.status, lp->scb.command);
scb465drivers/net/apricot.clp->scb.command = CUC_ABORT|RX_ABORT;
scb471drivers/net/apricot.cwhile ((lp->scb.status, lp->scb.command) || lp->scb.command)
scb475drivers/net/apricot.clp->scb.status, lp->scb.command);
scb508drivers/net/apricot.cwhile (lp->scb.status, lp->scb.command)
scb512drivers/net/apricot.clp->scb.status, lp->scb.command);
scb516drivers/net/apricot.clp->scb.cmd = cmd;
scb517drivers/net/apricot.clp->scb.command = CUC_START;
scb523drivers/net/apricot.clp->cmd_head = lp->scb.cmd;
scb603drivers/net/apricot.clp->scb.command = CUC_START|RX_START;
scb748drivers/net/apricot.clp->scb.command = 0;
scb749drivers/net/apricot.clp->scb.cmd = (struct i596_cmd *) I596_NULL;
scb750drivers/net/apricot.clp->scb.rfd = (struct i596_rfd *)I596_NULL;
scb780drivers/net/apricot.cwhile (lp->scb.status, lp->scb.command)
scb783drivers/net/apricot.cprintk("%s: i596 interrupt, timeout status %4.4x command %4.4x.\n", dev->name, lp->scb.status, lp->scb.command);
scb786drivers/net/apricot.cstatus = lp->scb.status;
scb881drivers/net/apricot.clp->scb.cmd = lp->cmd_head;
scb902drivers/net/apricot.cwhile (lp->scb.status, lp->scb.command)
scb905drivers/net/apricot.cprintk("%s: i596 interrupt, timeout status %4.4x command %4.4x.\n", dev->name, lp->scb.status, lp->scb.command);
scb908drivers/net/apricot.clp->scb.command = ack_cmd;
scb933drivers/net/apricot.cdev->name, lp->scb.status);
scb935drivers/net/apricot.clp->scb.command = CUC_ABORT|RX_ABORT;
scb940drivers/net/apricot.cwhile (lp->scb.status, lp->scb.command)
scb944drivers/net/apricot.cdev->name, lp->scb.status, lp->scb.command);
scb143drivers/net/ni52.cif(!p->scb->cmd) break; \
scb189drivers/net/ni52.cvolatile struct scb_struct  *scb;  /* volatile is important */
scb293drivers/net/ni52.cp->scb  = (struct scb_struct *)  (dev->mem_start);
scb301drivers/net/ni52.cp->iscp->scb_offset = make16(p->scb);
scb312drivers/net/ni52.cmemset((char *)p->scb,0,sizeof(struct scb_struct));
scb461drivers/net/ni52.cptr = (void *) ((char *)p->scb + sizeof(struct scb_struct));
scb479drivers/net/ni52.cp->scb->cbl_offset = make16(cfg_cmd);
scb481drivers/net/ni52.cp->scb->cmd = CUC_START; /* cmd.-unit start */
scb505drivers/net/ni52.cp->scb->cbl_offset = make16(ias_cmd);
scb507drivers/net/ni52.cp->scb->cmd = CUC_START; /* cmd.-unit start */
scb529drivers/net/ni52.cp->scb->cbl_offset = make16(tdr_cmd);
scb531drivers/net/ni52.cp->scb->cmd = CUC_START; /* cmd.-unit start */
scb546drivers/net/ni52.cp->scb->cmd = p->scb->status & STAT_MASK;
scb566drivers/net/ni52.cp->scb->cmd = p->scb->status & STAT_MASK;
scb623drivers/net/ni52.cp->scb->cbl_offset = make16(mc_cmd);
scb624drivers/net/ni52.cp->scb->cmd = CUC_START;
scb668drivers/net/ni52.cp->scb->cbl_offset = make16(p->nop_cmds[0]);
scb669drivers/net/ni52.cp->scb->cmd = CUC_START;
scb718drivers/net/ni52.cp->scb->rfa_offset    = make16(p->rfd_first);
scb743drivers/net/ni52.cwhile((stat=p->scb->status & STAT_MASK))
scb745drivers/net/ni52.cp->scb->cmd = stat;
scb758drivers/net/ni52.cprintk("%s: oops! CU has left active state. stat: %04x/%04x.\n",dev->name,(int) stat,(int) p->scb->status);
scb764drivers/net/ni52.cif(p->scb->status & RU_SUSPEND) /* special case: RU_SUSPEND */
scb767drivers/net/ni52.cp->scb->cmd = RUC_RESUME;
scb772drivers/net/ni52.cprintk("%s: Receiver-Unit went 'NOT READY': %04x/%04x.\n",dev->name,(int) stat,(int) p->scb->status);
scb777drivers/net/ni52.cif(p->scb->cmd)   /* timed out? */
scb849drivers/net/ni52.cp->scb->cmd = RUC_ABORT; /* usually the RU is in the 'no resource'-state .. abort it now. */
scb856drivers/net/ni52.cprintk("%s: Receive-Unit restarted. Status: %04x\n",dev->name,p->scb->status);
scb918drivers/net/ni52.cp->scb->rfa_offset = make16(p->rfd_first);
scb919drivers/net/ni52.cp->scb->cmd = RUC_START;
scb942drivers/net/ni52.cif(p->scb->status & CU_ACTIVE) /* COMMAND-UNIT active? */
scb949drivers/net/ni52.cp->scb->cmd = CUC_ABORT;
scb952drivers/net/ni52.cp->scb->cbl_offset = make16(p->nop_cmds[p->nop_point]);
scb953drivers/net/ni52.cp->scb->cmd = CUC_START;
scb962drivers/net/ni52.cprintk("%s: xmitter timed out, try to restart! stat: %04x\n",dev->name,p->scb->status);
scb998drivers/net/ni52.cp->scb->cbl_offset = make16(p->xmit_cmds[0]);
scb999drivers/net/ni52.cp->scb->cmd = CUC_START;
scb1007drivers/net/ni52.cif( (p->scb->status & CU_ACTIVE)) /* test it, because CU sometimes doesn't start immediately */
scb1060drivers/net/ni52.ccrc = p->scb->crc_errs; /* get error-statistic from the ni82586 */
scb1061drivers/net/ni52.cp->scb->crc_errs -= crc;
scb1062drivers/net/ni52.caln = p->scb->aln_errs;
scb1063drivers/net/ni52.cp->scb->aln_errs -= aln;
scb1064drivers/net/ni52.crsc = p->scb->rsc_errs;
scb1065drivers/net/ni52.cp->scb->rsc_errs -= rsc;
scb1066drivers/net/ni52.covrn = p->scb->ovrn_errs;
scb1067drivers/net/ni52.cp->scb->ovrn_errs -= ovrn;
scb505drivers/net/wavelan.cscb_t    scb;
scb552drivers/net/wavelan.cmemset(&scb, 0x00, sizeof(scb));
scb553drivers/net/wavelan.cscb.scb_command = SCB_CMD_RESET;
scb554drivers/net/wavelan.cscb.scb_cbl_offset = OFFSET_CU;
scb555drivers/net/wavelan.cscb.scb_rfa_offset = OFFSET_RU;
scb556drivers/net/wavelan.cobram_write(ioaddr, OFFSET_SCB, (unsigned char *)&scb, sizeof(scb));
scb580drivers/net/wavelan.cobram_read(ioaddr, OFFSET_SCB, (unsigned char *)&scb, sizeof(scb));
scb582drivers/net/wavelan.cif (scb.scb_status == (SCB_ST_CX | SCB_ST_CNA))
scb590drivers/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);
scb2262drivers/net/wavelan.cscb_t  scb;
scb2264drivers/net/wavelan.cobram_read(ioaddr, OFFSET_SCB, (unsigned char *)&scb, sizeof(scb));   
scb2272drivers/net/wavelan.c(scb.scb_status & (SCB_ST_CX | SCB_ST_FR | SCB_ST_CNA | SCB_ST_RNR)) >> 12,
scb2273drivers/net/wavelan.c(scb.scb_status & SCB_ST_CX) ? "cmd completion interrupt," : "",
scb2274drivers/net/wavelan.c(scb.scb_status & SCB_ST_FR) ? "frame received," : "",
scb2275drivers/net/wavelan.c(scb.scb_status & SCB_ST_CNA) ? "cmd unit not active," : "",
scb2276drivers/net/wavelan.c(scb.scb_status & SCB_ST_RNR) ? "rcv unit not ready," : ""
scb2281drivers/net/wavelan.c(scb.scb_status & SCB_ST_CUS) >> 8,
scb2282drivers/net/wavelan.c((scb.scb_status & SCB_ST_CUS) == SCB_ST_CUS_IDLE) ? "idle" : "",
scb2283drivers/net/wavelan.c((scb.scb_status & SCB_ST_CUS) == SCB_ST_CUS_SUSP) ? "suspended" : "",
scb2284drivers/net/wavelan.c((scb.scb_status & SCB_ST_CUS) == SCB_ST_CUS_ACTV) ? "active" : ""
scb2289drivers/net/wavelan.c(scb.scb_status & SCB_ST_RUS) >> 4,
scb2290drivers/net/wavelan.c((scb.scb_status & SCB_ST_RUS) == SCB_ST_RUS_IDLE) ? "idle" : "",
scb2291drivers/net/wavelan.c((scb.scb_status & SCB_ST_RUS) == SCB_ST_RUS_SUSP) ? "suspended" : "",
scb2292drivers/net/wavelan.c((scb.scb_status & SCB_ST_RUS) == SCB_ST_RUS_NRES) ? "no resources" : "",
scb2293drivers/net/wavelan.c((scb.scb_status & SCB_ST_RUS) == SCB_ST_RUS_RDY) ? "ready" : ""
scb2300drivers/net/wavelan.c(scb.scb_command & (SCB_CMD_ACK_CX | SCB_CMD_ACK_FR | SCB_CMD_ACK_CNA | SCB_CMD_ACK_RNR)) >> 12,
scb2301drivers/net/wavelan.c(scb.scb_command & SCB_CMD_ACK_CX) ? "ack cmd completion," : "",
scb2302drivers/net/wavelan.c(scb.scb_command & SCB_CMD_ACK_FR) ? "ack frame received," : "",
scb2303drivers/net/wavelan.c(scb.scb_command & SCB_CMD_ACK_CNA) ? "ack CU not active," : "",
scb2304drivers/net/wavelan.c(scb.scb_command & SCB_CMD_ACK_RNR) ? "ack RU not ready," : ""
scb2309drivers/net/wavelan.c(scb.scb_command & SCB_CMD_CUC) >> 8,
scb2310drivers/net/wavelan.c((scb.scb_command & SCB_CMD_CUC) == SCB_CMD_CUC_NOP) ? "nop" : "",
scb2311drivers/net/wavelan.c((scb.scb_command & SCB_CMD_CUC) == SCB_CMD_CUC_GO) ? "start cbl_offset" : "",
scb2312drivers/net/wavelan.c((scb.scb_command & SCB_CMD_CUC) == SCB_CMD_CUC_RES) ? "resume execution" : "",
scb2313drivers/net/wavelan.c((scb.scb_command & SCB_CMD_CUC) == SCB_CMD_CUC_SUS) ? "suspend execution" : "",
scb2314drivers/net/wavelan.c((scb.scb_command & SCB_CMD_CUC) == SCB_CMD_CUC_ABT) ? "abort execution" : ""
scb2319drivers/net/wavelan.c(scb.scb_command & SCB_CMD_RUC) >> 4,
scb2320drivers/net/wavelan.c((scb.scb_command & SCB_CMD_RUC) == SCB_CMD_RUC_NOP) ? "nop" : "",
scb2321drivers/net/wavelan.c((scb.scb_command & SCB_CMD_RUC) == SCB_CMD_RUC_GO) ? "start rfa_offset" : "",
scb2322drivers/net/wavelan.c((scb.scb_command & SCB_CMD_RUC) == SCB_CMD_RUC_RES) ? "resume reception" : "",
scb2323drivers/net/wavelan.c((scb.scb_command & SCB_CMD_RUC) == SCB_CMD_RUC_SUS) ? "suspend reception" : "",
scb2324drivers/net/wavelan.c((scb.scb_command & SCB_CMD_RUC) == SCB_CMD_RUC_ABT) ? "abort reception" : ""
scb2327drivers/net/wavelan.cprintk(" cbl_offset 0x%x", scb.scb_cbl_offset);
scb2328drivers/net/wavelan.cprintk(" rfa_offset 0x%x", scb.scb_rfa_offset);
scb2330drivers/net/wavelan.cprintk(" crcerrs %d", scb.scb_crcerrs);
scb2331drivers/net/wavelan.cprintk(" alnerrs %d", scb.scb_alnerrs);
scb2332drivers/net/wavelan.cprintk(" rscerrs %d", scb.scb_rscerrs);
scb2333drivers/net/wavelan.cprintk(" ovrnerrs %d", scb.scb_ovrnerrs);
scb1232drivers/scsi/aic7xxx.caic7xxx_putscb(int base, struct aic7xxx_scb *scb)
scb1240drivers/scsi/aic7xxx.coutb(scb->position, QINFIFO(base));
scb1254drivers/scsi/aic7xxx.c:"S" (scb), "c" (SCB_DOWNLOAD_SIZE), "d" (SCBARRAY(base))
scb1269drivers/scsi/aic7xxx.caic7xxx_putdmascb(int base, struct aic7xxx_scb *scb)
scb1283drivers/scsi/aic7xxx.c:"S" (scb), "c" (31), "d" (SCBARRAY(base))
scb1297drivers/scsi/aic7xxx.caic7xxx_getscb(int base, struct aic7xxx_scb *scb)
scb1308drivers/scsi/aic7xxx.c:"D" (scb), "c" (SCB_UPLOAD_SIZE), "d" (SCBARRAY(base))
scb1394drivers/scsi/aic7xxx.cstruct aic7xxx_scb *scb;
scb1725drivers/scsi/aic7xxx.cscb = &(p->scb_array[scbptr]);
scb1727drivers/scsi/aic7xxx.cif ((scb->state != SCB_ACTIVE) || (scb->cmd == NULL))
scb1731drivers/scsi/aic7xxx.cintstat, scbptr, scb->state, (unsigned int) scb->cmd);
scb1735drivers/scsi/aic7xxx.ccmd = scb->cmd;
scb1736drivers/scsi/aic7xxx.caic7xxx_getscb(base, scb);
scb1737drivers/scsi/aic7xxx.caic7xxx_status(cmd) = scb->target_status;
scb1739drivers/scsi/aic7xxx.ccmd->result = cmd->result | scb->target_status;
scb1745drivers/scsi/aic7xxx.cswitch (status_byte(scb->target_status))
scb1763drivers/scsi/aic7xxx.cmemcpy((void *) scb->sense_cmd, (void *) generic_sense,
scb1766drivers/scsi/aic7xxx.cscb->sense_cmd[1] = cmd->lun << 5;
scb1767drivers/scsi/aic7xxx.cscb->sense_cmd[4] = sizeof(cmd->sense_buffer);
scb1770drivers/scsi/aic7xxx.cscb->sense_sg.address = (char *) &cmd->sense_buffer;
scb1771drivers/scsi/aic7xxx.cscb->sense_sg.length = sizeof(cmd->sense_buffer);
scb1772drivers/scsi/aic7xxx.creq_buf = &scb->sense_sg;
scb1778drivers/scsi/aic7xxx.cmemset(scb, 0, SCB_DOWNLOAD_SIZE);
scb1779drivers/scsi/aic7xxx.cscb->target_channel_lun = ((cmd->target << 4) & 0xF0) |
scb1781drivers/scsi/aic7xxx.caddr = scb->sense_cmd;
scb1782drivers/scsi/aic7xxx.cscb->SCSI_cmd_length = COMMAND_SIZE(scb->sense_cmd[0]);
scb1783drivers/scsi/aic7xxx.cmemcpy(scb->SCSI_cmd_pointer, &addr,
scb1784drivers/scsi/aic7xxx.csizeof(scb->SCSI_cmd_pointer));
scb1786drivers/scsi/aic7xxx.cscb->SG_segment_count = 1;
scb1787drivers/scsi/aic7xxx.cmemcpy (scb->SG_list_pointer, &req_buf,
scb1788drivers/scsi/aic7xxx.csizeof(scb->SG_list_pointer));
scb1790drivers/scsi/aic7xxx.cscb->SG_segment_count = 0;
scb1791drivers/scsi/aic7xxx.cmemcpy (scb->data_pointer, &req_buf,
scb1792drivers/scsi/aic7xxx.csizeof(scb->data_pointer));
scb1793drivers/scsi/aic7xxx.cmemcpy (scb->data_count, &req_buflen, 3);
scb1801drivers/scsi/aic7xxx.c:"S" (scb), "c" (SCB_DOWNLOAD_SIZE), "d" (SCBARRAY(base))
scb1813drivers/scsi/aic7xxx.chead = scb->position;
scb1820drivers/scsi/aic7xxx.ctail = scb->position;
scb1827drivers/scsi/aic7xxx.ctail = scb->position;
scb1864drivers/scsi/aic7xxx.cscb->target_status);
scb1876drivers/scsi/aic7xxx.cscb = &(p->scb_array[scbptr]);
scb1877drivers/scsi/aic7xxx.cif ((scb->state != SCB_ACTIVE) || (scb->cmd == NULL))
scb1881drivers/scsi/aic7xxx.cintstat, scbptr, scb->state, (unsigned int) scb->cmd);
scb1885drivers/scsi/aic7xxx.ccmd = scb->cmd;
scb1898drivers/scsi/aic7xxx.cactual = aic7xxx_length(cmd, scb->residual_SG_segment_count);
scb1911drivers/scsi/aic7xxx.caic7xxx_status(cmd) = scb->target_status;
scb1919drivers/scsi/aic7xxx.cscb = &(p->scb_array[scbptr]);
scb1920drivers/scsi/aic7xxx.cif ((scb->state != SCB_ACTIVE) || (scb->cmd == NULL))
scb1924drivers/scsi/aic7xxx.cintstat, scbptr, scb->state, (unsigned int) scb->cmd);
scb1928drivers/scsi/aic7xxx.ccmd = scb->cmd;
scb1948drivers/scsi/aic7xxx.cscb->state = SCB_FREE;
scb1949drivers/scsi/aic7xxx.cscb->cmd = NULL;
scb1950drivers/scsi/aic7xxx.cscb->next = p->free_scb;      /* preserve next pointer */
scb1951drivers/scsi/aic7xxx.cp->free_scb = scb;            /* add at head of list */
scb1961drivers/scsi/aic7xxx.cscb = &(p->scb_array[scbptr]);
scb1962drivers/scsi/aic7xxx.cif ((scb->state != SCB_ACTIVE) || (scb->cmd == NULL))
scb1966drivers/scsi/aic7xxx.cintstat, scbptr, scb->state, (unsigned int) scb->cmd);
scb1975drivers/scsi/aic7xxx.cif (scb->state & SCB_DEVICE_RESET)
scb2002drivers/scsi/aic7xxx.cscb = &p->scb_array[scbptr];
scb2003drivers/scsi/aic7xxx.cif ((scb->state != SCB_ACTIVE) || (scb->cmd == NULL))
scb2015drivers/scsi/aic7xxx.cscb = NULL;
scb2019drivers/scsi/aic7xxx.ccmd = scb->cmd;
scb2046drivers/scsi/aic7xxx.cif (scb->target_channel_lun & 0x88)
scb2100drivers/scsi/aic7xxx.cscb->state = SCB_FREE;
scb2101drivers/scsi/aic7xxx.cscb->cmd = NULL;
scb2102drivers/scsi/aic7xxx.cscb->next = p->free_scb;        /* preserve next pointer */
scb2103drivers/scsi/aic7xxx.cp->free_scb = scb;              /* add at head of list */
scb2110drivers/scsi/aic7xxx.cscb->position, scb->state, (unsigned int) scb->cmd);
scb2135drivers/scsi/aic7xxx.cscb = NULL;
scb2149drivers/scsi/aic7xxx.cscb = NULL;
scb2168drivers/scsi/aic7xxx.cscb = &(p->scb_array[complete]);
scb2169drivers/scsi/aic7xxx.cif ((scb->state != SCB_ACTIVE) || (scb->cmd == NULL))
scb2175drivers/scsi/aic7xxx.cscb->state, (unsigned int) scb->cmd);
scb2179drivers/scsi/aic7xxx.ccmd = scb->cmd;
scb2188drivers/scsi/aic7xxx.cscb->state, (unsigned int) scb->cmd, (unsigned int) p->free_scb);
scb2197drivers/scsi/aic7xxx.cscb->state = SCB_FREE;
scb2198drivers/scsi/aic7xxx.cscb->next = p->free_scb;
scb2199drivers/scsi/aic7xxx.cscb->cmd = NULL;
scb2200drivers/scsi/aic7xxx.cp->free_scb = &(p->scb_array[scb->position]);
scb2204drivers/scsi/aic7xxx.cif (scb != &p->scb_array[scb->position])
scb2206drivers/scsi/aic7xxx.cprintk("aic7xxx_isr: (complete) address mismatch, pos %d\n", scb->position);
scb2209drivers/scsi/aic7xxx.cscb->state, (unsigned int) scb->cmd, (unsigned int) p->free_scb);
scb3273drivers/scsi/aic7xxx.cstruct aic7xxx_scb *scb)
scb3295drivers/scsi/aic7xxx.cscb->control = scb->control | SCB_TE;
scb3302drivers/scsi/aic7xxx.cscb->control = scb->control | SCB_NEEDWDTR;
scb3312drivers/scsi/aic7xxx.cscb->control = scb->control | SCB_NEEDSDTR;
scb3323drivers/scsi/aic7xxx.cscb->target_channel_lun = ((cmd->target << 4) & 0xF0) |
scb3348drivers/scsi/aic7xxx.cscb->SCSI_cmd_length = cmd->cmd_len;
scb3349drivers/scsi/aic7xxx.cmemcpy(scb->SCSI_cmd_pointer, &addr, sizeof(scb->SCSI_cmd_pointer));
scb3357drivers/scsi/aic7xxx.cscb->SG_segment_count = cmd->use_sg;
scb3358drivers/scsi/aic7xxx.cmemcpy(scb->SG_list_pointer, &cmd->request_buffer,
scb3359drivers/scsi/aic7xxx.csizeof(scb->SG_list_pointer));
scb3368drivers/scsi/aic7xxx.cscb->SG_segment_count = 1;
scb3369drivers/scsi/aic7xxx.cscb->sg.address = (char *) cmd->request_buffer;
scb3370drivers/scsi/aic7xxx.cscb->sg.length = cmd->request_bufflen;
scb3371drivers/scsi/aic7xxx.caddr = &scb->sg;
scb3372drivers/scsi/aic7xxx.cmemcpy(scb->SG_list_pointer, &addr, sizeof(scb->SG_list_pointer));
scb3374drivers/scsi/aic7xxx.cscb->SG_segment_count = 0;
scb3375drivers/scsi/aic7xxx.cmemcpy(scb->data_pointer, &cmd->request_buffer, sizeof(scb->data_pointer));
scb3376drivers/scsi/aic7xxx.cmemcpy(scb->data_count, &cmd->request_bufflen, 3);
scb3396drivers/scsi/aic7xxx.cstruct aic7xxx_scb *scb;
scb3441drivers/scsi/aic7xxx.cscb = p->free_scb;
scb3442drivers/scsi/aic7xxx.cif (scb != NULL)
scb3444drivers/scsi/aic7xxx.cp->free_scb = scb->next;   /* remove and update head of list */
scb3452drivers/scsi/aic7xxx.cscb = &(p->scb_array[scb->position]);
scb3453drivers/scsi/aic7xxx.cscb->control = 0;
scb3454drivers/scsi/aic7xxx.cscb->state = SCB_ACTIVE;
scb3469drivers/scsi/aic7xxx.cscb = &(p->scb_array[p->numscb]);
scb3470drivers/scsi/aic7xxx.cmemset(scb, 0, sizeof(*scb));
scb3472drivers/scsi/aic7xxx.cscb->position = p->numscb;
scb3474drivers/scsi/aic7xxx.cscb->state = SCB_ACTIVE;
scb3475drivers/scsi/aic7xxx.cscb->next_waiting = SCB_LIST_NULL;
scb3476drivers/scsi/aic7xxx.cmemcpy(scb->host_scb, &scb, sizeof(scb));
scb3478drivers/scsi/aic7xxx.cscb->control = SCB_NEEDDMA;
scb3482drivers/scsi/aic7xxx.coutb(scb->position, SCBPTR(p->base));
scb3483drivers/scsi/aic7xxx.caic7xxx_putdmascb(p->base, scb);
scb3486drivers/scsi/aic7xxx.cscb->control = 0;
scb3490drivers/scsi/aic7xxx.cscb->cmd = cmd;
scb3491drivers/scsi/aic7xxx.caic7xxx_position(cmd) = scb->position;
scb3497drivers/scsi/aic7xxx.caic7xxx_buildscb(p, cmd, scb);
scb3500drivers/scsi/aic7xxx.cif (scb != &p->scb_array[scb->position])
scb3505drivers/scsi/aic7xxx.cscb->position, (unsigned int) scb->cmd,
scb3506drivers/scsi/aic7xxx.cscb->state, (unsigned int) p->free_scb);
scb3523drivers/scsi/aic7xxx.caic7xxx_putscb(p->base, scb);
scb3526drivers/scsi/aic7xxx.coutb(scb->position, SCBPTR(p->base));
scb3528drivers/scsi/aic7xxx.caic7xxx_putscb(p->base, scb);
scb3530drivers/scsi/aic7xxx.coutb(scb->position, QINFIFO(p->base));
scb3584drivers/scsi/aic7xxx.cstruct aic7xxx_scb *scb;
scb3592drivers/scsi/aic7xxx.cscb = &p->scb_array[aic7xxx_position(cmd)];
scb3612drivers/scsi/aic7xxx.cif (scbsave[i] == scb->position)
scb3639drivers/scsi/aic7xxx.cif (active_scb != scb->position)
scb3641drivers/scsi/aic7xxx.coutb(scb->position, SCBPTR(p->base));
scb3734drivers/scsi/aic7xxx.cscb->state = SCB_FREE;          /* mark the scb as free */
scb3735drivers/scsi/aic7xxx.cscb->cmd = NULL;                /* clear the command pointer */
scb3736drivers/scsi/aic7xxx.cscb->next = p->free_scb;        /* preserve next pointer */
scb3737drivers/scsi/aic7xxx.cp->free_scb = scb;              /* add at head of free list */
scb347drivers/scsi/wd7000.cstruct scb *next;             /* for lists of scbs */
scb601drivers/scsi/wd7000.cregister Scb *scb, *p;
scb637drivers/scsi/wd7000.cscb = scbfree;  freescbs -= needed;
scb645drivers/scsi/wd7000.creturn scb;
scb649drivers/scsi/wd7000.cstatic inline void free_scb( Scb *scb )
scb656drivers/scsi/wd7000.cmemset(scb, 0, sizeof(Scb));
scb657drivers/scsi/wd7000.cscb->next = scbfree;  scbfree = scb;
scb808drivers/scsi/wd7000.cregister Scb *scb;             /* for SCSI commands */
scb864drivers/scsi/wd7000.cscb = (struct scb *) scsi2int((unchar *)icmbs[icmb].scbptr);
scb866drivers/scsi/wd7000.cif (!(scb->op & ICB_OP_MASK))  {   /* an SCB is done */
scb867drivers/scsi/wd7000.cSCpnt = scb->SCpnt;
scb869drivers/scsi/wd7000.chost_error = scb->vue | (icmb_status << 8);
scb870drivers/scsi/wd7000.cscsi_error = scb->status;
scb874drivers/scsi/wd7000.cfree_scb(scb);
scb879drivers/scsi/wd7000.cicb = (IcbAny *) scb;
scb893drivers/scsi/wd7000.cregister Scb *scb;
scb904drivers/scsi/wd7000.cscb = alloc_scbs(1);
scb905drivers/scsi/wd7000.cscb->idlun = idlun;
scb906drivers/scsi/wd7000.cmemcpy(scb->cdb, cdb, cdblen);
scb907drivers/scsi/wd7000.cscb->direc = 0x40;    /* Disable direction check */
scb909drivers/scsi/wd7000.cscb->SCpnt = SCpnt;         /* so we can find stuff later */
scb910drivers/scsi/wd7000.cSCpnt->host_scribble = (unchar *) scb;
scb911drivers/scsi/wd7000.cscb->host = host;
scb924drivers/scsi/wd7000.csgb = scb->sgb;
scb925drivers/scsi/wd7000.cscb->op = 1;
scb926drivers/scsi/wd7000.cany2scsi(scb->dataptr, (int) sgb);
scb927drivers/scsi/wd7000.cany2scsi(scb->maxlen, SCpnt->use_sg * sizeof (Sgb) );
scb934drivers/scsi/wd7000.cscb->op = 0;
scb935drivers/scsi/wd7000.cany2scsi(scb->dataptr, (int) SCpnt->request_buffer);
scb936drivers/scsi/wd7000.cany2scsi(scb->maxlen, SCpnt->request_bufflen);
scb938drivers/scsi/wd7000.cwhile (!mail_out(host, scb)) /* keep trying */;
scb969drivers/scsi/wd7000.cmail_out(host, (struct scb *) &icb);
scb1081drivers/scsi/wd7000.cmail_out(host, (struct scb *) &icb);