1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303 |
- /*
- Linux Driver for BusLogic MultiMaster and FlashPoint SCSI Host Adapters
- Copyright 1995-1998 by Leonard N. Zubkoff <lnz@dandelion.com>
- This program is free software; you may redistribute and/or modify it under
- the terms of the GNU General Public License Version 2 as published by the
- Free Software Foundation.
- This program is distributed in the hope that it will be useful, but
- WITHOUT ANY WARRANTY, without even the implied warranty of MERCHANTABILITY
- or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
- for complete details.
- The author respectfully requests that any modifications to this software be
- sent directly to him for evaluation and testing.
- Special thanks to Wayne Yen, Jin-Lon Hon, and Alex Win of BusLogic, whose
- advice has been invaluable, to David Gentzel, for writing the original Linux
- BusLogic driver, and to Paul Gortmaker, for being such a dedicated test site.
- Finally, special thanks to Mylex/BusLogic for making the FlashPoint SCCB
- Manager available as freely redistributable source code.
- */
- #ifndef _BUSLOGIC_H
- #define _BUSLOGIC_H
- #ifndef PACKED
- #define PACKED __attribute__((packed))
- #endif
- /*
- Define the maximum number of BusLogic Host Adapters supported by this driver.
- */
- #define BLOGIC_MAX_ADAPTERS 16
- /*
- Define the maximum number of Target Devices supported by this driver.
- */
- #define BLOGIC_MAXDEV 16
- /*
- Define the maximum number of Scatter/Gather Segments used by this driver.
- For optimal performance, it is important that this limit be at least as
- large as the largest single request generated by the I/O Subsystem.
- */
- #define BLOGIC_SG_LIMIT 128
- /*
- Define the maximum, maximum automatic, minimum automatic, and default Queue
- Depth to allow for Target Devices depending on whether or not they support
- Tagged Queuing and whether or not ISA Bounce Buffers are required.
- */
- #define BLOGIC_MAX_TAG_DEPTH 64
- #define BLOGIC_MAX_AUTO_TAG_DEPTH 28
- #define BLOGIC_MIN_AUTO_TAG_DEPTH 7
- #define BLOGIC_TAG_DEPTH_BB 3
- #define BLOGIC_UNTAG_DEPTH 3
- #define BLOGIC_UNTAG_DEPTH_BB 2
- /*
- Define the default amount of time in seconds to wait between a Host Adapter
- Hard Reset which initiates a SCSI Bus Reset and issuing any SCSI commands.
- Some SCSI devices get confused if they receive SCSI commands too soon after
- a SCSI Bus Reset.
- */
- #define BLOGIC_BUS_SETTLE_TIME 2
- /*
- Define the maximum number of Mailboxes that should be used for MultiMaster
- Host Adapters. This number is chosen to be larger than the maximum Host
- Adapter Queue Depth and small enough so that the Host Adapter structure
- does not cross an allocation block size boundary.
- */
- #define BLOGIC_MAX_MAILBOX 211
- /*
- Define the number of CCBs that should be allocated as a group to optimize
- Kernel memory allocation.
- */
- #define BLOGIC_CCB_GRP_ALLOCSIZE 7
- /*
- Define the Host Adapter Line and Message Buffer Sizes.
- */
- #define BLOGIC_LINEBUF_SIZE 100
- #define BLOGIC_MSGBUF_SIZE 9700
- /*
- Define the Driver Message Levels.
- */
- enum blogic_msglevel {
- BLOGIC_ANNOUNCE_LEVEL = 0,
- BLOGIC_INFO_LEVEL = 1,
- BLOGIC_NOTICE_LEVEL = 2,
- BLOGIC_WARN_LEVEL = 3,
- BLOGIC_ERR_LEVEL = 4
- };
- static char *blogic_msglevelmap[] = { KERN_NOTICE, KERN_NOTICE, KERN_NOTICE, KERN_WARNING, KERN_ERR };
- /*
- Define Driver Message macros.
- */
- #define blogic_announce(format, args...) \
- blogic_msg(BLOGIC_ANNOUNCE_LEVEL, format, ##args)
- #define blogic_info(format, args...) \
- blogic_msg(BLOGIC_INFO_LEVEL, format, ##args)
- #define blogic_notice(format, args...) \
- blogic_msg(BLOGIC_NOTICE_LEVEL, format, ##args)
- #define blogic_warn(format, args...) \
- blogic_msg(BLOGIC_WARN_LEVEL, format, ##args)
- #define blogic_err(format, args...) \
- blogic_msg(BLOGIC_ERR_LEVEL, format, ##args)
- /*
- Define the types of BusLogic Host Adapters that are supported and the number
- of I/O Addresses required by each type.
- */
- enum blogic_adapter_type {
- BLOGIC_MULTIMASTER = 1,
- BLOGIC_FLASHPOINT = 2
- } PACKED;
- #define BLOGIC_MULTIMASTER_ADDR_COUNT 4
- #define BLOGIC_FLASHPOINT_ADDR_COUNT 256
- static int blogic_adapter_addr_count[3] = { 0, BLOGIC_MULTIMASTER_ADDR_COUNT, BLOGIC_FLASHPOINT_ADDR_COUNT };
- /*
- Define macros for testing the Host Adapter Type.
- */
- #ifdef CONFIG_SCSI_FLASHPOINT
- #define blogic_multimaster_type(adapter) \
- (adapter->adapter_type == BLOGIC_MULTIMASTER)
- #define blogic_flashpoint_type(adapter) \
- (adapter->adapter_type == BLOGIC_FLASHPOINT)
- #else
- #define blogic_multimaster_type(adapter) (true)
- #define blogic_flashpoint_type(adapter) (false)
- #endif
- /*
- Define the possible Host Adapter Bus Types.
- */
- enum blogic_adapter_bus_type {
- BLOGIC_UNKNOWN_BUS = 0,
- BLOGIC_ISA_BUS = 1,
- BLOGIC_EISA_BUS = 2,
- BLOGIC_PCI_BUS = 3,
- BLOGIC_VESA_BUS = 4,
- BLOGIC_MCA_BUS = 5
- } PACKED;
- static char *blogic_adapter_busnames[] = { "Unknown", "ISA", "EISA", "PCI", "VESA", "MCA" };
- static enum blogic_adapter_bus_type blogic_adater_bus_types[] = {
- BLOGIC_VESA_BUS, /* BT-4xx */
- BLOGIC_ISA_BUS, /* BT-5xx */
- BLOGIC_MCA_BUS, /* BT-6xx */
- BLOGIC_EISA_BUS, /* BT-7xx */
- BLOGIC_UNKNOWN_BUS, /* BT-8xx */
- BLOGIC_PCI_BUS /* BT-9xx */
- };
- /*
- Define the possible Host Adapter BIOS Disk Geometry Translations.
- */
- enum blogic_bios_diskgeometry {
- BLOGIC_BIOS_NODISK = 0,
- BLOGIC_BIOS_DISK64x32 = 1,
- BLOGIC_BIOS_DISK128x32 = 2,
- BLOGIC_BIOS_DISK255x63 = 3
- } PACKED;
- /*
- Define a 10^18 Statistics Byte Counter data type.
- */
- struct blogic_byte_count {
- unsigned int units;
- unsigned int billions;
- };
- /*
- Define the structure for I/O Address and Bus Probing Information.
- */
- struct blogic_probeinfo {
- enum blogic_adapter_type adapter_type;
- enum blogic_adapter_bus_type adapter_bus_type;
- unsigned long io_addr;
- unsigned long pci_addr;
- struct pci_dev *pci_device;
- unsigned char bus;
- unsigned char dev;
- unsigned char irq_ch;
- };
- /*
- Define the Probe Options.
- */
- struct blogic_probe_options {
- bool noprobe:1; /* Bit 0 */
- bool noprobe_isa:1; /* Bit 1 */
- bool noprobe_pci:1; /* Bit 2 */
- bool nosort_pci:1; /* Bit 3 */
- bool multimaster_first:1; /* Bit 4 */
- bool flashpoint_first:1; /* Bit 5 */
- bool limited_isa:1; /* Bit 6 */
- bool probe330:1; /* Bit 7 */
- bool probe334:1; /* Bit 8 */
- bool probe230:1; /* Bit 9 */
- bool probe234:1; /* Bit 10 */
- bool probe130:1; /* Bit 11 */
- bool probe134:1; /* Bit 12 */
- };
- /*
- Define the Global Options.
- */
- struct blogic_global_options {
- bool trace_probe:1; /* Bit 0 */
- bool trace_hw_reset:1; /* Bit 1 */
- bool trace_config:1; /* Bit 2 */
- bool trace_err:1; /* Bit 3 */
- };
- /*
- Define the BusLogic SCSI Host Adapter I/O Register Offsets.
- */
- #define BLOGIC_CNTRL_REG 0 /* WO register */
- #define BLOGIC_STATUS_REG 0 /* RO register */
- #define BLOGIC_CMD_PARM_REG 1 /* WO register */
- #define BLOGIC_DATAIN_REG 1 /* RO register */
- #define BLOGIC_INT_REG 2 /* RO register */
- #define BLOGIC_GEOMETRY_REG 3 /* RO register */
- /*
- Define the structure of the write-only Control Register.
- */
- union blogic_cntrl_reg {
- unsigned char all;
- struct {
- unsigned char:4; /* Bits 0-3 */
- bool bus_reset:1; /* Bit 4 */
- bool int_reset:1; /* Bit 5 */
- bool soft_reset:1; /* Bit 6 */
- bool hard_reset:1; /* Bit 7 */
- } cr;
- };
- /*
- Define the structure of the read-only Status Register.
- */
- union blogic_stat_reg {
- unsigned char all;
- struct {
- bool cmd_invalid:1; /* Bit 0 */
- bool rsvd:1; /* Bit 1 */
- bool datain_ready:1; /* Bit 2 */
- bool cmd_param_busy:1; /* Bit 3 */
- bool adapter_ready:1; /* Bit 4 */
- bool init_reqd:1; /* Bit 5 */
- bool diag_failed:1; /* Bit 6 */
- bool diag_active:1; /* Bit 7 */
- } sr;
- };
- /*
- Define the structure of the read-only Interrupt Register.
- */
- union blogic_int_reg {
- unsigned char all;
- struct {
- bool mailin_loaded:1; /* Bit 0 */
- bool mailout_avail:1; /* Bit 1 */
- bool cmd_complete:1; /* Bit 2 */
- bool ext_busreset:1; /* Bit 3 */
- unsigned char rsvd:3; /* Bits 4-6 */
- bool int_valid:1; /* Bit 7 */
- } ir;
- };
- /*
- Define the structure of the read-only Geometry Register.
- */
- union blogic_geo_reg {
- unsigned char all;
- struct {
- enum blogic_bios_diskgeometry d0_geo:2; /* Bits 0-1 */
- enum blogic_bios_diskgeometry d1_geo:2; /* Bits 2-3 */
- unsigned char:3; /* Bits 4-6 */
- bool ext_trans_enable:1; /* Bit 7 */
- } gr;
- };
- /*
- Define the BusLogic SCSI Host Adapter Command Register Operation Codes.
- */
- enum blogic_opcode {
- BLOGIC_TEST_CMP_COMPLETE = 0x00,
- BLOGIC_INIT_MBOX = 0x01,
- BLOGIC_EXEC_MBOX_CMD = 0x02,
- BLOGIC_EXEC_BIOS_CMD = 0x03,
- BLOGIC_GET_BOARD_ID = 0x04,
- BLOGIC_ENABLE_OUTBOX_AVAIL_INT = 0x05,
- BLOGIC_SET_SELECT_TIMEOUT = 0x06,
- BLOGIC_SET_PREEMPT_TIME = 0x07,
- BLOGIC_SET_TIMEOFF_BUS = 0x08,
- BLOGIC_SET_TXRATE = 0x09,
- BLOGIC_INQ_DEV0TO7 = 0x0A,
- BLOGIC_INQ_CONFIG = 0x0B,
- BLOGIC_TGT_MODE = 0x0C,
- BLOGIC_INQ_SETUPINFO = 0x0D,
- BLOGIC_WRITE_LOCALRAM = 0x1A,
- BLOGIC_READ_LOCALRAM = 0x1B,
- BLOGIC_WRITE_BUSMASTER_FIFO = 0x1C,
- BLOGIC_READ_BUSMASTER_FIFO = 0x1D,
- BLOGIC_ECHO_CMDDATA = 0x1F,
- BLOGIC_ADAPTER_DIAG = 0x20,
- BLOGIC_SET_OPTIONS = 0x21,
- BLOGIC_INQ_DEV8TO15 = 0x23,
- BLOGIC_INQ_DEV = 0x24,
- BLOGIC_DISABLE_INT = 0x25,
- BLOGIC_INIT_EXT_MBOX = 0x81,
- BLOGIC_EXEC_SCS_CMD = 0x83,
- BLOGIC_INQ_FWVER_D3 = 0x84,
- BLOGIC_INQ_FWVER_LETTER = 0x85,
- BLOGIC_INQ_PCI_INFO = 0x86,
- BLOGIC_INQ_MODELNO = 0x8B,
- BLOGIC_INQ_SYNC_PERIOD = 0x8C,
- BLOGIC_INQ_EXTSETUP = 0x8D,
- BLOGIC_STRICT_RR = 0x8F,
- BLOGIC_STORE_LOCALRAM = 0x90,
- BLOGIC_FETCH_LOCALRAM = 0x91,
- BLOGIC_STORE_TO_EEPROM = 0x92,
- BLOGIC_LOAD_AUTOSCSICODE = 0x94,
- BLOGIC_MOD_IOADDR = 0x95,
- BLOGIC_SETCCB_FMT = 0x96,
- BLOGIC_WRITE_INQBUF = 0x9A,
- BLOGIC_READ_INQBUF = 0x9B,
- BLOGIC_FLASH_LOAD = 0xA7,
- BLOGIC_READ_SCAMDATA = 0xA8,
- BLOGIC_WRITE_SCAMDATA = 0xA9
- };
- /*
- Define the Inquire Board ID reply structure.
- */
- struct blogic_board_id {
- unsigned char type; /* Byte 0 */
- unsigned char custom_features; /* Byte 1 */
- unsigned char fw_ver_digit1; /* Byte 2 */
- unsigned char fw_ver_digit2; /* Byte 3 */
- };
- /*
- Define the Inquire Configuration reply structure.
- */
- struct blogic_config {
- unsigned char:5; /* Byte 0 Bits 0-4 */
- bool dma_ch5:1; /* Byte 0 Bit 5 */
- bool dma_ch6:1; /* Byte 0 Bit 6 */
- bool dma_ch7:1; /* Byte 0 Bit 7 */
- bool irq_ch9:1; /* Byte 1 Bit 0 */
- bool irq_ch10:1; /* Byte 1 Bit 1 */
- bool irq_ch11:1; /* Byte 1 Bit 2 */
- bool irq_ch12:1; /* Byte 1 Bit 3 */
- unsigned char:1; /* Byte 1 Bit 4 */
- bool irq_ch14:1; /* Byte 1 Bit 5 */
- bool irq_ch15:1; /* Byte 1 Bit 6 */
- unsigned char:1; /* Byte 1 Bit 7 */
- unsigned char id:4; /* Byte 2 Bits 0-3 */
- unsigned char:4; /* Byte 2 Bits 4-7 */
- };
- /*
- Define the Inquire Setup Information reply structure.
- */
- struct blogic_syncval {
- unsigned char offset:4; /* Bits 0-3 */
- unsigned char tx_period:3; /* Bits 4-6 */
- bool sync:1; /* Bit 7 */
- };
- struct blogic_setup_info {
- bool sync:1; /* Byte 0 Bit 0 */
- bool parity:1; /* Byte 0 Bit 1 */
- unsigned char:6; /* Byte 0 Bits 2-7 */
- unsigned char tx_rate; /* Byte 1 */
- unsigned char preempt_time; /* Byte 2 */
- unsigned char timeoff_bus; /* Byte 3 */
- unsigned char mbox_count; /* Byte 4 */
- unsigned char mbox_addr[3]; /* Bytes 5-7 */
- struct blogic_syncval sync0to7[8]; /* Bytes 8-15 */
- unsigned char disconnect_ok0to7; /* Byte 16 */
- unsigned char sig; /* Byte 17 */
- unsigned char char_d; /* Byte 18 */
- unsigned char bus_type; /* Byte 19 */
- unsigned char wide_tx_ok0to7; /* Byte 20 */
- unsigned char wide_tx_active0to7; /* Byte 21 */
- struct blogic_syncval sync8to15[8]; /* Bytes 22-29 */
- unsigned char disconnect_ok8to15; /* Byte 30 */
- unsigned char:8; /* Byte 31 */
- unsigned char wide_tx_ok8to15; /* Byte 32 */
- unsigned char wide_tx_active8to15; /* Byte 33 */
- };
- /*
- Define the Initialize Extended Mailbox request structure.
- */
- struct blogic_extmbox_req {
- unsigned char mbox_count; /* Byte 0 */
- u32 base_mbox_addr; /* Bytes 1-4 */
- } PACKED;
- /*
- Define the Inquire PCI Host Adapter Information reply type. The ISA
- Compatible I/O Port values are defined here and are also used with
- the Modify I/O Address command.
- */
- enum blogic_isa_ioport {
- BLOGIC_IO_330 = 0,
- BLOGIC_IO_334 = 1,
- BLOGIC_IO_230 = 2,
- BLOGIC_IO_234 = 3,
- BLOGIC_IO_130 = 4,
- BLOGIC_IO_134 = 5,
- BLOGIC_IO_DISABLE = 6,
- BLOGIC_IO_DISABLE2 = 7
- } PACKED;
- struct blogic_adapter_info {
- enum blogic_isa_ioport isa_port; /* Byte 0 */
- unsigned char irq_ch; /* Byte 1 */
- bool low_term:1; /* Byte 2 Bit 0 */
- bool high_term:1; /* Byte 2 Bit 1 */
- unsigned char:2; /* Byte 2 Bits 2-3 */
- bool JP1:1; /* Byte 2 Bit 4 */
- bool JP2:1; /* Byte 2 Bit 5 */
- bool JP3:1; /* Byte 2 Bit 6 */
- bool genericinfo_valid:1; /* Byte 2 Bit 7 */
- unsigned char:8; /* Byte 3 */
- };
- /*
- Define the Inquire Extended Setup Information reply structure.
- */
- struct blogic_ext_setup {
- unsigned char bus_type; /* Byte 0 */
- unsigned char bios_addr; /* Byte 1 */
- unsigned short sg_limit; /* Bytes 2-3 */
- unsigned char mbox_count; /* Byte 4 */
- u32 base_mbox_addr; /* Bytes 5-8 */
- struct {
- unsigned char:2; /* Byte 9 Bits 0-1 */
- bool fast_on_eisa:1; /* Byte 9 Bit 2 */
- unsigned char:3; /* Byte 9 Bits 3-5 */
- bool level_int:1; /* Byte 9 Bit 6 */
- unsigned char:1; /* Byte 9 Bit 7 */
- } misc;
- unsigned char fw_rev[3]; /* Bytes 10-12 */
- bool wide:1; /* Byte 13 Bit 0 */
- bool differential:1; /* Byte 13 Bit 1 */
- bool scam:1; /* Byte 13 Bit 2 */
- bool ultra:1; /* Byte 13 Bit 3 */
- bool smart_term:1; /* Byte 13 Bit 4 */
- unsigned char:3; /* Byte 13 Bits 5-7 */
- } PACKED;
- /*
- Define the Enable Strict Round Robin Mode request type.
- */
- enum blogic_rr_req {
- BLOGIC_AGGRESSIVE_RR = 0,
- BLOGIC_STRICT_RR_MODE = 1
- } PACKED;
- /*
- Define the Fetch Host Adapter Local RAM request type.
- */
- #define BLOGIC_BIOS_BASE 0
- #define BLOGIC_AUTOSCSI_BASE 64
- struct blogic_fetch_localram {
- unsigned char offset; /* Byte 0 */
- unsigned char count; /* Byte 1 */
- };
- /*
- Define the Host Adapter Local RAM AutoSCSI structure.
- */
- struct blogic_autoscsi {
- unsigned char factory_sig[2]; /* Bytes 0-1 */
- unsigned char info_bytes; /* Byte 2 */
- unsigned char adapter_type[6]; /* Bytes 3-8 */
- unsigned char:8; /* Byte 9 */
- bool floppy:1; /* Byte 10 Bit 0 */
- bool floppy_sec:1; /* Byte 10 Bit 1 */
- bool level_int:1; /* Byte 10 Bit 2 */
- unsigned char:2; /* Byte 10 Bits 3-4 */
- unsigned char systemram_bios:3; /* Byte 10 Bits 5-7 */
- unsigned char dma_ch:7; /* Byte 11 Bits 0-6 */
- bool dma_autoconf:1; /* Byte 11 Bit 7 */
- unsigned char irq_ch:7; /* Byte 12 Bits 0-6 */
- bool irq_autoconf:1; /* Byte 12 Bit 7 */
- unsigned char dma_tx_rate; /* Byte 13 */
- unsigned char scsi_id; /* Byte 14 */
- bool low_term:1; /* Byte 15 Bit 0 */
- bool parity:1; /* Byte 15 Bit 1 */
- bool high_term:1; /* Byte 15 Bit 2 */
- bool noisy_cable:1; /* Byte 15 Bit 3 */
- bool fast_sync_neg:1; /* Byte 15 Bit 4 */
- bool reset_enabled:1; /* Byte 15 Bit 5 */
- bool:1; /* Byte 15 Bit 6 */
- bool active_negation:1; /* Byte 15 Bit 7 */
- unsigned char bus_on_delay; /* Byte 16 */
- unsigned char bus_off_delay; /* Byte 17 */
- bool bios_enabled:1; /* Byte 18 Bit 0 */
- bool int19_redir_enabled:1; /* Byte 18 Bit 1 */
- bool ext_trans_enable:1; /* Byte 18 Bit 2 */
- bool removable_as_fixed:1; /* Byte 18 Bit 3 */
- bool:1; /* Byte 18 Bit 4 */
- bool morethan2_drives:1; /* Byte 18 Bit 5 */
- bool bios_int:1; /* Byte 18 Bit 6 */
- bool floptical:1; /* Byte 19 Bit 7 */
- unsigned short dev_enabled; /* Bytes 19-20 */
- unsigned short wide_ok; /* Bytes 21-22 */
- unsigned short fast_ok; /* Bytes 23-24 */
- unsigned short sync_ok; /* Bytes 25-26 */
- unsigned short discon_ok; /* Bytes 27-28 */
- unsigned short send_start_unit; /* Bytes 29-30 */
- unsigned short ignore_bios_scan; /* Bytes 31-32 */
- unsigned char pci_int_pin:2; /* Byte 33 Bits 0-1 */
- unsigned char adapter_ioport:2; /* Byte 33 Bits 2-3 */
- bool strict_rr_enabled:1; /* Byte 33 Bit 4 */
- bool vesabus_33mhzplus:1; /* Byte 33 Bit 5 */
- bool vesa_burst_write:1; /* Byte 33 Bit 6 */
- bool vesa_burst_read:1; /* Byte 33 Bit 7 */
- unsigned short ultra_ok; /* Bytes 34-35 */
- unsigned int:32; /* Bytes 36-39 */
- unsigned char:8; /* Byte 40 */
- unsigned char autoscsi_maxlun; /* Byte 41 */
- bool:1; /* Byte 42 Bit 0 */
- bool scam_dominant:1; /* Byte 42 Bit 1 */
- bool scam_enabled:1; /* Byte 42 Bit 2 */
- bool scam_lev2:1; /* Byte 42 Bit 3 */
- unsigned char:4; /* Byte 42 Bits 4-7 */
- bool int13_exten:1; /* Byte 43 Bit 0 */
- bool:1; /* Byte 43 Bit 1 */
- bool cd_boot:1; /* Byte 43 Bit 2 */
- unsigned char:5; /* Byte 43 Bits 3-7 */
- unsigned char boot_id:4; /* Byte 44 Bits 0-3 */
- unsigned char boot_ch:4; /* Byte 44 Bits 4-7 */
- unsigned char force_scan_order:1; /* Byte 45 Bit 0 */
- unsigned char:7; /* Byte 45 Bits 1-7 */
- unsigned short nontagged_to_alt_ok; /* Bytes 46-47 */
- unsigned short reneg_sync_on_check; /* Bytes 48-49 */
- unsigned char rsvd[10]; /* Bytes 50-59 */
- unsigned char manuf_diag[2]; /* Bytes 60-61 */
- unsigned short cksum; /* Bytes 62-63 */
- } PACKED;
- /*
- Define the Host Adapter Local RAM Auto SCSI Byte 45 structure.
- */
- struct blogic_autoscsi_byte45 {
- unsigned char force_scan_order:1; /* Bit 0 */
- unsigned char:7; /* Bits 1-7 */
- };
- /*
- Define the Host Adapter Local RAM BIOS Drive Map Byte structure.
- */
- #define BLOGIC_BIOS_DRVMAP 17
- struct blogic_bios_drvmap {
- unsigned char tgt_idbit3:1; /* Bit 0 */
- unsigned char:2; /* Bits 1-2 */
- enum blogic_bios_diskgeometry diskgeom:2; /* Bits 3-4 */
- unsigned char tgt_id:3; /* Bits 5-7 */
- };
- /*
- Define the Set CCB Format request type. Extended LUN Format CCBs are
- necessary to support more than 8 Logical Units per Target Device.
- */
- enum blogic_setccb_fmt {
- BLOGIC_LEGACY_LUN_CCB = 0,
- BLOGIC_EXT_LUN_CCB = 1
- } PACKED;
- /*
- Define the Outgoing Mailbox Action Codes.
- */
- enum blogic_action {
- BLOGIC_OUTBOX_FREE = 0x00,
- BLOGIC_MBOX_START = 0x01,
- BLOGIC_MBOX_ABORT = 0x02
- } PACKED;
- /*
- Define the Incoming Mailbox Completion Codes. The MultiMaster Firmware
- only uses codes 0 - 4. The FlashPoint SCCB Manager has no mailboxes, so
- completion codes are stored in the CCB; it only uses codes 1, 2, 4, and 5.
- */
- enum blogic_cmplt_code {
- BLOGIC_INBOX_FREE = 0x00,
- BLOGIC_CMD_COMPLETE_GOOD = 0x01,
- BLOGIC_CMD_ABORT_BY_HOST = 0x02,
- BLOGIC_CMD_NOTFOUND = 0x03,
- BLOGIC_CMD_COMPLETE_ERROR = 0x04,
- BLOGIC_INVALID_CCB = 0x05
- } PACKED;
- /*
- Define the Command Control Block (CCB) Opcodes.
- */
- enum blogic_ccb_opcode {
- BLOGIC_INITIATOR_CCB = 0x00,
- BLOGIC_TGT_CCB = 0x01,
- BLOGIC_INITIATOR_CCB_SG = 0x02,
- BLOGIC_INITIATOR_CCBB_RESIDUAL = 0x03,
- BLOGIC_INITIATOR_CCB_SG_RESIDUAL = 0x04,
- BLOGIC_BDR = 0x81
- } PACKED;
- /*
- Define the CCB Data Direction Codes.
- */
- enum blogic_datadir {
- BLOGIC_UNCHECKED_TX = 0,
- BLOGIC_DATAIN_CHECKED = 1,
- BLOGIC_DATAOUT_CHECKED = 2,
- BLOGIC_NOTX = 3
- };
- /*
- Define the Host Adapter Status Codes. The MultiMaster Firmware does not
- return status code 0x0C; it uses 0x12 for both overruns and underruns.
- */
- enum blogic_adapter_status {
- BLOGIC_CMD_CMPLT_NORMAL = 0x00,
- BLOGIC_LINK_CMD_CMPLT = 0x0A,
- BLOGIC_LINK_CMD_CMPLT_FLAG = 0x0B,
- BLOGIC_DATA_UNDERRUN = 0x0C,
- BLOGIC_SELECT_TIMEOUT = 0x11,
- BLOGIC_DATA_OVERRUN = 0x12,
- BLOGIC_NOEXPECT_BUSFREE = 0x13,
- BLOGIC_INVALID_BUSPHASE = 0x14,
- BLOGIC_INVALID_OUTBOX_CODE = 0x15,
- BLOGIC_INVALID_CMD_CODE = 0x16,
- BLOGIC_LINKCCB_BADLUN = 0x17,
- BLOGIC_BAD_CMD_PARAM = 0x1A,
- BLOGIC_AUTOREQSENSE_FAIL = 0x1B,
- BLOGIC_TAGQUEUE_REJECT = 0x1C,
- BLOGIC_BAD_MSG_RCVD = 0x1D,
- BLOGIC_HW_FAIL = 0x20,
- BLOGIC_NORESPONSE_TO_ATN = 0x21,
- BLOGIC_HW_RESET = 0x22,
- BLOGIC_RST_FROM_OTHERDEV = 0x23,
- BLOGIC_BAD_RECONNECT = 0x24,
- BLOGIC_HW_BDR = 0x25,
- BLOGIC_ABRT_QUEUE = 0x26,
- BLOGIC_ADAPTER_SW_ERROR = 0x27,
- BLOGIC_HW_TIMEOUT = 0x30,
- BLOGIC_PARITY_ERR = 0x34
- } PACKED;
- /*
- Define the SCSI Target Device Status Codes.
- */
- enum blogic_tgt_status {
- BLOGIC_OP_GOOD = 0x00,
- BLOGIC_CHECKCONDITION = 0x02,
- BLOGIC_DEVBUSY = 0x08
- } PACKED;
- /*
- Define the Queue Tag Codes.
- */
- enum blogic_queuetag {
- BLOGIC_SIMPLETAG = 0,
- BLOGIC_HEADTAG = 1,
- BLOGIC_ORDEREDTAG = 2,
- BLOGIC_RSVDTAG = 3
- };
- /*
- Define the SCSI Command Descriptor Block (CDB).
- */
- #define BLOGIC_CDB_MAXLEN 12
- /*
- Define the Scatter/Gather Segment structure required by the MultiMaster
- Firmware Interface and the FlashPoint SCCB Manager.
- */
- struct blogic_sg_seg {
- u32 segbytes; /* Bytes 0-3 */
- u32 segdata; /* Bytes 4-7 */
- };
- /*
- Define the Driver CCB Status Codes.
- */
- enum blogic_ccb_status {
- BLOGIC_CCB_FREE = 0,
- BLOGIC_CCB_ACTIVE = 1,
- BLOGIC_CCB_COMPLETE = 2,
- BLOGIC_CCB_RESET = 3
- } PACKED;
- /*
- Define the 32 Bit Mode Command Control Block (CCB) structure. The first 40
- bytes are defined by and common to both the MultiMaster Firmware and the
- FlashPoint SCCB Manager. The next 60 bytes are defined by the FlashPoint
- SCCB Manager. The remaining components are defined by the Linux BusLogic
- Driver. Extended LUN Format CCBs differ from Legacy LUN Format 32 Bit Mode
- CCBs only in having the TagEnable and QueueTag fields moved from byte 17 to
- byte 1, and the Logical Unit field in byte 17 expanded to 6 bits. In theory,
- Extended LUN Format CCBs can support up to 64 Logical Units, but in practice
- many devices will respond improperly to Logical Units between 32 and 63, and
- the SCSI-2 specification defines Bit 5 as LUNTAR. Extended LUN Format CCBs
- are used by recent versions of the MultiMaster Firmware, as well as by the
- FlashPoint SCCB Manager; the FlashPoint SCCB Manager only supports 32 Logical
- Units. Since 64 Logical Units are unlikely to be needed in practice, and
- since they are problematic for the above reasons, and since limiting them to
- 5 bits simplifies the CCB structure definition, this driver only supports
- 32 Logical Units per Target Device.
- */
- struct blogic_ccb {
- /*
- MultiMaster Firmware and FlashPoint SCCB Manager Common Portion.
- */
- enum blogic_ccb_opcode opcode; /* Byte 0 */
- unsigned char:3; /* Byte 1 Bits 0-2 */
- enum blogic_datadir datadir:2; /* Byte 1 Bits 3-4 */
- bool tag_enable:1; /* Byte 1 Bit 5 */
- enum blogic_queuetag queuetag:2; /* Byte 1 Bits 6-7 */
- unsigned char cdblen; /* Byte 2 */
- unsigned char sense_datalen; /* Byte 3 */
- u32 datalen; /* Bytes 4-7 */
- void *data; /* Bytes 8-11 */
- unsigned char:8; /* Byte 12 */
- unsigned char:8; /* Byte 13 */
- enum blogic_adapter_status adapter_status; /* Byte 14 */
- enum blogic_tgt_status tgt_status; /* Byte 15 */
- unsigned char tgt_id; /* Byte 16 */
- unsigned char lun:5; /* Byte 17 Bits 0-4 */
- bool legacytag_enable:1; /* Byte 17 Bit 5 */
- enum blogic_queuetag legacy_tag:2; /* Byte 17 Bits 6-7 */
- unsigned char cdb[BLOGIC_CDB_MAXLEN]; /* Bytes 18-29 */
- unsigned char:8; /* Byte 30 */
- unsigned char:8; /* Byte 31 */
- u32 rsvd_int; /* Bytes 32-35 */
- u32 sensedata; /* Bytes 36-39 */
- /*
- FlashPoint SCCB Manager Defined Portion.
- */
- void (*callback) (struct blogic_ccb *); /* Bytes 40-43 */
- u32 base_addr; /* Bytes 44-47 */
- enum blogic_cmplt_code comp_code; /* Byte 48 */
- #ifdef CONFIG_SCSI_FLASHPOINT
- unsigned char:8; /* Byte 49 */
- u16 os_flags; /* Bytes 50-51 */
- unsigned char private[24]; /* Bytes 52-99 */
- void *rsvd1;
- void *rsvd2;
- unsigned char private2[16];
- #endif
- /*
- BusLogic Linux Driver Defined Portion.
- */
- dma_addr_t allocgrp_head;
- unsigned int allocgrp_size;
- u32 dma_handle;
- enum blogic_ccb_status status;
- unsigned long serial;
- struct scsi_cmnd *command;
- struct blogic_adapter *adapter;
- struct blogic_ccb *next;
- struct blogic_ccb *next_all;
- struct blogic_sg_seg sglist[BLOGIC_SG_LIMIT];
- };
- /*
- Define the 32 Bit Mode Outgoing Mailbox structure.
- */
- struct blogic_outbox {
- u32 ccb; /* Bytes 0-3 */
- u32:24; /* Bytes 4-6 */
- enum blogic_action action; /* Byte 7 */
- };
- /*
- Define the 32 Bit Mode Incoming Mailbox structure.
- */
- struct blogic_inbox {
- u32 ccb; /* Bytes 0-3 */
- enum blogic_adapter_status adapter_status; /* Byte 4 */
- enum blogic_tgt_status tgt_status; /* Byte 5 */
- unsigned char:8; /* Byte 6 */
- enum blogic_cmplt_code comp_code; /* Byte 7 */
- };
- /*
- Define the BusLogic Driver Options structure.
- */
- struct blogic_drvr_options {
- unsigned short tagq_ok;
- unsigned short tagq_ok_mask;
- unsigned short bus_settle_time;
- unsigned short stop_tgt_inquiry;
- unsigned char common_qdepth;
- unsigned char qdepth[BLOGIC_MAXDEV];
- };
- /*
- Define the Host Adapter Target Flags structure.
- */
- struct blogic_tgt_flags {
- bool tgt_exists:1;
- bool tagq_ok:1;
- bool wide_ok:1;
- bool tagq_active:1;
- bool wide_active:1;
- bool cmd_good:1;
- bool tgt_info_in:1;
- };
- /*
- Define the Host Adapter Target Statistics structure.
- */
- #define BLOGIC_SZ_BUCKETS 10
- struct blogic_tgt_stats {
- unsigned int cmds_tried;
- unsigned int cmds_complete;
- unsigned int read_cmds;
- unsigned int write_cmds;
- struct blogic_byte_count bytesread;
- struct blogic_byte_count byteswritten;
- unsigned int read_sz_buckets[BLOGIC_SZ_BUCKETS];
- unsigned int write_sz_buckets[BLOGIC_SZ_BUCKETS];
- unsigned short aborts_request;
- unsigned short aborts_tried;
- unsigned short aborts_done;
- unsigned short bdr_request;
- unsigned short bdr_tried;
- unsigned short bdr_done;
- unsigned short adatper_reset_req;
- unsigned short adapter_reset_attempt;
- unsigned short adapter_reset_done;
- };
- /*
- Define the FlashPoint Card Handle data type.
- */
- #define FPOINT_BADCARD_HANDLE 0xFFFFFFFFL
- /*
- Define the FlashPoint Information structure. This structure is defined
- by the FlashPoint SCCB Manager.
- */
- struct fpoint_info {
- u32 base_addr; /* Bytes 0-3 */
- bool present; /* Byte 4 */
- unsigned char irq_ch; /* Byte 5 */
- unsigned char scsi_id; /* Byte 6 */
- unsigned char scsi_lun; /* Byte 7 */
- u16 fw_rev; /* Bytes 8-9 */
- u16 sync_ok; /* Bytes 10-11 */
- u16 fast_ok; /* Bytes 12-13 */
- u16 ultra_ok; /* Bytes 14-15 */
- u16 discon_ok; /* Bytes 16-17 */
- u16 wide_ok; /* Bytes 18-19 */
- bool parity:1; /* Byte 20 Bit 0 */
- bool wide:1; /* Byte 20 Bit 1 */
- bool softreset:1; /* Byte 20 Bit 2 */
- bool ext_trans_enable:1; /* Byte 20 Bit 3 */
- bool low_term:1; /* Byte 20 Bit 4 */
- bool high_term:1; /* Byte 20 Bit 5 */
- bool report_underrun:1; /* Byte 20 Bit 6 */
- bool scam_enabled:1; /* Byte 20 Bit 7 */
- bool scam_lev2:1; /* Byte 21 Bit 0 */
- unsigned char:7; /* Byte 21 Bits 1-7 */
- unsigned char family; /* Byte 22 */
- unsigned char bus_type; /* Byte 23 */
- unsigned char model[3]; /* Bytes 24-26 */
- unsigned char relative_cardnum; /* Byte 27 */
- unsigned char rsvd[4]; /* Bytes 28-31 */
- u32 os_rsvd; /* Bytes 32-35 */
- unsigned char translation_info[4]; /* Bytes 36-39 */
- u32 rsvd2[5]; /* Bytes 40-59 */
- u32 sec_range; /* Bytes 60-63 */
- };
- /*
- Define the BusLogic Driver Host Adapter structure.
- */
- struct blogic_adapter {
- struct Scsi_Host *scsi_host;
- struct pci_dev *pci_device;
- enum blogic_adapter_type adapter_type;
- enum blogic_adapter_bus_type adapter_bus_type;
- unsigned long io_addr;
- unsigned long pci_addr;
- unsigned short addr_count;
- unsigned char host_no;
- unsigned char model[9];
- unsigned char fw_ver[6];
- unsigned char full_model[18];
- unsigned char bus;
- unsigned char dev;
- unsigned char irq_ch;
- unsigned char dma_ch;
- unsigned char scsi_id;
- bool irq_acquired:1;
- bool dma_chan_acquired:1;
- bool ext_trans_enable:1;
- bool parity:1;
- bool reset_enabled:1;
- bool level_int:1;
- bool wide:1;
- bool differential:1;
- bool scam:1;
- bool ultra:1;
- bool ext_lun:1;
- bool terminfo_valid:1;
- bool low_term:1;
- bool high_term:1;
- bool need_bouncebuf:1;
- bool strict_rr:1;
- bool scam_enabled:1;
- bool scam_lev2:1;
- bool adapter_initd:1;
- bool adapter_extreset:1;
- bool adapter_intern_err:1;
- bool processing_ccbs;
- volatile bool adapter_cmd_complete;
- unsigned short adapter_sglimit;
- unsigned short drvr_sglimit;
- unsigned short maxdev;
- unsigned short maxlun;
- unsigned short mbox_count;
- unsigned short initccbs;
- unsigned short inc_ccbs;
- unsigned short alloc_ccbs;
- unsigned short drvr_qdepth;
- unsigned short adapter_qdepth;
- unsigned short untag_qdepth;
- unsigned short common_qdepth;
- unsigned short bus_settle_time;
- unsigned short sync_ok;
- unsigned short fast_ok;
- unsigned short ultra_ok;
- unsigned short wide_ok;
- unsigned short discon_ok;
- unsigned short tagq_ok;
- unsigned short ext_resets;
- unsigned short adapter_intern_errors;
- unsigned short tgt_count;
- unsigned short msgbuflen;
- u32 bios_addr;
- struct blogic_drvr_options *drvr_opts;
- struct fpoint_info fpinfo;
- void *cardhandle;
- struct list_head host_list;
- struct blogic_ccb *all_ccbs;
- struct blogic_ccb *free_ccbs;
- struct blogic_ccb *firstccb;
- struct blogic_ccb *lastccb;
- struct blogic_ccb *bdr_pend[BLOGIC_MAXDEV];
- struct blogic_tgt_flags tgt_flags[BLOGIC_MAXDEV];
- unsigned char qdepth[BLOGIC_MAXDEV];
- unsigned char sync_period[BLOGIC_MAXDEV];
- unsigned char sync_offset[BLOGIC_MAXDEV];
- unsigned char active_cmds[BLOGIC_MAXDEV];
- unsigned int cmds_since_rst[BLOGIC_MAXDEV];
- unsigned long last_seqpoint[BLOGIC_MAXDEV];
- unsigned long last_resettried[BLOGIC_MAXDEV];
- unsigned long last_resetdone[BLOGIC_MAXDEV];
- struct blogic_outbox *first_outbox;
- struct blogic_outbox *last_outbox;
- struct blogic_outbox *next_outbox;
- struct blogic_inbox *first_inbox;
- struct blogic_inbox *last_inbox;
- struct blogic_inbox *next_inbox;
- struct blogic_tgt_stats tgt_stats[BLOGIC_MAXDEV];
- unsigned char *mbox_space;
- dma_addr_t mbox_space_handle;
- unsigned int mbox_sz;
- unsigned long ccb_offset;
- char msgbuf[BLOGIC_MSGBUF_SIZE];
- };
- /*
- Define a structure for the BIOS Disk Parameters.
- */
- struct bios_diskparam {
- int heads;
- int sectors;
- int cylinders;
- };
- /*
- Define a structure for the SCSI Inquiry command results.
- */
- struct scsi_inquiry {
- unsigned char devtype:5; /* Byte 0 Bits 0-4 */
- unsigned char dev_qual:3; /* Byte 0 Bits 5-7 */
- unsigned char dev_modifier:7; /* Byte 1 Bits 0-6 */
- bool rmb:1; /* Byte 1 Bit 7 */
- unsigned char ansi_ver:3; /* Byte 2 Bits 0-2 */
- unsigned char ecma_ver:3; /* Byte 2 Bits 3-5 */
- unsigned char iso_ver:2; /* Byte 2 Bits 6-7 */
- unsigned char resp_fmt:4; /* Byte 3 Bits 0-3 */
- unsigned char:2; /* Byte 3 Bits 4-5 */
- bool TrmIOP:1; /* Byte 3 Bit 6 */
- bool AENC:1; /* Byte 3 Bit 7 */
- unsigned char addl_len; /* Byte 4 */
- unsigned char:8; /* Byte 5 */
- unsigned char:8; /* Byte 6 */
- bool SftRe:1; /* Byte 7 Bit 0 */
- bool CmdQue:1; /* Byte 7 Bit 1 */
- bool:1; /* Byte 7 Bit 2 */
- bool linked:1; /* Byte 7 Bit 3 */
- bool sync:1; /* Byte 7 Bit 4 */
- bool WBus16:1; /* Byte 7 Bit 5 */
- bool WBus32:1; /* Byte 7 Bit 6 */
- bool RelAdr:1; /* Byte 7 Bit 7 */
- unsigned char vendor[8]; /* Bytes 8-15 */
- unsigned char product[16]; /* Bytes 16-31 */
- unsigned char product_rev[4]; /* Bytes 32-35 */
- };
- /*
- Define functions to provide an abstraction for reading and writing the
- Host Adapter I/O Registers.
- */
- static inline void blogic_busreset(struct blogic_adapter *adapter)
- {
- union blogic_cntrl_reg cr;
- cr.all = 0;
- cr.cr.bus_reset = true;
- outb(cr.all, adapter->io_addr + BLOGIC_CNTRL_REG);
- }
- static inline void blogic_intreset(struct blogic_adapter *adapter)
- {
- union blogic_cntrl_reg cr;
- cr.all = 0;
- cr.cr.int_reset = true;
- outb(cr.all, adapter->io_addr + BLOGIC_CNTRL_REG);
- }
- static inline void blogic_softreset(struct blogic_adapter *adapter)
- {
- union blogic_cntrl_reg cr;
- cr.all = 0;
- cr.cr.soft_reset = true;
- outb(cr.all, adapter->io_addr + BLOGIC_CNTRL_REG);
- }
- static inline void blogic_hardreset(struct blogic_adapter *adapter)
- {
- union blogic_cntrl_reg cr;
- cr.all = 0;
- cr.cr.hard_reset = true;
- outb(cr.all, adapter->io_addr + BLOGIC_CNTRL_REG);
- }
- static inline unsigned char blogic_rdstatus(struct blogic_adapter *adapter)
- {
- return inb(adapter->io_addr + BLOGIC_STATUS_REG);
- }
- static inline void blogic_setcmdparam(struct blogic_adapter *adapter,
- unsigned char value)
- {
- outb(value, adapter->io_addr + BLOGIC_CMD_PARM_REG);
- }
- static inline unsigned char blogic_rddatain(struct blogic_adapter *adapter)
- {
- return inb(adapter->io_addr + BLOGIC_DATAIN_REG);
- }
- static inline unsigned char blogic_rdint(struct blogic_adapter *adapter)
- {
- return inb(adapter->io_addr + BLOGIC_INT_REG);
- }
- static inline unsigned char blogic_rdgeom(struct blogic_adapter *adapter)
- {
- return inb(adapter->io_addr + BLOGIC_GEOMETRY_REG);
- }
- /*
- blogic_execmbox issues an Execute Mailbox Command, which
- notifies the Host Adapter that an entry has been made in an Outgoing
- Mailbox.
- */
- static inline void blogic_execmbox(struct blogic_adapter *adapter)
- {
- blogic_setcmdparam(adapter, BLOGIC_EXEC_MBOX_CMD);
- }
- /*
- blogic_delay waits for Seconds to elapse.
- */
- static inline void blogic_delay(int seconds)
- {
- mdelay(1000 * seconds);
- }
- /*
- virt_to_32bit_virt maps between Kernel Virtual Addresses and
- 32 bit Kernel Virtual Addresses. This avoids compilation warnings
- on 64 bit architectures.
- */
- static inline u32 virt_to_32bit_virt(void *virt_addr)
- {
- return (u32) (unsigned long) virt_addr;
- }
- /*
- blogic_inc_count increments counter by 1, stopping at
- 65535 rather than wrapping around to 0.
- */
- static inline void blogic_inc_count(unsigned short *count)
- {
- if (*count < 65535)
- (*count)++;
- }
- /*
- blogic_addcount increments Byte Counter by Amount.
- */
- static inline void blogic_addcount(struct blogic_byte_count *bytecount,
- unsigned int amount)
- {
- bytecount->units += amount;
- if (bytecount->units > 999999999) {
- bytecount->units -= 1000000000;
- bytecount->billions++;
- }
- }
- /*
- blogic_incszbucket increments the Bucket for Amount.
- */
- static inline void blogic_incszbucket(unsigned int *cmdsz_buckets,
- unsigned int amount)
- {
- int index = 0;
- if (amount < 8 * 1024) {
- if (amount < 2 * 1024)
- index = (amount < 1 * 1024 ? 0 : 1);
- else
- index = (amount < 4 * 1024 ? 2 : 3);
- } else if (amount < 128 * 1024) {
- if (amount < 32 * 1024)
- index = (amount < 16 * 1024 ? 4 : 5);
- else
- index = (amount < 64 * 1024 ? 6 : 7);
- } else
- index = (amount < 256 * 1024 ? 8 : 9);
- cmdsz_buckets[index]++;
- }
- /*
- Define the version number of the FlashPoint Firmware (SCCB Manager).
- */
- #define FLASHPOINT_FW_VER "5.02"
- /*
- Define the possible return values from FlashPoint_HandleInterrupt.
- */
- #define FPOINT_NORMAL_INT 0x00
- #define FPOINT_INTERN_ERR 0xFE
- #define FPOINT_EXT_RESET 0xFF
- /*
- Define prototypes for the forward referenced BusLogic Driver
- Internal Functions.
- */
- static const char *blogic_drvr_info(struct Scsi_Host *);
- static int blogic_qcmd(struct Scsi_Host *h, struct scsi_cmnd *);
- static int blogic_diskparam(struct scsi_device *, struct block_device *, sector_t, int *);
- static int blogic_slaveconfig(struct scsi_device *);
- static void blogic_qcompleted_ccb(struct blogic_ccb *);
- static irqreturn_t blogic_inthandler(int, void *);
- static int blogic_resetadapter(struct blogic_adapter *, bool hard_reset);
- static void blogic_msg(enum blogic_msglevel, char *, struct blogic_adapter *, ...);
- static int __init blogic_setup(char *);
- #endif /* _BUSLOGIC_H */
|