xref: /freebsd/sys/dev/qlxgb/qla_def.h (revision 43e29d03f416d7dda52112a29600a7c82ee1a91e)
1 /*-
2  * SPDX-License-Identifier: BSD-2-Clause
3  *
4  * Copyright (c) 2011-2013 Qlogic Corporation
5  * All rights reserved.
6  *
7  *  Redistribution and use in source and binary forms, with or without
8  *  modification, are permitted provided that the following conditions
9  *  are met:
10  *
11  *  1. Redistributions of source code must retain the above copyright
12  *     notice, this list of conditions and the following disclaimer.
13  *  2. Redistributions in binary form must reproduce the above copyright
14  *     notice, this list of conditions and the following disclaimer in the
15  *     documentation and/or other materials provided with the distribution.
16  *
17  *  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
18  *  AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19  *  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20  *  ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
21  *  LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22  *  CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23  *  SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
24  *  INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
25  *  CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
26  *  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27  *  POSSIBILITY OF SUCH DAMAGE.
28  *
29  * $FreeBSD$
30  */
31 
32 /*
33  * File: qla_def.h
34  * Author : David C Somayajulu, Qlogic Corporation, Aliso Viejo, CA 92656.
35  */
36 
37 #ifndef _QLA_DEF_H_
38 #define _QLA_DEF_H_
39 
40 #define BIT_0                   (0x1 << 0)
41 #define BIT_1                   (0x1 << 1)
42 #define BIT_2                   (0x1 << 2)
43 #define BIT_3                   (0x1 << 3)
44 #define BIT_4                   (0x1 << 4)
45 #define BIT_5                   (0x1 << 5)
46 #define BIT_6                   (0x1 << 6)
47 #define BIT_7                   (0x1 << 7)
48 #define BIT_8                   (0x1 << 8)
49 #define BIT_9                   (0x1 << 9)
50 #define BIT_10                  (0x1 << 10)
51 #define BIT_11                  (0x1 << 11)
52 #define BIT_12                  (0x1 << 12)
53 #define BIT_13                  (0x1 << 13)
54 #define BIT_14                  (0x1 << 14)
55 #define BIT_15                  (0x1 << 15)
56 #define BIT_16                  (0x1 << 16)
57 #define BIT_17                  (0x1 << 17)
58 #define BIT_18                  (0x1 << 18)
59 #define BIT_19                  (0x1 << 19)
60 #define BIT_20                  (0x1 << 20)
61 #define BIT_21                  (0x1 << 21)
62 #define BIT_22                  (0x1 << 22)
63 #define BIT_23                  (0x1 << 23)
64 #define BIT_24                  (0x1 << 24)
65 #define BIT_25                  (0x1 << 25)
66 #define BIT_26                  (0x1 << 26)
67 #define BIT_27                  (0x1 << 27)
68 #define BIT_28                  (0x1 << 28)
69 #define BIT_29                  (0x1 << 29)
70 #define BIT_30                  (0x1 << 30)
71 #define BIT_31                  (0x1 << 31)
72 
73 struct qla_rx_buf {
74 	struct mbuf	*m_head;
75 	bus_dmamap_t	map;
76 	bus_addr_t      paddr;
77 	uint32_t	handle;
78 	void		*next;
79 };
80 typedef struct qla_rx_buf qla_rx_buf_t;
81 
82 struct qla_tx_buf {
83 	struct mbuf	*m_head;
84 	bus_dmamap_t	map;
85 };
86 typedef struct qla_tx_buf qla_tx_buf_t;
87 
88 #define QLA_MAX_SEGMENTS	63	/* maximum # of segs in a sg list */
89 #define QLA_MAX_FRAME_SIZE	MJUM9BYTES
90 #define QLA_STD_FRAME_SIZE	1514
91 #define QLA_MAX_TSO_FRAME_SIZE	((64 * 1024 - 1) + 22)
92 
93 /* Number of MSIX/MSI Vectors required */
94 #define Q8_MSI_COUNT		4
95 
96 struct qla_ivec {
97 	struct resource		*irq;
98 	void			*handle;
99 	int			irq_rid;
100 	void			*ha;
101 	struct task		rcv_task;
102 	struct taskqueue	*rcv_tq;
103 };
104 
105 typedef struct qla_ivec qla_ivec_t;
106 
107 #define QLA_WATCHDOG_CALLOUT_TICKS	1
108 
109 /*
110  * Adapter structure contains the hardware independent information of the
111  * pci function.
112  */
113 struct qla_host {
114         volatile struct {
115                 volatile uint32_t
116 			qla_watchdog_active  :1,
117 			qla_watchdog_exit    :1,
118 			qla_watchdog_pause   :1,
119 			lro_init	:1,
120 			stop_rcv	:1,
121 			link_up		:1,
122 			parent_tag	:1,
123 			lock_init	:1;
124         } flags;
125 
126 	device_t		pci_dev;
127 
128 	uint8_t			pci_func;
129 	uint16_t		watchdog_ticks;
130 	uint8_t			resvd;
131 
132         /* ioctl related */
133         struct cdev             *ioctl_dev;
134 
135 	/* register mapping */
136 	struct resource		*pci_reg;
137 	int			reg_rid;
138 
139 	/* interrupts */
140 	struct resource         *irq;
141 	int			msix_count;
142 	void			*intr_handle;
143 	qla_ivec_t		irq_vec[Q8_MSI_COUNT];
144 
145 	/* parent dma tag */
146 	bus_dma_tag_t           parent_tag;
147 
148 	/* interface to o.s */
149 	if_t			ifp;
150 
151 	struct ifmedia		media;
152 	uint16_t		max_frame_size;
153 	uint16_t		rsrvd0;
154 	int			if_flags;
155 
156 	/* hardware access lock */
157 	struct mtx		hw_lock;
158 	volatile uint32_t	hw_lock_held;
159 
160 	/* transmit and receive buffers */
161 	qla_tx_buf_t		tx_buf[NUM_TX_DESCRIPTORS];
162 	bus_dma_tag_t		tx_tag;
163 	struct mtx		tx_lock;
164 	struct task		tx_task;
165 	struct taskqueue	*tx_tq;
166 	struct callout		tx_callout;
167 
168 	qla_rx_buf_t		rx_buf[NUM_RX_DESCRIPTORS];
169 	qla_rx_buf_t		rx_jbuf[NUM_RX_JUMBO_DESCRIPTORS];
170 	bus_dma_tag_t		rx_tag;
171 
172 	struct mtx		rx_lock;
173 	struct mtx		rxj_lock;
174 
175 	/* stats */
176 	uint32_t		err_m_getcl;
177 	uint32_t		err_m_getjcl;
178 	uint32_t		err_tx_dmamap_create;
179 	uint32_t		err_tx_dmamap_load;
180 	uint32_t		err_tx_defrag;
181 
182 	uint64_t		rx_frames;
183 	uint64_t		rx_bytes;
184 
185 	uint64_t		tx_frames;
186 	uint64_t		tx_bytes;
187 
188         uint32_t                fw_ver_major;
189         uint32_t                fw_ver_minor;
190         uint32_t                fw_ver_sub;
191         uint32_t                fw_ver_build;
192 
193 	/* hardware specific */
194 	qla_hw_t		hw;
195 
196 	/* debug stuff */
197 	volatile const char 	*qla_lock;
198 	volatile const char	*qla_unlock;
199 
200 	uint8_t			fw_ver_str[32];
201 };
202 typedef struct qla_host qla_host_t;
203 
204 /* note that align has to be a power of 2 */
205 #define QL_ALIGN(size, align) (((size) + ((align) - 1)) & (~((align) - 1)))
206 #define QL_MIN(x, y) ((x < y) ? x : y)
207 
208 #define QL_RUNNING(ifp) \
209 		((if_getdrvflags(ifp) & (IFF_DRV_RUNNING | IFF_DRV_OACTIVE)) == \
210 			IFF_DRV_RUNNING)
211 
212 #endif /* #ifndef _QLA_DEF_H_ */
213