| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | /*
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   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. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | #define BLOGIC_MAX_ADAPTERS		16
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the maximum number of Target Devices supported by this driver. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | #define BLOGIC_MAXDEV			16
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   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. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | #define BLOGIC_SG_LIMIT		128
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   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. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | #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
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   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. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | #define BLOGIC_BUS_SETTLE_TIME		2
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   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. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | #define BLOGIC_MAX_MAILBOX		211
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the number of CCBs that should be allocated as a group to optimize | 
					
						
							|  |  |  |   Kernel memory allocation. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | #define BLOGIC_CCB_GRP_ALLOCSIZE	7
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the Host Adapter Line and Message Buffer Sizes. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | #define BLOGIC_LINEBUF_SIZE		100
 | 
					
						
							|  |  |  | #define BLOGIC_MSGBUF_SIZE		9700
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the Driver Message Levels. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | enum blogic_msglevel { | 
					
						
							|  |  |  | 	BLOGIC_ANNOUNCE_LEVEL = 0, | 
					
						
							|  |  |  | 	BLOGIC_INFO_LEVEL = 1, | 
					
						
							|  |  |  | 	BLOGIC_NOTICE_LEVEL = 2, | 
					
						
							|  |  |  | 	BLOGIC_WARN_LEVEL = 3, | 
					
						
							|  |  |  | 	BLOGIC_ERR_LEVEL = 4 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | static char *blogic_msglevelmap[] = { KERN_NOTICE, KERN_NOTICE, KERN_NOTICE, KERN_WARNING, KERN_ERR }; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define Driver Message macros. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | #define blogic_announce(format, args...) \
 | 
					
						
							|  |  |  | 	blogic_msg(BLOGIC_ANNOUNCE_LEVEL, format, ##args) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | #define blogic_info(format, args...) \
 | 
					
						
							|  |  |  | 	blogic_msg(BLOGIC_INFO_LEVEL, format, ##args) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | #define blogic_notice(format, args...) \
 | 
					
						
							|  |  |  | 	blogic_msg(BLOGIC_NOTICE_LEVEL, format, ##args) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | #define blogic_warn(format, args...) \
 | 
					
						
							|  |  |  | 	blogic_msg(BLOGIC_WARN_LEVEL, format, ##args) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | #define blogic_err(format, args...) \
 | 
					
						
							|  |  |  | 	blogic_msg(BLOGIC_ERR_LEVEL, format, ##args) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the types of BusLogic Host Adapters that are supported and the number | 
					
						
							|  |  |  |   of I/O Addresses required by each type. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | enum blogic_adapter_type { | 
					
						
							|  |  |  | 	BLOGIC_MULTIMASTER = 1, | 
					
						
							|  |  |  | 	BLOGIC_FLASHPOINT = 2 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } PACKED; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | #define BLOGIC_MULTIMASTER_ADDR_COUNT	4
 | 
					
						
							|  |  |  | #define BLOGIC_FLASHPOINT_ADDR_COUNT	256
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | static int blogic_adapter_addr_count[3] = { 0, BLOGIC_MULTIMASTER_ADDR_COUNT, BLOGIC_FLASHPOINT_ADDR_COUNT }; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define macros for testing the Host Adapter Type. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-13 06:55:08 -06:00
										 |  |  | #ifdef CONFIG_SCSI_FLASHPOINT
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | #define blogic_multimaster_type(adapter) \
 | 
					
						
							|  |  |  | 	(adapter->adapter_type == BLOGIC_MULTIMASTER) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | #define blogic_flashpoint_type(adapter) \
 | 
					
						
							|  |  |  | 	(adapter->adapter_type == BLOGIC_FLASHPOINT) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | #define blogic_multimaster_type(adapter)	(true)
 | 
					
						
							|  |  |  | #define blogic_flashpoint_type(adapter)		(false)
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the possible Host Adapter Bus Types. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 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 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } PACKED; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | static char *blogic_adapter_busnames[] = { "Unknown", "ISA", "EISA", "PCI", "VESA", "MCA" }; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 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 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the possible Host Adapter BIOS Disk Geometry Translations. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | enum blogic_bios_diskgeometry { | 
					
						
							|  |  |  | 	BLOGIC_BIOS_NODISK = 0, | 
					
						
							|  |  |  | 	BLOGIC_BIOS_DISK64x32 = 1, | 
					
						
							|  |  |  | 	BLOGIC_BIOS_DISK128x32 = 2, | 
					
						
							|  |  |  | 	BLOGIC_BIOS_DISK255x63 = 3 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } PACKED; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define a 10^18 Statistics Byte Counter data type. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | struct blogic_byte_count { | 
					
						
							|  |  |  | 	unsigned int units; | 
					
						
							|  |  |  | 	unsigned int billions; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the structure for I/O Address and Bus Probing Information. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 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; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the Probe Options. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 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 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the Global Options. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 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 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the BusLogic SCSI Host Adapter I/O Register Offsets. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | #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 */
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the structure of the write-only Control Register. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | union blogic_cntrl_reg { | 
					
						
							|  |  |  | 	unsigned char all; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 	struct { | 
					
						
							|  |  |  | 		unsigned char:4;	/* Bits 0-3 */ | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 		bool bus_reset:1;	/* Bit 4 */ | 
					
						
							|  |  |  | 		bool int_reset:1;	/* Bit 5 */ | 
					
						
							|  |  |  | 		bool soft_reset:1;	/* Bit 6 */ | 
					
						
							|  |  |  | 		bool hard_reset:1;	/* Bit 7 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 	} cr; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the structure of the read-only Status Register. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | union blogic_stat_reg { | 
					
						
							|  |  |  | 	unsigned char all; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 	struct { | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 		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 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 	} sr; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the structure of the read-only Interrupt Register. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | union blogic_int_reg { | 
					
						
							|  |  |  | 	unsigned char all; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 	struct { | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 		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 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 	} ir; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the structure of the read-only Geometry Register. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | union blogic_geo_reg { | 
					
						
							|  |  |  | 	unsigned char all; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 	struct { | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 		enum blogic_bios_diskgeometry d0_geo:2;	/* Bits 0-1 */ | 
					
						
							|  |  |  | 		enum blogic_bios_diskgeometry d1_geo:2;	/* Bits 2-3 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 		unsigned char:3;	/* Bits 4-6 */ | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 		bool ext_trans_enable:1;	/* Bit 7 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 	} gr; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the BusLogic SCSI Host Adapter Command Register Operation Codes. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 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 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the Inquire Board ID reply structure. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 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 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the Inquire Configuration reply structure. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | struct blogic_config { | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 	unsigned char:5;	/* Byte 0 Bits 0-4 */ | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	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 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 	unsigned char:1;	/* Byte 1 Bit 4 */ | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	bool irq_ch14:1;	/* Byte 1 Bit 5 */ | 
					
						
							|  |  |  | 	bool irq_ch15:1;	/* Byte 1 Bit 6 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 	unsigned char:1;	/* Byte 1 Bit 7 */ | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	unsigned char id:4;	/* Byte 2 Bits 0-3 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 	unsigned char:4;	/* Byte 2 Bits 4-7 */ | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the Inquire Setup Information reply structure. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | struct blogic_syncval { | 
					
						
							|  |  |  | 	unsigned char offset:4;		/* Bits 0-3 */ | 
					
						
							|  |  |  | 	unsigned char tx_period:3;	/* Bits 4-6 */ | 
					
						
							|  |  |  | 	bool sync:1;			/* Bit 7 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 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 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the Initialize Extended Mailbox request structure. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | struct blogic_extmbox_req { | 
					
						
							|  |  |  | 	unsigned char mbox_count;	/* Byte 0 */ | 
					
						
							|  |  |  | 	u32 base_mbox_addr;		/* Bytes 1-4 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } 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. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 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 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } PACKED; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 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 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the Inquire Extended Setup Information reply structure. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 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 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 	struct { | 
					
						
							|  |  |  | 		unsigned char:2;	/* Byte 9 Bits 0-1 */ | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 		bool fast_on_eisa:1;	/* Byte 9 Bit 2 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 		unsigned char:3;	/* Byte 9 Bits 3-5 */ | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 		bool level_int:1;	/* Byte 9 Bit 6 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 		unsigned char:1;	/* Byte 9 Bit 7 */ | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	} 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 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } PACKED; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the Enable Strict Round Robin Mode request type. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | enum blogic_rr_req { | 
					
						
							|  |  |  | 	BLOGIC_AGGRESSIVE_RR = 0, | 
					
						
							|  |  |  | 	BLOGIC_STRICT_RR_MODE = 1 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } PACKED; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the Fetch Host Adapter Local RAM request type. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | #define BLOGIC_BIOS_BASE		0
 | 
					
						
							|  |  |  | #define BLOGIC_AUTOSCSI_BASE		64
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | struct blogic_fetch_localram { | 
					
						
							|  |  |  | 	unsigned char offset;	/* Byte 0 */ | 
					
						
							|  |  |  | 	unsigned char count;	/* Byte 1 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the Host Adapter Local RAM AutoSCSI structure. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 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 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } PACKED; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the Host Adapter Local RAM Auto SCSI Byte 45 structure. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | struct blogic_autoscsi_byte45 { | 
					
						
							|  |  |  | 	unsigned char force_scan_order:1;	/* Bit 0 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 	unsigned char:7;	/* Bits 1-7 */ | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the Host Adapter Local RAM BIOS Drive Map Byte structure. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | #define BLOGIC_BIOS_DRVMAP		17
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 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 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the Set CCB Format request type.  Extended LUN Format CCBs are | 
					
						
							|  |  |  |   necessary to support more than 8 Logical Units per Target Device. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | enum blogic_setccb_fmt { | 
					
						
							|  |  |  | 	BLOGIC_LEGACY_LUN_CCB = 0, | 
					
						
							|  |  |  | 	BLOGIC_EXT_LUN_CCB = 1 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } PACKED; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the Outgoing Mailbox Action Codes. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | enum blogic_action { | 
					
						
							|  |  |  | 	BLOGIC_OUTBOX_FREE = 0x00, | 
					
						
							|  |  |  | 	BLOGIC_MBOX_START = 0x01, | 
					
						
							|  |  |  | 	BLOGIC_MBOX_ABORT = 0x02 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } 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. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 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 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } PACKED; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the Command Control Block (CCB) Opcodes. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 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 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } PACKED; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the CCB Data Direction Codes. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | enum blogic_datadir { | 
					
						
							|  |  |  | 	BLOGIC_UNCHECKED_TX = 0, | 
					
						
							|  |  |  | 	BLOGIC_DATAIN_CHECKED = 1, | 
					
						
							|  |  |  | 	BLOGIC_DATAOUT_CHECKED = 2, | 
					
						
							|  |  |  | 	BLOGIC_NOTX = 3 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the Host Adapter Status Codes.  The MultiMaster Firmware does not | 
					
						
							|  |  |  |   return status code 0x0C; it uses 0x12 for both overruns and underruns. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 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 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } PACKED; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the SCSI Target Device Status Codes. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | enum blogic_tgt_status { | 
					
						
							|  |  |  | 	BLOGIC_OP_GOOD = 0x00, | 
					
						
							|  |  |  | 	BLOGIC_CHECKCONDITION = 0x02, | 
					
						
							|  |  |  | 	BLOGIC_DEVBUSY = 0x08 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } PACKED; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the Queue Tag Codes. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | enum blogic_queuetag { | 
					
						
							|  |  |  | 	BLOGIC_SIMPLETAG = 0, | 
					
						
							|  |  |  | 	BLOGIC_HEADTAG = 1, | 
					
						
							|  |  |  | 	BLOGIC_ORDEREDTAG = 2, | 
					
						
							|  |  |  | 	BLOGIC_RSVDTAG = 3 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the SCSI Command Descriptor Block (CDB). | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | #define BLOGIC_CDB_MAXLEN			12
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the Scatter/Gather Segment structure required by the MultiMaster | 
					
						
							|  |  |  |   Firmware Interface and the FlashPoint SCCB Manager. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | struct blogic_sg_seg { | 
					
						
							|  |  |  | 	u32 segbytes;	/* Bytes 0-3 */ | 
					
						
							|  |  |  | 	u32 segdata;	/* Bytes 4-7 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the Driver CCB Status Codes. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | enum blogic_ccb_status { | 
					
						
							|  |  |  | 	BLOGIC_CCB_FREE = 0, | 
					
						
							|  |  |  | 	BLOGIC_CCB_ACTIVE = 1, | 
					
						
							|  |  |  | 	BLOGIC_CCB_COMPLETE = 2, | 
					
						
							|  |  |  | 	BLOGIC_CCB_RESET = 3 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } 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. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | struct blogic_ccb { | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 	/*
 | 
					
						
							|  |  |  | 	   MultiMaster Firmware and FlashPoint SCCB Manager Common Portion. | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	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 */ | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:14 -06:00
										 |  |  | 	void *data;					/* Bytes 8-11 */ | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	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 */ | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:14 -06:00
										 |  |  | 	u32 rsvd_int;					/* Bytes 32-35 */ | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	u32 sensedata;					/* Bytes 36-39 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 	/*
 | 
					
						
							|  |  |  | 	   FlashPoint SCCB Manager Defined Portion. | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	void (*callback) (struct blogic_ccb *);		/* Bytes 40-43 */ | 
					
						
							|  |  |  | 	u32 base_addr;					/* Bytes 44-47 */ | 
					
						
							|  |  |  | 	enum blogic_cmplt_code comp_code;		/* Byte 48 */ | 
					
						
							| 
									
										
										
										
											2008-03-13 06:55:08 -06:00
										 |  |  | #ifdef CONFIG_SCSI_FLASHPOINT
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	unsigned char:8;				/* Byte 49 */ | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:14 -06:00
										 |  |  | 	u16 os_flags;					/* Bytes 50-51 */ | 
					
						
							|  |  |  | 	unsigned char private[24];			/* Bytes 52-99 */ | 
					
						
							|  |  |  | 	void *rsvd1; | 
					
						
							|  |  |  | 	void *rsvd2; | 
					
						
							|  |  |  | 	unsigned char private2[16]; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 	/*
 | 
					
						
							|  |  |  | 	   BusLogic Linux Driver Defined Portion. | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	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]; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the 32 Bit Mode Outgoing Mailbox structure. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | struct blogic_outbox { | 
					
						
							|  |  |  | 	u32 ccb;			/* Bytes 0-3 */ | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:14 -06:00
										 |  |  | 	u32:24;				/* Bytes 4-6 */ | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	enum blogic_action action;	/* Byte 7 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the 32 Bit Mode Incoming Mailbox structure. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | struct blogic_inbox { | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:14 -06:00
										 |  |  | 	u32 ccb;					/* Bytes 0-3 */ | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	enum blogic_adapter_status adapter_status;	/* Byte 4 */ | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:14 -06:00
										 |  |  | 	enum blogic_tgt_status tgt_status;		/* Byte 5 */ | 
					
						
							|  |  |  | 	unsigned char:8;				/* Byte 6 */ | 
					
						
							|  |  |  | 	enum blogic_cmplt_code comp_code;		/* Byte 7 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the BusLogic Driver Options structure. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 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]; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the Host Adapter Target Flags structure. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 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; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the Host Adapter Target Statistics structure. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | #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; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the FlashPoint Card Handle data type. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:14 -06:00
										 |  |  | #define FPOINT_BADCARD_HANDLE		0xFFFFFFFFL
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the FlashPoint Information structure.  This structure is defined | 
					
						
							|  |  |  |   by the FlashPoint SCCB Manager. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 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 */ | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:14 -06:00
										 |  |  | 	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 */ | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	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 */ | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:14 -06:00
										 |  |  | 	u32 os_rsvd;				/* Bytes 32-35 */ | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	unsigned char translation_info[4];	/* Bytes 36-39 */ | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:14 -06:00
										 |  |  | 	u32 rsvd2[5];				/* Bytes 40-59 */ | 
					
						
							|  |  |  | 	u32 sec_range;				/* Bytes 60-63 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the BusLogic Driver Host Adapter structure. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 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; | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:14 -06:00
										 |  |  | 	void *cardhandle; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 	struct list_head host_list; | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	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]; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define a structure for the BIOS Disk Parameters. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | struct bios_diskparam { | 
					
						
							|  |  |  | 	int heads; | 
					
						
							|  |  |  | 	int sectors; | 
					
						
							|  |  |  | 	int cylinders; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define a structure for the SCSI Inquiry command results. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 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 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define functions to provide an abstraction for reading and writing the | 
					
						
							|  |  |  |   Host Adapter I/O Registers. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | static inline void blogic_busreset(struct blogic_adapter *adapter) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	union blogic_cntrl_reg cr; | 
					
						
							|  |  |  | 	cr.all = 0; | 
					
						
							|  |  |  | 	cr.cr.bus_reset = true; | 
					
						
							|  |  |  | 	outb(cr.all, adapter->io_addr + BLOGIC_CNTRL_REG); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | static inline void blogic_intreset(struct blogic_adapter *adapter) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	union blogic_cntrl_reg cr; | 
					
						
							|  |  |  | 	cr.all = 0; | 
					
						
							|  |  |  | 	cr.cr.int_reset = true; | 
					
						
							|  |  |  | 	outb(cr.all, adapter->io_addr + BLOGIC_CNTRL_REG); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | static inline void blogic_softreset(struct blogic_adapter *adapter) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	union blogic_cntrl_reg cr; | 
					
						
							|  |  |  | 	cr.all = 0; | 
					
						
							|  |  |  | 	cr.cr.soft_reset = true; | 
					
						
							|  |  |  | 	outb(cr.all, adapter->io_addr + BLOGIC_CNTRL_REG); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | static inline void blogic_hardreset(struct blogic_adapter *adapter) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	union blogic_cntrl_reg cr; | 
					
						
							|  |  |  | 	cr.all = 0; | 
					
						
							|  |  |  | 	cr.cr.hard_reset = true; | 
					
						
							|  |  |  | 	outb(cr.all, adapter->io_addr + BLOGIC_CNTRL_REG); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | static inline unsigned char blogic_rdstatus(struct blogic_adapter *adapter) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	return inb(adapter->io_addr + BLOGIC_STATUS_REG); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | static inline void blogic_setcmdparam(struct blogic_adapter *adapter, | 
					
						
							|  |  |  | 					unsigned char value) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	outb(value, adapter->io_addr + BLOGIC_CMD_PARM_REG); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | static inline unsigned char blogic_rddatain(struct blogic_adapter *adapter) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	return inb(adapter->io_addr + BLOGIC_DATAIN_REG); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | static inline unsigned char blogic_rdint(struct blogic_adapter *adapter) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	return inb(adapter->io_addr + BLOGIC_INT_REG); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | static inline unsigned char blogic_rdgeom(struct blogic_adapter *adapter) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	return inb(adapter->io_addr + BLOGIC_GEOMETRY_REG); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  |   blogic_execmbox issues an Execute Mailbox Command, which | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  |   notifies the Host Adapter that an entry has been made in an Outgoing | 
					
						
							|  |  |  |   Mailbox. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | static inline void blogic_execmbox(struct blogic_adapter *adapter) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	blogic_setcmdparam(adapter, BLOGIC_EXEC_MBOX_CMD); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  |   blogic_delay waits for Seconds to elapse. | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | static inline void blogic_delay(int seconds) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	mdelay(1000 * seconds); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  |   virt_to_32bit_virt maps between Kernel Virtual Addresses and | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  |   32 bit Kernel Virtual Addresses.  This avoids compilation warnings | 
					
						
							|  |  |  |   on 64 bit architectures. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | static inline u32 virt_to_32bit_virt(void *virt_addr) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	return (u32) (unsigned long) virt_addr; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  |   blogic_inc_count increments counter by 1, stopping at | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  |   65535 rather than wrapping around to 0. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | static inline void blogic_inc_count(unsigned short *count) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	if (*count < 65535) | 
					
						
							|  |  |  | 		(*count)++; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  |   blogic_addcount increments Byte Counter by Amount. | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | static inline void blogic_addcount(struct blogic_byte_count *bytecount, | 
					
						
							|  |  |  | 					unsigned int amount) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	bytecount->units += amount; | 
					
						
							|  |  |  | 	if (bytecount->units > 999999999) { | 
					
						
							|  |  |  | 		bytecount->units -= 1000000000; | 
					
						
							|  |  |  | 		bytecount->billions++; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  |   blogic_incszbucket increments the Bucket for Amount. | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | static inline void blogic_incszbucket(unsigned int *cmdsz_buckets, | 
					
						
							|  |  |  | 					unsigned int amount) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 	int index = 0; | 
					
						
							|  |  |  | 	if (amount < 8 * 1024) { | 
					
						
							|  |  |  | 		if (amount < 2 * 1024) | 
					
						
							|  |  |  | 			index = (amount < 1 * 1024 ? 0 : 1); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 		else | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 			index = (amount < 4 * 1024 ? 2 : 3); | 
					
						
							|  |  |  | 	} else if (amount < 128 * 1024) { | 
					
						
							|  |  |  | 		if (amount < 32 * 1024) | 
					
						
							|  |  |  | 			index = (amount < 16 * 1024 ? 4 : 5); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 		else | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 			index = (amount < 64 * 1024 ? 6 : 7); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 	} else | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 		index = (amount < 256 * 1024 ? 8 : 9); | 
					
						
							|  |  |  | 	cmdsz_buckets[index]++; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the version number of the FlashPoint Firmware (SCCB Manager). | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | #define FLASHPOINT_FW_VER		"5.02"
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define the possible return values from FlashPoint_HandleInterrupt. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | #define FPOINT_NORMAL_INT		0x00
 | 
					
						
							|  |  |  | #define FPOINT_INTERN_ERR		0xFE
 | 
					
						
							|  |  |  | #define FPOINT_EXT_RESET		0xFF
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Define prototypes for the forward referenced BusLogic Driver | 
					
						
							|  |  |  |   Internal Functions. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-16 19:44:13 -06:00
										 |  |  | 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 *); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | #endif				/* _BUSLOGIC_H */
 |