aha1542.h
上传用户:lgb322
上传日期:2013-02-24
资源大小:30529k
文件大小:6k
源码类别:

嵌入式Linux

开发平台:

Unix_Linux

  1. #ifndef _AHA1542_H
  2. /* $Id: aha1542.h,v 1.1 1992/07/24 06:27:38 root Exp root $
  3.  *
  4.  * Header file for the adaptec 1542 driver for Linux
  5.  *
  6.  * $Log: aha1542.h,v $
  7.  * Revision 1.1  1992/07/24  06:27:38  root
  8.  * Initial revision
  9.  *
  10.  * Revision 1.2  1992/07/04  18:41:49  root
  11.  * Replaced distribution with current drivers
  12.  *
  13.  * Revision 1.3  1992/06/23  23:58:20  root
  14.  * Fixes.
  15.  *
  16.  * Revision 1.2  1992/05/26  22:13:23  root
  17.  * Changed bug that prevented DMA above first 2 mbytes.
  18.  *
  19.  * Revision 1.1  1992/05/22  21:00:29  root
  20.  * Initial revision
  21.  *
  22.  * Revision 1.1  1992/04/24  18:01:50  root
  23.  * Initial revision
  24.  *
  25.  * Revision 1.1  1992/04/02  03:23:13  drew
  26.  * Initial revision
  27.  *
  28.  * Revision 1.3  1992/01/27  14:46:29  tthorn
  29.  * *** empty log message ***
  30.  *
  31.  */
  32. #include <linux/types.h>
  33. #include <linux/kdev_t.h>
  34. /* I/O Port interface 4.2 */
  35. /* READ */
  36. #define STATUS(base) base
  37. #define STST 0x80 /* Self Test in Progress */
  38. #define DIAGF 0x40 /* Internal Diagnostic Failure */
  39. #define INIT 0x20 /* Mailbox Initialization Required */
  40. #define IDLE 0x10 /* SCSI Host Adapter Idle */
  41. #define CDF 0x08 /* Command/Data Out Port Full */
  42. #define DF 0x04 /* Data In Port Full */
  43. #define INVDCMD 0x01 /* Invalid H A Command */
  44. #define STATMASK 0xfd /* 0x02 is reserved */
  45. #define INTRFLAGS(base) (STATUS(base)+2)
  46. #define ANYINTR 0x80 /* Any Interrupt */
  47. #define SCRD 0x08 /* SCSI Reset Detected */
  48. #define HACC 0x04 /* HA Command Complete */
  49. #define MBOA 0x02 /* MBO Empty */
  50. #define MBIF 0x01 /* MBI Full */
  51. #define INTRMASK 0x8f
  52. /* WRITE */
  53. #define CONTROL(base) STATUS(base)
  54. #define HRST 0x80 /* Hard Reset */
  55. #define SRST 0x40 /* Soft Reset */
  56. #define IRST 0x20 /* Interrupt Reset */
  57. #define SCRST 0x10 /* SCSI Bus Reset */
  58. /* READ/WRITE */
  59. #define DATA(base) (STATUS(base)+1)
  60. #define CMD_NOP 0x00 /* No Operation */
  61. #define CMD_MBINIT 0x01 /* Mailbox Initialization */
  62. #define CMD_START_SCSI 0x02 /* Start SCSI Command */
  63. #define CMD_INQUIRY 0x04 /* Adapter Inquiry */
  64. #define CMD_EMBOI 0x05 /* Enable MailBox Out Interrupt */
  65. #define CMD_BUSON_TIME 0x07 /* Set Bus-On Time */
  66. #define CMD_BUSOFF_TIME 0x08 /* Set Bus-Off Time */
  67. #define CMD_DMASPEED 0x09 /* Set AT Bus Transfer Speed */
  68. #define CMD_RETDEVS 0x0a /* Return Installed Devices */
  69. #define CMD_RETCONF 0x0b /* Return Configuration Data */
  70. #define CMD_RETSETUP 0x0d /* Return Setup Data */
  71. #define CMD_ECHO 0x1f /* ECHO Command Data */
  72. #define CMD_EXTBIOS     0x28    /* Return extend bios information only 1542C */
  73. #define CMD_MBENABLE    0x29    /* Set Mailbox Interface enable only 1542C */
  74. /* Mailbox Definition 5.2.1 and 5.2.2 */
  75. struct mailbox {
  76.   unchar status; /* Command/Status */
  77.   unchar ccbptr[3]; /* msb, .., lsb */
  78. };
  79. /* This is used with scatter-gather */
  80. struct chain {
  81.   unchar datalen[3]; /* Size of this part of chain */
  82.   unchar dataptr[3]; /* Location of data */
  83. };
  84. /* These belong in scsi.h also */
  85. #define any2scsi(up, p)
  86. (up)[0] = (((unsigned long)(p)) >> 16)  ;
  87. (up)[1] = (((unsigned long)(p)) >> 8);
  88. (up)[2] = ((unsigned long)(p));
  89. #define scsi2int(up) ( (((long)*(up)) << 16) + (((long)(up)[1]) << 8) + ((long)(up)[2]) )
  90. #define xany2scsi(up, p)
  91. (up)[0] = ((long)(p)) >> 24;
  92. (up)[1] = ((long)(p)) >> 16;
  93. (up)[2] = ((long)(p)) >> 8;
  94. (up)[3] = ((long)(p));
  95. #define xscsi2int(up) ( (((long)(up)[0]) << 24) + (((long)(up)[1]) << 16) 
  96.       + (((long)(up)[2]) <<  8) +  ((long)(up)[3]) )
  97. #define MAX_CDB 12
  98. #define MAX_SENSE 14
  99. struct ccb { /* Command Control Block 5.3 */
  100.   unchar op; /* Command Control Block Operation Code */
  101.   unchar idlun; /* op=0,2:Target Id, op=1:Initiator Id */
  102. /* Outbound data transfer, length is checked*/
  103. /* Inbound data transfer, length is checked */
  104. /* Logical Unit Number */
  105.   unchar cdblen; /* SCSI Command Length */
  106.   unchar rsalen; /* Request Sense Allocation Length/Disable */
  107.   unchar datalen[3]; /* Data Length (msb, .., lsb) */
  108.   unchar dataptr[3]; /* Data Pointer */
  109.   unchar linkptr[3]; /* Link Pointer */
  110.   unchar commlinkid; /* Command Linking Identifier */
  111.   unchar hastat; /* Host Adapter Status (HASTAT) */
  112.   unchar tarstat; /* Target Device Status */
  113.   unchar reserved[2];
  114.   unchar cdb[MAX_CDB+MAX_SENSE];/* SCSI Command Descriptor Block */
  115. /* REQUEST SENSE */
  116. };
  117. static int aha1542_detect(Scsi_Host_Template *);
  118. static int aha1542_command(Scsi_Cmnd *);
  119. static int aha1542_queuecommand(Scsi_Cmnd *, void (*done)(Scsi_Cmnd *));
  120. static int aha1542_abort(Scsi_Cmnd * SCpnt);
  121. static int aha1542_bus_reset(Scsi_Cmnd * SCpnt);
  122. static int aha1542_dev_reset(Scsi_Cmnd * SCpnt);
  123. static int aha1542_host_reset(Scsi_Cmnd * SCpnt);
  124. static int aha1542_old_abort(Scsi_Cmnd * SCpnt);
  125. static int aha1542_old_reset(Scsi_Cmnd *, unsigned int);
  126. static int aha1542_biosparam(Disk *, kdev_t, int*);
  127. #define AHA1542_MAILBOXES 8
  128. #define AHA1542_SCATTER 16
  129. #define AHA1542_CMDLUN 1
  130. #ifndef NULL
  131. #define NULL 0
  132. #endif
  133. #define AHA1542 {    proc_name: "aha1542",
  134.      name: "Adaptec 1542", 
  135.      detect: aha1542_detect,
  136.      command: aha1542_command,
  137.      queuecommand: aha1542_queuecommand,
  138.                      abort:         aha1542_old_abort,
  139.                      reset: aha1542_old_reset,
  140.      eh_abort_handler: aha1542_abort,
  141.      eh_device_reset_handler: aha1542_dev_reset,
  142.      eh_bus_reset_handler: aha1542_bus_reset,
  143.      eh_host_reset_handler: aha1542_host_reset,
  144.      bios_param: aha1542_biosparam,      
  145.      can_queue: AHA1542_MAILBOXES, 
  146.      this_id: 7, 
  147.      sg_tablesize: AHA1542_SCATTER, 
  148.      cmd_per_lun: AHA1542_CMDLUN, 
  149.      unchecked_isa_dma: 1, 
  150.      use_clustering: ENABLE_CLUSTERING,
  151.      use_new_eh_code: 1}
  152. #endif