19 #ifdef CONFIG_SCSI_FLASHPOINT
24 #define CRCMASK 0xA001
26 #define FAILURE 0xFFFFFFFFL
29 typedef void (*CALL_BK_FN) (
struct sccb *);
31 struct sccb_mgr_info {
32 unsigned long si_baseaddr;
33 unsigned char si_present;
34 unsigned char si_intvect;
37 unsigned short si_fw_revision;
38 unsigned short si_per_targ_init_sync;
39 unsigned short si_per_targ_fast_nego;
40 unsigned short si_per_targ_ultra_nego;
41 unsigned short si_per_targ_no_disc;
42 unsigned short si_per_targ_wide_nego;
44 unsigned char si_card_family;
45 unsigned char si_bustype;
46 unsigned char si_card_model[3];
47 unsigned char si_relative_cardnum;
48 unsigned char si_reserved[4];
49 unsigned long si_OS_reserved;
50 unsigned char si_XlatInfo[4];
51 unsigned long si_reserved2[5];
52 unsigned long si_secondary_range;
55 #define SCSI_PARITY_ENA 0x0001
56 #define LOW_BYTE_TERM 0x0010
57 #define HIGH_BYTE_TERM 0x0020
58 #define BUSTYPE_PCI 0x3
60 #define SUPPORT_16TAR_32LUN 0x0002
61 #define SOFT_RESET 0x0004
62 #define EXTENDED_TRANSLATION 0x0008
63 #define POST_ALL_UNDERRRUNS 0x0040
64 #define FLAG_SCAM_ENABLED 0x0080
65 #define FLAG_SCAM_LEVEL2 0x0100
67 #define HARPOON_FAMILY 0x02
75 unsigned char OperationCode;
76 unsigned char ControlByte;
77 unsigned char CdbLength;
78 unsigned char RequestSenseLength;
80 unsigned long DataPointer;
81 unsigned char CcbRes[2];
82 unsigned char HostStatus;
83 unsigned char TargetStatus;
86 unsigned char Cdb[12];
87 unsigned char CcbRes1;
90 unsigned long SensePointer;
92 CALL_BK_FN SccbCallback;
93 unsigned long SccbIOPort;
94 unsigned char SccbStatus;
95 unsigned char SCCBRes2;
96 unsigned short SccbOSFlags;
98 unsigned long Sccb_XferCnt;
99 unsigned long Sccb_ATC;
100 unsigned long SccbVirtDataPtr;
101 unsigned long Sccb_res1;
102 unsigned short Sccb_MGRFlags;
103 unsigned short Sccb_sgseg;
104 unsigned char Sccb_scsimsg;
105 unsigned char Sccb_tag;
106 unsigned char Sccb_scsistat;
107 unsigned char Sccb_idmsg;
108 struct sccb *Sccb_forwardlink;
109 struct sccb *Sccb_backlink;
110 unsigned long Sccb_savedATC;
111 unsigned char Save_Cdb[6];
112 unsigned char Save_CdbLen;
113 unsigned char Sccb_XferState;
114 unsigned long Sccb_SGoffset;
119 #define SCATTER_GATHER_COMMAND 0x02
120 #define RESIDUAL_COMMAND 0x03
121 #define RESIDUAL_SG_COMMAND 0x04
122 #define RESET_COMMAND 0x81
124 #define F_USE_CMD_Q 0x20
125 #define TAG_TYPE_MASK 0xC0
126 #define SCCB_DATA_XFER_OUT 0x10
127 #define SCCB_DATA_XFER_IN 0x08
129 #define NO_AUTO_REQUEST_SENSE 0x01
131 #define BUS_FREE_ST 0
133 #define SELECT_BDR_ST 2
134 #define SELECT_SN_ST 3
135 #define SELECT_WN_ST 4
136 #define SELECT_Q_ST 5
138 #define DATA_OUT_ST 7
140 #define DISCONNECT_ST 9
143 #define F_HOST_XFER_DIR 0x01
144 #define F_ALL_XFERRED 0x02
145 #define F_SG_XFER 0x04
146 #define F_AUTO_SENSE 0x08
147 #define F_ODD_BALL_CNT 0x10
148 #define F_NO_DATA_YET 0x80
150 #define F_STATUSLOADED 0x01
151 #define F_DEV_SELECTED 0x04
153 #define SCCB_COMPLETE 0x00
154 #define SCCB_DATA_UNDER_RUN 0x0C
155 #define SCCB_SELECTION_TIMEOUT 0x11
156 #define SCCB_DATA_OVER_RUN 0x12
157 #define SCCB_PHASE_SEQUENCE_FAIL 0x14
159 #define SCCB_GROSS_FW_ERR 0x27
160 #define SCCB_BM_ERR 0x30
161 #define SCCB_PARITY_ERR 0x34
163 #define SCCB_IN_PROCESS 0x00
164 #define SCCB_SUCCESS 0x01
165 #define SCCB_ABORT 0x02
166 #define SCCB_ERROR 0x04
168 #define ORION_FW_REV 3110
170 #define QUEUE_DEPTH 254+1
172 #define MAX_MB_CARDS 4
174 #define MAX_SCSI_TAR 16
176 #define LUN_MASK 0x1f
178 #define SG_BUF_CNT 16
180 #define SG_ELEMENT_SIZE 8
182 #define RD_HARPOON(ioport) inb((u32)ioport)
183 #define RDW_HARPOON(ioport) inw((u32)ioport)
184 #define RD_HARP32(ioport,offset,data) (data = inl((u32)(ioport + offset)))
185 #define WR_HARPOON(ioport,val) outb((u8) val, (u32)ioport)
186 #define WRW_HARPOON(ioport,val) outw((u16)val, (u32)ioport)
187 #define WR_HARP32(ioport,offset,data) outl(data, (u32)(ioport + offset))
189 #define TAR_SYNC_MASK (BIT(7)+BIT(6))
190 #define SYNC_TRYING BIT(6)
191 #define SYNC_SUPPORTED (BIT(7)+BIT(6))
193 #define TAR_WIDE_MASK (BIT(5)+BIT(4))
194 #define WIDE_ENABLED BIT(4)
195 #define WIDE_NEGOCIATED BIT(5)
197 #define TAR_TAG_Q_MASK (BIT(3)+BIT(2))
198 #define TAG_Q_TRYING BIT(2)
199 #define TAG_Q_REJECT BIT(3)
201 #define TAR_ALLOW_DISC BIT(0)
203 #define EE_SYNC_MASK (BIT(0)+BIT(1))
204 #define EE_SYNC_5MB BIT(0)
205 #define EE_SYNC_10MB BIT(1)
206 #define EE_SYNC_20MB (BIT(0)+BIT(1))
208 #define EE_WIDE_SCSI BIT(7)
210 struct sccb_mgr_tar_info {
212 struct sccb *TarSelQ_Head;
213 struct sccb *TarSelQ_Tail;
214 unsigned char TarLUN_CA;
215 unsigned char TarTagQ_Cnt;
216 unsigned char TarSelQ_Cnt;
217 unsigned char TarStatus;
218 unsigned char TarEEValue;
219 unsigned char TarSyncCtrl;
220 unsigned char TarReserved[2];
221 unsigned char LunDiscQ_Idx[
MAX_LUN];
222 unsigned char TarLUNBusy[
MAX_LUN];
226 unsigned char niModel;
227 unsigned char niCardNo;
228 unsigned long niBaseAddr;
229 unsigned char niSysConf;
230 unsigned char niScsiConf;
231 unsigned char niScamConf;
232 unsigned char niAdapId;
233 unsigned char niSyncTbl[MAX_SCSI_TAR / 2];
234 unsigned char niScamTbl[MAX_SCSI_TAR][4];
243 struct sccb *currentSCCB;
244 struct sccb_mgr_info *cardInfo;
246 unsigned long ioPort;
248 unsigned short cmdCounter;
249 unsigned char discQCount;
250 unsigned char tagQ_Lst;
251 unsigned char cardIndex;
252 unsigned char scanIndex;
253 unsigned char globalFlags;
255 struct nvram_info *pNvRamInfo;
260 #define F_TAG_STARTED 0x01
261 #define F_CONLUN_IO 0x02
262 #define F_DO_RENEGO 0x04
263 #define F_NO_FILTER 0x08
264 #define F_GREEN_PC 0x10
265 #define F_HOST_XFER_ACT 0x20
266 #define F_NEW_SCCB_CMD 0x40
267 #define F_UPDATE_EEPROM 0x80
269 #define ID_STRING_LENGTH 32
270 #define TYPE_CODE0 0x63
272 #define SLV_TYPE_CODE0 0xA3
274 #define ASSIGN_ID 0x00
275 #define SET_P_FLAG 0x01
276 #define CFG_CMPLT 0x03
277 #define DOM_MSTR 0x0F
278 #define SYNC_PTRN 0x1F
282 #define MISC_CODE 0x14
283 #define CLR_P_FLAG 0x18
285 #define INIT_SELTD 0x01
286 #define LEVEL2_TAR 0x02
288 enum scam_id_st {
ID0,
ID1,
ID2,
ID3, ID4, ID5, ID6, ID7, ID8, ID9, ID10, ID11,
290 ID13, ID14, ID15, ID_UNUSED, ID_UNASSIGNED,
ID_ASSIGNED, LEGACY,
291 CLR_PRIORITY, NO_ID_AVAIL
294 typedef struct SCCBscam_info {
296 unsigned char id_string[ID_STRING_LENGTH];
297 enum scam_id_st
state;
301 #define SCSI_REQUEST_SENSE 0x03
302 #define SCSI_READ 0x08
303 #define SCSI_WRITE 0x0A
304 #define SCSI_START_STOP_UNIT 0x1B
305 #define SCSI_READ_EXTENDED 0x28
306 #define SCSI_WRITE_EXTENDED 0x2A
307 #define SCSI_WRITE_AND_VERIFY 0x2E
311 #define SSQ_FULL 0x28
313 #define SMCMD_COMP 0x00
315 #define SMSAVE_DATA_PTR 0x02
316 #define SMREST_DATA_PTR 0x03
319 #define SMREJECT 0x07
321 #define SMPARITY 0x09
322 #define SMDEV_RESET 0x0C
323 #define SMABORT_TAG 0x0D
324 #define SMINIT_RECOVERY 0x0F
325 #define SMREL_RECOVERY 0x10
328 #define DISC_PRIV 0x40
334 #define SMIGNORWR 0x23
336 #define SIX_BYTE_CMD 0x06
337 #define TWELVE_BYTE_CMD 0x0C
340 #define MAX_OFFSET 0x0F
342 #define EEPROM_WD_CNT 256
344 #define EEPROM_CHECK_SUM 0
345 #define FW_SIGNATURE 2
346 #define MODEL_NUMB_0 4
347 #define MODEL_NUMB_2 6
348 #define MODEL_NUMB_4 8
349 #define SYSTEM_CONFIG 16
350 #define SCSI_CONFIG 17
351 #define BIOS_CONFIG 18
352 #define SCAM_CONFIG 20
353 #define ADAPTER_SCSI_ID 24
355 #define IGNORE_B_SCAN 32
356 #define SEND_START_ENA 34
357 #define DEVICE_ENABLE 36
359 #define SYNC_RATE_TBL 38
360 #define SYNC_RATE_TBL01 38
361 #define SYNC_RATE_TBL23 40
362 #define SYNC_RATE_TBL45 42
363 #define SYNC_RATE_TBL67 44
364 #define SYNC_RATE_TBL89 46
365 #define SYNC_RATE_TBLab 48
366 #define SYNC_RATE_TBLcd 50
367 #define SYNC_RATE_TBLef 52
369 #define EE_SCAMBASE 256
371 #define SCAM_ENABLED BIT(2)
372 #define SCAM_LEVEL2 BIT(3)
374 #define RENEGO_ENA BIT(10)
375 #define CONNIO_ENA BIT(11)
376 #define GREEN_PC_ENA BIT(12)
378 #define AUTO_RATE_00 00
379 #define AUTO_RATE_05 01
380 #define AUTO_RATE_10 02
381 #define AUTO_RATE_20 03
383 #define WIDE_NEGO_BIT BIT(7)
384 #define DISC_ENABLE_BIT BIT(6)
386 #define hp_vendor_id_0 0x00
387 #define ORION_VEND_0 0x4B
389 #define hp_vendor_id_1 0x01
390 #define ORION_VEND_1 0x10
392 #define hp_device_id_0 0x02
393 #define ORION_DEV_0 0x30
395 #define hp_device_id_1 0x03
396 #define ORION_DEV_1 0x81
401 #define hp_sub_device_id_0 0x06
403 #define hp_semaphore 0x0C
404 #define SCCB_MGR_ACTIVE BIT(0)
405 #define TICKLE_ME BIT(1)
406 #define SCCB_MGR_PRESENT BIT(3)
407 #define BIOS_IN_USE BIT(4)
409 #define hp_sys_ctrl 0x0F
411 #define STOP_CLK BIT(0)
412 #define DRVR_RST BIT(1)
413 #define HALT_MACH BIT(3)
414 #define HARD_ABORT BIT(4)
416 #define hp_host_blk_cnt 0x13
418 #define XFER_BLK64 0x06
420 #define BM_THRESHOLD 0x40
422 #define hp_int_mask 0x17
424 #define INT_CMD_COMPL BIT(0)
425 #define INT_EXT_STATUS BIT(1)
427 #define hp_xfer_cnt_lo 0x18
428 #define hp_xfer_cnt_hi 0x1A
429 #define hp_xfer_cmd 0x1B
431 #define XFER_HOST_DMA 0x00
432 #define XFER_DMA_HOST 0x01
434 #define XFER_HOST_AUTO 0x00
436 #define XFER_DMA_8BIT 0x20
438 #define DISABLE_INT BIT(7)
440 #define HOST_WRT_CMD ((DISABLE_INT + XFER_HOST_DMA + XFER_HOST_AUTO + XFER_DMA_8BIT))
441 #define HOST_RD_CMD ((DISABLE_INT + XFER_DMA_HOST + XFER_HOST_AUTO + XFER_DMA_8BIT))
443 #define hp_host_addr_lo 0x1C
444 #define hp_host_addr_hmi 0x1E
446 #define hp_ee_ctrl 0x22
448 #define EXT_ARB_ACK BIT(7)
449 #define SCSI_TERM_ENA_H BIT(6)
450 #define SEE_MS BIT(5)
451 #define SEE_CS BIT(3)
452 #define SEE_CLK BIT(2)
453 #define SEE_DO BIT(1)
454 #define SEE_DI BIT(0)
457 #define EE_WRITE 0x05
459 #define EWEN_ADDR 0x03C0
461 #define EWDS_ADDR 0x0000
463 #define hp_bm_ctrl 0x26
465 #define SCSI_TERM_ENA_L BIT(0)
466 #define FLUSH_XFER_CNTR BIT(1)
467 #define FORCE1_XFER BIT(5)
468 #define FAST_SINGLE BIT(6)
470 #define BMCTRL_DEFAULT (FORCE1_XFER|FAST_SINGLE|SCSI_TERM_ENA_L)
472 #define hp_sg_addr 0x28
473 #define hp_page_ctrl 0x29
475 #define SCATTER_EN BIT(0)
476 #define SGRAM_ARAM BIT(1)
477 #define G_INT_DISABLE BIT(3)
478 #define NARROW_SCSI_CARD BIT(4)
480 #define hp_pci_stat_cfg 0x2D
482 #define REC_MASTER_ABORT BIT(5)
484 #define hp_rev_num 0x33
486 #define hp_stack_data 0x34
487 #define hp_stack_addr 0x35
489 #define hp_ext_status 0x36
491 #define BM_FORCE_OFF BIT(0)
492 #define PCI_TGT_ABORT BIT(0)
493 #define PCI_DEV_TMOUT BIT(1)
494 #define CMD_ABORTED BIT(4)
495 #define BM_PARITY_ERR BIT(5)
496 #define PIO_OVERRUN BIT(6)
497 #define BM_CMD_BUSY BIT(7)
498 #define BAD_EXT_STATUS (BM_FORCE_OFF | PCI_DEV_TMOUT | CMD_ABORTED | \
499 BM_PARITY_ERR | PIO_OVERRUN)
501 #define hp_int_status 0x37
503 #define EXT_STATUS_ON BIT(1)
504 #define SCSI_INTERRUPT BIT(2)
505 #define INT_ASSERTED BIT(5)
507 #define hp_fifo_cnt 0x38
509 #define hp_intena 0x40
512 #define PROG_HLT BIT(6)
513 #define PARITY BIT(5)
516 #define SCAM_SEL BIT(2)
518 #define TIMEOUT BIT(0)
519 #define BUS_FREE BIT(15)
520 #define XFER_CNT_0 BIT(14)
521 #define PHASE BIT(13)
522 #define IUNKWN BIT(12)
523 #define ICMD_COMP BIT(11)
524 #define ITICKLE BIT(10)
525 #define IDO_STRT BIT(9)
526 #define ITAR_DISC BIT(8)
527 #define AUTO_INT (BIT(12)+BIT(11)+BIT(10)+BIT(9)+BIT(8))
528 #define CLR_ALL_INT 0xFFFF
529 #define CLR_ALL_INT_1 0xFF00
531 #define hp_intstat 0x42
533 #define hp_scsisig 0x44
535 #define SCSI_SEL BIT(7)
536 #define SCSI_BSY BIT(6)
537 #define SCSI_REQ BIT(5)
538 #define SCSI_ACK BIT(4)
539 #define SCSI_ATN BIT(3)
540 #define SCSI_CD BIT(2)
541 #define SCSI_MSG BIT(1)
542 #define SCSI_IOBIT BIT(0)
544 #define S_SCSI_PHZ (BIT(2)+BIT(1)+BIT(0))
545 #define S_MSGO_PH (BIT(2)+BIT(1) )
546 #define S_MSGI_PH (BIT(2)+BIT(1)+BIT(0))
547 #define S_DATAI_PH ( BIT(0))
548 #define S_DATAO_PH 0x00
549 #define S_ILL_PH ( BIT(1) )
551 #define hp_scsictrl_0 0x45
553 #define SEL_TAR BIT(6)
554 #define ENA_ATN BIT(4)
555 #define ENA_RESEL BIT(2)
556 #define SCSI_RST BIT(1)
557 #define ENA_SCAM_SEL BIT(0)
559 #define hp_portctrl_0 0x46
561 #define SCSI_PORT BIT(7)
562 #define SCSI_INBIT BIT(6)
563 #define DMA_PORT BIT(5)
564 #define DMA_RD BIT(4)
565 #define HOST_PORT BIT(3)
566 #define HOST_WRT BIT(2)
567 #define SCSI_BUS_EN BIT(1)
568 #define START_TO BIT(0)
570 #define hp_scsireset 0x47
572 #define SCSI_INI BIT(6)
573 #define SCAM_EN BIT(5)
574 #define DMA_RESET BIT(3)
575 #define HPSCSI_RESET BIT(2)
576 #define PROG_RESET BIT(1)
577 #define FIFO_CLR BIT(0)
579 #define hp_xfercnt_0 0x48
580 #define hp_xfercnt_2 0x4A
582 #define hp_fifodata_0 0x4C
583 #define hp_addstat 0x4E
585 #define SCAM_TIMER BIT(7)
586 #define SCSI_MODE8 BIT(3)
587 #define SCSI_PAR_ERR BIT(0)
589 #define hp_prgmcnt_0 0x4F
591 #define hp_selfid_0 0x50
592 #define hp_selfid_1 0x51
593 #define hp_arb_id 0x52
595 #define hp_select_id 0x53
597 #define hp_synctarg_base 0x54
598 #define hp_synctarg_12 0x54
599 #define hp_synctarg_13 0x55
600 #define hp_synctarg_14 0x56
601 #define hp_synctarg_15 0x57
603 #define hp_synctarg_8 0x58
604 #define hp_synctarg_9 0x59
605 #define hp_synctarg_10 0x5A
606 #define hp_synctarg_11 0x5B
608 #define hp_synctarg_4 0x5C
609 #define hp_synctarg_5 0x5D
610 #define hp_synctarg_6 0x5E
611 #define hp_synctarg_7 0x5F
613 #define hp_synctarg_0 0x60
614 #define hp_synctarg_1 0x61
615 #define hp_synctarg_2 0x62
616 #define hp_synctarg_3 0x63
618 #define NARROW_SCSI BIT(4)
619 #define DEFAULT_OFFSET 0x0F
621 #define hp_autostart_0 0x64
622 #define hp_autostart_1 0x65
623 #define hp_autostart_3 0x67
625 #define AUTO_IMMED BIT(5)
626 #define SELECT BIT(6)
627 #define END_DATA (BIT(7)+BIT(6))
629 #define hp_gp_reg_0 0x68
630 #define hp_gp_reg_1 0x69
631 #define hp_gp_reg_3 0x6B
633 #define hp_seltimeout 0x6C
639 #define TO_250ms 0x99
640 #define TO_290ms 0xB1
642 #define hp_clkctrl_0 0x6D
644 #define PWR_DWN BIT(6)
645 #define ACTdeassert BIT(4)
646 #define CLK_40MHZ (BIT(1) + BIT(0))
648 #define CLKCTRL_DEFAULT (ACTdeassert | CLK_40MHZ)
650 #define hp_fiforead 0x6E
651 #define hp_fifowrite 0x6F
653 #define hp_offsetctr 0x70
654 #define hp_xferstat 0x71
656 #define FIFO_EMPTY BIT(6)
658 #define hp_portctrl_1 0x72
660 #define CHK_SCSI_P BIT(3)
661 #define HOST_MODE8 BIT(0)
663 #define hp_xfer_pad 0x73
665 #define ID_UNLOCK BIT(3)
667 #define hp_scsidata_0 0x74
668 #define hp_scsidata_1 0x75
670 #define hp_aramBase 0x80
671 #define BIOS_DATA_OFFSET 0x60
672 #define BIOS_RELATIVE_CARD 0x64
674 #define AR3 (BIT(9) + BIT(8))
675 #define SDATA BIT(10)
677 #define CRD_OP BIT(11)
679 #define CRR_OP BIT(12)
681 #define CPE_OP (BIT(14)+BIT(11))
683 #define CPN_OP (BIT(14)+BIT(12))
685 #define ADATA_OUT 0x00
686 #define ADATA_IN BIT(8)
687 #define ACOMMAND BIT(10)
688 #define ASTATUS (BIT(10)+BIT(8))
689 #define AMSG_OUT (BIT(10)+BIT(9))
690 #define AMSG_IN (BIT(10)+BIT(9)+BIT(8))
692 #define BRH_OP BIT(13)
696 #define NOT_EQ BIT(9)
698 #define TCB_OP (BIT(13)+BIT(11))
700 #define FIFO_0 BIT(10)
702 #define MPM_OP BIT(15)
704 #define MRR_OP BIT(14)
706 #define S_IDREG (BIT(2)+BIT(1)+BIT(0))
710 #define D_BUCKET (BIT(2) + BIT(1) + BIT(0))
712 #define RAT_OP (BIT(14)+BIT(13)+BIT(11))
714 #define SSI_OP (BIT(15)+BIT(11))
716 #define SSI_ITAR_DISC (ITAR_DISC >> 8)
717 #define SSI_IDO_STRT (IDO_STRT >> 8)
719 #define SSI_ICMD_COMP (ICMD_COMP >> 8)
720 #define SSI_ITICKLE (ITICKLE >> 8)
722 #define SSI_IUNKWN (IUNKWN >> 8)
723 #define SSI_INO_CC (IUNKWN >> 8)
724 #define SSI_IRFAIL (IUNKWN >> 8)
738 #define ID_MSG_STRT hp_aramBase + 0x00
739 #define NON_TAG_ID_MSG hp_aramBase + 0x06
740 #define CMD_STRT hp_aramBase + 0x08
741 #define SYNC_MSGS hp_aramBase + 0x08
743 #define TAG_STRT 0x00
744 #define DISCONNECT_START 0x10/2
745 #define END_DATA_START 0x14/2
746 #define CMD_ONLY_STRT CMDPZ/2
747 #define SELCHK_STRT SELCHK/2
749 #define GET_XFER_CNT(port, xfercnt) {RD_HARP32(port,hp_xfercnt_0,xfercnt); xfercnt &= 0xFFFFFF;}
754 #define HP_SETUP_ADDR_CNT(port,addr,count) (WRW_HARPOON((port+hp_host_addr_lo), (unsigned short)(addr & 0x0000FFFFL)),\
756 WRW_HARPOON((port+hp_host_addr_hmi), (unsigned short)(addr & 0x0000FFFFL)),\
757 WR_HARP32(port,hp_xfercnt_0,count),\
758 WRW_HARPOON((port+hp_xfer_cnt_lo), (unsigned short)(count & 0x0000FFFFL)),\
760 WR_HARPOON(port+hp_xfer_cnt_hi, (count & 0xFF)))
762 #define ACCEPT_MSG(port) {while(RD_HARPOON(port+hp_scsisig) & SCSI_REQ){}\
763 WR_HARPOON(port+hp_scsisig, S_ILL_PH);}
765 #define ACCEPT_MSG_ATN(port) {while(RD_HARPOON(port+hp_scsisig) & SCSI_REQ){}\
766 WR_HARPOON(port+hp_scsisig, (S_ILL_PH|SCSI_ATN));}
768 #define DISABLE_AUTO(port) (WR_HARPOON(port+hp_scsireset, PROG_RESET),\
769 WR_HARPOON(port+hp_scsireset, 0x00))
771 #define ARAM_ACCESS(p_port) (WR_HARPOON(p_port+hp_page_ctrl, \
772 (RD_HARPOON(p_port+hp_page_ctrl) | SGRAM_ARAM)))
774 #define SGRAM_ACCESS(p_port) (WR_HARPOON(p_port+hp_page_ctrl, \
775 (RD_HARPOON(p_port+hp_page_ctrl) & ~SGRAM_ARAM)))
777 #define MDISABLE_INT(p_port) (WR_HARPOON(p_port+hp_page_ctrl, \
778 (RD_HARPOON(p_port+hp_page_ctrl) | G_INT_DISABLE)))
780 #define MENABLE_INT(p_port) (WR_HARPOON(p_port+hp_page_ctrl, \
781 (RD_HARPOON(p_port+hp_page_ctrl) & ~G_INT_DISABLE)))
783 static unsigned char FPT_sisyncn(
unsigned long port,
unsigned char p_card,
784 unsigned char syncFlag);
785 static void FPT_ssel(
unsigned long port,
unsigned char p_card);
786 static void FPT_sres(
unsigned long port,
unsigned char p_card,
787 struct sccb_card *pCurrCard);
788 static void FPT_shandem(
unsigned long port,
unsigned char p_card,
789 struct sccb *pCurrSCCB);
790 static void FPT_stsyncn(
unsigned long port,
unsigned char p_card);
791 static void FPT_sisyncr(
unsigned long port,
unsigned char sync_pulse,
793 static void FPT_sssyncv(
unsigned long p_port,
unsigned char p_id,
794 unsigned char p_sync_value,
795 struct sccb_mgr_tar_info *currTar_Info);
796 static void FPT_sresb(
unsigned long port,
unsigned char p_card);
797 static void FPT_sxfrp(
unsigned long p_port,
unsigned char p_card);
798 static void FPT_schkdd(
unsigned long port,
unsigned char p_card);
799 static unsigned char FPT_RdStack(
unsigned long port,
unsigned char index);
800 static void FPT_WrStack(
unsigned long portBase,
unsigned char index,
802 static unsigned char FPT_ChkIfChipInitialized(
unsigned long ioPort);
804 static void FPT_SendMsg(
unsigned long port,
unsigned char message);
805 static void FPT_queueFlushTargSccb(
unsigned char p_card,
unsigned char thisTarg,
808 static void FPT_sinits(
struct sccb *p_sccb,
unsigned char p_card);
809 static void FPT_RNVRamData(
struct nvram_info *pNvRamInfo);
811 static unsigned char FPT_siwidn(
unsigned long port,
unsigned char p_card);
812 static void FPT_stwidn(
unsigned long port,
unsigned char p_card);
813 static void FPT_siwidr(
unsigned long port,
unsigned char width);
815 static void FPT_queueSelectFail(
struct sccb_card *pCurrCard,
816 unsigned char p_card);
817 static void FPT_queueDisconnect(
struct sccb *p_SCCB,
unsigned char p_card);
818 static void FPT_queueCmdComplete(
struct sccb_card *pCurrCard,
819 struct sccb *p_SCCB,
unsigned char p_card);
820 static void FPT_queueSearchSelect(
struct sccb_card *pCurrCard,
821 unsigned char p_card);
822 static void FPT_queueFlushSccb(
unsigned char p_card,
unsigned char error_code);
823 static void FPT_queueAddSccb(
struct sccb *p_SCCB,
unsigned char card);
824 static unsigned char FPT_queueFindSccb(
struct sccb *p_SCCB,
825 unsigned char p_card);
826 static void FPT_utilUpdateResidual(
struct sccb *p_SCCB);
827 static unsigned short FPT_CalcCrc16(
unsigned char buffer[]);
828 static unsigned char FPT_CalcLrc(
unsigned char buffer[]);
830 static void FPT_Wait1Second(
unsigned long p_port);
831 static void FPT_Wait(
unsigned long p_port,
unsigned char p_delay);
832 static void FPT_utilEEWriteOnOff(
unsigned long p_port,
unsigned char p_mode);
833 static void FPT_utilEEWrite(
unsigned long p_port,
unsigned short ee_data,
834 unsigned short ee_addr);
835 static unsigned short FPT_utilEERead(
unsigned long p_port,
836 unsigned short ee_addr);
837 static unsigned short FPT_utilEEReadOrg(
unsigned long p_port,
838 unsigned short ee_addr);
839 static void FPT_utilEESendCmdAddr(
unsigned long p_port,
unsigned char ee_cmd,
840 unsigned short ee_addr);
842 static void FPT_phaseDataOut(
unsigned long port,
unsigned char p_card);
843 static void FPT_phaseDataIn(
unsigned long port,
unsigned char p_card);
844 static void FPT_phaseCommand(
unsigned long port,
unsigned char p_card);
845 static void FPT_phaseStatus(
unsigned long port,
unsigned char p_card);
846 static void FPT_phaseMsgOut(
unsigned long port,
unsigned char p_card);
847 static void FPT_phaseMsgIn(
unsigned long port,
unsigned char p_card);
848 static void FPT_phaseIllegal(
unsigned long port,
unsigned char p_card);
850 static void FPT_phaseDecode(
unsigned long port,
unsigned char p_card);
851 static void FPT_phaseChkFifo(
unsigned long port,
unsigned char p_card);
852 static void FPT_phaseBusFree(
unsigned long p_port,
unsigned char p_card);
854 static void FPT_XbowInit(
unsigned long port,
unsigned char scamFlg);
855 static void FPT_BusMasterInit(
unsigned long p_port);
856 static void FPT_DiagEEPROM(
unsigned long p_port);
858 static void FPT_dataXferProcessor(
unsigned long port,
859 struct sccb_card *pCurrCard);
860 static void FPT_busMstrSGDataXferStart(
unsigned long port,
861 struct sccb *pCurrSCCB);
862 static void FPT_busMstrDataXferStart(
unsigned long port,
863 struct sccb *pCurrSCCB);
864 static void FPT_hostDataXferAbort(
unsigned long port,
unsigned char p_card,
865 struct sccb *pCurrSCCB);
866 static void FPT_hostDataXferRestart(
struct sccb *currSCCB);
868 static unsigned char FPT_SccbMgr_bad_isr(
unsigned long p_port,
869 unsigned char p_card,
870 struct sccb_card *pCurrCard,
871 unsigned short p_int);
873 static void FPT_SccbMgrTableInitAll(
void);
874 static void FPT_SccbMgrTableInitCard(
struct sccb_card *pCurrCard,
875 unsigned char p_card);
876 static void FPT_SccbMgrTableInitTarget(
unsigned char p_card,
879 static void FPT_scini(
unsigned char p_card,
unsigned char p_our_id,
880 unsigned char p_power_up);
882 static int FPT_scarb(
unsigned long p_port,
unsigned char p_sel_type);
883 static void FPT_scbusf(
unsigned long p_port);
884 static void FPT_scsel(
unsigned long p_port);
885 static void FPT_scasid(
unsigned char p_card,
unsigned long p_port);
886 static unsigned char FPT_scxferc(
unsigned long p_port,
unsigned char p_data);
887 static unsigned char FPT_scsendi(
unsigned long p_port,
888 unsigned char p_id_string[]);
889 static unsigned char FPT_sciso(
unsigned long p_port,
890 unsigned char p_id_string[]);
891 static void FPT_scwirod(
unsigned long p_port,
unsigned char p_data_bit);
892 static void FPT_scwiros(
unsigned long p_port,
unsigned char p_data_bit);
893 static unsigned char FPT_scvalq(
unsigned char p_quintet);
894 static unsigned char FPT_scsell(
unsigned long p_port,
unsigned char targ_id);
895 static void FPT_scwtsel(
unsigned long p_port);
896 static void FPT_inisci(
unsigned char p_card,
unsigned long p_port,
897 unsigned char p_our_id);
898 static void FPT_scsavdi(
unsigned char p_card,
unsigned long p_port);
899 static unsigned char FPT_scmachid(
unsigned char p_card,
900 unsigned char p_id_string[]);
902 static void FPT_autoCmdCmplt(
unsigned long p_port,
unsigned char p_card);
903 static void FPT_autoLoadDefaultMap(
unsigned long p_port);
905 static struct sccb_mgr_tar_info FPT_sccbMgrTbl[
MAX_CARDS][MAX_SCSI_TAR] =
907 static struct sccb_card FPT_BL_Card[
MAX_CARDS] = { {0} };
908 static SCCBSCAM_INFO FPT_scamInfo[MAX_SCSI_TAR] = { {{0}} };
909 static struct nvram_info FPT_nvRamInfo[MAX_MB_CARDS] = { {0} };
911 static unsigned char FPT_mbCards = 0;
912 static unsigned char FPT_scamHAString[] =
913 { 0x63, 0x07,
'B',
'U',
'S',
'L',
'O',
'G',
'I',
'C',
914 ' ',
'B',
'T',
'-',
'9',
'3',
'0',
915 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20,
916 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20
919 static unsigned short FPT_default_intena = 0;
921 static void (*FPT_s_PhaseTbl[8]) (
unsigned long,
unsigned char) = {
934 static unsigned char first_time = 1;
936 unsigned char i,
j,
id, ScamFlg;
937 unsigned short temp,
temp2, temp3, temp4, temp5, temp6;
939 struct nvram_info *pCurrNvRam;
941 ioport = pCardInfo->si_baseaddr;
943 if (RD_HARPOON(ioport + hp_vendor_id_0) != ORION_VEND_0)
946 if ((RD_HARPOON(ioport + hp_vendor_id_1) != ORION_VEND_1))
949 if ((RD_HARPOON(ioport + hp_device_id_0) != ORION_DEV_0))
952 if ((RD_HARPOON(ioport + hp_device_id_1) != ORION_DEV_1))
955 if (RD_HARPOON(ioport + hp_rev_num) != 0x0f) {
962 if (RD_HARPOON(ioport + hp_sub_device_id_0) & 0x0f)
967 FPT_SccbMgrTableInitAll();
972 if (FPT_RdStack(ioport, 0) != 0x00) {
973 if (FPT_ChkIfChipInitialized(ioport) == 0) {
975 WR_HARPOON(ioport + hp_semaphore, 0x00);
976 FPT_XbowInit(ioport, 0);
977 FPT_DiagEEPROM(ioport);
979 if (FPT_mbCards < MAX_MB_CARDS) {
980 pCurrNvRam = &FPT_nvRamInfo[FPT_mbCards];
982 pCurrNvRam->niBaseAddr =
ioport;
983 FPT_RNVRamData(pCurrNvRam);
990 WR_HARPOON(ioport + hp_clkctrl_0, CLKCTRL_DEFAULT);
991 WR_HARPOON(ioport + hp_sys_ctrl, 0x00);
994 pCardInfo->si_id = pCurrNvRam->niAdapId;
998 char)(FPT_utilEERead(ioport,
1000 2)) & (
unsigned char)0x0FF);
1002 pCardInfo->si_lun = 0x00;
1003 pCardInfo->si_fw_revision = ORION_FW_REV;
1010 for (
id = 0;
id < (16 / 2);
id++) {
1013 temp = (
unsigned short)pCurrNvRam->niSyncTbl[
id];
1014 temp = ((temp & 0x03) + ((temp << 4) & 0xc0)) +
1015 (((temp << 4) & 0x0300) + ((temp << 8) & 0xc000));
1018 FPT_utilEERead(ioport,
1019 (
unsigned short)((SYNC_RATE_TBL / 2)
1022 for (i = 0; i < 2; temp >>= 8, i++) {
1029 switch (temp & 0x3) {
1040 if (temp & DISC_ENABLE_BIT)
1043 if (temp & WIDE_NEGO_BIT)
1049 pCardInfo->si_per_targ_init_sync =
temp2;
1050 pCardInfo->si_per_targ_no_disc = temp3;
1051 pCardInfo->si_per_targ_wide_nego = temp4;
1052 pCardInfo->si_per_targ_fast_nego = temp5;
1053 pCardInfo->si_per_targ_ultra_nego = temp6;
1056 i = pCurrNvRam->niSysConf;
1062 ScamFlg = pCurrNvRam->niScamConf;
1065 (
unsigned char)FPT_utilEERead(ioport, SCAM_CONFIG / 2);
1067 pCardInfo->si_flags = 0x0000;
1070 pCardInfo->si_flags |= SCSI_PARITY_ENA;
1076 pCardInfo->si_flags |= EXTENDED_TRANSLATION;
1078 if (ScamFlg & SCAM_ENABLED)
1079 pCardInfo->si_flags |= FLAG_SCAM_ENABLED;
1081 if (ScamFlg & SCAM_LEVEL2)
1082 pCardInfo->si_flags |= FLAG_SCAM_LEVEL2;
1084 j = (RD_HARPOON(ioport + hp_bm_ctrl) & ~SCSI_TERM_ENA_L);
1086 j |= SCSI_TERM_ENA_L;
1088 WR_HARPOON(ioport + hp_bm_ctrl, j);
1090 j = (RD_HARPOON(ioport + hp_ee_ctrl) & ~SCSI_TERM_ENA_H);
1092 j |= SCSI_TERM_ENA_H;
1094 WR_HARPOON(ioport + hp_ee_ctrl, j);
1096 if (!(RD_HARPOON(ioport + hp_page_ctrl) & NARROW_SCSI_CARD))
1098 pCardInfo->si_flags |= SUPPORT_16TAR_32LUN;
1100 pCardInfo->si_card_family = HARPOON_FAMILY;
1104 pCardInfo->si_card_model[0] =
'9';
1105 switch (pCurrNvRam->niModel & 0x0f) {
1107 pCardInfo->si_card_model[1] =
'3';
1108 pCardInfo->si_card_model[2] =
'0';
1111 pCardInfo->si_card_model[1] =
'5';
1112 pCardInfo->si_card_model[2] =
'0';
1115 pCardInfo->si_card_model[1] =
'3';
1116 pCardInfo->si_card_model[2] =
'2';
1119 pCardInfo->si_card_model[1] =
'5';
1120 pCardInfo->si_card_model[2] =
'2';
1124 temp = FPT_utilEERead(ioport, (MODEL_NUMB_0 / 2));
1125 pCardInfo->si_card_model[0] = (
unsigned char)(temp >> 8);
1126 temp = FPT_utilEERead(ioport, (MODEL_NUMB_2 / 2));
1128 pCardInfo->si_card_model[1] = (
unsigned char)(temp & 0x00FF);
1129 pCardInfo->si_card_model[2] = (
unsigned char)(temp >> 8);
1132 if (pCardInfo->si_card_model[1] ==
'3') {
1133 if (RD_HARPOON(ioport + hp_ee_ctrl) &
BIT(7))
1134 pCardInfo->si_flags |= LOW_BYTE_TERM;
1135 }
else if (pCardInfo->si_card_model[2] ==
'0') {
1136 temp = RD_HARPOON(ioport + hp_xfer_pad);
1137 WR_HARPOON(ioport + hp_xfer_pad, (temp & ~
BIT(4)));
1138 if (RD_HARPOON(ioport + hp_ee_ctrl) &
BIT(7))
1139 pCardInfo->si_flags |= LOW_BYTE_TERM;
1140 WR_HARPOON(ioport + hp_xfer_pad, (temp |
BIT(4)));
1141 if (RD_HARPOON(ioport + hp_ee_ctrl) &
BIT(7))
1142 pCardInfo->si_flags |= HIGH_BYTE_TERM;
1143 WR_HARPOON(ioport + hp_xfer_pad, temp);
1145 temp = RD_HARPOON(ioport + hp_ee_ctrl);
1146 temp2 = RD_HARPOON(ioport + hp_xfer_pad);
1147 WR_HARPOON(ioport + hp_ee_ctrl, (temp | SEE_CS));
1148 WR_HARPOON(ioport + hp_xfer_pad, (temp2 |
BIT(4)));
1150 for (i = 0; i < 8; i++) {
1152 if (!(RD_HARPOON(ioport + hp_ee_ctrl) &
BIT(7)))
1154 WR_HARPOON(ioport + hp_xfer_pad, (temp2 & ~
BIT(4)));
1155 WR_HARPOON(ioport + hp_xfer_pad, (temp2 |
BIT(4)));
1157 WR_HARPOON(ioport + hp_ee_ctrl, temp);
1158 WR_HARPOON(ioport + hp_xfer_pad, temp2);
1159 if (!(temp3 &
BIT(7)))
1160 pCardInfo->si_flags |= LOW_BYTE_TERM;
1161 if (!(temp3 &
BIT(6)))
1162 pCardInfo->si_flags |= HIGH_BYTE_TERM;
1165 ARAM_ACCESS(ioport);
1167 for (i = 0; i < 4; i++) {
1169 pCardInfo->si_XlatInfo[
i] =
1170 RD_HARPOON(ioport + hp_aramBase + BIOS_DATA_OFFSET + i);
1176 pCardInfo->si_relative_cardnum =
1178 char)(RD_HARPOON(ioport + hp_aramBase + BIOS_RELATIVE_CARD) - 1);
1180 SGRAM_ACCESS(ioport);
1182 FPT_s_PhaseTbl[0] = FPT_phaseDataOut;
1183 FPT_s_PhaseTbl[1] = FPT_phaseDataIn;
1184 FPT_s_PhaseTbl[2] = FPT_phaseIllegal;
1185 FPT_s_PhaseTbl[3] = FPT_phaseIllegal;
1186 FPT_s_PhaseTbl[4] = FPT_phaseCommand;
1187 FPT_s_PhaseTbl[5] = FPT_phaseStatus;
1188 FPT_s_PhaseTbl[6] = FPT_phaseMsgOut;
1189 FPT_s_PhaseTbl[7] = FPT_phaseMsgIn;
1191 pCardInfo->si_present = 0x01;
1207 struct sccb_card *CurrCard =
NULL;
1208 struct nvram_info *pCurrNvRam;
1209 unsigned char i,
j, thisCard, ScamFlg;
1210 unsigned short temp, sync_bit_map,
id;
1213 ioport = pCardInfo->si_baseaddr;
1215 for (thisCard = 0; thisCard <=
MAX_CARDS; thisCard++) {
1222 if (FPT_BL_Card[thisCard].ioPort == ioport) {
1224 CurrCard = &FPT_BL_Card[thisCard];
1225 FPT_SccbMgrTableInitCard(CurrCard, thisCard);
1229 else if (FPT_BL_Card[thisCard].ioPort == 0x00) {
1231 FPT_BL_Card[thisCard].ioPort =
ioport;
1232 CurrCard = &FPT_BL_Card[thisCard];
1235 for (i = 0; i < FPT_mbCards; i++) {
1236 if (CurrCard->ioPort ==
1237 FPT_nvRamInfo[i].niBaseAddr)
1238 CurrCard->pNvRamInfo =
1241 FPT_SccbMgrTableInitCard(CurrCard, thisCard);
1242 CurrCard->cardIndex = thisCard;
1243 CurrCard->cardInfo = pCardInfo;
1249 pCurrNvRam = CurrCard->pNvRamInfo;
1252 ScamFlg = pCurrNvRam->niScamConf;
1255 (
unsigned char)FPT_utilEERead(ioport, SCAM_CONFIG / 2);
1258 FPT_BusMasterInit(ioport);
1259 FPT_XbowInit(ioport, ScamFlg);
1261 FPT_autoLoadDefaultMap(ioport);
1263 for (i = 0,
id = 0x01; i != pCardInfo->si_id; i++,
id <<= 1) {
1266 WR_HARPOON(ioport + hp_selfid_0,
id);
1267 WR_HARPOON(ioport + hp_selfid_1, 0x00);
1268 WR_HARPOON(ioport + hp_arb_id, pCardInfo->si_id);
1269 CurrCard->ourId = pCardInfo->si_id;
1271 i = (
unsigned char)pCardInfo->si_flags;
1272 if (i & SCSI_PARITY_ENA)
1273 WR_HARPOON(ioport + hp_portctrl_1, (HOST_MODE8 | CHK_SCSI_P));
1275 j = (RD_HARPOON(ioport + hp_bm_ctrl) & ~SCSI_TERM_ENA_L);
1276 if (i & LOW_BYTE_TERM)
1277 j |= SCSI_TERM_ENA_L;
1278 WR_HARPOON(ioport + hp_bm_ctrl, j);
1280 j = (RD_HARPOON(ioport + hp_ee_ctrl) & ~SCSI_TERM_ENA_H);
1281 if (i & HIGH_BYTE_TERM)
1282 j |= SCSI_TERM_ENA_H;
1283 WR_HARPOON(ioport + hp_ee_ctrl, j);
1287 FPT_sresb(ioport, thisCard);
1289 FPT_scini(thisCard, pCardInfo->si_id, 0);
1292 if (pCardInfo->si_flags & POST_ALL_UNDERRRUNS)
1293 CurrCard->globalFlags |= F_NO_FILTER;
1296 if (pCurrNvRam->niSysConf & 0x10)
1297 CurrCard->globalFlags |= F_GREEN_PC;
1299 if (FPT_utilEERead(ioport, (
SYSTEM_CONFIG / 2)) & GREEN_PC_ENA)
1300 CurrCard->globalFlags |= F_GREEN_PC;
1306 if (pCurrNvRam->niScsiConf & 0x04)
1307 CurrCard->globalFlags |= F_DO_RENEGO;
1309 if (FPT_utilEERead(ioport, (SCSI_CONFIG / 2)) & RENEGO_ENA)
1310 CurrCard->globalFlags |= F_DO_RENEGO;
1314 if (pCurrNvRam->niScsiConf & 0x08)
1315 CurrCard->globalFlags |= F_CONLUN_IO;
1317 if (FPT_utilEERead(ioport, (SCSI_CONFIG / 2)) & CONNIO_ENA)
1318 CurrCard->globalFlags |= F_CONLUN_IO;
1321 temp = pCardInfo->si_per_targ_no_disc;
1323 for (i = 0,
id = 1; i < MAX_SCSI_TAR; i++,
id <<= 1) {
1326 FPT_sccbMgrTbl[thisCard][
i].TarStatus |= TAR_ALLOW_DISC;
1329 sync_bit_map = 0x0001;
1331 for (
id = 0;
id < (MAX_SCSI_TAR / 2);
id++) {
1334 temp = (
unsigned short)pCurrNvRam->niSyncTbl[
id];
1335 temp = ((temp & 0x03) + ((temp << 4) & 0xc0)) +
1336 (((temp << 4) & 0x0300) + ((temp << 8) & 0xc000));
1339 FPT_utilEERead(ioport,
1340 (
unsigned short)((SYNC_RATE_TBL / 2)
1343 for (i = 0; i < 2; temp >>= 8, i++) {
1345 if (pCardInfo->si_per_targ_init_sync & sync_bit_map) {
1347 FPT_sccbMgrTbl[thisCard][
id * 2 +
1349 (
unsigned char)temp;
1353 FPT_sccbMgrTbl[thisCard][
id * 2 +
1356 FPT_sccbMgrTbl[thisCard][
id * 2 +
1358 (
unsigned char)(temp & ~EE_SYNC_MASK);
1364 if (pCardInfo->si_per_targ_wide_nego & sync_bit_map) {
1366 FPT_sccbMgrTbl[thisCard][
id * 2 +
1373 FPT_sccbMgrTbl[thisCard][
id * 2 +
1383 WR_HARPOON((ioport + hp_semaphore),
1384 (
unsigned char)(RD_HARPOON((ioport + hp_semaphore)) |
1387 return (
unsigned long)CurrCard;
1393 unsigned long portBase;
1394 unsigned long regOffset;
1395 unsigned long scamData;
1396 unsigned long *pScamTbl;
1397 struct nvram_info *pCurrNvRam;
1399 pCurrNvRam = ((
struct sccb_card *)pCurrCard)->pNvRamInfo;
1402 FPT_WrStack(pCurrNvRam->niBaseAddr, 0, pCurrNvRam->niModel);
1403 FPT_WrStack(pCurrNvRam->niBaseAddr, 1, pCurrNvRam->niSysConf);
1404 FPT_WrStack(pCurrNvRam->niBaseAddr, 2, pCurrNvRam->niScsiConf);
1405 FPT_WrStack(pCurrNvRam->niBaseAddr, 3, pCurrNvRam->niScamConf);
1406 FPT_WrStack(pCurrNvRam->niBaseAddr, 4, pCurrNvRam->niAdapId);
1408 for (i = 0; i < MAX_SCSI_TAR / 2; i++)
1409 FPT_WrStack(pCurrNvRam->niBaseAddr,
1410 (
unsigned char)(i + 5),
1411 pCurrNvRam->niSyncTbl[i]);
1413 portBase = pCurrNvRam->niBaseAddr;
1415 for (i = 0; i < MAX_SCSI_TAR; i++) {
1416 regOffset = hp_aramBase + 64 + i * 4;
1417 pScamTbl = (
unsigned long *)&pCurrNvRam->niScamTbl[i];
1418 scamData = *pScamTbl;
1419 WR_HARP32(portBase, regOffset, scamData);
1423 FPT_WrStack(((
struct sccb_card *)pCurrCard)->ioPort, 0, 0);
1427 static void FPT_RNVRamData(
struct nvram_info *pNvRamInfo)
1430 unsigned long portBase;
1431 unsigned long regOffset;
1432 unsigned long scamData;
1433 unsigned long *pScamTbl;
1435 pNvRamInfo->niModel = FPT_RdStack(pNvRamInfo->niBaseAddr, 0);
1436 pNvRamInfo->niSysConf = FPT_RdStack(pNvRamInfo->niBaseAddr, 1);
1437 pNvRamInfo->niScsiConf = FPT_RdStack(pNvRamInfo->niBaseAddr, 2);
1438 pNvRamInfo->niScamConf = FPT_RdStack(pNvRamInfo->niBaseAddr, 3);
1439 pNvRamInfo->niAdapId = FPT_RdStack(pNvRamInfo->niBaseAddr, 4);
1441 for (i = 0; i < MAX_SCSI_TAR / 2; i++)
1442 pNvRamInfo->niSyncTbl[i] =
1443 FPT_RdStack(pNvRamInfo->niBaseAddr, (
unsigned char)(i + 5));
1445 portBase = pNvRamInfo->niBaseAddr;
1447 for (i = 0; i < MAX_SCSI_TAR; i++) {
1448 regOffset = hp_aramBase + 64 + i * 4;
1449 RD_HARP32(portBase, regOffset, scamData);
1450 pScamTbl = (
unsigned long *)&pNvRamInfo->niScamTbl[i];
1451 *pScamTbl = scamData;
1456 static unsigned char FPT_RdStack(
unsigned long portBase,
unsigned char index)
1458 WR_HARPOON(portBase + hp_stack_addr, index);
1459 return RD_HARPOON(portBase + hp_stack_data);
1462 static void FPT_WrStack(
unsigned long portBase,
unsigned char index,
1465 WR_HARPOON(portBase + hp_stack_addr, index);
1466 WR_HARPOON(portBase + hp_stack_data, data);
1469 static unsigned char FPT_ChkIfChipInitialized(
unsigned long ioPort)
1471 if ((RD_HARPOON(ioPort + hp_arb_id) & 0x0f) != FPT_RdStack(ioPort, 4))
1473 if ((RD_HARPOON(ioPort + hp_clkctrl_0) & CLKCTRL_DEFAULT)
1476 if ((RD_HARPOON(ioPort + hp_seltimeout) == TO_250ms) ||
1477 (RD_HARPOON(ioPort + hp_seltimeout) == TO_290ms))
1495 unsigned char thisCard,
lun;
1496 struct sccb *pSaveSccb;
1499 thisCard = ((
struct sccb_card *)pCurrCard)->cardIndex;
1500 ioport = ((
struct sccb_card *)pCurrCard)->ioPort;
1502 if ((p_Sccb->TargID >= MAX_SCSI_TAR) || (p_Sccb->Lun >=
MAX_LUN)) {
1504 p_Sccb->HostStatus = SCCB_COMPLETE;
1505 p_Sccb->SccbStatus = SCCB_ERROR;
1506 callback = (CALL_BK_FN) p_Sccb->SccbCallback;
1513 FPT_sinits(p_Sccb, thisCard);
1515 if (!((
struct sccb_card *)pCurrCard)->cmdCounter) {
1516 WR_HARPOON(ioport + hp_semaphore,
1517 (RD_HARPOON(ioport + hp_semaphore)
1518 | SCCB_MGR_ACTIVE));
1520 if (((
struct sccb_card *)pCurrCard)->globalFlags & F_GREEN_PC) {
1521 WR_HARPOON(ioport + hp_clkctrl_0, CLKCTRL_DEFAULT);
1522 WR_HARPOON(ioport + hp_sys_ctrl, 0x00);
1526 ((
struct sccb_card *)pCurrCard)->cmdCounter++;
1528 if (RD_HARPOON(ioport + hp_semaphore) & BIOS_IN_USE) {
1530 WR_HARPOON(ioport + hp_semaphore,
1531 (RD_HARPOON(ioport + hp_semaphore)
1535 ((
struct sccb_card *)pCurrCard)->currentSCCB;
1536 ((
struct sccb_card *)pCurrCard)->currentSCCB = p_Sccb;
1537 FPT_queueSelectFail(&FPT_BL_Card[thisCard], thisCard);
1538 ((
struct sccb_card *)pCurrCard)->currentSCCB =
1541 FPT_queueAddSccb(p_Sccb, thisCard);
1545 else if ((RD_HARPOON(ioport + hp_page_ctrl) & G_INT_DISABLE)) {
1549 ((
struct sccb_card *)pCurrCard)->currentSCCB;
1550 ((
struct sccb_card *)pCurrCard)->currentSCCB = p_Sccb;
1551 FPT_queueSelectFail(&FPT_BL_Card[thisCard], thisCard);
1552 ((
struct sccb_card *)pCurrCard)->currentSCCB =
1555 FPT_queueAddSccb(p_Sccb, thisCard);
1561 MDISABLE_INT(ioport);
1563 if ((((
struct sccb_card *)pCurrCard)->globalFlags & F_CONLUN_IO)
1565 ((FPT_sccbMgrTbl[thisCard][p_Sccb->TargID].
1566 TarStatus & TAR_TAG_Q_MASK) != TAG_Q_TRYING))
1570 if ((((
struct sccb_card *)pCurrCard)->currentSCCB ==
NULL) &&
1571 (FPT_sccbMgrTbl[thisCard][p_Sccb->TargID].TarSelQ_Cnt == 0)
1572 && (FPT_sccbMgrTbl[thisCard][p_Sccb->TargID].TarLUNBusy[lun]
1575 ((
struct sccb_card *)pCurrCard)->currentSCCB = p_Sccb;
1576 FPT_ssel(p_Sccb->SccbIOPort, thisCard);
1583 ((
struct sccb_card *)pCurrCard)->
1585 ((
struct sccb_card *)pCurrCard)->currentSCCB =
1587 FPT_queueSelectFail(&FPT_BL_Card[thisCard],
1589 ((
struct sccb_card *)pCurrCard)->currentSCCB =
1592 FPT_queueAddSccb(p_Sccb, thisCard);
1596 MENABLE_INT(ioport);
1614 unsigned char thisCard;
1617 struct sccb *pSaveSCCB;
1618 struct sccb_mgr_tar_info *currTar_Info;
1620 ioport = ((
struct sccb_card *)pCurrCard)->ioPort;
1622 thisCard = ((
struct sccb_card *)pCurrCard)->cardIndex;
1624 if (!(RD_HARPOON(ioport + hp_page_ctrl) & G_INT_DISABLE)) {
1626 if (FPT_queueFindSccb(p_Sccb, thisCard)) {
1628 ((
struct sccb_card *)pCurrCard)->cmdCounter--;
1630 if (!((
struct sccb_card *)pCurrCard)->cmdCounter)
1631 WR_HARPOON(ioport + hp_semaphore,
1632 (RD_HARPOON(ioport + hp_semaphore)
1634 char)(~(SCCB_MGR_ACTIVE |
1637 p_Sccb->SccbStatus = SCCB_ABORT;
1638 callback = p_Sccb->SccbCallback;
1645 if (((
struct sccb_card *)pCurrCard)->currentSCCB ==
1647 p_Sccb->SccbStatus = SCCB_ABORT;
1654 TID = p_Sccb->TargID;
1656 if (p_Sccb->Sccb_tag) {
1657 MDISABLE_INT(ioport);
1658 if (((
struct sccb_card *)pCurrCard)->
1659 discQ_Tbl[p_Sccb->Sccb_tag] ==
1661 p_Sccb->SccbStatus = SCCB_ABORT;
1662 p_Sccb->Sccb_scsistat =
1664 p_Sccb->Sccb_scsimsg =
1667 if (((
struct sccb_card *)
1668 pCurrCard)->currentSCCB ==
1670 ((
struct sccb_card *)
1672 currentSCCB = p_Sccb;
1680 ((
struct sccb_card *)
1682 currentSCCB = p_Sccb;
1683 FPT_queueSelectFail((
struct sccb_card *)pCurrCard, thisCard);
1684 ((
struct sccb_card *)
1686 currentSCCB = pSaveSCCB;
1689 MENABLE_INT(ioport);
1693 &FPT_sccbMgrTbl[thisCard][p_Sccb->
1696 if (FPT_BL_Card[thisCard].
1697 discQ_Tbl[currTar_Info->
1698 LunDiscQ_Idx[p_Sccb->Lun]]
1700 p_Sccb->SccbStatus = SCCB_ABORT;
1722 ioport = ((
struct sccb_card *)pCurrCard)->ioPort;
1724 if (RD_HARPOON(ioport + hp_int_status) & INT_ASSERTED) {
1744 struct sccb *currSCCB;
1745 unsigned char thisCard,
result, bm_status, bm_int_st;
1746 unsigned short hp_int;
1750 thisCard = ((
struct sccb_card *)pCurrCard)->cardIndex;
1751 ioport = ((
struct sccb_card *)pCurrCard)->ioPort;
1753 MDISABLE_INT(ioport);
1755 if ((bm_int_st = RD_HARPOON(ioport + hp_int_status)) & EXT_STATUS_ON)
1758 hp_ext_status) & (
unsigned char)BAD_EXT_STATUS;
1762 WR_HARPOON(ioport + hp_int_mask, (INT_CMD_COMPL |
SCSI_INTERRUPT));
1765 RDW_HARPOON((ioport +
1766 hp_intstat)) & FPT_default_intena) | bm_status) {
1768 currSCCB = ((
struct sccb_card *)pCurrCard)->currentSCCB;
1772 FPT_SccbMgr_bad_isr(ioport, thisCard,
1773 ((
struct sccb_card *)pCurrCard),
1775 WRW_HARPOON((ioport + hp_intstat),
1781 MENABLE_INT(ioport);
1786 else if (hp_int & ICMD_COMP) {
1788 if (!(hp_int & BUS_FREE)) {
1795 (RDW_HARPOON((ioport + hp_intstat)) &
1796 (BUS_FREE | RSEL))) ;
1799 if (((
struct sccb_card *)pCurrCard)->
1800 globalFlags & F_HOST_XFER_ACT)
1802 FPT_phaseChkFifo(ioport, thisCard);
1808 WRW_HARPOON((ioport + hp_intstat), CLR_ALL_INT_1);
1810 FPT_autoCmdCmplt(ioport, thisCard);
1814 else if (hp_int & ITAR_DISC) {
1816 if (((
struct sccb_card *)pCurrCard)->
1817 globalFlags & F_HOST_XFER_ACT) {
1819 FPT_phaseChkFifo(ioport, thisCard);
1823 if (RD_HARPOON(ioport + hp_gp_reg_1) == SMSAVE_DATA_PTR) {
1825 WR_HARPOON(ioport + hp_gp_reg_1, 0x00);
1826 currSCCB->Sccb_XferState |= F_NO_DATA_YET;
1828 currSCCB->Sccb_savedATC = currSCCB->Sccb_ATC;
1831 currSCCB->Sccb_scsistat = DISCONNECT_ST;
1832 FPT_queueDisconnect(currSCCB, thisCard);
1840 (RDW_HARPOON((ioport + hp_intstat)) &
1842 && !((RDW_HARPOON((ioport + hp_intstat)) & PHASE)
1843 && RD_HARPOON((ioport + hp_scsisig)) ==
1844 (
SCSI_BSY | SCSI_REQ | SCSI_CD | SCSI_MSG |
1853 (RDW_HARPOON((ioport + hp_intstat)) &
1854 (BUS_FREE | RSEL))) {
1855 MENABLE_INT(ioport);
1859 WRW_HARPOON((ioport + hp_intstat),
1860 (BUS_FREE | ITAR_DISC));
1862 ((
struct sccb_card *)pCurrCard)->globalFlags |=
1867 else if (hp_int & RSEL) {
1869 WRW_HARPOON((ioport + hp_intstat),
1870 (PROG_HLT | RSEL | PHASE | BUS_FREE));
1872 if (RDW_HARPOON((ioport + hp_intstat)) & ITAR_DISC) {
1873 if (((
struct sccb_card *)pCurrCard)->
1874 globalFlags & F_HOST_XFER_ACT) {
1875 FPT_phaseChkFifo(ioport, thisCard);
1878 if (RD_HARPOON(ioport + hp_gp_reg_1) ==
1880 WR_HARPOON(ioport + hp_gp_reg_1, 0x00);
1881 currSCCB->Sccb_XferState |=
1883 currSCCB->Sccb_savedATC =
1887 WRW_HARPOON((ioport + hp_intstat),
1888 (BUS_FREE | ITAR_DISC));
1889 currSCCB->Sccb_scsistat = DISCONNECT_ST;
1890 FPT_queueDisconnect(currSCCB, thisCard);
1893 FPT_sres(ioport, thisCard,
1894 ((
struct sccb_card *)pCurrCard));
1895 FPT_phaseDecode(ioport, thisCard);
1899 else if ((hp_int & IDO_STRT) && (!(hp_int & BUS_FREE))) {
1901 WRW_HARPOON((ioport + hp_intstat),
1902 (IDO_STRT | XFER_CNT_0));
1903 FPT_phaseDecode(ioport, thisCard);
1907 else if ((hp_int & IUNKWN) || (hp_int & PROG_HLT)) {
1908 WRW_HARPOON((ioport + hp_intstat),
1909 (PHASE | IUNKWN | PROG_HLT));
1910 if ((RD_HARPOON(ioport + hp_prgmcnt_0) & (
unsigned char)
1911 0x3f) < (
unsigned char)SELCHK) {
1912 FPT_phaseDecode(ioport, thisCard);
1922 char)(RD_HARPOON(ioport + hp_fifowrite));
1925 char)(RD_HARPOON(ioport + hp_gp_reg_3));
1926 WR_HARPOON(ioport + hp_xfer_pad,
1927 (
unsigned char)ID_UNLOCK);
1928 WR_HARPOON(ioport + hp_select_id,
1929 (
unsigned char)(target | target <<
1931 WR_HARPOON(ioport + hp_xfer_pad,
1932 (
unsigned char)0x00);
1933 WR_HARPOON(ioport + hp_fifowrite, i);
1934 WR_HARPOON(ioport + hp_autostart_3,
1935 (AUTO_IMMED + TAG_STRT));
1939 else if (hp_int & XFER_CNT_0) {
1941 WRW_HARPOON((ioport + hp_intstat), XFER_CNT_0);
1943 FPT_schkdd(ioport, thisCard);
1947 else if (hp_int & BUS_FREE) {
1949 WRW_HARPOON((ioport + hp_intstat), BUS_FREE);
1951 if (((
struct sccb_card *)pCurrCard)->
1952 globalFlags & F_HOST_XFER_ACT) {
1954 FPT_hostDataXferAbort(ioport, thisCard,
1958 FPT_phaseBusFree(ioport, thisCard);
1961 else if (hp_int & ITICKLE) {
1963 WRW_HARPOON((ioport + hp_intstat), ITICKLE);
1964 ((
struct sccb_card *)pCurrCard)->globalFlags |=
1968 if (((
struct sccb_card *)pCurrCard)->
1969 globalFlags & F_NEW_SCCB_CMD) {
1971 ((
struct sccb_card *)pCurrCard)->globalFlags &=
1974 if (((
struct sccb_card *)pCurrCard)->currentSCCB ==
1977 FPT_queueSearchSelect(((
struct sccb_card *)
1978 pCurrCard), thisCard);
1981 if (((
struct sccb_card *)pCurrCard)->currentSCCB !=
1983 ((
struct sccb_card *)pCurrCard)->globalFlags &=
1985 FPT_ssel(ioport, thisCard);
1994 MENABLE_INT(ioport);
2009 static unsigned char FPT_SccbMgr_bad_isr(
unsigned long p_port,
2010 unsigned char p_card,
2011 struct sccb_card *pCurrCard,
2012 unsigned short p_int)
2014 unsigned char temp, ScamFlg;
2015 struct sccb_mgr_tar_info *currTar_Info;
2016 struct nvram_info *pCurrNvRam;
2018 if (RD_HARPOON(p_port + hp_ext_status) &
2019 (BM_FORCE_OFF | PCI_DEV_TMOUT | BM_PARITY_ERR | PIO_OVERRUN)) {
2021 if (pCurrCard->globalFlags & F_HOST_XFER_ACT) {
2023 FPT_hostDataXferAbort(p_port, p_card,
2024 pCurrCard->currentSCCB);
2027 if (RD_HARPOON(p_port + hp_pci_stat_cfg) & REC_MASTER_ABORT)
2029 WR_HARPOON(p_port + hp_pci_stat_cfg,
2030 (RD_HARPOON(p_port + hp_pci_stat_cfg) &
2031 ~REC_MASTER_ABORT));
2033 WR_HARPOON(p_port + hp_host_blk_cnt, 0x00);
2037 if (pCurrCard->currentSCCB !=
NULL) {
2039 if (!pCurrCard->currentSCCB->HostStatus)
2040 pCurrCard->currentSCCB->HostStatus =
2043 FPT_sxfrp(p_port, p_card);
2045 temp = (
unsigned char)(RD_HARPOON(p_port + hp_ee_ctrl) &
2046 (EXT_ARB_ACK | SCSI_TERM_ENA_H));
2047 WR_HARPOON(p_port + hp_ee_ctrl,
2048 ((
unsigned char)temp | SEE_MS | SEE_CS));
2049 WR_HARPOON(p_port + hp_ee_ctrl, temp);
2052 (RDW_HARPOON((p_port + hp_intstat)) &
2053 (BUS_FREE |
RESET))) {
2054 FPT_phaseDecode(p_port, p_card);
2059 else if (p_int &
RESET) {
2061 WR_HARPOON(p_port + hp_clkctrl_0, CLKCTRL_DEFAULT);
2062 WR_HARPOON(p_port + hp_sys_ctrl, 0x00);
2063 if (pCurrCard->currentSCCB !=
NULL) {
2065 if (pCurrCard->globalFlags & F_HOST_XFER_ACT)
2067 FPT_hostDataXferAbort(p_port, p_card,
2068 pCurrCard->currentSCCB);
2071 DISABLE_AUTO(p_port);
2073 FPT_sresb(p_port, p_card);
2075 while (RD_HARPOON(p_port + hp_scsictrl_0) &
SCSI_RST) {
2078 pCurrNvRam = pCurrCard->pNvRamInfo;
2080 ScamFlg = pCurrNvRam->niScamConf;
2083 (
unsigned char)FPT_utilEERead(p_port,
2087 FPT_XbowInit(p_port, ScamFlg);
2089 FPT_scini(p_card, pCurrCard->ourId, 0);
2094 else if (p_int &
FIFO) {
2096 WRW_HARPOON((p_port + hp_intstat), FIFO);
2098 if (pCurrCard->currentSCCB !=
NULL)
2099 FPT_sxfrp(p_port, p_card);
2104 DISABLE_AUTO(p_port);
2106 WRW_HARPOON((p_port + hp_intstat),
2107 (PROG_HLT | TIMEOUT |
SEL | BUS_FREE | PHASE |
2110 pCurrCard->currentSCCB->HostStatus = SCCB_SELECTION_TIMEOUT;
2113 &FPT_sccbMgrTbl[p_card][pCurrCard->currentSCCB->TargID];
2114 if ((pCurrCard->globalFlags & F_CONLUN_IO)
2115 && ((currTar_Info->TarStatus & TAR_TAG_Q_MASK) !=
2117 currTar_Info->TarLUNBusy[pCurrCard->currentSCCB->Lun] =
2120 currTar_Info->TarLUNBusy[0] = 0;
2122 if (currTar_Info->TarEEValue & EE_SYNC_MASK) {
2123 currTar_Info->TarSyncCtrl = 0;
2124 currTar_Info->TarStatus &= ~TAR_SYNC_MASK;
2127 if (currTar_Info->TarEEValue & EE_WIDE_SCSI) {
2128 currTar_Info->TarStatus &= ~TAR_WIDE_MASK;
2131 FPT_sssyncv(p_port, pCurrCard->currentSCCB->TargID, NARROW_SCSI,
2134 FPT_queueCmdComplete(pCurrCard, pCurrCard->currentSCCB, p_card);
2140 FPT_scarb(p_port, LEVEL2_TAR);
2142 FPT_scasid(p_card, p_port);
2146 WRW_HARPOON((p_port + hp_intstat), SCAM_SEL);
2160 static void FPT_SccbMgrTableInitAll()
2162 unsigned char thisCard;
2164 for (thisCard = 0; thisCard <
MAX_CARDS; thisCard++) {
2165 FPT_SccbMgrTableInitCard(&FPT_BL_Card[thisCard], thisCard);
2167 FPT_BL_Card[thisCard].ioPort = 0x00;
2168 FPT_BL_Card[thisCard].cardInfo =
NULL;
2169 FPT_BL_Card[thisCard].cardIndex = 0xFF;
2170 FPT_BL_Card[thisCard].ourId = 0x00;
2171 FPT_BL_Card[thisCard].pNvRamInfo =
NULL;
2183 static void FPT_SccbMgrTableInitCard(
struct sccb_card *pCurrCard,
2184 unsigned char p_card)
2186 unsigned char scsiID, qtag;
2189 FPT_BL_Card[p_card].discQ_Tbl[qtag] =
NULL;
2192 for (scsiID = 0; scsiID < MAX_SCSI_TAR; scsiID++) {
2193 FPT_sccbMgrTbl[p_card][scsiID].TarStatus = 0;
2194 FPT_sccbMgrTbl[p_card][scsiID].TarEEValue = 0;
2195 FPT_SccbMgrTableInitTarget(p_card, scsiID);
2198 pCurrCard->scanIndex = 0x00;
2199 pCurrCard->currentSCCB =
NULL;
2200 pCurrCard->globalFlags = 0x00;
2201 pCurrCard->cmdCounter = 0x00;
2202 pCurrCard->tagQ_Lst = 0x01;
2203 pCurrCard->discQCount = 0;
2215 static void FPT_SccbMgrTableInitTarget(
unsigned char p_card,
2216 unsigned char target)
2219 unsigned char lun, qtag;
2220 struct sccb_mgr_tar_info *currTar_Info;
2222 currTar_Info = &FPT_sccbMgrTbl[p_card][
target];
2224 currTar_Info->TarSelQ_Cnt = 0;
2225 currTar_Info->TarSyncCtrl = 0;
2227 currTar_Info->TarSelQ_Head =
NULL;
2228 currTar_Info->TarSelQ_Tail =
NULL;
2229 currTar_Info->TarTagQ_Cnt = 0;
2230 currTar_Info->TarLUN_CA = 0;
2232 for (lun = 0; lun <
MAX_LUN; lun++) {
2233 currTar_Info->TarLUNBusy[
lun] = 0;
2234 currTar_Info->LunDiscQ_Idx[
lun] = 0;
2238 if (FPT_BL_Card[p_card].discQ_Tbl[qtag] !=
NULL) {
2239 if (FPT_BL_Card[p_card].discQ_Tbl[qtag]->TargID ==
2241 FPT_BL_Card[p_card].discQ_Tbl[qtag] =
NULL;
2242 FPT_BL_Card[p_card].discQCount--;
2257 static unsigned char FPT_sfm(
unsigned long port,
struct sccb *pCurrSCCB)
2260 unsigned short TimeOutLoop;
2263 while ((!(RD_HARPOON(port + hp_scsisig) & SCSI_REQ)) &&
2264 (TimeOutLoop++ < 20000)) {
2267 WR_HARPOON(port + hp_portctrl_0, SCSI_PORT);
2269 message = RD_HARPOON(port + hp_scsidata_0);
2271 WR_HARPOON(port + hp_scsisig,
SCSI_ACK + S_MSGI_PH);
2273 if (TimeOutLoop > 20000)
2276 if ((RDW_HARPOON((port + hp_intstat)) &
PARITY) &&
2277 (RD_HARPOON(port + hp_addstat) & SCSI_PAR_ERR)) {
2278 WR_HARPOON(port + hp_scsisig, (
SCSI_ACK + S_ILL_PH));
2279 WR_HARPOON(port + hp_xferstat, 0);
2280 WR_HARPOON(port + hp_fiforead, 0);
2281 WR_HARPOON(port + hp_fifowrite, 0);
2282 if (pCurrSCCB !=
NULL) {
2283 pCurrSCCB->Sccb_scsimsg = SMPARITY;
2287 ACCEPT_MSG_ATN(port);
2289 while ((!(RD_HARPOON(port + hp_scsisig) & SCSI_REQ)) &&
2290 (TimeOutLoop++ < 20000)) {
2292 if (TimeOutLoop > 20000) {
2293 WRW_HARPOON((port + hp_intstat), PARITY);
2296 if ((RD_HARPOON(port + hp_scsisig) & S_SCSI_PHZ) !=
2298 WRW_HARPOON((port + hp_intstat), PARITY);
2301 WR_HARPOON(port + hp_portctrl_0, SCSI_PORT);
2303 RD_HARPOON(port + hp_scsidata_0);
2305 WR_HARPOON(port + hp_scsisig, (
SCSI_ACK + S_ILL_PH));
2310 WR_HARPOON(port + hp_scsisig, (
SCSI_ACK + S_ILL_PH));
2311 WR_HARPOON(port + hp_xferstat, 0);
2312 WR_HARPOON(port + hp_fiforead, 0);
2313 WR_HARPOON(port + hp_fifowrite, 0);
2325 static void FPT_ssel(
unsigned long port,
unsigned char p_card)
2328 unsigned char auto_loaded,
i,
target, *theCCB;
2330 unsigned long cdb_reg;
2331 struct sccb_card *CurrCard;
2332 struct sccb *currSCCB;
2333 struct sccb_mgr_tar_info *currTar_Info;
2334 unsigned char lastTag,
lun;
2336 CurrCard = &FPT_BL_Card[p_card];
2337 currSCCB = CurrCard->currentSCCB;
2338 target = currSCCB->TargID;
2339 currTar_Info = &FPT_sccbMgrTbl[p_card][
target];
2340 lastTag = CurrCard->tagQ_Lst;
2344 if ((currTar_Info->TarStatus & TAR_TAG_Q_MASK) == TAG_Q_REJECT)
2345 currSCCB->ControlByte &= ~F_USE_CMD_Q;
2347 if (((CurrCard->globalFlags & F_CONLUN_IO) &&
2348 ((currTar_Info->TarStatus & TAR_TAG_Q_MASK) != TAG_Q_TRYING)))
2350 lun = currSCCB->Lun;
2354 if (CurrCard->globalFlags & F_TAG_STARTED) {
2355 if (!(currSCCB->ControlByte & F_USE_CMD_Q)) {
2356 if ((currTar_Info->TarLUN_CA == 0)
2357 && ((currTar_Info->TarStatus & TAR_TAG_Q_MASK)
2360 if (currTar_Info->TarTagQ_Cnt != 0) {
2361 currTar_Info->TarLUNBusy[
lun] = 1;
2362 FPT_queueSelectFail(CurrCard, p_card);
2368 currTar_Info->TarLUNBusy[
lun] = 1;
2374 currTar_Info->TarLUNBusy[
lun] = 1;
2380 if (currTar_Info->TarLUN_CA == 1) {
2381 FPT_queueSelectFail(CurrCard, p_card);
2386 currTar_Info->TarLUNBusy[
lun] = 1;
2393 currTar_Info->TarLUNBusy[
lun] = 1;
2396 if ((((CurrCard->globalFlags & F_CONLUN_IO) &&
2397 ((currTar_Info->TarStatus & TAR_TAG_Q_MASK) != TAG_Q_TRYING))
2398 || (!(currSCCB->ControlByte & F_USE_CMD_Q)))) {
2399 if (CurrCard->discQCount >= QUEUE_DEPTH) {
2400 currTar_Info->TarLUNBusy[
lun] = 1;
2401 FPT_queueSelectFail(CurrCard, p_card);
2406 if (++lastTag >= QUEUE_DEPTH)
2408 if (CurrCard->discQ_Tbl[lastTag] ==
NULL) {
2409 CurrCard->tagQ_Lst = lastTag;
2410 currTar_Info->LunDiscQ_Idx[
lun] = lastTag;
2411 CurrCard->discQ_Tbl[lastTag] = currSCCB;
2412 CurrCard->discQCount++;
2416 if (i == QUEUE_DEPTH) {
2417 currTar_Info->TarLUNBusy[
lun] = 1;
2418 FPT_queueSelectFail(CurrCard, p_card);
2426 WR_HARPOON(port + hp_select_id, target);
2427 WR_HARPOON(port + hp_gp_reg_3, target);
2430 WRW_HARPOON((port + ID_MSG_STRT), (MPM_OP + AMSG_OUT +
2432 Sccb_idmsg & ~DISC_PRIV)));
2434 WRW_HARPOON((port + ID_MSG_STRT + 2), BRH_OP +
ALWAYS +
NP);
2436 currSCCB->Sccb_scsimsg = SMDEV_RESET;
2438 WR_HARPOON(port + hp_autostart_3, (
SELECT + SELCHK_STRT));
2440 currSCCB->Sccb_scsistat = SELECT_BDR_ST;
2442 if (currTar_Info->TarEEValue & EE_SYNC_MASK) {
2443 currTar_Info->TarSyncCtrl = 0;
2444 currTar_Info->TarStatus &= ~TAR_SYNC_MASK;
2447 if (currTar_Info->TarEEValue & EE_WIDE_SCSI) {
2448 currTar_Info->TarStatus &= ~TAR_WIDE_MASK;
2451 FPT_sssyncv(port, target, NARROW_SCSI, currTar_Info);
2452 FPT_SccbMgrTableInitTarget(p_card, target);
2456 else if (currSCCB->Sccb_scsistat == ABORT_ST) {
2457 WRW_HARPOON((port + ID_MSG_STRT), (MPM_OP + AMSG_OUT +
2459 Sccb_idmsg & ~DISC_PRIV)));
2461 WRW_HARPOON((port + ID_MSG_STRT + 2), BRH_OP +
ALWAYS + CMDPZ);
2463 WRW_HARPOON((port + SYNC_MSGS + 0), (MPM_OP + AMSG_OUT +
2468 >> 6) | (
unsigned char)
2470 WRW_HARPOON((port + SYNC_MSGS + 2),
2471 (MPM_OP + AMSG_OUT + currSCCB->Sccb_tag));
2472 WRW_HARPOON((port + SYNC_MSGS + 4), (BRH_OP +
ALWAYS +
NP));
2474 WR_HARPOON(port + hp_autostart_3, (
SELECT + SELCHK_STRT));
2479 else if (!(currTar_Info->TarStatus & WIDE_NEGOCIATED)) {
2480 auto_loaded = FPT_siwidn(port, p_card);
2481 currSCCB->Sccb_scsistat = SELECT_WN_ST;
2484 else if (!((currTar_Info->TarStatus & TAR_SYNC_MASK)
2485 == SYNC_SUPPORTED)) {
2486 auto_loaded = FPT_sisyncn(port, p_card, 0);
2487 currSCCB->Sccb_scsistat = SELECT_SN_ST;
2492 if (currSCCB->ControlByte & F_USE_CMD_Q) {
2494 CurrCard->globalFlags |= F_TAG_STARTED;
2496 if ((currTar_Info->TarStatus & TAR_TAG_Q_MASK)
2498 currSCCB->ControlByte &= ~F_USE_CMD_Q;
2502 WRW_HARPOON((port + ID_MSG_STRT),
2503 BRH_OP +
ALWAYS + NTCMD);
2505 WRW_HARPOON((port + NON_TAG_ID_MSG),
2506 (MPM_OP + AMSG_OUT +
2507 currSCCB->Sccb_idmsg));
2509 WR_HARPOON(port + hp_autostart_3,
2514 currSCCB->Sccb_scsistat = SELECT_ST;
2516 currTar_Info->TarLUNBusy[
lun] = 1;
2520 WRW_HARPOON((port + ID_MSG_STRT),
2521 (MPM_OP + AMSG_OUT +
2522 currSCCB->Sccb_idmsg));
2524 WRW_HARPOON((port + ID_MSG_STRT + 2),
2525 (MPM_OP + AMSG_OUT +
2526 (((
unsigned char)(currSCCB->
2529 >> 6) | (
unsigned char)0x20)));
2532 if (++lastTag >= QUEUE_DEPTH)
2534 if (CurrCard->discQ_Tbl[lastTag] ==
2538 (MPM_OP + AMSG_OUT +
2540 CurrCard->tagQ_Lst = lastTag;
2541 currSCCB->Sccb_tag = lastTag;
2542 CurrCard->discQ_Tbl[lastTag] =
2544 CurrCard->discQCount++;
2549 if (i == QUEUE_DEPTH) {
2550 currTar_Info->TarLUNBusy[
lun] = 1;
2551 FPT_queueSelectFail(CurrCard, p_card);
2556 currSCCB->Sccb_scsistat = SELECT_Q_ST;
2558 WR_HARPOON(port + hp_autostart_3,
2565 WRW_HARPOON((port + ID_MSG_STRT),
2566 BRH_OP +
ALWAYS + NTCMD);
2568 WRW_HARPOON((port + NON_TAG_ID_MSG),
2569 (MPM_OP + AMSG_OUT + currSCCB->Sccb_idmsg));
2571 currSCCB->Sccb_scsistat = SELECT_ST;
2573 WR_HARPOON(port + hp_autostart_3,
2577 theCCB = (
unsigned char *)&currSCCB->Cdb[0];
2579 cdb_reg = port + CMD_STRT;
2581 for (i = 0; i < currSCCB->CdbLength; i++) {
2582 WRW_HARPOON(cdb_reg, (MPM_OP +
ACOMMAND + *theCCB));
2587 if (currSCCB->CdbLength != TWELVE_BYTE_CMD)
2588 WRW_HARPOON(cdb_reg, (BRH_OP +
ALWAYS +
NP));
2592 WRW_HARPOON((port + hp_fiforead), (
unsigned short)0x00);
2593 WR_HARPOON(port + hp_xferstat, 0x00);
2595 WRW_HARPOON((port + hp_intstat), (PROG_HLT | TIMEOUT |
SEL | BUS_FREE));
2597 WR_HARPOON(port + hp_portctrl_0, (SCSI_PORT));
2599 if (!(currSCCB->Sccb_MGRFlags & F_DEV_SELECTED)) {
2600 WR_HARPOON(port + hp_scsictrl_0,
2601 (SEL_TAR | ENA_ATN | ENA_RESEL | ENA_SCAM_SEL));
2606 auto_loaded = AUTO_IMMED;
2610 WR_HARPOON(port + hp_autostart_3, auto_loaded);
2624 static void FPT_sres(
unsigned long port,
unsigned char p_card,
2625 struct sccb_card *pCurrCard)
2628 unsigned char our_target,
message, lun = 0,
tag, msgRetryCount;
2630 struct sccb_mgr_tar_info *currTar_Info;
2631 struct sccb *currSCCB;
2633 if (pCurrCard->currentSCCB !=
NULL) {
2635 &FPT_sccbMgrTbl[p_card][pCurrCard->currentSCCB->TargID];
2638 WR_HARPOON((port + hp_scsictrl_0), (ENA_RESEL | ENA_SCAM_SEL));
2640 currSCCB = pCurrCard->currentSCCB;
2641 if (currSCCB->Sccb_scsistat == SELECT_WN_ST) {
2642 currTar_Info->TarStatus &= ~TAR_WIDE_MASK;
2643 currSCCB->Sccb_scsistat = BUS_FREE_ST;
2645 if (currSCCB->Sccb_scsistat == SELECT_SN_ST) {
2646 currTar_Info->TarStatus &= ~TAR_SYNC_MASK;
2647 currSCCB->Sccb_scsistat = BUS_FREE_ST;
2649 if (((pCurrCard->globalFlags & F_CONLUN_IO) &&
2650 ((currTar_Info->TarStatus & TAR_TAG_Q_MASK) !=
2652 currTar_Info->TarLUNBusy[currSCCB->Lun] = 0;
2653 if (currSCCB->Sccb_scsistat != ABORT_ST) {
2654 pCurrCard->discQCount--;
2655 pCurrCard->discQ_Tbl[currTar_Info->
2656 LunDiscQ_Idx[currSCCB->
2661 currTar_Info->TarLUNBusy[0] = 0;
2662 if (currSCCB->Sccb_tag) {
2663 if (currSCCB->Sccb_scsistat != ABORT_ST) {
2664 pCurrCard->discQCount--;
2665 pCurrCard->discQ_Tbl[currSCCB->
2669 if (currSCCB->Sccb_scsistat != ABORT_ST) {
2670 pCurrCard->discQCount--;
2671 pCurrCard->discQ_Tbl[currTar_Info->
2678 FPT_queueSelectFail(&FPT_BL_Card[p_card], p_card);
2681 WRW_HARPOON((port + hp_fiforead), (
unsigned short)0x00);
2683 our_target = (
unsigned char)(RD_HARPOON(port + hp_select_id) >> 4);
2684 currTar_Info = &FPT_sccbMgrTbl[p_card][our_target];
2689 currTar_Info = &FPT_sccbMgrTbl[p_card][our_target];
2692 while (!(RD_HARPOON(port + hp_scsisig) & SCSI_REQ)) {
2693 if (!(RD_HARPOON(port + hp_scsisig) &
SCSI_BSY)) {
2695 WRW_HARPOON((port + hp_intstat), PHASE);
2700 WRW_HARPOON((port + hp_intstat), PHASE);
2701 if ((RD_HARPOON(port + hp_scsisig) & S_SCSI_PHZ) == S_MSGI_PH) {
2703 message = FPT_sfm(port, pCurrCard->currentSCCB);
2706 if (message <= (0x80 | LUN_MASK)) {
2707 lun = message & (
unsigned char)LUN_MASK;
2710 TarStatus & TAR_TAG_Q_MASK) ==
2712 if (currTar_Info->TarTagQ_Cnt !=
2759 ACCEPT_MSG_ATN(port);
2769 ACCEPT_MSG_ATN(port);
2772 (RDW_HARPOON((port + hp_intstat)) &
2774 && !(RD_HARPOON(port + hp_scsisig) & SCSI_REQ)
2775 && (RD_HARPOON(port + hp_scsisig) & SCSI_BSY)) ;
2782 if (msgRetryCount == 1) {
2783 FPT_SendMsg(port, SMPARITY);
2785 FPT_SendMsg(port, SMDEV_RESET);
2787 FPT_sssyncv(port, our_target, NARROW_SCSI,
2790 if (FPT_sccbMgrTbl[p_card][our_target].
2791 TarEEValue & EE_SYNC_MASK) {
2793 FPT_sccbMgrTbl[p_card][our_target].
2794 TarStatus &= ~TAR_SYNC_MASK;
2798 if (FPT_sccbMgrTbl[p_card][our_target].
2799 TarEEValue & EE_WIDE_SCSI) {
2801 FPT_sccbMgrTbl[p_card][our_target].
2802 TarStatus &= ~TAR_WIDE_MASK;
2805 FPT_queueFlushTargSccb(p_card, our_target,
2807 FPT_SccbMgrTableInitTarget(p_card, our_target);
2811 }
while (message == 0);
2813 if (((pCurrCard->globalFlags & F_CONLUN_IO) &&
2814 ((currTar_Info->TarStatus & TAR_TAG_Q_MASK) != TAG_Q_TRYING))) {
2815 currTar_Info->TarLUNBusy[
lun] = 1;
2816 pCurrCard->currentSCCB =
2817 pCurrCard->discQ_Tbl[currTar_Info->LunDiscQ_Idx[
lun]];
2818 if (pCurrCard->currentSCCB !=
NULL) {
2821 ACCEPT_MSG_ATN(port);
2824 currTar_Info->TarLUNBusy[0] = 1;
2827 if (pCurrCard->discQ_Tbl[
tag] !=
NULL) {
2828 pCurrCard->currentSCCB =
2829 pCurrCard->discQ_Tbl[
tag];
2830 currTar_Info->TarTagQ_Cnt--;
2833 ACCEPT_MSG_ATN(port);
2836 pCurrCard->currentSCCB =
2837 pCurrCard->discQ_Tbl[currTar_Info->LunDiscQ_Idx[0]];
2838 if (pCurrCard->currentSCCB !=
NULL) {
2841 ACCEPT_MSG_ATN(port);
2846 if (pCurrCard->currentSCCB !=
NULL) {
2847 if (pCurrCard->currentSCCB->Sccb_scsistat == ABORT_ST) {
2851 FPT_queueFindSccb(pCurrCard->currentSCCB, p_card);
2855 while (!(RDW_HARPOON((port + hp_intstat)) & (PHASE | RESET)) &&
2856 !(RD_HARPOON(port + hp_scsisig) & SCSI_REQ) &&
2857 (RD_HARPOON(port + hp_scsisig) & SCSI_BSY)) ;
2860 static void FPT_SendMsg(
unsigned long port,
unsigned char message)
2862 while (!(RD_HARPOON(port + hp_scsisig) & SCSI_REQ)) {
2863 if (!(RD_HARPOON(port + hp_scsisig) & SCSI_BSY)) {
2865 WRW_HARPOON((port + hp_intstat), PHASE);
2870 WRW_HARPOON((port + hp_intstat), PHASE);
2871 if ((RD_HARPOON(port + hp_scsisig) & S_SCSI_PHZ) == S_MSGO_PH) {
2872 WRW_HARPOON((port + hp_intstat),
2873 (BUS_FREE | PHASE | XFER_CNT_0));
2875 WR_HARPOON(port + hp_portctrl_0, SCSI_BUS_EN);
2877 WR_HARPOON(port + hp_scsidata_0, message);
2879 WR_HARPOON(port + hp_scsisig, (
SCSI_ACK + S_ILL_PH));
2883 WR_HARPOON(port + hp_portctrl_0, 0x00);
2885 if ((message == SMABORT) || (message == SMDEV_RESET) ||
2886 (message == SMABORT_TAG)) {
2888 (RDW_HARPOON((port + hp_intstat)) &
2889 (BUS_FREE | PHASE))) {
2892 if (RDW_HARPOON((port + hp_intstat)) & BUS_FREE) {
2893 WRW_HARPOON((port + hp_intstat), BUS_FREE);
2907 static void FPT_sdecm(
unsigned char message,
unsigned long port,
2908 unsigned char p_card)
2910 struct sccb *currSCCB;
2911 struct sccb_card *CurrCard;
2912 struct sccb_mgr_tar_info *currTar_Info;
2914 CurrCard = &FPT_BL_Card[p_card];
2915 currSCCB = CurrCard->currentSCCB;
2917 currTar_Info = &FPT_sccbMgrTbl[p_card][currSCCB->TargID];
2919 if (message == SMREST_DATA_PTR) {
2920 if (!(currSCCB->Sccb_XferState & F_NO_DATA_YET)) {
2921 currSCCB->Sccb_ATC = currSCCB->Sccb_savedATC;
2923 FPT_hostDataXferRestart(currSCCB);
2927 WR_HARPOON(port + hp_autostart_1,
2928 (AUTO_IMMED + DISCONNECT_START));
2931 else if (message == SMCMD_COMP) {
2933 if (currSCCB->Sccb_scsistat == SELECT_Q_ST) {
2934 currTar_Info->TarStatus &=
2935 ~(
unsigned char)TAR_TAG_Q_MASK;
2936 currTar_Info->TarStatus |= (
unsigned char)TAG_Q_REJECT;
2943 else if ((message == SMNO_OP) || (message >= SMIDENT)
2944 || (message == SMINIT_RECOVERY) || (message == SMREL_RECOVERY)) {
2947 WR_HARPOON(port + hp_autostart_1,
2948 (AUTO_IMMED + DISCONNECT_START));
2951 else if (message == SMREJECT) {
2953 if ((currSCCB->Sccb_scsistat == SELECT_SN_ST) ||
2954 (currSCCB->Sccb_scsistat == SELECT_WN_ST) ||
2955 ((currTar_Info->TarStatus & TAR_SYNC_MASK) == SYNC_TRYING)
2956 || ((currTar_Info->TarStatus & TAR_TAG_Q_MASK) ==
2959 WRW_HARPOON((port + hp_intstat), BUS_FREE);
2963 while ((!(RD_HARPOON(port + hp_scsisig) & SCSI_REQ)) &&
2964 (!(RDW_HARPOON((port + hp_intstat)) & BUS_FREE)))
2968 if (currSCCB->Lun == 0x00) {
2969 if ((currSCCB->Sccb_scsistat == SELECT_SN_ST)) {
2971 currTar_Info->TarStatus |=
2972 (
unsigned char)SYNC_SUPPORTED;
2974 currTar_Info->TarEEValue &=
2978 else if ((currSCCB->Sccb_scsistat ==
2981 currTar_Info->TarStatus =
2983 TarStatus & ~WIDE_ENABLED) |
2986 currTar_Info->TarEEValue &=
2991 else if ((currTar_Info->
2992 TarStatus & TAR_TAG_Q_MASK) ==
2994 currTar_Info->TarStatus =
2996 TarStatus & ~(
unsigned char)
2997 TAR_TAG_Q_MASK) | TAG_Q_REJECT;
2999 currSCCB->ControlByte &= ~F_USE_CMD_Q;
3000 CurrCard->discQCount--;
3001 CurrCard->discQ_Tbl[currSCCB->
3003 currSCCB->Sccb_tag = 0x00;
3008 if (RDW_HARPOON((port + hp_intstat)) & BUS_FREE) {
3010 if (currSCCB->Lun == 0x00) {
3011 WRW_HARPOON((port + hp_intstat),
3013 CurrCard->globalFlags |= F_NEW_SCCB_CMD;
3019 if ((CurrCard->globalFlags & F_CONLUN_IO) &&
3021 TarStatus & TAR_TAG_Q_MASK) !=
3023 currTar_Info->TarLUNBusy[currSCCB->
3026 currTar_Info->TarLUNBusy[0] = 1;
3028 currSCCB->ControlByte &=
3029 ~(
unsigned char)F_USE_CMD_Q;
3031 WR_HARPOON(port + hp_autostart_1,
3032 (AUTO_IMMED + DISCONNECT_START));
3040 while ((!(RD_HARPOON(port + hp_scsisig) & SCSI_REQ)) &&
3041 (!(RDW_HARPOON((port + hp_intstat)) & BUS_FREE)))
3045 if (!(RDW_HARPOON((port + hp_intstat)) & BUS_FREE)) {
3046 WR_HARPOON(port + hp_autostart_1,
3047 (AUTO_IMMED + DISCONNECT_START));
3052 else if (message == SMEXT) {
3055 FPT_shandem(port, p_card, currSCCB);
3058 else if (message == SMIGNORWR) {
3062 message = FPT_sfm(port, currSCCB);
3064 if (currSCCB->Sccb_scsimsg != SMPARITY)
3066 WR_HARPOON(port + hp_autostart_1,
3067 (AUTO_IMMED + DISCONNECT_START));
3072 currSCCB->HostStatus = SCCB_PHASE_SEQUENCE_FAIL;
3073 currSCCB->Sccb_scsimsg = SMREJECT;
3075 ACCEPT_MSG_ATN(port);
3076 WR_HARPOON(port + hp_autostart_1,
3077 (AUTO_IMMED + DISCONNECT_START));
3088 static void FPT_shandem(
unsigned long port,
unsigned char p_card,
3089 struct sccb *pCurrSCCB)
3093 length = FPT_sfm(port, pCurrSCCB);
3097 message = FPT_sfm(port, pCurrSCCB);
3100 if (message == SMSYNC) {
3102 if (length == 0x03) {
3105 FPT_stsyncn(port, p_card);
3108 pCurrSCCB->Sccb_scsimsg = SMREJECT;
3109 ACCEPT_MSG_ATN(port);
3111 }
else if (message == SMWDTR) {
3113 if (length == 0x02) {
3116 FPT_stwidn(port, p_card);
3119 pCurrSCCB->Sccb_scsimsg = SMREJECT;
3120 ACCEPT_MSG_ATN(port);
3122 WR_HARPOON(port + hp_autostart_1,
3128 pCurrSCCB->Sccb_scsimsg = SMREJECT;
3129 ACCEPT_MSG_ATN(port);
3131 WR_HARPOON(port + hp_autostart_1,
3132 (AUTO_IMMED + DISCONNECT_START));
3135 if (pCurrSCCB->Sccb_scsimsg != SMPARITY)
3137 WR_HARPOON(port + hp_autostart_1,
3138 (AUTO_IMMED + DISCONNECT_START));
3141 if (pCurrSCCB->Sccb_scsimsg == SMPARITY)
3142 WR_HARPOON(port + hp_autostart_1,
3143 (AUTO_IMMED + DISCONNECT_START));
3156 static unsigned char FPT_sisyncn(
unsigned long port,
unsigned char p_card,
3157 unsigned char syncFlag)
3159 struct sccb *currSCCB;
3160 struct sccb_mgr_tar_info *currTar_Info;
3162 currSCCB = FPT_BL_Card[p_card].currentSCCB;
3163 currTar_Info = &FPT_sccbMgrTbl[p_card][currSCCB->TargID];
3165 if (!((currTar_Info->TarStatus & TAR_SYNC_MASK) == SYNC_TRYING)) {
3167 WRW_HARPOON((port + ID_MSG_STRT),
3168 (MPM_OP + AMSG_OUT +
3170 Sccb_idmsg & ~(
unsigned char)DISC_PRIV)));
3172 WRW_HARPOON((port + ID_MSG_STRT + 2), BRH_OP +
ALWAYS + CMDPZ);
3174 WRW_HARPOON((port + SYNC_MSGS + 0),
3175 (MPM_OP + AMSG_OUT + SMEXT));
3176 WRW_HARPOON((port + SYNC_MSGS + 2), (MPM_OP + AMSG_OUT + 0x03));
3177 WRW_HARPOON((port + SYNC_MSGS + 4),
3178 (MPM_OP + AMSG_OUT + SMSYNC));
3180 if ((currTar_Info->TarEEValue & EE_SYNC_MASK) == EE_SYNC_20MB)
3182 WRW_HARPOON((port + SYNC_MSGS + 6),
3183 (MPM_OP + AMSG_OUT + 12));
3185 else if ((currTar_Info->TarEEValue & EE_SYNC_MASK) ==
3188 WRW_HARPOON((port + SYNC_MSGS + 6),
3189 (MPM_OP + AMSG_OUT + 25));
3191 else if ((currTar_Info->TarEEValue & EE_SYNC_MASK) ==
3194 WRW_HARPOON((port + SYNC_MSGS + 6),
3195 (MPM_OP + AMSG_OUT + 50));
3198 WRW_HARPOON((port + SYNC_MSGS + 6),
3199 (MPM_OP + AMSG_OUT + 00));
3201 WRW_HARPOON((port + SYNC_MSGS + 8), (RAT_OP));
3202 WRW_HARPOON((port + SYNC_MSGS + 10),
3204 WRW_HARPOON((port + SYNC_MSGS + 12), (BRH_OP +
ALWAYS +
NP));
3206 if (syncFlag == 0) {
3207 WR_HARPOON(port + hp_autostart_3,
3209 currTar_Info->TarStatus =
3211 TarStatus & ~(
unsigned char)TAR_SYNC_MASK) |
3212 (
unsigned char)SYNC_TRYING);
3214 WR_HARPOON(port + hp_autostart_3,
3215 (AUTO_IMMED + CMD_ONLY_STRT));
3223 currTar_Info->TarStatus |= (
unsigned char)SYNC_SUPPORTED;
3224 currTar_Info->TarEEValue &= ~EE_SYNC_MASK;
3237 static void FPT_stsyncn(
unsigned long port,
unsigned char p_card)
3239 unsigned char sync_msg,
offset, sync_reg, our_sync_msg;
3240 struct sccb *currSCCB;
3241 struct sccb_mgr_tar_info *currTar_Info;
3243 currSCCB = FPT_BL_Card[p_card].currentSCCB;
3244 currTar_Info = &FPT_sccbMgrTbl[p_card][currSCCB->TargID];
3246 sync_msg = FPT_sfm(port, currSCCB);
3248 if ((sync_msg == 0x00) && (currSCCB->Sccb_scsimsg == SMPARITY)) {
3249 WR_HARPOON(port + hp_autostart_1,
3250 (AUTO_IMMED + DISCONNECT_START));
3256 offset = FPT_sfm(port, currSCCB);
3258 if ((offset == 0x00) && (currSCCB->Sccb_scsimsg == SMPARITY)) {
3259 WR_HARPOON(port + hp_autostart_1,
3260 (AUTO_IMMED + DISCONNECT_START));
3264 if ((currTar_Info->TarEEValue & EE_SYNC_MASK) == EE_SYNC_20MB)
3268 else if ((currTar_Info->TarEEValue & EE_SYNC_MASK) == EE_SYNC_10MB)
3272 else if ((currTar_Info->TarEEValue & EE_SYNC_MASK) == EE_SYNC_5MB)
3279 if (sync_msg < our_sync_msg) {
3280 sync_msg = our_sync_msg;
3283 if (offset ==
ASYNC)
3319 if (sync_msg > 100) {
3325 if (currTar_Info->TarStatus & WIDE_ENABLED)
3331 sync_reg |= (offset | NARROW_SCSI);
3333 FPT_sssyncv(port, currSCCB->TargID, sync_reg, currTar_Info);
3335 if (currSCCB->Sccb_scsistat == SELECT_SN_ST) {
3339 currTar_Info->TarStatus = ((currTar_Info->TarStatus &
3340 ~(
unsigned char)TAR_SYNC_MASK) |
3341 (
unsigned char)SYNC_SUPPORTED);
3343 WR_HARPOON(port + hp_autostart_1,
3344 (AUTO_IMMED + DISCONNECT_START));
3349 ACCEPT_MSG_ATN(port);
3351 FPT_sisyncr(port, sync_msg, offset);
3353 currTar_Info->TarStatus = ((currTar_Info->TarStatus &
3354 ~(
unsigned char)TAR_SYNC_MASK) |
3355 (
unsigned char)SYNC_SUPPORTED);
3366 static void FPT_sisyncr(
unsigned long port,
unsigned char sync_pulse,
3367 unsigned char offset)
3370 WRW_HARPOON((port + SYNC_MSGS + 0), (MPM_OP + AMSG_OUT + SMEXT));
3371 WRW_HARPOON((port + SYNC_MSGS + 2), (MPM_OP + AMSG_OUT + 0x03));
3372 WRW_HARPOON((port + SYNC_MSGS + 4), (MPM_OP + AMSG_OUT + SMSYNC));
3373 WRW_HARPOON((port + SYNC_MSGS + 6), (MPM_OP + AMSG_OUT + sync_pulse));
3374 WRW_HARPOON((port + SYNC_MSGS + 8), (RAT_OP));
3375 WRW_HARPOON((port + SYNC_MSGS + 10), (MPM_OP + AMSG_OUT + offset));
3376 WRW_HARPOON((port + SYNC_MSGS + 12), (BRH_OP +
ALWAYS +
NP));
3379 WR_HARPOON(port + hp_portctrl_0, SCSI_PORT);
3380 WRW_HARPOON((port + hp_intstat), CLR_ALL_INT_1);
3382 WR_HARPOON(port + hp_autostart_3, (AUTO_IMMED + CMD_ONLY_STRT));
3384 while (!(RDW_HARPOON((port + hp_intstat)) & (BUS_FREE | AUTO_INT))) {
3397 static unsigned char FPT_siwidn(
unsigned long port,
unsigned char p_card)
3399 struct sccb *currSCCB;
3400 struct sccb_mgr_tar_info *currTar_Info;
3402 currSCCB = FPT_BL_Card[p_card].currentSCCB;
3403 currTar_Info = &FPT_sccbMgrTbl[p_card][currSCCB->TargID];
3405 if (!((currTar_Info->TarStatus & TAR_WIDE_MASK) == WIDE_NEGOCIATED)) {
3407 WRW_HARPOON((port + ID_MSG_STRT),
3408 (MPM_OP + AMSG_OUT +
3410 Sccb_idmsg & ~(
unsigned char)DISC_PRIV)));
3412 WRW_HARPOON((port + ID_MSG_STRT + 2), BRH_OP +
ALWAYS + CMDPZ);
3414 WRW_HARPOON((port + SYNC_MSGS + 0),
3415 (MPM_OP + AMSG_OUT + SMEXT));
3416 WRW_HARPOON((port + SYNC_MSGS + 2), (MPM_OP + AMSG_OUT + 0x02));
3417 WRW_HARPOON((port + SYNC_MSGS + 4),
3418 (MPM_OP + AMSG_OUT + SMWDTR));
3419 WRW_HARPOON((port + SYNC_MSGS + 6), (RAT_OP));
3420 WRW_HARPOON((port + SYNC_MSGS + 8),
3421 (MPM_OP + AMSG_OUT + SM16BIT));
3422 WRW_HARPOON((port + SYNC_MSGS + 10), (BRH_OP +
ALWAYS +
NP));
3424 WR_HARPOON(port + hp_autostart_3, (
SELECT + SELCHK_STRT));
3426 currTar_Info->TarStatus = ((currTar_Info->TarStatus &
3427 ~(
unsigned char)TAR_WIDE_MASK) |
3428 (
unsigned char)WIDE_ENABLED);
3435 currTar_Info->TarStatus = ((currTar_Info->TarStatus &
3436 ~(
unsigned char)TAR_WIDE_MASK) |
3439 currTar_Info->TarEEValue &= ~EE_WIDE_SCSI;
3452 static void FPT_stwidn(
unsigned long port,
unsigned char p_card)
3454 unsigned char width;
3455 struct sccb *currSCCB;
3456 struct sccb_mgr_tar_info *currTar_Info;
3458 currSCCB = FPT_BL_Card[p_card].currentSCCB;
3459 currTar_Info = &FPT_sccbMgrTbl[p_card][currSCCB->TargID];
3461 width = FPT_sfm(port, currSCCB);
3463 if ((width == 0x00) && (currSCCB->Sccb_scsimsg == SMPARITY)) {
3464 WR_HARPOON(port + hp_autostart_1,
3465 (AUTO_IMMED + DISCONNECT_START));
3469 if (!(currTar_Info->TarEEValue & EE_WIDE_SCSI))
3473 currTar_Info->TarStatus |= WIDE_ENABLED;
3476 width = NARROW_SCSI;
3477 currTar_Info->TarStatus &= ~WIDE_ENABLED;
3480 FPT_sssyncv(port, currSCCB->TargID, width, currTar_Info);
3482 if (currSCCB->Sccb_scsistat == SELECT_WN_ST) {
3484 currTar_Info->TarStatus |= WIDE_NEGOCIATED;
3487 ((currTar_Info->TarStatus & TAR_SYNC_MASK) ==
3489 ACCEPT_MSG_ATN(port);
3491 FPT_sisyncn(port, p_card, 1);
3492 currSCCB->Sccb_scsistat = SELECT_SN_ST;
3496 WR_HARPOON(port + hp_autostart_1,
3497 (AUTO_IMMED + DISCONNECT_START));
3503 ACCEPT_MSG_ATN(port);
3505 if (currTar_Info->TarEEValue & EE_WIDE_SCSI)
3510 FPT_siwidr(port, width);
3512 currTar_Info->TarStatus |= (WIDE_NEGOCIATED | WIDE_ENABLED);
3523 static void FPT_siwidr(
unsigned long port,
unsigned char width)
3526 WRW_HARPOON((port + SYNC_MSGS + 0), (MPM_OP + AMSG_OUT + SMEXT));
3527 WRW_HARPOON((port + SYNC_MSGS + 2), (MPM_OP + AMSG_OUT + 0x02));
3528 WRW_HARPOON((port + SYNC_MSGS + 4), (MPM_OP + AMSG_OUT + SMWDTR));
3529 WRW_HARPOON((port + SYNC_MSGS + 6), (RAT_OP));
3530 WRW_HARPOON((port + SYNC_MSGS + 8), (MPM_OP + AMSG_OUT + width));
3531 WRW_HARPOON((port + SYNC_MSGS + 10), (BRH_OP +
ALWAYS +
NP));
3534 WR_HARPOON(port + hp_portctrl_0, SCSI_PORT);
3535 WRW_HARPOON((port + hp_intstat), CLR_ALL_INT_1);
3537 WR_HARPOON(port + hp_autostart_3, (AUTO_IMMED + CMD_ONLY_STRT));
3539 while (!(RDW_HARPOON((port + hp_intstat)) & (BUS_FREE | AUTO_INT))) {
3551 static void FPT_sssyncv(
unsigned long p_port,
unsigned char p_id,
3552 unsigned char p_sync_value,
3553 struct sccb_mgr_tar_info *currTar_Info)
3555 unsigned char index;
3611 WR_HARPOON(p_port + hp_synctarg_base + index, p_sync_value);
3613 currTar_Info->TarSyncCtrl = p_sync_value;
3623 static void FPT_sresb(
unsigned long port,
unsigned char p_card)
3625 unsigned char scsiID,
i;
3627 struct sccb_mgr_tar_info *currTar_Info;
3629 WR_HARPOON(port + hp_page_ctrl,
3630 (RD_HARPOON(port + hp_page_ctrl) | G_INT_DISABLE));
3631 WRW_HARPOON((port + hp_intstat), CLR_ALL_INT);
3633 WR_HARPOON(port + hp_scsictrl_0, SCSI_RST);
3635 scsiID = RD_HARPOON(port + hp_seltimeout);
3636 WR_HARPOON(port + hp_seltimeout, TO_5ms);
3637 WRW_HARPOON((port + hp_intstat), TIMEOUT);
3639 WR_HARPOON(port + hp_portctrl_0, (SCSI_PORT | START_TO));
3641 while (!(RDW_HARPOON((port + hp_intstat)) & TIMEOUT)) {
3644 WR_HARPOON(port + hp_seltimeout, scsiID);
3646 WR_HARPOON(port + hp_scsictrl_0, ENA_SCAM_SEL);
3648 FPT_Wait(port, TO_5ms);
3650 WRW_HARPOON((port + hp_intstat), CLR_ALL_INT);
3652 WR_HARPOON(port + hp_int_mask, (RD_HARPOON(port + hp_int_mask) | 0x00));
3654 for (scsiID = 0; scsiID < MAX_SCSI_TAR; scsiID++) {
3655 currTar_Info = &FPT_sccbMgrTbl[p_card][scsiID];
3657 if (currTar_Info->TarEEValue & EE_SYNC_MASK) {
3658 currTar_Info->TarSyncCtrl = 0;
3659 currTar_Info->TarStatus &= ~TAR_SYNC_MASK;
3662 if (currTar_Info->TarEEValue & EE_WIDE_SCSI) {
3663 currTar_Info->TarStatus &= ~TAR_WIDE_MASK;
3666 FPT_sssyncv(port, scsiID, NARROW_SCSI, currTar_Info);
3668 FPT_SccbMgrTableInitTarget(p_card, scsiID);
3671 FPT_BL_Card[p_card].scanIndex = 0x00;
3672 FPT_BL_Card[p_card].currentSCCB =
NULL;
3673 FPT_BL_Card[p_card].globalFlags &= ~(F_TAG_STARTED | F_HOST_XFER_ACT
3675 FPT_BL_Card[p_card].cmdCounter = 0x00;
3676 FPT_BL_Card[p_card].discQCount = 0x00;
3677 FPT_BL_Card[p_card].tagQ_Lst = 0x01;
3680 FPT_BL_Card[p_card].discQ_Tbl[i] =
NULL;
3682 WR_HARPOON(port + hp_page_ctrl,
3683 (RD_HARPOON(port + hp_page_ctrl) & ~G_INT_DISABLE));
3694 static void FPT_ssenss(
struct sccb_card *pCurrCard)
3697 struct sccb *currSCCB;
3699 currSCCB = pCurrCard->currentSCCB;
3701 currSCCB->Save_CdbLen = currSCCB->CdbLength;
3703 for (i = 0; i < 6; i++) {
3705 currSCCB->Save_Cdb[
i] = currSCCB->Cdb[
i];
3708 currSCCB->CdbLength = SIX_BYTE_CMD;
3709 currSCCB->Cdb[0] = SCSI_REQUEST_SENSE;
3710 currSCCB->Cdb[1] = currSCCB->Cdb[1] & (
unsigned char)0xE0;
3711 currSCCB->Cdb[2] = 0x00;
3712 currSCCB->Cdb[3] = 0x00;
3713 currSCCB->Cdb[4] = currSCCB->RequestSenseLength;
3714 currSCCB->Cdb[5] = 0x00;
3716 currSCCB->Sccb_XferCnt = (
unsigned long)currSCCB->RequestSenseLength;
3718 currSCCB->Sccb_ATC = 0x00;
3720 currSCCB->Sccb_XferState |= F_AUTO_SENSE;
3722 currSCCB->Sccb_XferState &= ~F_SG_XFER;
3724 currSCCB->Sccb_idmsg = currSCCB->Sccb_idmsg & ~(
unsigned char)DISC_PRIV;
3726 currSCCB->ControlByte = 0x00;
3728 currSCCB->Sccb_MGRFlags &= F_STATUSLOADED;
3740 static void FPT_sxfrp(
unsigned long p_port,
unsigned char p_card)
3742 unsigned char curr_phz;
3744 DISABLE_AUTO(p_port);
3746 if (FPT_BL_Card[p_card].globalFlags & F_HOST_XFER_ACT) {
3748 FPT_hostDataXferAbort(p_port, p_card,
3749 FPT_BL_Card[p_card].currentSCCB);
3756 if (RDW_HARPOON((p_port + hp_intstat)) &
3757 (BUS_FREE | XFER_CNT_0 | AUTO_INT))
3760 WR_HARPOON(p_port + hp_xfercnt_0, 0x00);
3762 curr_phz = RD_HARPOON(p_port + hp_scsisig) & (
unsigned char)S_SCSI_PHZ;
3764 WRW_HARPOON((p_port + hp_intstat), XFER_CNT_0);
3766 WR_HARPOON(p_port + hp_scsisig, curr_phz);
3768 while (!(RDW_HARPOON((p_port + hp_intstat)) & (BUS_FREE | RESET)) &&
3770 (RD_HARPOON(p_port + hp_scsisig) & (
unsigned char)S_SCSI_PHZ)))
3772 if (curr_phz & (
unsigned char)SCSI_IOBIT) {
3773 WR_HARPOON(p_port + hp_portctrl_0,
3776 if (!(RD_HARPOON(p_port + hp_xferstat) &
FIFO_EMPTY)) {
3777 RD_HARPOON(p_port + hp_fifodata_0);
3780 WR_HARPOON(p_port + hp_portctrl_0,
3782 if (RD_HARPOON(p_port + hp_xferstat) &
FIFO_EMPTY) {
3783 WR_HARPOON(p_port + hp_fifodata_0, 0xFA);
3788 while (!(RDW_HARPOON((p_port + hp_intstat)) & (BUS_FREE | RESET))) {
3789 if (RD_HARPOON(p_port + hp_scsisig) & SCSI_REQ)
3793 WR_HARPOON(p_port + hp_portctrl_0,
3795 while (!(RD_HARPOON(p_port + hp_xferstat) &
FIFO_EMPTY)) {
3796 RD_HARPOON(p_port + hp_fifodata_0);
3799 if (!(RDW_HARPOON((p_port + hp_intstat)) & (BUS_FREE | RESET))) {
3800 WR_HARPOON(p_port + hp_autostart_0,
3801 (AUTO_IMMED + DISCONNECT_START));
3802 while (!(RDW_HARPOON((p_port + hp_intstat)) & AUTO_INT)) {
3805 if (RDW_HARPOON((p_port + hp_intstat)) &
3806 (ICMD_COMP | ITAR_DISC))
3808 (RDW_HARPOON((p_port + hp_intstat)) &
3809 (BUS_FREE | RSEL))) ;
3822 static void FPT_schkdd(
unsigned long port,
unsigned char p_card)
3824 unsigned short TimeOutLoop;
3825 unsigned char sPhase;
3827 struct sccb *currSCCB;
3829 currSCCB = FPT_BL_Card[p_card].currentSCCB;
3831 if ((currSCCB->Sccb_scsistat != DATA_OUT_ST) &&
3832 (currSCCB->Sccb_scsistat != DATA_IN_ST)) {
3836 if (currSCCB->Sccb_XferState & F_ODD_BALL_CNT) {
3838 currSCCB->Sccb_ATC += (currSCCB->Sccb_XferCnt - 1);
3840 currSCCB->Sccb_XferCnt = 1;
3842 currSCCB->Sccb_XferState &= ~F_ODD_BALL_CNT;
3843 WRW_HARPOON((port + hp_fiforead), (
unsigned short)0x00);
3844 WR_HARPOON(port + hp_xferstat, 0x00);
3849 currSCCB->Sccb_ATC += currSCCB->Sccb_XferCnt;
3851 currSCCB->Sccb_XferCnt = 0;
3854 if ((RDW_HARPOON((port + hp_intstat)) & PARITY) &&
3855 (currSCCB->HostStatus == SCCB_COMPLETE)) {
3857 currSCCB->HostStatus = SCCB_PARITY_ERR;
3858 WRW_HARPOON((port + hp_intstat), PARITY);
3861 FPT_hostDataXferAbort(port, p_card, currSCCB);
3863 while (RD_HARPOON(port + hp_scsisig) &
SCSI_ACK) {
3868 while (RD_HARPOON(port + hp_xferstat) & FIFO_EMPTY) {
3869 if (RDW_HARPOON((port + hp_intstat)) & BUS_FREE) {
3872 if (RD_HARPOON(port + hp_offsetctr) & (
unsigned char)0x1F) {
3875 if (RDW_HARPOON((port + hp_intstat)) & RESET) {
3878 if ((RD_HARPOON(port + hp_scsisig) & SCSI_REQ)
3879 || (TimeOutLoop++ > 0x3000))
3883 sPhase = RD_HARPOON(port + hp_scsisig) & (SCSI_BSY | S_SCSI_PHZ);
3884 if ((!(RD_HARPOON(port + hp_xferstat) & FIFO_EMPTY)) ||
3885 (RD_HARPOON(port + hp_offsetctr) & (
unsigned char)0x1F) ||
3886 (sPhase == (SCSI_BSY | S_DATAO_PH)) ||
3887 (sPhase == (SCSI_BSY | S_DATAI_PH))) {
3889 WR_HARPOON(port + hp_portctrl_0, SCSI_PORT);
3891 if (!(currSCCB->Sccb_XferState & F_ALL_XFERRED)) {
3892 if (currSCCB->Sccb_XferState & F_HOST_XFER_DIR) {
3893 FPT_phaseDataIn(port, p_card);
3897 FPT_phaseDataOut(port, p_card);
3900 FPT_sxfrp(port, p_card);
3901 if (!(RDW_HARPOON((port + hp_intstat)) &
3902 (BUS_FREE | ICMD_COMP | ITAR_DISC | RESET))) {
3903 WRW_HARPOON((port + hp_intstat), AUTO_INT);
3904 FPT_phaseDecode(port, p_card);
3911 WR_HARPOON(port + hp_portctrl_0, 0x00);
3923 static void FPT_sinits(
struct sccb *p_sccb,
unsigned char p_card)
3925 struct sccb_mgr_tar_info *currTar_Info;
3927 if ((p_sccb->TargID >= MAX_SCSI_TAR) || (p_sccb->Lun >= MAX_LUN)) {
3930 currTar_Info = &FPT_sccbMgrTbl[p_card][p_sccb->TargID];
3932 p_sccb->Sccb_XferState = 0x00;
3933 p_sccb->Sccb_XferCnt = p_sccb->DataLength;
3935 if ((p_sccb->OperationCode == SCATTER_GATHER_COMMAND) ||
3936 (p_sccb->OperationCode == RESIDUAL_SG_COMMAND)) {
3938 p_sccb->Sccb_SGoffset = 0;
3939 p_sccb->Sccb_XferState = F_SG_XFER;
3940 p_sccb->Sccb_XferCnt = 0x00;
3943 if (p_sccb->DataLength == 0x00)
3945 p_sccb->Sccb_XferState |= F_ALL_XFERRED;
3947 if (p_sccb->ControlByte & F_USE_CMD_Q) {
3948 if ((currTar_Info->TarStatus & TAR_TAG_Q_MASK) == TAG_Q_REJECT)
3949 p_sccb->ControlByte &= ~F_USE_CMD_Q;
3952 currTar_Info->TarStatus |= TAG_Q_TRYING;
3964 if ((currTar_Info->TarStatus & TAR_ALLOW_DISC) ||
3965 (currTar_Info->TarStatus & TAG_Q_TRYING)) {
3966 p_sccb->Sccb_idmsg =
3967 (
unsigned char)(SMIDENT | DISC_PRIV) | p_sccb->Lun;
3972 p_sccb->Sccb_idmsg = (
unsigned char)SMIDENT | p_sccb->Lun;
3975 p_sccb->HostStatus = 0x00;
3976 p_sccb->TargetStatus = 0x00;
3977 p_sccb->Sccb_tag = 0x00;
3978 p_sccb->Sccb_MGRFlags = 0x00;
3979 p_sccb->Sccb_sgseg = 0x00;
3980 p_sccb->Sccb_ATC = 0x00;
3981 p_sccb->Sccb_savedATC = 0x00;
3987 p_sccb->Sccb_scsistat = BUS_FREE_ST;
3988 p_sccb->SccbStatus = SCCB_IN_PROCESS;
3989 p_sccb->Sccb_scsimsg = SMNO_OP;
4001 static void FPT_phaseDecode(
unsigned long p_port,
unsigned char p_card)
4003 unsigned char phase_ref;
4006 DISABLE_AUTO(p_port);
4009 (
unsigned char)(RD_HARPOON(p_port + hp_scsisig) & S_SCSI_PHZ);
4011 phase = FPT_s_PhaseTbl[phase_ref];
4013 (*phase) (p_port, p_card);
4024 static void FPT_phaseDataOut(
unsigned long port,
unsigned char p_card)
4027 struct sccb *currSCCB;
4029 currSCCB = FPT_BL_Card[p_card].currentSCCB;
4030 if (currSCCB ==
NULL) {
4034 currSCCB->Sccb_scsistat = DATA_OUT_ST;
4035 currSCCB->Sccb_XferState &= ~(F_HOST_XFER_DIR | F_NO_DATA_YET);
4037 WR_HARPOON(port + hp_portctrl_0, SCSI_PORT);
4039 WRW_HARPOON((port + hp_intstat), XFER_CNT_0);
4041 WR_HARPOON(port + hp_autostart_0, (END_DATA + END_DATA_START));
4043 FPT_dataXferProcessor(port, &FPT_BL_Card[p_card]);
4045 if (currSCCB->Sccb_XferCnt == 0) {
4047 if ((currSCCB->ControlByte & SCCB_DATA_XFER_OUT) &&
4048 (currSCCB->HostStatus == SCCB_COMPLETE))
4049 currSCCB->HostStatus = SCCB_DATA_OVER_RUN;
4051 FPT_sxfrp(port, p_card);
4052 if (!(RDW_HARPOON((port + hp_intstat)) & (BUS_FREE | RESET)))
4053 FPT_phaseDecode(port, p_card);
4065 static void FPT_phaseDataIn(
unsigned long port,
unsigned char p_card)
4068 struct sccb *currSCCB;
4070 currSCCB = FPT_BL_Card[p_card].currentSCCB;
4072 if (currSCCB ==
NULL) {
4076 currSCCB->Sccb_scsistat = DATA_IN_ST;
4077 currSCCB->Sccb_XferState |= F_HOST_XFER_DIR;
4078 currSCCB->Sccb_XferState &= ~F_NO_DATA_YET;
4080 WR_HARPOON(port + hp_portctrl_0, SCSI_PORT);
4082 WRW_HARPOON((port + hp_intstat), XFER_CNT_0);
4084 WR_HARPOON(port + hp_autostart_0, (END_DATA + END_DATA_START));
4086 FPT_dataXferProcessor(port, &FPT_BL_Card[p_card]);
4088 if (currSCCB->Sccb_XferCnt == 0) {
4090 if ((currSCCB->ControlByte & SCCB_DATA_XFER_IN) &&
4091 (currSCCB->HostStatus == SCCB_COMPLETE))
4092 currSCCB->HostStatus = SCCB_DATA_OVER_RUN;
4094 FPT_sxfrp(port, p_card);
4095 if (!(RDW_HARPOON((port + hp_intstat)) & (BUS_FREE | RESET)))
4096 FPT_phaseDecode(port, p_card);
4109 static void FPT_phaseCommand(
unsigned long p_port,
unsigned char p_card)
4111 struct sccb *currSCCB;
4112 unsigned long cdb_reg;
4115 currSCCB = FPT_BL_Card[p_card].currentSCCB;
4119 currSCCB->HostStatus = SCCB_PHASE_SEQUENCE_FAIL;
4120 currSCCB->CdbLength = SIX_BYTE_CMD;
4123 WR_HARPOON(p_port + hp_scsisig, 0x00);
4125 ARAM_ACCESS(p_port);
4127 cdb_reg = p_port + CMD_STRT;
4129 for (i = 0; i < currSCCB->CdbLength; i++) {
4133 WRW_HARPOON(cdb_reg, (MPM_OP +
ACOMMAND + 0x00));
4136 WRW_HARPOON(cdb_reg,
4137 (MPM_OP +
ACOMMAND + currSCCB->Cdb[i]));
4141 if (currSCCB->CdbLength != TWELVE_BYTE_CMD)
4142 WRW_HARPOON(cdb_reg, (BRH_OP +
ALWAYS +
NP));
4144 WR_HARPOON(p_port + hp_portctrl_0, (SCSI_PORT));
4146 currSCCB->Sccb_scsistat = COMMAND_ST;
4148 WR_HARPOON(p_port + hp_autostart_3, (AUTO_IMMED | CMD_ONLY_STRT));
4149 SGRAM_ACCESS(p_port);
4160 static void FPT_phaseStatus(
unsigned long port,
unsigned char p_card)
4167 WR_HARPOON(port + hp_scsisig, 0x00);
4169 WR_HARPOON(port + hp_autostart_0, (AUTO_IMMED + END_DATA_START));
4181 static void FPT_phaseMsgOut(
unsigned long port,
unsigned char p_card)
4183 unsigned char message, scsiID;
4184 struct sccb *currSCCB;
4185 struct sccb_mgr_tar_info *currTar_Info;
4187 currSCCB = FPT_BL_Card[p_card].currentSCCB;
4189 if (currSCCB !=
NULL) {
4191 message = currSCCB->Sccb_scsimsg;
4192 scsiID = currSCCB->TargID;
4194 if (message == SMDEV_RESET) {
4196 currTar_Info = &FPT_sccbMgrTbl[p_card][scsiID];
4197 currTar_Info->TarSyncCtrl = 0;
4198 FPT_sssyncv(port, scsiID, NARROW_SCSI, currTar_Info);
4200 if (FPT_sccbMgrTbl[p_card][scsiID].
4201 TarEEValue & EE_SYNC_MASK) {
4203 FPT_sccbMgrTbl[p_card][scsiID].TarStatus &=
4208 if (FPT_sccbMgrTbl[p_card][scsiID].
4209 TarEEValue & EE_WIDE_SCSI) {
4211 FPT_sccbMgrTbl[p_card][scsiID].TarStatus &=
4215 FPT_queueFlushSccb(p_card, SCCB_COMPLETE);
4216 FPT_SccbMgrTableInitTarget(p_card, scsiID);
4217 }
else if (currSCCB->Sccb_scsistat == ABORT_ST) {
4218 currSCCB->HostStatus = SCCB_COMPLETE;
4219 if (FPT_BL_Card[p_card].discQ_Tbl[currSCCB->Sccb_tag] !=
4221 FPT_BL_Card[p_card].discQ_Tbl[currSCCB->
4223 FPT_sccbMgrTbl[p_card][scsiID].TarTagQ_Cnt--;
4228 else if (currSCCB->Sccb_scsistat < COMMAND_ST) {
4230 if (message == SMNO_OP) {
4231 currSCCB->Sccb_MGRFlags |= F_DEV_SELECTED;
4233 FPT_ssel(port, p_card);
4238 if (message == SMABORT)
4240 FPT_queueFlushSccb(p_card, SCCB_COMPLETE);
4247 WRW_HARPOON((port + hp_intstat), (BUS_FREE | PHASE | XFER_CNT_0));
4249 WR_HARPOON(port + hp_portctrl_0, SCSI_BUS_EN);
4251 WR_HARPOON(port + hp_scsidata_0, message);
4253 WR_HARPOON(port + hp_scsisig, (SCSI_ACK + S_ILL_PH));
4257 WR_HARPOON(port + hp_portctrl_0, 0x00);
4259 if ((message == SMABORT) || (message == SMDEV_RESET) ||
4260 (message == SMABORT_TAG)) {
4262 while (!(RDW_HARPOON((port + hp_intstat)) & (BUS_FREE | PHASE))) {
4265 if (RDW_HARPOON((port + hp_intstat)) & BUS_FREE) {
4266 WRW_HARPOON((port + hp_intstat), BUS_FREE);
4268 if (currSCCB !=
NULL) {
4270 if ((FPT_BL_Card[p_card].
4271 globalFlags & F_CONLUN_IO)
4273 ((FPT_sccbMgrTbl[p_card][currSCCB->TargID].
4274 TarStatus & TAR_TAG_Q_MASK) !=
4276 FPT_sccbMgrTbl[p_card][currSCCB->
4278 TarLUNBusy[currSCCB->Lun] = 0;
4280 FPT_sccbMgrTbl[p_card][currSCCB->
4284 FPT_queueCmdComplete(&FPT_BL_Card[p_card],
4289 FPT_BL_Card[p_card].globalFlags |=
4296 FPT_sxfrp(port, p_card);
4302 if (message == SMPARITY) {
4303 currSCCB->Sccb_scsimsg = SMNO_OP;
4304 WR_HARPOON(port + hp_autostart_1,
4305 (AUTO_IMMED + DISCONNECT_START));
4307 FPT_sxfrp(port, p_card);
4320 static void FPT_phaseMsgIn(
unsigned long port,
unsigned char p_card)
4323 struct sccb *currSCCB;
4325 currSCCB = FPT_BL_Card[p_card].currentSCCB;
4327 if (FPT_BL_Card[p_card].globalFlags & F_HOST_XFER_ACT) {
4329 FPT_phaseChkFifo(port, p_card);
4332 message = RD_HARPOON(port + hp_scsidata_0);
4333 if ((message == SMDISC) || (message == SMSAVE_DATA_PTR)) {
4335 WR_HARPOON(port + hp_autostart_1,
4336 (AUTO_IMMED + END_DATA_START));
4342 message = FPT_sfm(port, currSCCB);
4345 FPT_sdecm(message, port, p_card);
4348 if (currSCCB->Sccb_scsimsg != SMPARITY)
4350 WR_HARPOON(port + hp_autostart_1,
4351 (AUTO_IMMED + DISCONNECT_START));
4367 static void FPT_phaseIllegal(
unsigned long port,
unsigned char p_card)
4369 struct sccb *currSCCB;
4371 currSCCB = FPT_BL_Card[p_card].currentSCCB;
4373 WR_HARPOON(port + hp_scsisig, RD_HARPOON(port + hp_scsisig));
4374 if (currSCCB !=
NULL) {
4376 currSCCB->HostStatus = SCCB_PHASE_SEQUENCE_FAIL;
4377 currSCCB->Sccb_scsistat = ABORT_ST;
4378 currSCCB->Sccb_scsimsg = SMABORT;
4381 ACCEPT_MSG_ATN(port);
4393 static void FPT_phaseChkFifo(
unsigned long port,
unsigned char p_card)
4395 unsigned long xfercnt;
4396 struct sccb *currSCCB;
4398 currSCCB = FPT_BL_Card[p_card].currentSCCB;
4400 if (currSCCB->Sccb_scsistat == DATA_IN_ST) {
4402 while ((!(RD_HARPOON(port + hp_xferstat) & FIFO_EMPTY)) &&
4403 (RD_HARPOON(port + hp_ext_status) & BM_CMD_BUSY)) {
4406 if (!(RD_HARPOON(port + hp_xferstat) & FIFO_EMPTY)) {
4407 currSCCB->Sccb_ATC += currSCCB->Sccb_XferCnt;
4409 currSCCB->Sccb_XferCnt = 0;
4411 if ((RDW_HARPOON((port + hp_intstat)) & PARITY) &&
4412 (currSCCB->HostStatus == SCCB_COMPLETE)) {
4413 currSCCB->HostStatus = SCCB_PARITY_ERR;
4414 WRW_HARPOON((port + hp_intstat), PARITY);
4417 FPT_hostDataXferAbort(port, p_card, currSCCB);
4419 FPT_dataXferProcessor(port, &FPT_BL_Card[p_card]);
4421 while ((!(RD_HARPOON(port + hp_xferstat) & FIFO_EMPTY))
4422 && (RD_HARPOON(port + hp_ext_status) &
4430 GET_XFER_CNT(port, xfercnt);
4432 WR_HARPOON(port + hp_xfercnt_0, 0x00);
4434 WR_HARPOON(port + hp_portctrl_0, 0x00);
4436 currSCCB->Sccb_ATC += (currSCCB->Sccb_XferCnt - xfercnt);
4438 currSCCB->Sccb_XferCnt = xfercnt;
4440 if ((RDW_HARPOON((port + hp_intstat)) & PARITY) &&
4441 (currSCCB->HostStatus == SCCB_COMPLETE)) {
4443 currSCCB->HostStatus = SCCB_PARITY_ERR;
4444 WRW_HARPOON((port + hp_intstat), PARITY);
4447 FPT_hostDataXferAbort(port, p_card, currSCCB);
4449 WR_HARPOON(port + hp_fifowrite, 0x00);
4450 WR_HARPOON(port + hp_fiforead, 0x00);
4451 WR_HARPOON(port + hp_xferstat, 0x00);
4453 WRW_HARPOON((port + hp_intstat), XFER_CNT_0);
4464 static void FPT_phaseBusFree(
unsigned long port,
unsigned char p_card)
4466 struct sccb *currSCCB;
4468 currSCCB = FPT_BL_Card[p_card].currentSCCB;
4470 if (currSCCB !=
NULL) {
4476 if ((FPT_BL_Card[p_card].globalFlags & F_CONLUN_IO) &&
4477 ((FPT_sccbMgrTbl[p_card][currSCCB->TargID].
4478 TarStatus & TAR_TAG_Q_MASK) != TAG_Q_TRYING))
4479 FPT_sccbMgrTbl[p_card][currSCCB->TargID].
4480 TarLUNBusy[currSCCB->Lun] = 0;
4482 FPT_sccbMgrTbl[p_card][currSCCB->TargID].
4485 FPT_queueCmdComplete(&FPT_BL_Card[p_card], currSCCB,
4488 FPT_queueSearchSelect(&FPT_BL_Card[p_card], p_card);
4492 else if (currSCCB->Sccb_scsistat == SELECT_SN_ST) {
4493 FPT_sccbMgrTbl[p_card][currSCCB->TargID].TarStatus |=
4494 (
unsigned char)SYNC_SUPPORTED;
4495 FPT_sccbMgrTbl[p_card][currSCCB->TargID].TarEEValue &=
4499 else if (currSCCB->Sccb_scsistat == SELECT_WN_ST) {
4500 FPT_sccbMgrTbl[p_card][currSCCB->TargID].TarStatus =
4501 (FPT_sccbMgrTbl[p_card][currSCCB->TargID].
4502 TarStatus & ~WIDE_ENABLED) | WIDE_NEGOCIATED;
4504 FPT_sccbMgrTbl[p_card][currSCCB->TargID].TarEEValue &=
4508 else if (currSCCB->Sccb_scsistat == SELECT_Q_ST) {
4513 if ((!(RD_HARPOON(port + hp_scsisig) & SCSI_BSY)) ||
4514 (RDW_HARPOON((port + hp_intstat)) & RSEL)) {
4515 FPT_sccbMgrTbl[p_card][currSCCB->TargID].
4516 TarStatus &= ~TAR_TAG_Q_MASK;
4517 FPT_sccbMgrTbl[p_card][currSCCB->TargID].
4518 TarStatus |= TAG_Q_REJECT;
4528 currSCCB->Sccb_scsistat = BUS_FREE_ST;
4530 if (!currSCCB->HostStatus) {
4531 currSCCB->HostStatus = SCCB_PHASE_SEQUENCE_FAIL;
4534 if ((FPT_BL_Card[p_card].globalFlags & F_CONLUN_IO) &&
4535 ((FPT_sccbMgrTbl[p_card][currSCCB->TargID].
4536 TarStatus & TAR_TAG_Q_MASK) != TAG_Q_TRYING))
4537 FPT_sccbMgrTbl[p_card][currSCCB->TargID].
4538 TarLUNBusy[currSCCB->Lun] = 0;
4540 FPT_sccbMgrTbl[p_card][currSCCB->TargID].
4543 FPT_queueCmdComplete(&FPT_BL_Card[p_card], currSCCB,
4548 FPT_BL_Card[p_card].globalFlags |= F_NEW_SCCB_CMD;
4560 static void FPT_autoLoadDefaultMap(
unsigned long p_port)
4562 unsigned long map_addr;
4564 ARAM_ACCESS(p_port);
4565 map_addr = p_port + hp_aramBase;
4567 WRW_HARPOON(map_addr, (MPM_OP + AMSG_OUT + 0xC0));
4569 WRW_HARPOON(map_addr, (MPM_OP + AMSG_OUT + 0x20));
4571 WRW_HARPOON(map_addr, RAT_OP);
4573 WRW_HARPOON(map_addr, (MPM_OP + AMSG_OUT + 0x00));
4575 WRW_HARPOON(map_addr, (MPM_OP +
ACOMMAND + 0x00));
4577 WRW_HARPOON(map_addr, (MPM_OP +
ACOMMAND + 0x00));
4579 WRW_HARPOON(map_addr, (MPM_OP +
ACOMMAND + 0x00));
4581 WRW_HARPOON(map_addr, (MPM_OP +
ACOMMAND + 0x00));
4583 WRW_HARPOON(map_addr, (MPM_OP +
ACOMMAND + 0x00));
4585 WRW_HARPOON(map_addr, (MPM_OP +
ACOMMAND + 0x00));
4587 WRW_HARPOON(map_addr, (MPM_OP +
ACOMMAND + 0x00));
4589 WRW_HARPOON(map_addr, (MPM_OP +
ACOMMAND + 0x00));
4591 WRW_HARPOON(map_addr, (MPM_OP +
ACOMMAND + 0x00));
4593 WRW_HARPOON(map_addr, (MPM_OP +
ACOMMAND + 0x00));
4595 WRW_HARPOON(map_addr, (MPM_OP +
ACOMMAND + 0x00));
4597 WRW_HARPOON(map_addr, (MPM_OP +
ACOMMAND + 0x00));
4599 WRW_HARPOON(map_addr, (CPE_OP + ADATA_OUT +
DINT));
4601 WRW_HARPOON(map_addr, (TCB_OP + FIFO_0 +
DI));
4603 WRW_HARPOON(map_addr, (SSI_OP + SSI_IDO_STRT));
4605 WRW_HARPOON(map_addr, (CPE_OP + ADATA_IN +
DINT));
4607 WRW_HARPOON(map_addr, (CPN_OP + AMSG_IN +
ST));
4609 WRW_HARPOON(map_addr, (CRD_OP +
SDATA + 0x02));
4611 WRW_HARPOON(map_addr, (BRH_OP + NOT_EQ +
DC));
4613 WRW_HARPOON(map_addr, (MRR_OP +
SDATA + D_AR1));
4615 WRW_HARPOON(map_addr, (CPN_OP + AMSG_IN +
ST));
4617 WRW_HARPOON(map_addr, (CRD_OP +
SDATA + 0x04));
4619 WRW_HARPOON(map_addr, (BRH_OP + NOT_EQ + UNKNWN));
4621 WRW_HARPOON(map_addr, (MRR_OP +
SDATA + D_BUCKET));
4623 WRW_HARPOON(map_addr, (SSI_OP + SSI_ITAR_DISC));
4625 WRW_HARPOON(map_addr, (CPN_OP +
ASTATUS + UNKNWN));
4627 WRW_HARPOON(map_addr, (MRR_OP +
SDATA + D_AR0));
4629 WRW_HARPOON(map_addr, (CPN_OP + AMSG_IN +
CC));
4631 WRW_HARPOON(map_addr, (CRD_OP +
SDATA + 0x00));
4633 WRW_HARPOON(map_addr, (BRH_OP + NOT_EQ +
CC));
4635 WRW_HARPOON(map_addr, (MRR_OP +
SDATA + D_BUCKET));
4637 WRW_HARPOON(map_addr, (SSI_OP + SSI_ICMD_COMP));
4640 WRW_HARPOON(map_addr, (SSI_OP + SSI_IUNKWN));
4642 WRW_HARPOON(map_addr, (SSI_OP + SSI_INO_CC));
4644 WRW_HARPOON(map_addr, (SSI_OP + SSI_ITICKLE));
4646 WRW_HARPOON(map_addr, (SSI_OP + SSI_IRFAIL));
4648 WRW_HARPOON(map_addr, (CRR_OP + AR3 + S_IDREG));
4650 WRW_HARPOON(map_addr, (BRH_OP +
EQUAL + 0x00));
4652 WRW_HARPOON(map_addr, (SSI_OP + SSI_INO_CC));
4654 SGRAM_ACCESS(p_port);
4666 static void FPT_autoCmdCmplt(
unsigned long p_port,
unsigned char p_card)
4668 struct sccb *currSCCB;
4671 currSCCB = FPT_BL_Card[p_card].currentSCCB;
4673 status_byte = RD_HARPOON(p_port + hp_gp_reg_0);
4675 FPT_sccbMgrTbl[p_card][currSCCB->TargID].TarLUN_CA = 0;
4677 if (status_byte != SSGOOD) {
4679 if (status_byte == SSQ_FULL) {
4681 if (((FPT_BL_Card[p_card].globalFlags & F_CONLUN_IO) &&
4682 ((FPT_sccbMgrTbl[p_card][currSCCB->TargID].
4683 TarStatus & TAR_TAG_Q_MASK) != TAG_Q_TRYING))) {
4684 FPT_sccbMgrTbl[p_card][currSCCB->TargID].
4685 TarLUNBusy[currSCCB->Lun] = 1;
4686 if (FPT_BL_Card[p_card].discQCount != 0)
4687 FPT_BL_Card[p_card].discQCount--;
4688 FPT_BL_Card[p_card].
4689 discQ_Tbl[FPT_sccbMgrTbl[p_card]
4691 LunDiscQ_Idx[currSCCB->Lun]] =
4694 FPT_sccbMgrTbl[p_card][currSCCB->TargID].
4696 if (currSCCB->Sccb_tag) {
4697 if (FPT_BL_Card[p_card].discQCount != 0)
4698 FPT_BL_Card[p_card].
4700 FPT_BL_Card[p_card].discQ_Tbl[currSCCB->
4704 if (FPT_BL_Card[p_card].discQCount != 0)
4705 FPT_BL_Card[p_card].
4707 FPT_BL_Card[p_card].
4708 discQ_Tbl[FPT_sccbMgrTbl[p_card]
4710 LunDiscQ_Idx[0]] =
NULL;
4714 currSCCB->Sccb_MGRFlags |= F_STATUSLOADED;
4716 FPT_queueSelectFail(&FPT_BL_Card[p_card], p_card);
4721 if (currSCCB->Sccb_scsistat == SELECT_SN_ST) {
4722 FPT_sccbMgrTbl[p_card][currSCCB->TargID].TarStatus |=
4723 (
unsigned char)SYNC_SUPPORTED;
4725 FPT_sccbMgrTbl[p_card][currSCCB->TargID].TarEEValue &=
4727 FPT_BL_Card[p_card].globalFlags |= F_NEW_SCCB_CMD;
4729 if (((FPT_BL_Card[p_card].globalFlags & F_CONLUN_IO) &&
4730 ((FPT_sccbMgrTbl[p_card][currSCCB->TargID].
4731 TarStatus & TAR_TAG_Q_MASK) != TAG_Q_TRYING))) {
4732 FPT_sccbMgrTbl[p_card][currSCCB->TargID].
4733 TarLUNBusy[currSCCB->Lun] = 1;
4734 if (FPT_BL_Card[p_card].discQCount != 0)
4735 FPT_BL_Card[p_card].discQCount--;
4736 FPT_BL_Card[p_card].
4737 discQ_Tbl[FPT_sccbMgrTbl[p_card]
4739 LunDiscQ_Idx[currSCCB->Lun]] =
4742 FPT_sccbMgrTbl[p_card][currSCCB->TargID].
4744 if (currSCCB->Sccb_tag) {
4745 if (FPT_BL_Card[p_card].discQCount != 0)
4746 FPT_BL_Card[p_card].
4748 FPT_BL_Card[p_card].discQ_Tbl[currSCCB->
4752 if (FPT_BL_Card[p_card].discQCount != 0)
4753 FPT_BL_Card[p_card].
4755 FPT_BL_Card[p_card].
4756 discQ_Tbl[FPT_sccbMgrTbl[p_card]
4758 LunDiscQ_Idx[0]] =
NULL;
4765 if (currSCCB->Sccb_scsistat == SELECT_WN_ST) {
4767 FPT_sccbMgrTbl[p_card][currSCCB->TargID].TarStatus =
4768 (FPT_sccbMgrTbl[p_card][currSCCB->TargID].
4769 TarStatus & ~WIDE_ENABLED) | WIDE_NEGOCIATED;
4771 FPT_sccbMgrTbl[p_card][currSCCB->TargID].TarEEValue &=
4773 FPT_BL_Card[p_card].globalFlags |= F_NEW_SCCB_CMD;
4775 if (((FPT_BL_Card[p_card].globalFlags & F_CONLUN_IO) &&
4776 ((FPT_sccbMgrTbl[p_card][currSCCB->TargID].
4777 TarStatus & TAR_TAG_Q_MASK) != TAG_Q_TRYING))) {
4778 FPT_sccbMgrTbl[p_card][currSCCB->TargID].
4779 TarLUNBusy[currSCCB->Lun] = 1;
4780 if (FPT_BL_Card[p_card].discQCount != 0)
4781 FPT_BL_Card[p_card].discQCount--;
4782 FPT_BL_Card[p_card].
4783 discQ_Tbl[FPT_sccbMgrTbl[p_card]
4785 LunDiscQ_Idx[currSCCB->Lun]] =
4788 FPT_sccbMgrTbl[p_card][currSCCB->TargID].
4790 if (currSCCB->Sccb_tag) {
4791 if (FPT_BL_Card[p_card].discQCount != 0)
4792 FPT_BL_Card[p_card].
4794 FPT_BL_Card[p_card].discQ_Tbl[currSCCB->
4798 if (FPT_BL_Card[p_card].discQCount != 0)
4799 FPT_BL_Card[p_card].
4801 FPT_BL_Card[p_card].
4802 discQ_Tbl[FPT_sccbMgrTbl[p_card]
4804 LunDiscQ_Idx[0]] =
NULL;
4811 if (status_byte == SSCHECK) {
4812 if (FPT_BL_Card[p_card].globalFlags & F_DO_RENEGO) {
4813 if (FPT_sccbMgrTbl[p_card][currSCCB->TargID].
4814 TarEEValue & EE_SYNC_MASK) {
4815 FPT_sccbMgrTbl[p_card][currSCCB->
4817 TarStatus &= ~TAR_SYNC_MASK;
4819 if (FPT_sccbMgrTbl[p_card][currSCCB->TargID].
4820 TarEEValue & EE_WIDE_SCSI) {
4821 FPT_sccbMgrTbl[p_card][currSCCB->
4823 TarStatus &= ~TAR_WIDE_MASK;
4828 if (!(currSCCB->Sccb_XferState & F_AUTO_SENSE)) {
4830 currSCCB->SccbStatus = SCCB_ERROR;
4833 if (status_byte == SSCHECK) {
4835 FPT_sccbMgrTbl[p_card][currSCCB->TargID].
4838 if (currSCCB->RequestSenseLength !=
4839 NO_AUTO_REQUEST_SENSE) {
4841 if (currSCCB->RequestSenseLength == 0)
4842 currSCCB->RequestSenseLength =
4845 FPT_ssenss(&FPT_BL_Card[p_card]);
4846 FPT_BL_Card[p_card].globalFlags |=
4849 if (((FPT_BL_Card[p_card].
4850 globalFlags & F_CONLUN_IO)
4852 ((FPT_sccbMgrTbl[p_card]
4854 TarStatus & TAR_TAG_Q_MASK) !=
4856 FPT_sccbMgrTbl[p_card]
4858 TarLUNBusy[currSCCB->Lun] =
4860 if (FPT_BL_Card[p_card].
4862 FPT_BL_Card[p_card].
4864 FPT_BL_Card[p_card].
4865 discQ_Tbl[FPT_sccbMgrTbl
4873 FPT_sccbMgrTbl[p_card]
4876 if (currSCCB->Sccb_tag) {
4877 if (FPT_BL_Card[p_card].
4882 FPT_BL_Card[p_card].
4883 discQ_Tbl[currSCCB->
4887 if (FPT_BL_Card[p_card].
4892 FPT_BL_Card[p_card].
4907 if ((FPT_BL_Card[p_card].globalFlags & F_CONLUN_IO) &&
4908 ((FPT_sccbMgrTbl[p_card][currSCCB->TargID].
4909 TarStatus & TAR_TAG_Q_MASK) != TAG_Q_TRYING))
4910 FPT_sccbMgrTbl[p_card][currSCCB->TargID].TarLUNBusy[currSCCB->
4913 FPT_sccbMgrTbl[p_card][currSCCB->TargID].TarLUNBusy[0] = 0;
4915 FPT_queueCmdComplete(&FPT_BL_Card[p_card], currSCCB, p_card);
4918 #define SHORT_WAIT 0x0000000F
4919 #define LONG_WAIT 0x0000FFFFL
4939 static void FPT_dataXferProcessor(
unsigned long port,
4940 struct sccb_card *pCurrCard)
4942 struct sccb *currSCCB;
4944 currSCCB = pCurrCard->currentSCCB;
4946 if (currSCCB->Sccb_XferState & F_SG_XFER) {
4947 if (pCurrCard->globalFlags & F_HOST_XFER_ACT)
4949 currSCCB->Sccb_sgseg += (
unsigned char)SG_BUF_CNT;
4950 currSCCB->Sccb_SGoffset = 0x00;
4952 pCurrCard->globalFlags |= F_HOST_XFER_ACT;
4954 FPT_busMstrSGDataXferStart(port, currSCCB);
4958 if (!(pCurrCard->globalFlags & F_HOST_XFER_ACT)) {
4959 pCurrCard->globalFlags |= F_HOST_XFER_ACT;
4961 FPT_busMstrDataXferStart(port, currSCCB);
4973 static void FPT_busMstrSGDataXferStart(
unsigned long p_port,
4974 struct sccb *pcurrSCCB)
4977 unsigned int sg_index;
4979 unsigned long reg_offset;
4981 if (pcurrSCCB->Sccb_XferState & F_HOST_XFER_DIR) {
4983 count = ((
unsigned long)HOST_RD_CMD) << 24;
4987 count = ((
unsigned long)HOST_WRT_CMD) << 24;
4992 sg_index = pcurrSCCB->Sccb_sgseg;
4993 reg_offset = hp_aramBase;
4995 i = (
unsigned char)(RD_HARPOON(p_port + hp_page_ctrl) &
4996 ~(SGRAM_ARAM | SCATTER_EN));
4998 WR_HARPOON(p_port + hp_page_ctrl, i);
5000 while ((sg_count < (
unsigned char)SG_BUF_CNT) &&
5001 ((
unsigned long)(sg_index * (
unsigned int)SG_ELEMENT_SIZE) <
5002 pcurrSCCB->DataLength)) {
5004 tmpSGCnt += *(((
unsigned long *)pcurrSCCB->DataPointer) +
5007 count |= *(((
unsigned long *)pcurrSCCB->DataPointer) +
5010 addr = *(((
unsigned long *)pcurrSCCB->DataPointer) +
5011 ((sg_index * 2) + 1));
5013 if ((!sg_count) && (pcurrSCCB->Sccb_SGoffset)) {
5016 ((count & 0x00FFFFFF
L) - pcurrSCCB->Sccb_SGoffset);
5018 (count & 0xFF000000
L) | pcurrSCCB->Sccb_SGoffset;
5020 tmpSGCnt = count & 0x00FFFFFFL;
5023 WR_HARP32(p_port, reg_offset, addr);
5026 WR_HARP32(p_port, reg_offset, count);
5029 count &= 0xFF000000
L;
5035 pcurrSCCB->Sccb_XferCnt = tmpSGCnt;
5037 WR_HARPOON(p_port + hp_sg_addr, (sg_count << 4));
5039 if (pcurrSCCB->Sccb_XferState & F_HOST_XFER_DIR) {
5041 WR_HARP32(p_port, hp_xfercnt_0, tmpSGCnt);
5043 WR_HARPOON(p_port + hp_portctrl_0,
5044 (DMA_PORT | SCSI_PORT | SCSI_INBIT));
5045 WR_HARPOON(p_port + hp_scsisig, S_DATAI_PH);
5050 if ((!(RD_HARPOON(p_port + hp_synctarg_0) & NARROW_SCSI)) &&
5051 (tmpSGCnt & 0x000000001)) {
5053 pcurrSCCB->Sccb_XferState |= F_ODD_BALL_CNT;
5057 WR_HARP32(p_port, hp_xfercnt_0, tmpSGCnt);
5059 WR_HARPOON(p_port + hp_portctrl_0,
5060 (SCSI_PORT | DMA_PORT |
DMA_RD));
5061 WR_HARPOON(p_port + hp_scsisig, S_DATAO_PH);
5064 WR_HARPOON(p_port + hp_page_ctrl, (
unsigned char)(i | SCATTER_EN));
5075 static void FPT_busMstrDataXferStart(
unsigned long p_port,
5076 struct sccb *pcurrSCCB)
5080 if (!(pcurrSCCB->Sccb_XferState & F_AUTO_SENSE)) {
5082 count = pcurrSCCB->Sccb_XferCnt;
5085 (
unsigned long)pcurrSCCB->DataPointer + pcurrSCCB->Sccb_ATC;
5089 addr = pcurrSCCB->SensePointer;
5090 count = pcurrSCCB->RequestSenseLength;
5094 HP_SETUP_ADDR_CNT(p_port, addr, count);
5096 if (pcurrSCCB->Sccb_XferState & F_HOST_XFER_DIR) {
5098 WR_HARPOON(p_port + hp_portctrl_0,
5099 (DMA_PORT | SCSI_PORT | SCSI_INBIT));
5100 WR_HARPOON(p_port + hp_scsisig, S_DATAI_PH);
5102 WR_HARPOON(p_port + hp_xfer_cmd,
5103 (XFER_DMA_HOST | XFER_HOST_AUTO | XFER_DMA_8BIT));
5108 WR_HARPOON(p_port + hp_portctrl_0,
5109 (SCSI_PORT | DMA_PORT |
DMA_RD));
5110 WR_HARPOON(p_port + hp_scsisig, S_DATAO_PH);
5112 WR_HARPOON(p_port + hp_xfer_cmd,
5113 (XFER_HOST_DMA | XFER_HOST_AUTO | XFER_DMA_8BIT));
5130 static unsigned char FPT_busMstrTimeOut(
unsigned long p_port)
5134 timeout = LONG_WAIT;
5136 WR_HARPOON(p_port + hp_sys_ctrl, HALT_MACH);
5138 while ((!(RD_HARPOON(p_port + hp_ext_status) &
CMD_ABORTED))
5142 if (RD_HARPOON(p_port + hp_ext_status) & BM_CMD_BUSY) {
5143 WR_HARPOON(p_port + hp_sys_ctrl, HARD_ABORT);
5145 timeout = LONG_WAIT;
5146 while ((RD_HARPOON(p_port + hp_ext_status) & BM_CMD_BUSY)
5151 RD_HARPOON(p_port + hp_int_status);
5153 if (RD_HARPOON(p_port + hp_ext_status) & BM_CMD_BUSY) {
5169 static void FPT_hostDataXferAbort(
unsigned long port,
unsigned char p_card,
5170 struct sccb *pCurrSCCB)
5173 unsigned long timeout;
5174 unsigned long remain_cnt;
5175 unsigned int sg_ptr;
5177 FPT_BL_Card[p_card].globalFlags &= ~F_HOST_XFER_ACT;
5179 if (pCurrSCCB->Sccb_XferState & F_AUTO_SENSE) {
5181 if (!(RD_HARPOON(port + hp_int_status) & INT_CMD_COMPL)) {
5183 WR_HARPOON(port + hp_bm_ctrl,
5184 (RD_HARPOON(port + hp_bm_ctrl) |
5186 timeout = LONG_WAIT;
5188 while ((RD_HARPOON(port + hp_ext_status) & BM_CMD_BUSY)
5192 WR_HARPOON(port + hp_bm_ctrl,
5193 (RD_HARPOON(port + hp_bm_ctrl) &
5196 if (RD_HARPOON(port + hp_ext_status) & BM_CMD_BUSY) {
5198 if (FPT_busMstrTimeOut(port)) {
5200 if (pCurrSCCB->HostStatus == 0x00)
5202 pCurrSCCB->HostStatus =
5207 if (RD_HARPOON(port + hp_int_status) &
5210 if (RD_HARPOON(port + hp_ext_status) &
5213 if (pCurrSCCB->HostStatus ==
5216 pCurrSCCB->HostStatus =
5223 else if (pCurrSCCB->Sccb_XferCnt) {
5225 if (pCurrSCCB->Sccb_XferState & F_SG_XFER) {
5227 WR_HARPOON(port + hp_page_ctrl,
5228 (RD_HARPOON(port + hp_page_ctrl) &
5231 WR_HARPOON(port + hp_sg_addr, 0x00);
5233 sg_ptr = pCurrSCCB->Sccb_sgseg + SG_BUF_CNT;
5236 (
unsigned int)(pCurrSCCB->DataLength /
5240 (
unsigned int)(pCurrSCCB->DataLength /
5244 remain_cnt = pCurrSCCB->Sccb_XferCnt;
5246 while (remain_cnt < 0x01000000L) {
5252 long)(*(((
unsigned long *)pCurrSCCB->
5253 DataPointer) + (sg_ptr * 2)))) {
5257 long)(*(((
unsigned long *)
5258 pCurrSCCB->DataPointer) +
5268 if (remain_cnt < 0x01000000L) {
5270 pCurrSCCB->Sccb_SGoffset = remain_cnt;
5272 pCurrSCCB->Sccb_sgseg = (
unsigned short)sg_ptr;
5274 if ((
unsigned long)(sg_ptr * SG_ELEMENT_SIZE) ==
5275 pCurrSCCB->DataLength && (remain_cnt == 0))
5277 pCurrSCCB->Sccb_XferState |=
5283 if (pCurrSCCB->HostStatus == 0x00) {
5285 pCurrSCCB->HostStatus =
5291 if (!(pCurrSCCB->Sccb_XferState & F_HOST_XFER_DIR)) {
5293 if (RD_HARPOON(port + hp_ext_status) & BM_CMD_BUSY) {
5295 FPT_busMstrTimeOut(port);
5300 if (RD_HARPOON(port + hp_int_status) &
5303 if (RD_HARPOON(port + hp_ext_status) &
5306 if (pCurrSCCB->HostStatus ==
5309 pCurrSCCB->HostStatus =
5320 if ((RD_HARPOON(port + hp_fifo_cnt)) >= BM_THRESHOLD) {
5322 timeout = SHORT_WAIT;
5324 while ((RD_HARPOON(port + hp_ext_status) &
5326 && ((RD_HARPOON(port + hp_fifo_cnt)) >=
5327 BM_THRESHOLD) && timeout--) {
5331 if (RD_HARPOON(port + hp_ext_status) & BM_CMD_BUSY) {
5333 WR_HARPOON(port + hp_bm_ctrl,
5334 (RD_HARPOON(port + hp_bm_ctrl) |
5337 timeout = LONG_WAIT;
5339 while ((RD_HARPOON(port + hp_ext_status) &
5340 BM_CMD_BUSY) && timeout--) {
5343 WR_HARPOON(port + hp_bm_ctrl,
5344 (RD_HARPOON(port + hp_bm_ctrl) &
5347 if (RD_HARPOON(port + hp_ext_status) &
5350 if (pCurrSCCB->HostStatus == 0x00) {
5352 pCurrSCCB->HostStatus =
5356 FPT_busMstrTimeOut(port);
5360 if (RD_HARPOON(port + hp_int_status) & INT_EXT_STATUS) {
5362 if (RD_HARPOON(port + hp_ext_status) &
5365 if (pCurrSCCB->HostStatus == 0x00) {
5367 pCurrSCCB->HostStatus =
5378 if (RD_HARPOON(port + hp_ext_status) & BM_CMD_BUSY) {
5380 timeout = LONG_WAIT;
5382 while ((RD_HARPOON(port + hp_ext_status) & BM_CMD_BUSY)
5386 if (RD_HARPOON(port + hp_ext_status) & BM_CMD_BUSY) {
5388 if (pCurrSCCB->HostStatus == 0x00) {
5390 pCurrSCCB->HostStatus = SCCB_BM_ERR;
5393 FPT_busMstrTimeOut(port);
5397 if (RD_HARPOON(port + hp_int_status) & INT_EXT_STATUS) {
5399 if (RD_HARPOON(port + hp_ext_status) & BAD_EXT_STATUS) {
5401 if (pCurrSCCB->HostStatus == 0x00) {
5403 pCurrSCCB->HostStatus = SCCB_BM_ERR;
5409 if (pCurrSCCB->Sccb_XferState & F_SG_XFER) {
5411 WR_HARPOON(port + hp_page_ctrl,
5412 (RD_HARPOON(port + hp_page_ctrl) &
5415 WR_HARPOON(port + hp_sg_addr, 0x00);
5417 pCurrSCCB->Sccb_sgseg += SG_BUF_CNT;
5419 pCurrSCCB->Sccb_SGoffset = 0x00;
5421 if ((
unsigned long)(pCurrSCCB->Sccb_sgseg *
5423 pCurrSCCB->DataLength) {
5425 pCurrSCCB->Sccb_XferState |= F_ALL_XFERRED;
5427 pCurrSCCB->Sccb_sgseg =
5428 (
unsigned short)(pCurrSCCB->DataLength /
5436 if (!(pCurrSCCB->Sccb_XferState & F_AUTO_SENSE))
5438 pCurrSCCB->Sccb_XferState |= F_ALL_XFERRED;
5442 WR_HARPOON(port + hp_int_mask, (INT_CMD_COMPL |
SCSI_INTERRUPT));
5453 static void FPT_hostDataXferRestart(
struct sccb *currSCCB)
5456 unsigned int sg_index;
5457 unsigned long *sg_ptr;
5459 if (currSCCB->Sccb_XferState & F_SG_XFER) {
5461 currSCCB->Sccb_XferCnt = 0;
5466 sg_ptr = (
unsigned long *)currSCCB->DataPointer;
5468 while (data_count < currSCCB->Sccb_ATC) {
5471 data_count += *(sg_ptr + (sg_index * 2));
5474 if (data_count == currSCCB->Sccb_ATC) {
5476 currSCCB->Sccb_SGoffset = 0;
5481 currSCCB->Sccb_SGoffset =
5482 data_count - currSCCB->Sccb_ATC;
5485 currSCCB->Sccb_sgseg = (
unsigned short)sg_index;
5489 currSCCB->Sccb_XferCnt =
5490 currSCCB->DataLength - currSCCB->Sccb_ATC;
5502 static void FPT_scini(
unsigned char p_card,
unsigned char p_our_id,
5503 unsigned char p_power_up)
5506 unsigned char loser, assigned_id;
5507 unsigned long p_port;
5509 unsigned char i,
k, ScamFlg;
5510 struct sccb_card *currCard;
5511 struct nvram_info *pCurrNvRam;
5513 currCard = &FPT_BL_Card[p_card];
5514 p_port = currCard->ioPort;
5515 pCurrNvRam = currCard->pNvRamInfo;
5518 ScamFlg = pCurrNvRam->niScamConf;
5519 i = pCurrNvRam->niSysConf;
5522 (
unsigned char)FPT_utilEERead(p_port, SCAM_CONFIG / 2);
5529 FPT_inisci(p_card, p_port, p_our_id);
5539 FPT_Wait1Second(p_port);
5541 if ((ScamFlg & SCAM_ENABLED) && (ScamFlg & SCAM_LEVEL2)) {
5542 while (!(FPT_scarb(p_port, INIT_SELTD))) {
5548 FPT_scxferc(p_port, SYNC_PTRN);
5549 FPT_scxferc(p_port, DOM_MSTR);
5552 &FPT_scamInfo[p_our_id].id_string[0]);
5553 }
while (loser == 0xFF);
5557 if ((p_power_up) && (!loser)) {
5558 FPT_sresb(p_port, p_card);
5559 FPT_Wait(p_port, TO_250ms);
5561 while (!(FPT_scarb(p_port, INIT_SELTD))) {
5567 FPT_scxferc(p_port, SYNC_PTRN);
5568 FPT_scxferc(p_port, DOM_MSTR);
5571 &FPT_scamInfo[p_our_id].
5573 }
while (loser == 0xFF);
5587 if (ScamFlg & SCAM_ENABLED) {
5589 for (i = 0; i < MAX_SCSI_TAR; i++) {
5590 if ((FPT_scamInfo[i].
state == ID_UNASSIGNED) ||
5591 (FPT_scamInfo[i].
state == ID_UNUSED)) {
5592 if (FPT_scsell(p_port, i)) {
5593 FPT_scamInfo[
i].state = LEGACY;
5594 if ((FPT_scamInfo[i].
5595 id_string[0] != 0xFF)
5596 || (FPT_scamInfo[i].
5597 id_string[1] != 0xFA)) {
5600 id_string[0] = 0xFF;
5602 id_string[1] = 0xFA;
5603 if (pCurrNvRam ==
NULL)
5613 FPT_sresb(p_port, p_card);
5614 FPT_Wait1Second(p_port);
5615 while (!(FPT_scarb(p_port, INIT_SELTD))) {
5618 FPT_scasid(p_card, p_port);
5623 else if ((loser) && (ScamFlg & SCAM_ENABLED)) {
5624 FPT_scamInfo[p_our_id].id_string[0] = SLV_TYPE_CODE0;
5626 FPT_scwtsel(p_port);
5629 while (FPT_scxferc(p_port, 0x00) != SYNC_PTRN) {
5632 i = FPT_scxferc(p_port, 0x00);
5633 if (i == ASSIGN_ID) {
5637 &FPT_scamInfo[p_our_id].id_string[0]))) {
5638 i = FPT_scxferc(p_port, 0x00);
5639 if (FPT_scvalq(i)) {
5640 k = FPT_scxferc(p_port, 0x00);
5642 if (FPT_scvalq(k)) {
5655 FPT_scamInfo[currCard->
5658 FPT_scamInfo[currCard->
5668 else if (i == SET_P_FLAG) {
5669 if (!(FPT_scsendi(p_port,
5670 &FPT_scamInfo[p_our_id].
5672 FPT_scamInfo[p_our_id].id_string[0] |=
5675 }
while (!assigned_id);
5677 while (FPT_scxferc(p_port, 0x00) != CFG_CMPLT) {
5681 if (ScamFlg & SCAM_ENABLED) {
5683 if (currCard->globalFlags & F_UPDATE_EEPROM) {
5684 FPT_scsavdi(p_card, p_port);
5685 currCard->globalFlags &= ~F_UPDATE_EEPROM;
5712 static int FPT_scarb(
unsigned long p_port,
unsigned char p_sel_type)
5714 if (p_sel_type == INIT_SELTD) {
5716 while (RD_HARPOON(p_port + hp_scsisig) & (
SCSI_SEL | SCSI_BSY)) {
5719 if (RD_HARPOON(p_port + hp_scsisig) &
SCSI_SEL)
5722 if (RD_HARPOON(p_port + hp_scsidata_0) != 00)
5725 WR_HARPOON(p_port + hp_scsisig,
5726 (RD_HARPOON(p_port + hp_scsisig) | SCSI_BSY));
5728 if (RD_HARPOON(p_port + hp_scsisig) & SCSI_SEL) {
5730 WR_HARPOON(p_port + hp_scsisig,
5731 (RD_HARPOON(p_port + hp_scsisig) &
5736 WR_HARPOON(p_port + hp_scsisig,
5737 (RD_HARPOON(p_port + hp_scsisig) | SCSI_SEL));
5739 if (RD_HARPOON(p_port + hp_scsidata_0) != 00) {
5741 WR_HARPOON(p_port + hp_scsisig,
5742 (RD_HARPOON(p_port + hp_scsisig) &
5743 ~(SCSI_BSY | SCSI_SEL)));
5748 WR_HARPOON(p_port + hp_clkctrl_0, (RD_HARPOON(p_port + hp_clkctrl_0)
5750 WR_HARPOON(p_port + hp_scsireset,
SCAM_EN);
5751 WR_HARPOON(p_port + hp_scsidata_0, 0x00);
5752 WR_HARPOON(p_port + hp_scsidata_1, 0x00);
5753 WR_HARPOON(p_port + hp_portctrl_0, SCSI_BUS_EN);
5755 WR_HARPOON(p_port + hp_scsisig,
5756 (RD_HARPOON(p_port + hp_scsisig) | SCSI_MSG));
5758 WR_HARPOON(p_port + hp_scsisig, (RD_HARPOON(p_port + hp_scsisig)
5761 FPT_Wait(p_port, TO_250ms);
5774 static void FPT_scbusf(
unsigned long p_port)
5776 WR_HARPOON(p_port + hp_page_ctrl,
5777 (RD_HARPOON(p_port + hp_page_ctrl) | G_INT_DISABLE));
5779 WR_HARPOON(p_port + hp_scsidata_0, 0x00);
5781 WR_HARPOON(p_port + hp_portctrl_0, (RD_HARPOON(p_port + hp_portctrl_0)
5784 WR_HARPOON(p_port + hp_scsisig, 0x00);
5786 WR_HARPOON(p_port + hp_scsireset, (RD_HARPOON(p_port + hp_scsireset)
5789 WR_HARPOON(p_port + hp_clkctrl_0, (RD_HARPOON(p_port + hp_clkctrl_0)
5792 WRW_HARPOON((p_port + hp_intstat), (BUS_FREE | AUTO_INT | SCAM_SEL));
5794 WR_HARPOON(p_port + hp_page_ctrl,
5795 (RD_HARPOON(p_port + hp_page_ctrl) & ~G_INT_DISABLE));
5806 static void FPT_scasid(
unsigned char p_card,
unsigned long p_port)
5808 unsigned char temp_id_string[ID_STRING_LENGTH];
5810 unsigned char i,
k, scam_id;
5811 unsigned char crcBytes[3];
5812 struct nvram_info *pCurrNvRam;
5813 unsigned short *pCrcBytes;
5815 pCurrNvRam = FPT_BL_Card[p_card].pNvRamInfo;
5821 for (k = 0; k < ID_STRING_LENGTH; k++) {
5822 temp_id_string[
k] = (
unsigned char)0x00;
5825 FPT_scxferc(p_port, SYNC_PTRN);
5826 FPT_scxferc(p_port, ASSIGN_ID);
5828 if (!(FPT_sciso(p_port, &temp_id_string[0]))) {
5830 pCrcBytes = (
unsigned short *)&crcBytes[0];
5831 *pCrcBytes = FPT_CalcCrc16(&temp_id_string[0]);
5832 crcBytes[2] = FPT_CalcLrc(&temp_id_string[0]);
5833 temp_id_string[1] = crcBytes[2];
5834 temp_id_string[2] = crcBytes[0];
5835 temp_id_string[3] = crcBytes[1];
5836 for (k = 4; k < ID_STRING_LENGTH; k++)
5837 temp_id_string[k] = (
unsigned char)0x00;
5839 i = FPT_scmachid(p_card, temp_id_string);
5841 if (i == CLR_PRIORITY) {
5842 FPT_scxferc(p_port, MISC_CODE);
5843 FPT_scxferc(p_port, CLR_P_FLAG);
5847 else if (i != NO_ID_AVAIL) {
5849 FPT_scxferc(p_port, ID_0_7);
5851 FPT_scxferc(p_port, ID_8_F);
5853 scam_id = (i & (
unsigned char)0x07);
5855 for (k = 1; k < 0x08; k <<= 1)
5859 FPT_scxferc(p_port, scam_id);
5871 FPT_scxferc(p_port, SYNC_PTRN);
5872 FPT_scxferc(p_port, CFG_CMPLT);
5883 static void FPT_scsel(
unsigned long p_port)
5886 WR_HARPOON(p_port + hp_scsisig, SCSI_SEL);
5887 FPT_scwiros(p_port, SCSI_MSG);
5889 WR_HARPOON(p_port + hp_scsisig, (SCSI_SEL | SCSI_BSY));
5891 WR_HARPOON(p_port + hp_scsisig,
5892 (SCSI_SEL | SCSI_BSY | SCSI_IOBIT | SCSI_CD));
5893 WR_HARPOON(p_port + hp_scsidata_0,
5894 (
unsigned char)(RD_HARPOON(p_port + hp_scsidata_0) |
5895 (
unsigned char)(
BIT(7) +
BIT(6))));
5897 WR_HARPOON(p_port + hp_scsisig, (SCSI_BSY | SCSI_IOBIT | SCSI_CD));
5898 FPT_scwiros(p_port, SCSI_SEL);
5900 WR_HARPOON(p_port + hp_scsidata_0,
5901 (
unsigned char)(RD_HARPOON(p_port + hp_scsidata_0) &
5902 ~(
unsigned char)
BIT(6)));
5903 FPT_scwirod(p_port,
BIT(6));
5905 WR_HARPOON(p_port + hp_scsisig,
5906 (SCSI_SEL | SCSI_BSY | SCSI_IOBIT | SCSI_CD));
5917 static unsigned char FPT_scxferc(
unsigned long p_port,
unsigned char p_data)
5919 unsigned char curr_data, ret_data;
5921 curr_data = p_data |
BIT(7) |
BIT(5);
5923 WR_HARPOON(p_port + hp_scsidata_0, curr_data);
5925 curr_data &= ~
BIT(7);
5927 WR_HARPOON(p_port + hp_scsidata_0, curr_data);
5929 FPT_scwirod(p_port,
BIT(7));
5930 while (!(RD_HARPOON(p_port + hp_scsidata_0) &
BIT(5))) ;
5932 ret_data = (RD_HARPOON(p_port + hp_scsidata_0) & (
unsigned char)0x1F);
5934 curr_data |=
BIT(6);
5936 WR_HARPOON(p_port + hp_scsidata_0, curr_data);
5938 curr_data &= ~
BIT(5);
5940 WR_HARPOON(p_port + hp_scsidata_0, curr_data);
5942 FPT_scwirod(p_port,
BIT(5));
5945 curr_data |=
BIT(7);
5947 WR_HARPOON(p_port + hp_scsidata_0, curr_data);
5949 curr_data &= ~
BIT(6);
5951 WR_HARPOON(p_port + hp_scsidata_0, curr_data);
5953 FPT_scwirod(p_port,
BIT(6));
5967 static unsigned char FPT_scsendi(
unsigned long p_port,
5968 unsigned char p_id_string[])
5970 unsigned char ret_data, byte_cnt, bit_cnt, defer;
5974 for (byte_cnt = 0; byte_cnt < ID_STRING_LENGTH; byte_cnt++) {
5976 for (bit_cnt = 0x80; bit_cnt != 0; bit_cnt >>= 1) {
5979 ret_data = FPT_scxferc(p_port, 00);
5981 else if (p_id_string[byte_cnt] & bit_cnt)
5983 ret_data = FPT_scxferc(p_port, 02);
5987 ret_data = FPT_scxferc(p_port, 01);
5992 if ((ret_data & 0x1C) == 0x10)
5995 if (ret_data & 0x1C)
5998 if ((defer) && (!(ret_data & 0x1F)))
6019 static unsigned char FPT_sciso(
unsigned long p_port,
6020 unsigned char p_id_string[])
6022 unsigned char ret_data, the_data, byte_cnt, bit_cnt;
6026 for (byte_cnt = 0; byte_cnt < ID_STRING_LENGTH; byte_cnt++) {
6028 for (bit_cnt = 0; bit_cnt < 8; bit_cnt++) {
6030 ret_data = FPT_scxferc(p_port, 0);
6032 if (ret_data & 0xFC)
6038 if (ret_data &
BIT(1)) {
6043 if ((ret_data & 0x1F) == 0) {
6062 p_id_string[byte_cnt] = the_data;
6078 static void FPT_scwirod(
unsigned long p_port,
unsigned char p_data_bit)
6083 while (i < MAX_SCSI_TAR) {
6085 if (RD_HARPOON(p_port + hp_scsidata_0) & p_data_bit)
6105 static void FPT_scwiros(
unsigned long p_port,
unsigned char p_data_bit)
6110 while (i < MAX_SCSI_TAR) {
6112 if (RD_HARPOON(p_port + hp_scsisig) & p_data_bit)
6131 static unsigned char FPT_scvalq(
unsigned char p_quintet)
6133 unsigned char count;
6135 for (count = 1; count < 0x08; count <<= 1) {
6136 if (!(p_quintet & count))
6140 if (p_quintet & 0x18)
6157 static unsigned char FPT_scsell(
unsigned long p_port,
unsigned char targ_id)
6161 WR_HARPOON(p_port + hp_page_ctrl,
6162 (RD_HARPOON(p_port + hp_page_ctrl) | G_INT_DISABLE));
6164 ARAM_ACCESS(p_port);
6166 WR_HARPOON(p_port + hp_addstat,
6167 (RD_HARPOON(p_port + hp_addstat) | SCAM_TIMER));
6168 WR_HARPOON(p_port + hp_seltimeout, TO_4ms);
6170 for (i = p_port + CMD_STRT; i < p_port + CMD_STRT + 12; i += 2) {
6171 WRW_HARPOON(i, (MPM_OP +
ACOMMAND));
6173 WRW_HARPOON(i, (BRH_OP +
ALWAYS +
NP));
6175 WRW_HARPOON((p_port + hp_intstat),
6176 (RESET | TIMEOUT |
SEL | BUS_FREE | AUTO_INT));
6178 WR_HARPOON(p_port + hp_select_id, targ_id);
6180 WR_HARPOON(p_port + hp_portctrl_0, SCSI_PORT);
6181 WR_HARPOON(p_port + hp_autostart_3, (
SELECT | CMD_ONLY_STRT));
6182 WR_HARPOON(p_port + hp_scsictrl_0, (SEL_TAR | ENA_RESEL));
6184 while (!(RDW_HARPOON((p_port + hp_intstat)) &
6185 (RESET | PROG_HLT | TIMEOUT | AUTO_INT))) {
6188 if (RDW_HARPOON((p_port + hp_intstat)) & RESET)
6189 FPT_Wait(p_port, TO_250ms);
6191 DISABLE_AUTO(p_port);
6193 WR_HARPOON(p_port + hp_addstat,
6194 (RD_HARPOON(p_port + hp_addstat) & ~SCAM_TIMER));
6195 WR_HARPOON(p_port + hp_seltimeout, TO_290ms);
6197 SGRAM_ACCESS(p_port);
6199 if (RDW_HARPOON((p_port + hp_intstat)) & (RESET | TIMEOUT)) {
6201 WRW_HARPOON((p_port + hp_intstat),
6202 (RESET | TIMEOUT |
SEL | BUS_FREE | PHASE));
6204 WR_HARPOON(p_port + hp_page_ctrl,
6205 (RD_HARPOON(p_port + hp_page_ctrl) &
6213 while (!(RDW_HARPOON((p_port + hp_intstat)) & BUS_FREE)) {
6214 if (RD_HARPOON(p_port + hp_scsisig) & SCSI_REQ) {
6215 WR_HARPOON(p_port + hp_scsisig,
6216 (SCSI_ACK + S_ILL_PH));
6221 WRW_HARPOON((p_port + hp_intstat), CLR_ALL_INT_1);
6223 WR_HARPOON(p_port + hp_page_ctrl,
6224 (RD_HARPOON(p_port + hp_page_ctrl) &
6239 static void FPT_scwtsel(
unsigned long p_port)
6241 while (!(RDW_HARPOON((p_port + hp_intstat)) & SCAM_SEL)) {
6253 static void FPT_inisci(
unsigned char p_card,
unsigned long p_port,
6254 unsigned char p_our_id)
6256 unsigned char i,
k, max_id;
6257 unsigned short ee_data;
6258 struct nvram_info *pCurrNvRam;
6260 pCurrNvRam = FPT_BL_Card[p_card].pNvRamInfo;
6262 if (RD_HARPOON(p_port + hp_page_ctrl) & NARROW_SCSI_CARD)
6269 for (i = 0; i < max_id; i++) {
6271 for (k = 0; k < 4; k++)
6272 FPT_scamInfo[i].id_string[k] =
6273 pCurrNvRam->niScamTbl[i][k];
6274 for (k = 4; k < ID_STRING_LENGTH; k++)
6275 FPT_scamInfo[i].id_string[k] =
6276 (
unsigned char)0x00;
6278 if (FPT_scamInfo[i].id_string[0] == 0x00)
6279 FPT_scamInfo[
i].state = ID_UNUSED;
6281 FPT_scamInfo[
i].state = ID_UNASSIGNED;
6285 for (i = 0; i < max_id; i++) {
6286 for (k = 0; k < ID_STRING_LENGTH; k += 2) {
6288 FPT_utilEERead(p_port,
6290 short)((EE_SCAMBASE / 2) +
6291 (
unsigned short)(i *
6292 ((
unsigned short)ID_STRING_LENGTH / 2)) + (
unsigned short)(k / 2)));
6293 FPT_scamInfo[
i].id_string[
k] =
6294 (
unsigned char)ee_data;
6296 FPT_scamInfo[
i].id_string[k + 1] =
6297 (
unsigned char)ee_data;
6300 if ((FPT_scamInfo[i].id_string[0] == 0x00) ||
6301 (FPT_scamInfo[
i].id_string[0] == 0xFF))
6303 FPT_scamInfo[
i].state = ID_UNUSED;
6306 FPT_scamInfo[
i].state = ID_UNASSIGNED;
6310 for (k = 0; k < ID_STRING_LENGTH; k++)
6311 FPT_scamInfo[p_our_id].id_string[k] = FPT_scamHAString[k];
6324 static unsigned char FPT_scmachid(
unsigned char p_card,
6325 unsigned char p_id_string[])
6330 for (i = 0; i < MAX_SCSI_TAR; i++) {
6334 for (k = 0; k < ID_STRING_LENGTH; k++) {
6335 if (p_id_string[k] != FPT_scamInfo[i].id_string[k])
6346 if (p_id_string[0] &
BIT(5))
6351 if (((p_id_string[0] & 0x06) == 0x02)
6352 || ((p_id_string[0] & 0x06) == 0x04))
6353 match = p_id_string[1] & (
unsigned char)0x1F;
6360 if (FPT_scamInfo[match].
state == ID_UNUSED) {
6361 for (k = 0; k < ID_STRING_LENGTH; k++) {
6362 FPT_scamInfo[
match].id_string[
k] =
6368 if (FPT_BL_Card[p_card].pNvRamInfo ==
NULL)
6369 FPT_BL_Card[p_card].globalFlags |=
6377 if (match == 0xFF) {
6378 if (p_id_string[0] &
BIT(5))
6381 match = MAX_SCSI_TAR - 1;
6385 if (p_id_string[0] &
BIT(7)) {
6386 return CLR_PRIORITY;
6389 if (p_id_string[0] &
BIT(5))
6394 if (((p_id_string[0] & 0x06) == 0x02)
6395 || ((p_id_string[0] & 0x06) == 0x04))
6396 match = p_id_string[1] & (
unsigned char)0x1F;
6404 if (FPT_scamInfo[match].
state == ID_UNASSIGNED) {
6405 for (k = 0; k < ID_STRING_LENGTH; k++) {
6406 FPT_scamInfo[
match].id_string[
k] =
6410 FPT_scamInfo[
match].id_string[0] |=
BIT(7);
6412 if (FPT_BL_Card[p_card].pNvRamInfo ==
NULL)
6413 FPT_BL_Card[p_card].globalFlags |=
6421 if (match == 0xFF) {
6422 if (p_id_string[0] &
BIT(5))
6425 match = MAX_SCSI_TAR - 1;
6440 static void FPT_scsavdi(
unsigned char p_card,
unsigned long p_port)
6442 unsigned char i,
k, max_id;
6443 unsigned short ee_data, sum_data;
6447 for (i = 1; i < EE_SCAMBASE / 2; i++) {
6448 sum_data += FPT_utilEERead(p_port, i);
6451 FPT_utilEEWriteOnOff(p_port, 1);
6453 if (RD_HARPOON(p_port + hp_page_ctrl) & NARROW_SCSI_CARD)
6459 for (i = 0; i < max_id; i++) {
6461 for (k = 0; k < ID_STRING_LENGTH; k += 2) {
6462 ee_data = FPT_scamInfo[
i].id_string[k + 1];
6464 ee_data |= FPT_scamInfo[
i].id_string[
k];
6465 sum_data += ee_data;
6466 FPT_utilEEWrite(p_port, ee_data,
6467 (
unsigned short)((EE_SCAMBASE / 2) +
6468 (
unsigned short)(i *
6469 ((
unsigned short)ID_STRING_LENGTH / 2)) + (
unsigned short)(k / 2)));
6473 FPT_utilEEWrite(p_port, sum_data, EEPROM_CHECK_SUM / 2);
6474 FPT_utilEEWriteOnOff(p_port, 0);
6485 static void FPT_XbowInit(
unsigned long port,
unsigned char ScamFlg)
6489 i = RD_HARPOON(port + hp_page_ctrl);
6490 WR_HARPOON(port + hp_page_ctrl, (
unsigned char)(i | G_INT_DISABLE));
6492 WR_HARPOON(port + hp_scsireset, 0x00);
6493 WR_HARPOON(port + hp_portctrl_1, HOST_MODE8);
6495 WR_HARPOON(port + hp_scsireset, (
DMA_RESET | HPSCSI_RESET | PROG_RESET |
6498 WR_HARPOON(port + hp_scsireset, SCSI_INI);
6500 WR_HARPOON(port + hp_clkctrl_0, CLKCTRL_DEFAULT);
6502 WR_HARPOON(port + hp_scsisig, 0x00);
6503 WR_HARPOON(port + hp_scsictrl_0, ENA_SCAM_SEL);
6505 WRW_HARPOON((port + hp_intstat), CLR_ALL_INT);
6507 FPT_default_intena = RESET | RSEL | PROG_HLT | TIMEOUT |
6508 BUS_FREE | XFER_CNT_0 | AUTO_INT;
6510 if ((ScamFlg & SCAM_ENABLED) && (ScamFlg & SCAM_LEVEL2))
6513 WRW_HARPOON((port + hp_intena), FPT_default_intena);
6515 WR_HARPOON(port + hp_seltimeout, TO_290ms);
6519 if (RD_HARPOON(port + hp_page_ctrl) & NARROW_SCSI_CARD)
6520 WR_HARPOON(port + hp_addstat, SCSI_MODE8);
6522 WR_HARPOON(port + hp_page_ctrl, i);
6534 static void FPT_BusMasterInit(
unsigned long p_port)
6537 WR_HARPOON(p_port + hp_sys_ctrl, DRVR_RST);
6538 WR_HARPOON(p_port + hp_sys_ctrl, 0x00);
6540 WR_HARPOON(p_port + hp_host_blk_cnt, XFER_BLK64);
6542 WR_HARPOON(p_port + hp_bm_ctrl, (BMCTRL_DEFAULT));
6544 WR_HARPOON(p_port + hp_ee_ctrl, (SCSI_TERM_ENA_H));
6546 RD_HARPOON(p_port + hp_int_status);
6547 WR_HARPOON(p_port + hp_int_mask, (INT_CMD_COMPL |
SCSI_INTERRUPT));
6548 WR_HARPOON(p_port + hp_page_ctrl, (RD_HARPOON(p_port + hp_page_ctrl) &
6561 static void FPT_DiagEEPROM(
unsigned long p_port)
6565 if (RD_HARPOON(p_port + hp_page_ctrl) & NARROW_SCSI_CARD)
6566 max_wd_cnt = EEPROM_WD_CNT;
6568 max_wd_cnt = EEPROM_WD_CNT * 2;
6570 temp = FPT_utilEERead(p_port, FW_SIGNATURE / 2);
6572 if (temp == 0x4641) {
6574 for (index = 2; index < max_wd_cnt; index++) {
6576 temp += FPT_utilEERead(p_port, index);
6580 if (temp == FPT_utilEERead(p_port, EEPROM_CHECK_SUM / 2)) {
6586 FPT_utilEEWriteOnOff(p_port, (
unsigned char)1);
6588 for (index = 0; index < max_wd_cnt; index++) {
6590 FPT_utilEEWrite(p_port, 0x0000, index);
6595 FPT_utilEEWrite(p_port, 0x4641, FW_SIGNATURE / 2);
6597 FPT_utilEEWrite(p_port, 0x3920, MODEL_NUMB_0 / 2);
6599 FPT_utilEEWrite(p_port, 0x3033, MODEL_NUMB_2 / 2);
6601 FPT_utilEEWrite(p_port, 0x2020, MODEL_NUMB_4 / 2);
6605 FPT_utilEEWrite(p_port, 0x0010, BIOS_CONFIG / 2);
6607 FPT_utilEEWrite(p_port, 0x0003, SCAM_CONFIG / 2);
6609 FPT_utilEEWrite(p_port, 0x0007, ADAPTER_SCSI_ID / 2);
6612 FPT_utilEEWrite(p_port, 0x0000, IGNORE_B_SCAN / 2);
6614 FPT_utilEEWrite(p_port, 0x0000, SEND_START_ENA / 2);
6619 FPT_utilEEWrite(p_port, 0x4242, SYNC_RATE_TBL01 / 2);
6621 FPT_utilEEWrite(p_port, 0x4242, SYNC_RATE_TBL23 / 2);
6623 FPT_utilEEWrite(p_port, 0x4242, SYNC_RATE_TBL45 / 2);
6625 FPT_utilEEWrite(p_port, 0x4242, SYNC_RATE_TBL67 / 2);
6627 FPT_utilEEWrite(p_port, 0x4242, SYNC_RATE_TBL89 / 2);
6629 FPT_utilEEWrite(p_port, 0x4242, SYNC_RATE_TBLab / 2);
6631 FPT_utilEEWrite(p_port, 0x4242, SYNC_RATE_TBLcd / 2);
6633 FPT_utilEEWrite(p_port, 0x4242, SYNC_RATE_TBLef / 2);
6636 FPT_utilEEWrite(p_port, 0x6C46, 64 / 2);
6638 FPT_utilEEWrite(p_port, 0x7361, 66 / 2);
6640 FPT_utilEEWrite(p_port, 0x5068, 68 / 2);
6642 FPT_utilEEWrite(p_port, 0x696F, 70 / 2);
6644 FPT_utilEEWrite(p_port, 0x746E, 72 / 2);
6646 FPT_utilEEWrite(p_port, 0x4C20, 74 / 2);
6648 FPT_utilEEWrite(p_port, 0x2054, 76 / 2);
6650 FPT_utilEEWrite(p_port, 0x2020, 78 / 2);
6653 index = ((EE_SCAMBASE / 2) + (7 * 16));
6654 FPT_utilEEWrite(p_port, (0x0700 + TYPE_CODE0), index);
6655 temp += (0x0700 + TYPE_CODE0);
6657 FPT_utilEEWrite(p_port, 0x5542, index);
6660 FPT_utilEEWrite(p_port, 0x4C53, index);
6663 FPT_utilEEWrite(p_port, 0x474F, index);
6666 FPT_utilEEWrite(p_port, 0x4349, index);
6669 FPT_utilEEWrite(p_port, 0x5442, index);
6672 FPT_utilEEWrite(p_port, 0x202D, index);
6675 FPT_utilEEWrite(p_port, 0x3339, index);
6678 FPT_utilEEWrite(p_port, 0x2030, index);
6681 FPT_utilEEWrite(p_port, 0x5453, index);
6684 FPT_utilEEWrite(p_port, 0x5645, index);
6687 FPT_utilEEWrite(p_port, 0x2045, index);
6690 FPT_utilEEWrite(p_port, 0x202F, index);
6693 FPT_utilEEWrite(p_port, 0x4F4A, index);
6696 FPT_utilEEWrite(p_port, 0x204E, index);
6699 FPT_utilEEWrite(p_port, 0x3539, index);
6702 FPT_utilEEWrite(p_port, temp, EEPROM_CHECK_SUM / 2);
6704 FPT_utilEEWriteOnOff(p_port, (
unsigned char)0);
6716 static void FPT_queueSearchSelect(
struct sccb_card *pCurrCard,
6717 unsigned char p_card)
6719 unsigned char scan_ptr,
lun;
6720 struct sccb_mgr_tar_info *currTar_Info;
6721 struct sccb *pOldSccb;
6723 scan_ptr = pCurrCard->scanIndex;
6725 currTar_Info = &FPT_sccbMgrTbl[p_card][scan_ptr];
6726 if ((pCurrCard->globalFlags & F_CONLUN_IO) &&
6727 ((currTar_Info->TarStatus & TAR_TAG_Q_MASK) !=
6729 if (currTar_Info->TarSelQ_Cnt != 0) {
6732 if (scan_ptr == MAX_SCSI_TAR)
6735 for (lun = 0; lun <
MAX_LUN; lun++) {
6736 if (currTar_Info->TarLUNBusy[lun] == 0) {
6738 pCurrCard->currentSCCB =
6739 currTar_Info->TarSelQ_Head;
6743 currentSCCB !=
NULL)
6746 currentSCCB->Lun)) {
6750 pCurrCard->currentSCCB =
6756 if (pCurrCard->currentSCCB ==
6759 if (pOldSccb !=
NULL) {
6802 pCurrCard->scanIndex = scan_ptr;
6804 pCurrCard->globalFlags |=
6814 if (scan_ptr == MAX_SCSI_TAR) {
6820 if ((currTar_Info->TarSelQ_Cnt != 0) &&
6821 (currTar_Info->TarLUNBusy[0] == 0)) {
6823 pCurrCard->currentSCCB =
6824 currTar_Info->TarSelQ_Head;
6826 currTar_Info->TarSelQ_Head =
6827 (
struct sccb *)(pCurrCard->currentSCCB)->
6830 if (currTar_Info->TarSelQ_Head ==
NULL) {
6831 currTar_Info->TarSelQ_Tail =
NULL;
6832 currTar_Info->TarSelQ_Cnt = 0;
6834 currTar_Info->TarSelQ_Cnt--;
6835 currTar_Info->TarSelQ_Head->
6836 Sccb_backlink = (
struct sccb *)
NULL;
6840 if (scan_ptr == MAX_SCSI_TAR)
6843 pCurrCard->scanIndex = scan_ptr;
6845 pCurrCard->globalFlags |= F_NEW_SCCB_CMD;
6852 if (scan_ptr == MAX_SCSI_TAR) {
6857 }
while (scan_ptr != pCurrCard->scanIndex);
6868 static void FPT_queueSelectFail(
struct sccb_card *pCurrCard,
6869 unsigned char p_card)
6871 unsigned char thisTarg;
6872 struct sccb_mgr_tar_info *currTar_Info;
6874 if (pCurrCard->currentSCCB !=
NULL) {
6876 (
unsigned char)(((
struct sccb *)(pCurrCard->currentSCCB))->
6878 currTar_Info = &FPT_sccbMgrTbl[p_card][thisTarg];
6880 pCurrCard->currentSCCB->Sccb_backlink = (
struct sccb *)
NULL;
6882 pCurrCard->currentSCCB->Sccb_forwardlink =
6883 currTar_Info->TarSelQ_Head;
6885 if (currTar_Info->TarSelQ_Cnt == 0) {
6886 currTar_Info->TarSelQ_Tail = pCurrCard->currentSCCB;
6890 currTar_Info->TarSelQ_Head->Sccb_backlink =
6891 pCurrCard->currentSCCB;
6894 currTar_Info->TarSelQ_Head = pCurrCard->currentSCCB;
6896 pCurrCard->currentSCCB =
NULL;
6897 currTar_Info->TarSelQ_Cnt++;
6909 static void FPT_queueCmdComplete(
struct sccb_card *pCurrCard,
6910 struct sccb *p_sccb,
unsigned char p_card)
6913 unsigned char i, SCSIcmd;
6915 struct sccb_mgr_tar_info *currTar_Info;
6917 SCSIcmd = p_sccb->Cdb[0];
6919 if (!(p_sccb->Sccb_XferState & F_ALL_XFERRED)) {
6922 ControlByte & (SCCB_DATA_XFER_OUT | SCCB_DATA_XFER_IN))
6923 && (p_sccb->HostStatus == SCCB_COMPLETE)
6924 && (p_sccb->TargetStatus != SSCHECK))
6926 if ((SCSIcmd == SCSI_READ) ||
6927 (SCSIcmd == SCSI_WRITE) ||
6928 (SCSIcmd == SCSI_READ_EXTENDED) ||
6929 (SCSIcmd == SCSI_WRITE_EXTENDED) ||
6930 (SCSIcmd == SCSI_WRITE_AND_VERIFY) ||
6931 (SCSIcmd == SCSI_START_STOP_UNIT) ||
6932 (pCurrCard->globalFlags & F_NO_FILTER)
6934 p_sccb->HostStatus = SCCB_DATA_UNDER_RUN;
6937 if (p_sccb->SccbStatus == SCCB_IN_PROCESS) {
6938 if (p_sccb->HostStatus || p_sccb->TargetStatus)
6939 p_sccb->SccbStatus = SCCB_ERROR;
6941 p_sccb->SccbStatus = SCCB_SUCCESS;
6944 if (p_sccb->Sccb_XferState & F_AUTO_SENSE) {
6946 p_sccb->CdbLength = p_sccb->Save_CdbLen;
6947 for (i = 0; i < 6; i++) {
6948 p_sccb->Cdb[
i] = p_sccb->Save_Cdb[
i];
6952 if ((p_sccb->OperationCode == RESIDUAL_SG_COMMAND) ||
6953 (p_sccb->OperationCode == RESIDUAL_COMMAND)) {
6955 FPT_utilUpdateResidual(p_sccb);
6958 pCurrCard->cmdCounter--;
6959 if (!pCurrCard->cmdCounter) {
6961 if (pCurrCard->globalFlags & F_GREEN_PC) {
6962 WR_HARPOON(pCurrCard->ioPort + hp_clkctrl_0,
6963 (PWR_DWN | CLKCTRL_DEFAULT));
6964 WR_HARPOON(pCurrCard->ioPort + hp_sys_ctrl, STOP_CLK);
6967 WR_HARPOON(pCurrCard->ioPort + hp_semaphore,
6968 (RD_HARPOON(pCurrCard->ioPort + hp_semaphore) &
6973 if (pCurrCard->discQCount != 0) {
6974 currTar_Info = &FPT_sccbMgrTbl[p_card][p_sccb->TargID];
6975 if (((pCurrCard->globalFlags & F_CONLUN_IO) &&
6976 ((currTar_Info->TarStatus & TAR_TAG_Q_MASK) !=
6978 pCurrCard->discQCount--;
6979 pCurrCard->discQ_Tbl[currTar_Info->
6980 LunDiscQ_Idx[p_sccb->Lun]] =
NULL;
6982 if (p_sccb->Sccb_tag) {
6983 pCurrCard->discQCount--;
6984 pCurrCard->discQ_Tbl[p_sccb->Sccb_tag] =
NULL;
6986 pCurrCard->discQCount--;
6987 pCurrCard->discQ_Tbl[currTar_Info->
6988 LunDiscQ_Idx[0]] =
NULL;
6994 callback = (CALL_BK_FN) p_sccb->SccbCallback;
6996 pCurrCard->globalFlags |= F_NEW_SCCB_CMD;
6997 pCurrCard->currentSCCB =
NULL;
7007 static void FPT_queueDisconnect(
struct sccb *p_sccb,
unsigned char p_card)
7009 struct sccb_mgr_tar_info *currTar_Info;
7011 currTar_Info = &FPT_sccbMgrTbl[p_card][p_sccb->TargID];
7013 if (((FPT_BL_Card[p_card].globalFlags & F_CONLUN_IO) &&
7014 ((currTar_Info->TarStatus & TAR_TAG_Q_MASK) != TAG_Q_TRYING))) {
7015 FPT_BL_Card[p_card].discQ_Tbl[currTar_Info->
7016 LunDiscQ_Idx[p_sccb->Lun]] =
7019 if (p_sccb->Sccb_tag) {
7020 FPT_BL_Card[p_card].discQ_Tbl[p_sccb->Sccb_tag] =
7022 FPT_sccbMgrTbl[p_card][p_sccb->TargID].TarLUNBusy[0] =
7024 FPT_sccbMgrTbl[p_card][p_sccb->TargID].TarTagQ_Cnt++;
7026 FPT_BL_Card[p_card].discQ_Tbl[currTar_Info->
7027 LunDiscQ_Idx[0]] = p_sccb;
7030 FPT_BL_Card[p_card].currentSCCB =
NULL;
7041 static void FPT_queueFlushSccb(
unsigned char p_card,
unsigned char error_code)
7043 unsigned char qtag, thisTarg;
7044 struct sccb *currSCCB;
7045 struct sccb_mgr_tar_info *currTar_Info;
7047 currSCCB = FPT_BL_Card[p_card].currentSCCB;
7048 if (currSCCB !=
NULL) {
7049 thisTarg = (
unsigned char)currSCCB->TargID;
7050 currTar_Info = &FPT_sccbMgrTbl[p_card][thisTarg];
7054 if (FPT_BL_Card[p_card].discQ_Tbl[qtag] &&
7055 (FPT_BL_Card[p_card].discQ_Tbl[qtag]->TargID ==
7058 FPT_BL_Card[p_card].discQ_Tbl[qtag]->
7059 HostStatus = (
unsigned char)error_code;
7061 FPT_queueCmdComplete(&FPT_BL_Card[p_card],
7062 FPT_BL_Card[p_card].
7063 discQ_Tbl[qtag], p_card);
7065 FPT_BL_Card[p_card].discQ_Tbl[qtag] =
NULL;
7066 currTar_Info->TarTagQ_Cnt--;
7082 static void FPT_queueFlushTargSccb(
unsigned char p_card,
unsigned char thisTarg,
7083 unsigned char error_code)
7086 struct sccb_mgr_tar_info *currTar_Info;
7088 currTar_Info = &FPT_sccbMgrTbl[p_card][thisTarg];
7092 if (FPT_BL_Card[p_card].discQ_Tbl[qtag] &&
7093 (FPT_BL_Card[p_card].discQ_Tbl[qtag]->TargID == thisTarg)) {
7095 FPT_BL_Card[p_card].discQ_Tbl[qtag]->HostStatus =
7096 (
unsigned char)error_code;
7098 FPT_queueCmdComplete(&FPT_BL_Card[p_card],
7099 FPT_BL_Card[p_card].
7100 discQ_Tbl[qtag], p_card);
7102 FPT_BL_Card[p_card].discQ_Tbl[qtag] =
NULL;
7103 currTar_Info->TarTagQ_Cnt--;
7110 static void FPT_queueAddSccb(
struct sccb *p_SCCB,
unsigned char p_card)
7112 struct sccb_mgr_tar_info *currTar_Info;
7113 currTar_Info = &FPT_sccbMgrTbl[p_card][p_SCCB->TargID];
7115 p_SCCB->Sccb_forwardlink =
NULL;
7117 p_SCCB->Sccb_backlink = currTar_Info->TarSelQ_Tail;
7119 if (currTar_Info->TarSelQ_Cnt == 0) {
7121 currTar_Info->TarSelQ_Head = p_SCCB;
7126 currTar_Info->TarSelQ_Tail->Sccb_forwardlink = p_SCCB;
7129 currTar_Info->TarSelQ_Tail = p_SCCB;
7130 currTar_Info->TarSelQ_Cnt++;
7142 static unsigned char FPT_queueFindSccb(
struct sccb *p_SCCB,
7143 unsigned char p_card)
7146 struct sccb_mgr_tar_info *currTar_Info;
7148 currTar_Info = &FPT_sccbMgrTbl[p_card][p_SCCB->TargID];
7150 q_ptr = currTar_Info->TarSelQ_Head;
7152 while (q_ptr !=
NULL) {
7154 if (q_ptr == p_SCCB) {
7156 if (currTar_Info->TarSelQ_Head == q_ptr) {
7158 currTar_Info->TarSelQ_Head =
7159 q_ptr->Sccb_forwardlink;
7162 if (currTar_Info->TarSelQ_Tail == q_ptr) {
7164 currTar_Info->TarSelQ_Tail =
7165 q_ptr->Sccb_backlink;
7168 if (q_ptr->Sccb_forwardlink !=
NULL) {
7169 q_ptr->Sccb_forwardlink->Sccb_backlink =
7170 q_ptr->Sccb_backlink;
7173 if (q_ptr->Sccb_backlink !=
NULL) {
7174 q_ptr->Sccb_backlink->Sccb_forwardlink =
7175 q_ptr->Sccb_forwardlink;
7178 currTar_Info->TarSelQ_Cnt--;
7184 q_ptr = q_ptr->Sccb_forwardlink;
7205 static void FPT_utilUpdateResidual(
struct sccb *p_SCCB)
7207 unsigned long partial_cnt;
7208 unsigned int sg_index;
7209 unsigned long *sg_ptr;
7211 if (p_SCCB->Sccb_XferState & F_ALL_XFERRED) {
7213 p_SCCB->DataLength = 0x0000;
7216 else if (p_SCCB->Sccb_XferState & F_SG_XFER) {
7218 partial_cnt = 0x0000;
7220 sg_index = p_SCCB->Sccb_sgseg;
7222 sg_ptr = (
unsigned long *)p_SCCB->DataPointer;
7224 if (p_SCCB->Sccb_SGoffset) {
7226 partial_cnt = p_SCCB->Sccb_SGoffset;
7230 while (((
unsigned long)sg_index *
7231 (
unsigned long)SG_ELEMENT_SIZE) < p_SCCB->DataLength) {
7233 partial_cnt += *(sg_ptr + (sg_index * 2));
7237 p_SCCB->DataLength = partial_cnt;
7242 p_SCCB->DataLength -= p_SCCB->Sccb_ATC;
7254 static void FPT_Wait1Second(
unsigned long p_port)
7258 for (i = 0; i < 4; i++) {
7260 FPT_Wait(p_port, TO_250ms);
7262 if ((RD_HARPOON(p_port + hp_scsictrl_0) & SCSI_RST))
7265 if ((RDW_HARPOON((p_port + hp_intstat)) & SCAM_SEL))
7278 static void FPT_Wait(
unsigned long p_port,
unsigned char p_delay)
7280 unsigned char old_timer;
7281 unsigned char green_flag;
7283 old_timer = RD_HARPOON(p_port + hp_seltimeout);
7285 green_flag = RD_HARPOON(p_port + hp_clkctrl_0);
7286 WR_HARPOON(p_port + hp_clkctrl_0, CLKCTRL_DEFAULT);
7288 WR_HARPOON(p_port + hp_seltimeout, p_delay);
7289 WRW_HARPOON((p_port + hp_intstat), TIMEOUT);
7290 WRW_HARPOON((p_port + hp_intena), (FPT_default_intena & ~TIMEOUT));
7292 WR_HARPOON(p_port + hp_portctrl_0,
7293 (RD_HARPOON(p_port + hp_portctrl_0) | START_TO));
7295 while (!(RDW_HARPOON((p_port + hp_intstat)) & TIMEOUT)) {
7297 if ((RD_HARPOON(p_port + hp_scsictrl_0) & SCSI_RST))
7300 if ((RDW_HARPOON((p_port + hp_intstat)) & SCAM_SEL))
7304 WR_HARPOON(p_port + hp_portctrl_0,
7305 (RD_HARPOON(p_port + hp_portctrl_0) & ~START_TO));
7307 WRW_HARPOON((p_port + hp_intstat), TIMEOUT);
7308 WRW_HARPOON((p_port + hp_intena), FPT_default_intena);
7310 WR_HARPOON(p_port + hp_clkctrl_0, green_flag);
7312 WR_HARPOON(p_port + hp_seltimeout, old_timer);
7324 static void FPT_utilEEWriteOnOff(
unsigned long p_port,
unsigned char p_mode)
7326 unsigned char ee_value;
7329 (
unsigned char)(RD_HARPOON(p_port + hp_ee_ctrl) &
7330 (EXT_ARB_ACK | SCSI_TERM_ENA_H));
7334 FPT_utilEESendCmdAddr(p_port,
EWEN, EWEN_ADDR);
7338 FPT_utilEESendCmdAddr(p_port,
EWDS, EWDS_ADDR);
7340 WR_HARPOON(p_port + hp_ee_ctrl, (ee_value | SEE_MS));
7341 WR_HARPOON(p_port + hp_ee_ctrl, ee_value);
7353 static void FPT_utilEEWrite(
unsigned long p_port,
unsigned short ee_data,
7354 unsigned short ee_addr)
7357 unsigned char ee_value;
7362 char)((RD_HARPOON(p_port + hp_ee_ctrl) &
7363 (EXT_ARB_ACK | SCSI_TERM_ENA_H)) | (SEE_MS | SEE_CS));
7365 FPT_utilEESendCmdAddr(p_port,
EE_WRITE, ee_addr);
7367 ee_value |= (SEE_MS + SEE_CS);
7369 for (i = 0x8000; i != 0; i >>= 1) {
7374 ee_value &= ~SEE_DO;
7376 WR_HARPOON(p_port + hp_ee_ctrl, ee_value);
7377 WR_HARPOON(p_port + hp_ee_ctrl, ee_value);
7378 ee_value |= SEE_CLK;
7379 WR_HARPOON(p_port + hp_ee_ctrl, ee_value);
7380 WR_HARPOON(p_port + hp_ee_ctrl, ee_value);
7381 ee_value &= ~SEE_CLK;
7382 WR_HARPOON(p_port + hp_ee_ctrl, ee_value);
7383 WR_HARPOON(p_port + hp_ee_ctrl, ee_value);
7385 ee_value &= (EXT_ARB_ACK | SCSI_TERM_ENA_H);
7386 WR_HARPOON(p_port + hp_ee_ctrl, (ee_value | SEE_MS));
7388 FPT_Wait(p_port, TO_10ms);
7390 WR_HARPOON(p_port + hp_ee_ctrl, (ee_value | SEE_MS | SEE_CS));
7391 WR_HARPOON(p_port + hp_ee_ctrl, (ee_value | SEE_MS));
7392 WR_HARPOON(p_port + hp_ee_ctrl, ee_value);
7404 static unsigned short FPT_utilEERead(
unsigned long p_port,
7405 unsigned short ee_addr)
7407 unsigned short i, ee_data1, ee_data2;
7410 ee_data1 = FPT_utilEEReadOrg(p_port, ee_addr);
7412 ee_data2 = FPT_utilEEReadOrg(p_port, ee_addr);
7414 if (ee_data1 == ee_data2)
7417 ee_data1 = ee_data2;
7434 static unsigned short FPT_utilEEReadOrg(
unsigned long p_port,
7435 unsigned short ee_addr)
7438 unsigned char ee_value;
7439 unsigned short i, ee_data;
7443 char)((RD_HARPOON(p_port + hp_ee_ctrl) &
7444 (EXT_ARB_ACK | SCSI_TERM_ENA_H)) | (SEE_MS | SEE_CS));
7446 FPT_utilEESendCmdAddr(p_port,
EE_READ, ee_addr);
7448 ee_value |= (SEE_MS + SEE_CS);
7451 for (i = 1; i <= 16; i++) {
7453 ee_value |= SEE_CLK;
7454 WR_HARPOON(p_port + hp_ee_ctrl, ee_value);
7455 WR_HARPOON(p_port + hp_ee_ctrl, ee_value);
7456 ee_value &= ~SEE_CLK;
7457 WR_HARPOON(p_port + hp_ee_ctrl, ee_value);
7458 WR_HARPOON(p_port + hp_ee_ctrl, ee_value);
7462 if (RD_HARPOON(p_port + hp_ee_ctrl) & SEE_DI)
7466 ee_value &= ~(SEE_MS + SEE_CS);
7467 WR_HARPOON(p_port + hp_ee_ctrl, (ee_value | SEE_MS));
7468 WR_HARPOON(p_port + hp_ee_ctrl, ee_value);
7482 static void FPT_utilEESendCmdAddr(
unsigned long p_port,
unsigned char ee_cmd,
7483 unsigned short ee_addr)
7485 unsigned char ee_value;
7486 unsigned char narrow_flg;
7491 (
unsigned char)(RD_HARPOON(p_port + hp_page_ctrl) &
7495 WR_HARPOON(p_port + hp_ee_ctrl, ee_value);
7498 WR_HARPOON(p_port + hp_ee_ctrl, ee_value);
7500 for (i = 0x04; i != 0; i >>= 1) {
7505 ee_value &= ~SEE_DO;
7507 WR_HARPOON(p_port + hp_ee_ctrl, ee_value);
7508 WR_HARPOON(p_port + hp_ee_ctrl, ee_value);
7509 ee_value |= SEE_CLK;
7510 WR_HARPOON(p_port + hp_ee_ctrl, ee_value);
7511 WR_HARPOON(p_port + hp_ee_ctrl, ee_value);
7512 ee_value &= ~SEE_CLK;
7513 WR_HARPOON(p_port + hp_ee_ctrl, ee_value);
7514 WR_HARPOON(p_port + hp_ee_ctrl, ee_value);
7528 ee_value &= ~SEE_DO;
7530 WR_HARPOON(p_port + hp_ee_ctrl, ee_value);
7531 WR_HARPOON(p_port + hp_ee_ctrl, ee_value);
7532 ee_value |= SEE_CLK;
7533 WR_HARPOON(p_port + hp_ee_ctrl, ee_value);
7534 WR_HARPOON(p_port + hp_ee_ctrl, ee_value);
7535 ee_value &= ~SEE_CLK;
7536 WR_HARPOON(p_port + hp_ee_ctrl, ee_value);
7537 WR_HARPOON(p_port + hp_ee_ctrl, ee_value);
7543 static unsigned short FPT_CalcCrc16(
unsigned char buffer[])
7545 unsigned short crc = 0;
7548 for (i = 0; i < ID_STRING_LENGTH; i++) {
7549 ch = (
unsigned short)buffer[i];
7550 for (j = 0; j < 8; j++) {
7552 crc = (crc >> 1) ^ CRCMASK;
7561 static unsigned char FPT_CalcLrc(
unsigned char buffer[])
7566 for (i = 0; i < ID_STRING_LENGTH; i++)
7575 static inline unsigned char
7583 FlashPoint__HardwareResetHostAdapter(
struct FlashPoint_Info *FlashPointInfo)
7621 #define FlashPoint_ProbeHostAdapter FlashPoint__ProbeHostAdapter
7622 #define FlashPoint_HardwareResetHostAdapter FlashPoint__HardwareResetHostAdapter
7623 #define FlashPoint_ReleaseHostAdapter FlashPoint__ReleaseHostAdapter
7624 #define FlashPoint_StartCCB FlashPoint__StartCCB
7625 #define FlashPoint_AbortCCB FlashPoint__AbortCCB
7626 #define FlashPoint_InterruptPending FlashPoint__InterruptPending
7627 #define FlashPoint_HandleInterrupt FlashPoint__HandleInterrupt