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

嵌入式Linux

开发平台:

Unix_Linux

  1. /*
  2.  *  linux/drivers/message/fusion/mptbase.h
  3.  *      High performance SCSI + LAN / Fibre Channel device drivers.
  4.  *      For use with PCI chip/adapter(s):
  5.  *          LSIFC9xx/LSI409xx Fibre Channel
  6.  *      running LSI Logic Fusion MPT (Message Passing Technology) firmware.
  7.  *
  8.  *  Credits:
  9.  *     (see mptbase.c)
  10.  *
  11.  *  Copyright (c) 1999-2001 LSI Logic Corporation
  12.  *  Originally By: Steven J. Ralston
  13.  *  (mailto:Steve.Ralston@lsil.com)
  14.  *
  15.  *  $Id: mptbase.h,v 1.46.2.2.2.2 2001/09/18 03:22:29 sralston Exp $
  16.  */
  17. /*=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=*/
  18. /*
  19.     This program is free software; you can redistribute it and/or modify
  20.     it under the terms of the GNU General Public License as published by
  21.     the Free Software Foundation; version 2 of the License.
  22.     This program is distributed in the hope that it will be useful,
  23.     but WITHOUT ANY WARRANTY; without even the implied warranty of
  24.     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  25.     GNU General Public License for more details.
  26.     NO WARRANTY
  27.     THE PROGRAM IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OR
  28.     CONDITIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED INCLUDING, WITHOUT
  29.     LIMITATION, ANY WARRANTIES OR CONDITIONS OF TITLE, NON-INFRINGEMENT,
  30.     MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Each Recipient is
  31.     solely responsible for determining the appropriateness of using and
  32.     distributing the Program and assumes all risks associated with its
  33.     exercise of rights under this Agreement, including but not limited to
  34.     the risks and costs of program errors, damage to or loss of data,
  35.     programs or equipment, and unavailability or interruption of operations.
  36.     DISCLAIMER OF LIABILITY
  37.     NEITHER RECIPIENT NOR ANY CONTRIBUTORS SHALL HAVE ANY LIABILITY FOR ANY
  38.     DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  39.     DAMAGES (INCLUDING WITHOUT LIMITATION LOST PROFITS), HOWEVER CAUSED AND
  40.     ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
  41.     TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
  42.     USE OR DISTRIBUTION OF THE PROGRAM OR THE EXERCISE OF ANY RIGHTS GRANTED
  43.     HEREUNDER, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGES
  44.     You should have received a copy of the GNU General Public License
  45.     along with this program; if not, write to the Free Software
  46.     Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
  47. */
  48. #ifndef MPTBASE_H_INCLUDED
  49. #define MPTBASE_H_INCLUDED
  50. /*{-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=*/
  51. #include "linux_compat.h" /* linux-2.2.x (vs. -2.4.x) tweaks */
  52. #include "lsi/mpi_type.h"
  53. #include "lsi/mpi.h" /* Fusion MPI(nterface) basic defs */
  54. #include "lsi/mpi_ioc.h" /* Fusion MPT IOC(ontroller) defs */
  55. #include "lsi/mpi_cnfg.h" /* IOC configuration support */
  56. #include "lsi/mpi_init.h" /* SCSI Host (initiator) protocol support */
  57. #include "lsi/mpi_lan.h" /* LAN over FC protocol support */
  58. #include "lsi/mpi_fc.h" /* Fibre Channel (lowlevel) support */
  59. #include "lsi/mpi_targ.h" /* SCSI/FCP Target protcol support */
  60. #include "lsi/fc_log.h"
  61. /*=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=*/
  62. #ifndef MODULEAUTHOR
  63. #define MODULEAUTHOR "LSI Logic Corporation"
  64. #endif
  65. #ifndef COPYRIGHT
  66. #define COPYRIGHT "Copyright (c) 1999-2001 " MODULEAUTHOR
  67. #endif
  68. #define MPT_LINUX_VERSION_COMMON "1.02.02"
  69. #define MPT_LINUX_PACKAGE_NAME "@(#)mptlinux-1.02.02"
  70. #define WHAT_MAGIC_STRING "@" "(" "#" ")"
  71. #define show_mptmod_ver(s,ver)  
  72. printk(KERN_INFO "%s %sn", s, ver);
  73. /*=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=*/
  74. /*
  75.  *  Fusion MPT(linux) driver configurable stuff...
  76.  */
  77. #define MPT_MAX_ADAPTERS 16
  78. #define MPT_MAX_PROTOCOL_DRIVERS 8
  79. #define MPT_MAX_FC_DEVICES 255
  80. #define MPT_MISCDEV_BASENAME "mptctl"
  81. #define MPT_MISCDEV_PATHNAME "/dev/" MPT_MISCDEV_BASENAME
  82. #define MPT_PROCFS_MPTBASEDIR "mpt"
  83. /* chg it to "driver/fusion" ? */
  84. #define MPT_PROCFS_SUMMARY_NODE MPT_PROCFS_MPTBASEDIR "/summary"
  85. #define MPT_PROCFS_SUMMARY_PATHNAME "/proc/" MPT_PROCFS_SUMMARY_NODE
  86. #define MPT_FW_REV_MAGIC_ID_STRING "FwRev="
  87. #ifdef __KERNEL__ /* { */
  88. #define  MPT_MAX_REQ_DEPTH 1023
  89. #define  MPT_REQ_DEPTH 256
  90. #define  MPT_MIN_REQ_DEPTH 128
  91. #define  MPT_MAX_REPLY_DEPTH MPT_MAX_REQ_DEPTH
  92. #define  MPT_REPLY_DEPTH 128
  93. #define  MPT_MIN_REPLY_DEPTH 8
  94. #define  MPT_MAX_REPLIES_PER_ISR 32
  95. #define  MPT_MAX_FRAME_SIZE 128
  96. #define  MPT_REQ_SIZE 128
  97. #define  MPT_REPLY_SIZE 128
  98. #define  MPT_SG_BUCKETS_PER_HUNK 1
  99. #ifdef MODULE
  100. #define  MPT_REQ_DEPTH_RANGE_STR __MODULE_STRING(MPT_MIN_REQ_DEPTH) "-" __MODULE_STRING(MPT_MAX_REQ_DEPTH)
  101. #define  MPT_REPLY_DEPTH_RANGE_STR __MODULE_STRING(MPT_MIN_REPLY_DEPTH) "-" __MODULE_STRING(MPT_MAX_REPLY_DEPTH)
  102. #define  MPT_REPLY_SIZE_RANGE_STR __MODULE_STRING(MPT_MIN_REPLY_SIZE) "-" __MODULE_STRING(MPT_MAX_FRAME_SIZE)
  103. #endif
  104. /*=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=*/
  105. /*
  106.  *  MPT protocol driver defs...
  107.  */
  108. typedef enum {
  109. MPTBASE_DRIVER, /* MPT base class */
  110. MPTCTL_DRIVER, /* MPT ioctl class */
  111. MPTSCSIH_DRIVER, /* MPT SCSI host (initiator) class */
  112. MPTLAN_DRIVER, /* MPT LAN class */
  113. MPTSTM_DRIVER, /* MPT SCSI target mode class */
  114. MPTUNKNOWN_DRIVER
  115. } MPT_DRIVER_CLASS;
  116. /*
  117.  *  MPT adapter / port / bus / device info structures...
  118.  */
  119. typedef union _MPT_FRAME_TRACKER {
  120. struct {
  121. struct _MPT_FRAME_HDR *forw;
  122. struct _MPT_FRAME_HDR *back;
  123. u32  arg1;
  124. void *argp1;
  125. } linkage;
  126. /*
  127.  * NOTE: On non-32-bit systems, where pointers are LARGE,
  128.  * using the linkage pointers destroys our sacred MsgContext
  129.  * field contents.  But we don't care anymore because these
  130.  * are now reset in mpt_put_msg_frame() just prior to sending
  131.  * a request off to the IOC.
  132.  */
  133. struct {
  134. u32 __hdr[2];
  135. /*
  136.  * The following _MUST_ match the location of the
  137.  * MsgContext field in the MPT message headers.
  138.  */
  139. union {
  140. u32  MsgContext;
  141. struct {
  142. u16  req_idx; /* Request index */
  143. u8  cb_idx; /* callback function index */
  144. u8  rsvd;
  145. } fld;
  146. } msgctxu;
  147. } hwhdr;
  148. } MPT_FRAME_TRACKER;
  149. /*
  150.  *  We might want to view/access a frame as:
  151.  *    1) generic request header
  152.  *    2) SCSIIORequest
  153.  *    3) SCSIIOReply
  154.  *    4) MPIDefaultReply
  155.  *    5) frame tracker
  156.  */
  157. typedef struct _MPT_FRAME_HDR {
  158. union {
  159. MPIHeader_t hdr;
  160. SCSIIORequest_t scsireq;
  161. SCSIIOReply_t sreply;
  162. MPIDefaultReply_t reply;
  163. MPT_FRAME_TRACKER frame;
  164. } u;
  165. } MPT_FRAME_HDR;
  166. typedef struct _MPT_Q_TRACKER {
  167. MPT_FRAME_HDR *head;
  168. MPT_FRAME_HDR *tail;
  169. } MPT_Q_TRACKER;
  170. typedef struct _MPT_SGL_HDR {
  171. SGESimple32_t  sge[1];
  172. } MPT_SGL_HDR;
  173. typedef struct _MPT_SGL64_HDR {
  174. SGESimple64_t  sge[1];
  175. } MPT_SGL64_HDR;
  176. typedef struct _Q_ITEM {
  177. struct _Q_ITEM *forw;
  178. struct _Q_ITEM *back;
  179. } Q_ITEM;
  180. typedef struct _Q_TRACKER {
  181. struct _Q_ITEM *head;
  182. struct _Q_ITEM *tail;
  183. } Q_TRACKER;
  184. /*
  185.  *  Chip-specific stuff...
  186.  */
  187. typedef enum {
  188. FC909 = 0x0909,
  189. FC919 = 0x0919,
  190. FC929 = 0x0929,
  191. C1030 = 0x1030,
  192. FCUNK = 0xFBAD
  193. } CHIP_TYPE;
  194. /*
  195.  *  System interface register set
  196.  */
  197. typedef struct _SYSIF_REGS
  198. {
  199. u32 Doorbell; /* 00     System<->IOC Doorbell reg  */
  200. u32 WriteSequence; /* 04     Write Sequence register    */
  201. u32 Diagnostic; /* 08     Diagnostic register        */
  202. u32 TestBase; /* 0C     Test Base Address          */
  203. u32 Reserved1[8]; /* 10-2F  reserved for future use    */
  204. u32 IntStatus; /* 30     Interrupt Status           */
  205. u32 IntMask; /* 34     Interrupt Mask             */
  206. u32 Reserved2[2]; /* 38-3F  reserved for future use    */
  207. u32 RequestFifo; /* 40     Request Post/Free FIFO     */
  208. u32 ReplyFifo; /* 44     Reply   Post/Free FIFO     */
  209. u32 Reserved3[2]; /* 48-4F  reserved for future use    */
  210. u32 HostIndex; /* 50     Host Index register        */
  211. u32 Reserved4[15]; /* 54-8F                             */
  212. u32 Fubar; /* 90     For Fubar usage            */
  213. u32 Reserved5[27]; /* 94-FF                             */
  214. } SYSIF_REGS;
  215. /*
  216.  * NOTE: Use MPI_{DOORBELL,WRITESEQ,DIAG}_xxx defs in lsi/mpi.h
  217.  * in conjunction with SYSIF_REGS accesses!
  218.  */
  219. typedef struct _MPT_ADAPTER
  220. {
  221. struct _MPT_ADAPTER *forw;
  222. struct _MPT_ADAPTER *back;
  223. int  id; /* Unique adapter id {0,1,2,...} */
  224. int  pci_irq;
  225. char  name[32]; /* "iocN"             */
  226. char *prod_name; /* "LSIFC9x9"         */
  227. u32  mem_phys; /* == f4020000 (mmap) */
  228. volatile SYSIF_REGS *chip; /* == c8817000 (mmap) */
  229. CHIP_TYPE  chip_type;
  230. int  mem_size;
  231. int  alloc_total;
  232. u32  last_state;
  233. int  active;
  234. int  sod_reset;
  235. unsigned long  last_kickstart;
  236. u8 *reply_alloc; /* Reply frames alloc ptr */
  237. dma_addr_t  reply_alloc_dma;
  238. MPT_FRAME_HDR *reply_frames; /* Reply frames - rounded up! */
  239. dma_addr_t  reply_frames_dma;
  240. int  reply_depth;
  241. int  reply_sz;
  242. /* We (host driver) get to manage our own RequestQueue! */
  243. u8 *req_alloc; /* Request frames alloc ptr */
  244. dma_addr_t  req_alloc_dma;
  245. MPT_FRAME_HDR *req_frames; /* Request msg frames for PULL mode! */
  246. dma_addr_t  req_frames_dma;
  247. int  req_depth;
  248. int  req_sz;
  249. MPT_Q_TRACKER  FreeQ;
  250. spinlock_t  FreeQlock;
  251. /* Pool of SCSI sense buffers for commands coming from
  252.  * the SCSI mid-layer.  We have one 256 byte sense buffer
  253.  * for each REQ entry.
  254.  */
  255. u8 *sense_buf_pool;
  256. dma_addr_t  sense_buf_pool_dma;
  257. struct pci_dev *pcidev;
  258. /* atomic_t  userCnt; */
  259. u8 *memmap;
  260. int  mtrr_reg;
  261. struct Scsi_Host *sh;
  262. struct proc_dir_entry *ioc_dentry;
  263. struct _MPT_ADAPTER *alt_ioc;
  264. int  hs_reply_idx;
  265. u32  hs_req[MPT_MAX_FRAME_SIZE/sizeof(u32)];
  266. u16  hs_reply[MPT_MAX_FRAME_SIZE/sizeof(u16)];
  267. IOCFactsReply_t  facts;
  268. PortFactsReply_t  pfacts[2];
  269. LANPage0_t  lan_cnfg_page0;
  270. LANPage1_t  lan_cnfg_page1;
  271. u8  FirstWhoInit;
  272. u8  pad1[3];
  273. } MPT_ADAPTER;
  274. typedef struct _MPT_ADAPTER_TRACKER {
  275. MPT_ADAPTER *head;
  276. MPT_ADAPTER *tail;
  277. } MPT_ADAPTER_TRACKER;
  278. /*
  279.  *  New return value convention:
  280.  *    1 = Ok to free associated request frame
  281.  *    0 = not Ok ...
  282.  */
  283. typedef int (*MPT_CALLBACK)(MPT_ADAPTER *ioc, MPT_FRAME_HDR *req, MPT_FRAME_HDR *reply);
  284. typedef int (*MPT_EVHANDLER)(MPT_ADAPTER *ioc, EventNotificationReply_t *evReply);
  285. typedef int (*MPT_RESETHANDLER)(MPT_ADAPTER *ioc, int reset_phase);
  286. /* reset_phase defs */
  287. #define MPT_IOC_PRE_RESET 0
  288. #define MPT_IOC_POST_RESET 1
  289. /*
  290.  * Invent MPT host event (super-set of MPI Events)
  291.  * Fitted to 1030's 64-byte [max] request frame size
  292.  */
  293. typedef struct _MPT_HOST_EVENT {
  294. EventNotificationReply_t  MpiEvent; /* 8 32-bit words! */
  295. u32  pad[6];
  296. void *next;
  297. } MPT_HOST_EVENT;
  298. #define MPT_HOSTEVENT_IOC_BRINGUP 0x91
  299. #define MPT_HOSTEVENT_IOC_RECOVER 0x92
  300. /*=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=*/
  301. /*
  302.  *  Funky (private) macros...
  303.  */
  304. #ifdef MPT_DEBUG
  305. #define dprintk(x)  printk x
  306. #else
  307. #define dprintk(x)
  308. #endif
  309. #ifdef MPT_DEBUG_HANDSHAKE
  310. #define dhsprintk(x)  printk x
  311. #else
  312. #define dhsprintk(x)
  313. #endif
  314. #if defined(MPT_DEBUG) || defined(MPT_DEBUG_MSG_FRAME)
  315. #define dmfprintk(x)  printk x
  316. #else
  317. #define dmfprintk(x)
  318. #endif
  319. #ifdef MPT_DEBUG_IRQ
  320. #define dirqprintk(x)  printk x
  321. #else
  322. #define dirqprintk(x)
  323. #endif
  324. #ifdef MPT_DEBUG_EVENTS
  325. #define deventprintk(x)  printk x
  326. #else
  327. #define deventprintk(x)
  328. #endif
  329. #ifdef MPT_DEBUG_SPINLOCK
  330. #define dslprintk(x)  printk x
  331. #else
  332. #define dslprintk(x)
  333. #endif
  334. #ifdef MPT_DEBUG_SG
  335. #define dsgprintk(x)  printk x
  336. #else
  337. #define dsgprintk(x)
  338. #endif
  339. #define MPT_INDEX_2_MFPTR(ioc,idx) 
  340. (MPT_FRAME_HDR*)( (u8*)(ioc)->req_frames + (ioc)->req_sz * (idx) )
  341. #define MFPTR_2_MPT_INDEX(ioc,mf) 
  342. (int)( ((u8*)mf - (u8*)(ioc)->req_frames) / (ioc)->req_sz )
  343. #define Q_INIT(q,type)  (q)->head = (q)->tail = (type*)(q)
  344. #define Q_IS_EMPTY(q)   ((Q_ITEM*)(q)->head == (Q_ITEM*)(q))
  345. #define Q_ADD_TAIL(qt,i,type) { 
  346. Q_TRACKER *_qt = (Q_TRACKER*)(qt); 
  347. Q_ITEM *oldTail = _qt->tail; 
  348. (i)->forw = (type*)_qt; 
  349. (i)->back = (type*)oldTail; 
  350. oldTail->forw = (Q_ITEM*)(i); 
  351. _qt->tail = (Q_ITEM*)(i); 
  352. }
  353. #define Q_ADD_HEAD(qt,i,type) { 
  354. Q_TRACKER *_qt = (Q_TRACKER*)(qt); 
  355. Q_ITEM *oldHead = _qt->head; 
  356. (i)->forw = (type*)oldHead; 
  357. (i)->back = (type*)_qt; 
  358. oldHead->back = (Q_ITEM*)(i); 
  359. _qt->head = (Q_ITEM*)(i); 
  360. }
  361. #define Q_DEL_ITEM(i) { 
  362. Q_ITEM  *_forw = (Q_ITEM*)(i)->forw; 
  363. Q_ITEM  *_back = (Q_ITEM*)(i)->back; 
  364. _back->forw = _forw; 
  365. _forw->back = _back; 
  366. }
  367. #define SWAB4(value) 
  368. (u32)(   (((value) & 0x000000ff) << 24) 
  369.        | (((value) & 0x0000ff00) << 8)  
  370.        | (((value) & 0x00ff0000) >> 8)  
  371.        | (((value) & 0xff000000) >> 24) )
  372. #if defined(MPT_DEBUG) || defined(MPT_DEBUG_MSG_FRAME)
  373. #define DBG_DUMP_REPLY_FRAME(mfp) 
  374. { u32 *m = (u32 *)(mfp);
  375. int  i, n = (le32_to_cpu(m[0]) & 0x00FF0000) >> 16;
  376. printk(KERN_INFO " ");
  377. for (i=0; i<n; i++)
  378. printk(" %08x", le32_to_cpu(m[i]));
  379. printk("n");
  380. }
  381. #define DBG_DUMP_REQUEST_FRAME_HDR(mfp) 
  382. { int  i, n = 3;
  383. u32 *m = (u32 *)(mfp);
  384. printk(KERN_INFO " ");
  385. for (i=0; i<n; i++)
  386. printk(" %08x", le32_to_cpu(m[i]));
  387. printk("n");
  388. }
  389. #else
  390. #define DBG_DUMP_REPLY_FRAME(mfp)
  391. #define DBG_DUMP_REQUEST_FRAME_HDR(mfp)
  392. #endif
  393. /*=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=*/
  394. #endif /* } __KERNEL__ */
  395. /*=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=*/
  396. /*
  397.  *  MPT Control IOCTLs and structures
  398.  */
  399. #define MPT_MAGIC_NUMBER 'm'
  400. #define MPTRWPERF _IOWR(MPT_MAGIC_NUMBER,0,struct mpt_raw_r_w)
  401. #define MPTRWPERF_CHK _IOR(MPT_MAGIC_NUMBER,13,struct mpt_raw_r_w)
  402. #define MPTRWPERF_RESET _IOR(MPT_MAGIC_NUMBER,14,struct mpt_raw_r_w)
  403. #define MPTFWDOWNLOAD _IOWR(MPT_MAGIC_NUMBER,15,struct mpt_fw_xfer)
  404. #define MPTSCSICMD _IOWR(MPT_MAGIC_NUMBER,16,struct mpt_scsi_cmd)
  405. /*
  406.  *  Define something *vague* enough that caller doesn't
  407.  *  really need to know anything about device parameters
  408.  *  (blk_size, capacity, etc.)
  409.  */
  410. struct mpt_raw_r_w {
  411. unsigned int  iocnum; /* IOC unit number */
  412. unsigned int  port; /* IOC port number */
  413. unsigned int  target; /* SCSI Target */
  414. unsigned int  lun; /* SCSI LUN */
  415. unsigned int  iters; /* N iterations */
  416. unsigned short  nblks; /* number of blocks per IO */
  417. unsigned short  qdepth; /* max Q depth on this device */
  418. unsigned char  range; /* 0-100% of FULL disk capacity, 0=use (nblks X iters) */
  419. unsigned char  skip; /* % of disk to skip */
  420. unsigned char  rdwr; /* 0-100%, 0=pure ReaDs, 100=pure WRites */
  421. unsigned char  seqran; /* 0-100%, 0=pure SEQential, 100=pure RANdom */
  422. unsigned int  cache_sz; /* In Kb!  Optimize hits to N Kb cache size */
  423. };
  424. struct mpt_fw_xfer {
  425. unsigned int  iocnum; /* IOC unit number */
  426. /* u8  flags;*/ /* Message flags - bit field */
  427. unsigned int  fwlen;
  428. void *bufp; /* Pointer to firmware buffer */
  429. };
  430. struct mpt_scsi_cmd {
  431. unsigned int  iocnum; /* IOC unit number */
  432. unsigned int  port; /* IOC port number */
  433. unsigned int  target; /* SCSI Target */
  434. unsigned int  lun; /* SCSI LUN */
  435. SCSIIORequest_t  scsi_req;
  436. SCSIIOReply_t  scsi_reply;
  437. };
  438. struct mpt_ioctl_sanity {
  439. unsigned int  iocnum;
  440. };
  441. #ifdef __KERNEL__ /* { */
  442. /*=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=*/
  443. /*
  444.  *  Public entry points...
  445.  */
  446. extern int  mpt_register(MPT_CALLBACK cbfunc, MPT_DRIVER_CLASS dclass);
  447. extern void  mpt_deregister(int cb_idx);
  448. extern int  mpt_event_register(int cb_idx, MPT_EVHANDLER ev_cbfunc);
  449. extern void  mpt_event_deregister(int cb_idx);
  450. extern int  mpt_reset_register(int cb_idx, MPT_RESETHANDLER reset_func);
  451. extern void  mpt_reset_deregister(int cb_idx);
  452. extern int  mpt_register_ascqops_strings(/*ASCQ_Table_t*/void *ascqTable, int ascqtbl_sz, const char **opsTable);
  453. extern void  mpt_deregister_ascqops_strings(void);
  454. extern MPT_FRAME_HDR *mpt_get_msg_frame(int handle, int iocid);
  455. extern void  mpt_free_msg_frame(int handle, int iocid, MPT_FRAME_HDR *mf);
  456. extern void  mpt_put_msg_frame(int handle, int iocid, MPT_FRAME_HDR *mf);
  457. extern int  mpt_send_handshake_request(int handle, int iocid, int reqBytes, u32 *req);
  458. extern int  mpt_verify_adapter(int iocid, MPT_ADAPTER **iocpp);
  459. extern MPT_ADAPTER *mpt_adapter_find_first(void);
  460. extern MPT_ADAPTER *mpt_adapter_find_next(MPT_ADAPTER *prev);
  461. extern void  mpt_print_ioc_summary(MPT_ADAPTER *ioc, char *buf, int *size, int len, int showlan);
  462. extern void  mpt_print_ioc_facts(MPT_ADAPTER *ioc, char *buf, int *size, int len);
  463. /*
  464.  *  Public data decl's...
  465.  */
  466. extern int   mpt_lan_index; /* needed by mptlan.c */
  467. extern int   mpt_stm_index; /* needed by mptstm.c */
  468. extern void  *mpt_v_ASCQ_TablePtr;
  469. extern const char **mpt_ScsiOpcodesPtr;
  470. extern int   mpt_ASCQ_TableSz;
  471. /*=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=*/
  472. #endif /* } __KERNEL__ */
  473. /*
  474.  *  More (public) macros...
  475.  */
  476. #ifndef MIN
  477. #define MIN(a, b)   (((a) < (b)) ? (a) : (b))
  478. #endif
  479. #ifndef MAX
  480. #define MAX(a, b)   (((a) > (b)) ? (a) : (b))
  481. #endif
  482. #ifndef offsetof
  483. #define offsetof(t, m) ((size_t) (&((t *)0)->m))
  484. #endif
  485. #if defined(__alpha__) || defined(__sparc_v9__)
  486. #define CAST_U32_TO_PTR(x) ((void *)(u64)x)
  487. #define CAST_PTR_TO_U32(x) ((u32)(u64)x)
  488. #else
  489. #define CAST_U32_TO_PTR(x) ((void *)x)
  490. #define CAST_PTR_TO_U32(x) ((u32)x)
  491. #endif
  492. #define MPT_PROTOCOL_FLAGS_c_c_c_c(pflags) 
  493. ((pflags) & MPI_PORTFACTS_PROTOCOL_INITIATOR) ? 'I' : 'i',
  494. ((pflags) & MPI_PORTFACTS_PROTOCOL_TARGET) ? 'T' : 't',
  495. ((pflags) & MPI_PORTFACTS_PROTOCOL_LAN) ? 'L' : 'l',
  496. ((pflags) & MPI_PORTFACTS_PROTOCOL_LOGBUSADDR) ? 'B' : 'b'
  497. /*}-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=*/
  498. #endif