mfivar.h revision 1.1 1 1.1 bouyer /* $OpenBSD: mfivar.h,v 1.28 2006/08/31 18:18:46 marco Exp $ */
2 1.1 bouyer /*
3 1.1 bouyer * Copyright (c) 2006 Marco Peereboom <marco (at) peereboom.us>
4 1.1 bouyer *
5 1.1 bouyer * Permission to use, copy, modify, and distribute this software for any
6 1.1 bouyer * purpose with or without fee is hereby granted, provided that the above
7 1.1 bouyer * copyright notice and this permission notice appear in all copies.
8 1.1 bouyer *
9 1.1 bouyer * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
10 1.1 bouyer * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
11 1.1 bouyer * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
12 1.1 bouyer * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
13 1.1 bouyer * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
14 1.1 bouyer * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
15 1.1 bouyer * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
16 1.1 bouyer */
17 1.1 bouyer
18 1.1 bouyer #define DEVNAME(_s) ((_s)->sc_dev.dv_xname)
19 1.1 bouyer
20 1.1 bouyer /* #define MFI_DEBUG */
21 1.1 bouyer #ifdef MFI_DEBUG
22 1.1 bouyer extern uint32_t mfi_debug;
23 1.1 bouyer #define DPRINTF(x...) do { if (mfi_debug) printf(x); } while(0)
24 1.1 bouyer #define DNPRINTF(n,x...) do { if (mfi_debug & n) printf(x); } while(0)
25 1.1 bouyer #define MFI_D_CMD 0x0001
26 1.1 bouyer #define MFI_D_INTR 0x0002
27 1.1 bouyer #define MFI_D_MISC 0x0004
28 1.1 bouyer #define MFI_D_DMA 0x0008
29 1.1 bouyer #define MFI_D_IOCTL 0x0010
30 1.1 bouyer #define MFI_D_RW 0x0020
31 1.1 bouyer #define MFI_D_MEM 0x0040
32 1.1 bouyer #define MFI_D_CCB 0x0080
33 1.1 bouyer #else
34 1.1 bouyer #define DPRINTF(x...)
35 1.1 bouyer #define DNPRINTF(n,x...)
36 1.1 bouyer #endif
37 1.1 bouyer
38 1.1 bouyer struct mfi_mem {
39 1.1 bouyer bus_dmamap_t am_map;
40 1.1 bouyer bus_dma_segment_t am_seg;
41 1.1 bouyer size_t am_size;
42 1.1 bouyer caddr_t am_kva;
43 1.1 bouyer };
44 1.1 bouyer
45 1.1 bouyer #define MFIMEM_MAP(_am) ((_am)->am_map)
46 1.1 bouyer #define MFIMEM_DVA(_am) ((_am)->am_map->dm_segs[0].ds_addr)
47 1.1 bouyer #define MFIMEM_KVA(_am) ((void *)(_am)->am_kva)
48 1.1 bouyer
49 1.1 bouyer struct mfi_prod_cons {
50 1.1 bouyer uint32_t mpc_producer;
51 1.1 bouyer uint32_t mpc_consumer;
52 1.1 bouyer uint32_t mpc_reply_q[1]; /* compensate for 1 extra reply per spec */
53 1.1 bouyer };
54 1.1 bouyer
55 1.1 bouyer struct mfi_ccb {
56 1.1 bouyer struct mfi_softc *ccb_sc;
57 1.1 bouyer
58 1.1 bouyer union mfi_frame *ccb_frame;
59 1.1 bouyer paddr_t ccb_pframe;
60 1.1 bouyer uint32_t ccb_frame_size;
61 1.1 bouyer uint32_t ccb_extra_frames;
62 1.1 bouyer
63 1.1 bouyer struct mfi_sense *ccb_sense;
64 1.1 bouyer paddr_t ccb_psense;
65 1.1 bouyer
66 1.1 bouyer bus_dmamap_t ccb_dmamap;
67 1.1 bouyer
68 1.1 bouyer union mfi_sgl *ccb_sgl;
69 1.1 bouyer
70 1.1 bouyer /* data for sgl */
71 1.1 bouyer void *ccb_data;
72 1.1 bouyer uint32_t ccb_len;
73 1.1 bouyer
74 1.1 bouyer uint32_t ccb_direction;
75 1.1 bouyer #define MFI_DATA_NONE 0
76 1.1 bouyer #define MFI_DATA_IN 1
77 1.1 bouyer #define MFI_DATA_OUT 2
78 1.1 bouyer
79 1.1 bouyer struct scsipi_xfer *ccb_xs;
80 1.1 bouyer
81 1.1 bouyer void (*ccb_done)(struct mfi_ccb *);
82 1.1 bouyer
83 1.1 bouyer volatile enum {
84 1.1 bouyer MFI_CCB_FREE,
85 1.1 bouyer MFI_CCB_READY,
86 1.1 bouyer MFI_CCB_DONE
87 1.1 bouyer } ccb_state;
88 1.1 bouyer uint32_t ccb_flags;
89 1.1 bouyer #define MFI_CCB_F_ERR (1<<0)
90 1.1 bouyer TAILQ_ENTRY(mfi_ccb) ccb_link;
91 1.1 bouyer };
92 1.1 bouyer
93 1.1 bouyer TAILQ_HEAD(mfi_ccb_list, mfi_ccb);
94 1.1 bouyer
95 1.1 bouyer struct mfi_softc {
96 1.1 bouyer struct device sc_dev;
97 1.1 bouyer struct scsipi_channel sc_chan;
98 1.1 bouyer struct scsipi_adapter sc_adapt;
99 1.1 bouyer
100 1.1 bouyer void *sc_ih;
101 1.1 bouyer
102 1.1 bouyer u_int32_t sc_flags;
103 1.1 bouyer
104 1.1 bouyer bus_space_tag_t sc_iot;
105 1.1 bouyer bus_space_handle_t sc_ioh;
106 1.1 bouyer bus_dma_tag_t sc_dmat;
107 1.1 bouyer
108 1.1 bouyer /* save some useful information for logical drives that is missing
109 1.1 bouyer * in sc_ld_list
110 1.1 bouyer */
111 1.1 bouyer struct {
112 1.1 bouyer uint32_t ld_present;
113 1.1 bouyer char ld_dev[16]; /* device name sd? */
114 1.1 bouyer } sc_ld[MFI_MAX_LD];
115 1.1 bouyer
116 1.1 bouyer /* scsi ioctl from sd device */
117 1.1 bouyer int (*sc_ioctl)(struct device *, u_long, caddr_t);
118 1.1 bouyer
119 1.1 bouyer /* firmware determined max, totals and other information*/
120 1.1 bouyer uint32_t sc_max_cmds;
121 1.1 bouyer uint32_t sc_max_sgl;
122 1.1 bouyer uint32_t sc_max_ld;
123 1.1 bouyer uint32_t sc_ld_cnt;
124 1.1 bouyer /* XXX these struct should be local to mgmt function */
125 1.1 bouyer struct mfi_ctrl_info sc_info;
126 1.1 bouyer struct mfi_ld_list sc_ld_list;
127 1.1 bouyer struct mfi_ld_details sc_ld_details;
128 1.1 bouyer
129 1.1 bouyer /* all commands */
130 1.1 bouyer struct mfi_ccb *sc_ccb;
131 1.1 bouyer
132 1.1 bouyer /* producer/consumer pointers and reply queue */
133 1.1 bouyer struct mfi_mem *sc_pcq;
134 1.1 bouyer
135 1.1 bouyer /* frame memory */
136 1.1 bouyer struct mfi_mem *sc_frames;
137 1.1 bouyer uint32_t sc_frames_size;
138 1.1 bouyer
139 1.1 bouyer /* sense memory */
140 1.1 bouyer struct mfi_mem *sc_sense;
141 1.1 bouyer
142 1.1 bouyer struct mfi_ccb_list sc_ccb_freeq;
143 1.1 bouyer
144 1.1 bouyer struct sensor *sc_sensors;
145 1.1 bouyer };
146 1.1 bouyer
147 1.1 bouyer int mfi_attach(struct mfi_softc *sc);
148 1.1 bouyer int mfi_intr(void *);
149