xref: /titanic_52/usr/src/uts/common/io/aac/aac.h (revision 121d13daefbeb0546d0d9c6ef16c753aa6890290)
1 /*
2  * Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
3  * Use is subject to license terms.
4  */
5 
6 /*
7  * Copyright 2005-06 Adaptec, Inc.
8  * Copyright (c) 2005-06 Adaptec Inc., Achim Leubner
9  * Copyright (c) 2000 Michael Smith
10  * Copyright (c) 2001 Scott Long
11  * Copyright (c) 2000 BSDi
12  * All rights reserved.
13  *
14  * Redistribution and use in source and binary forms, with or without
15  * modification, are permitted provided that the following conditions
16  * are met:
17  * 1. Redistributions of source code must retain the above copyright
18  *    notice, this list of conditions and the following disclaimer.
19  * 2. Redistributions in binary form must reproduce the above copyright
20  *    notice, this list of conditions and the following disclaimer in the
21  *    documentation and/or other materials provided with the distribution.
22  *
23  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
24  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
25  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
26  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
27  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
28  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
29  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
32  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
33  * SUCH DAMAGE.
34  *
35  *    $FreeBSD: src/sys/dev/aac/aacvar.h,v 1.47 2005/10/08 15:55:09 scottl Exp $
36  */
37 
38 #ifndef	_AAC_H_
39 #define	_AAC_H_
40 
41 #ifdef	__cplusplus
42 extern "C" {
43 #endif
44 
45 #define	AAC_ROUNDUP(x, y)		(((x) + (y) - 1) / (y) * (y))
46 
47 #define	AAC_TYPE_DEVO			1
48 #define	AAC_TYPE_ALPHA			2
49 #define	AAC_TYPE_BETA			3
50 #define	AAC_TYPE_RELEASE		4
51 
52 #ifndef	AAC_DRIVER_BUILD
53 #define	AAC_DRIVER_BUILD		1
54 #endif
55 
56 #define	AAC_DRIVER_MAJOR_VERSION	2
57 #define	AAC_DRIVER_MINOR_VERSION	2
58 #define	AAC_DRIVER_BUGFIX_LEVEL		7
59 #define	AAC_DRIVER_TYPE			AAC_TYPE_RELEASE
60 
61 #define	STR(s)				# s
62 #define	AAC_VERSION(a, b, c)		STR(a.b.c)
63 #define	AAC_DRIVER_VERSION		AAC_VERSION(AAC_DRIVER_MAJOR_VERSION, \
64 					AAC_DRIVER_MINOR_VERSION, \
65 					AAC_DRIVER_BUGFIX_LEVEL)
66 
67 #define	AACOK				0
68 #define	AACERR				-1
69 
70 #define	AAC_MAX_ADAPTERS		64
71 
72 /* Definitions for mode sense */
73 #ifndef	SD_MODE_SENSE_PAGE3_CODE
74 #define	SD_MODE_SENSE_PAGE3_CODE	0x03
75 #endif
76 
77 #ifndef	SD_MODE_SENSE_PAGE4_CODE
78 #define	SD_MODE_SENSE_PAGE4_CODE	0x04
79 #endif
80 
81 #ifndef	SCMD_SYNCHRONIZE_CACHE
82 #define	SCMD_SYNCHRONIZE_CACHE		0x35
83 #endif
84 
85 /*
86  * The controller reports status events in AIFs. We hang on to a number of
87  * these in order to pass them out to user-space management tools.
88  */
89 #define	AAC_AIFQ_LENGTH			64
90 
91 #ifdef __x86
92 #define	AAC_IMMEDIATE_TIMEOUT		30	/* seconds */
93 #else
94 #define	AAC_IMMEDIATE_TIMEOUT		60	/* seconds */
95 #endif
96 #define	AAC_FWUP_TIMEOUT		180	/* wait up to 3 minutes */
97 #define	AAC_IOCTL_TIMEOUT		900	/* wait up to 15 minutes */
98 
99 /* Adapter hardware interface types */
100 #define	AAC_HWIF_UNKNOWN		0
101 #define	AAC_HWIF_I960RX			1
102 #define	AAC_HWIF_RKT			2
103 
104 #define	AAC_TYPE_UNKNOWN		0
105 #define	AAC_TYPE_SCSI			1
106 #define	AAC_TYPE_SATA			2
107 #define	AAC_TYPE_SAS			3
108 
109 #define	AAC_LS32(d)			((uint32_t)((d) & 0xffffffffull))
110 #define	AAC_MS32(d)			((uint32_t)((d) >> 32))
111 #define	AAC_LO32(p64)			((uint32_t *)(p64))
112 #define	AAC_HI32(p64)			((uint32_t *)(p64) + 1)
113 
114 /*
115  * AAC_CMDQ_SYNC should be 0 and AAC_CMDQ_ASYNC be 1 for Sync FIB io
116  * to be served before async FIB io, see aac_start_waiting_io().
117  * So that io requests sent by interactive userland commands get
118  * responded asap.
119  */
120 enum aac_cmdq {
121 	AAC_CMDQ_SYNC,	/* sync FIB queue */
122 	AAC_CMDQ_ASYNC,	/* async FIB queue */
123 	AAC_CMDQ_NUM
124 };
125 
126 /*
127  * IO command flags
128  */
129 #define	AAC_IOCMD_SYNC		(1 << AAC_CMDQ_SYNC)
130 #define	AAC_IOCMD_ASYNC		(1 << AAC_CMDQ_ASYNC)
131 #define	AAC_IOCMD_OUTSTANDING	(1 << AAC_CMDQ_NUM)
132 #define	AAC_IOCMD_ALL		(AAC_IOCMD_SYNC | AAC_IOCMD_ASYNC | \
133 				AAC_IOCMD_OUTSTANDING)
134 
135 struct aac_cmd_queue {
136 	struct aac_cmd *q_head; /* also as the header of aac_cmd */
137 	struct aac_cmd *q_tail;
138 };
139 
140 struct aac_card_type {
141 	uint16_t vendor;	/* PCI Vendor ID */
142 	uint16_t device;	/* PCI Device ID */
143 	uint16_t subvendor;	/* PCI Subsystem Vendor ID */
144 	uint16_t subsys;	/* PCI Subsystem ID */
145 	uint16_t hwif;		/* card chip type: i960 or Rocket */
146 	uint16_t quirks;	/* card odd limits */
147 	uint16_t type;		/* hard drive type */
148 	char *vid;		/* ASCII data for INQUIRY command vendor id */
149 	char *desc;		/* ASCII data for INQUIRY command product id */
150 };
151 
152 /* Device types */
153 #define	AAC_DEV_LD		0	/* logical device */
154 #define	AAC_DEV_PD		1	/* physical device */
155 
156 /* DR events */
157 #define	AAC_EVT_NONE		0
158 #define	AAC_EVT_ONLINE		1
159 #define	AAC_EVT_OFFLINE		2
160 
161 /* Device flags */
162 #define	AAC_DFLAG_VALID		(1 << 0)
163 #define	AAC_DFLAG_CONFIGURING	(1 << 1)
164 
165 #define	AAC_DEV_IS_VALID(dvp)	((dvp)->flags & AAC_DFLAG_VALID)
166 
167 struct aac_device {
168 	int flags;
169 
170 	uint8_t type;
171 	dev_info_t *dip;
172 	int ncmds[AAC_CMDQ_NUM];	/* outstanding cmds of the device */
173 	int throttle[AAC_CMDQ_NUM];	/* hold IO cmds for the device */
174 };
175 
176 /* Array description */
177 struct aac_container {
178 	struct aac_device dev;
179 
180 	uint32_t cid;		/* container id */
181 	uint32_t uid;		/* container uid */
182 	uint64_t size;		/* in block */
183 	uint8_t locked;
184 	uint8_t deleted;
185 	uint8_t reset;		/* container is being reseted */
186 };
187 
188 /* Non-DASD phys. device descrption, eg. CDROM or tape */
189 struct aac_nondasd {
190 	struct aac_device dev;
191 
192 	uint32_t bus;
193 	uint32_t tid;
194 };
195 
196 /*
197  * The firmware can support a lot of outstanding commands. Each aac_slot
198  * is corresponding to one of such commands. It records the command and
199  * associated DMA resource for FIB command.
200  */
201 struct aac_slot {
202 	struct aac_slot *next;	/* next slot in the free slot list */
203 	int index;		/* index of this slot */
204 	ddi_acc_handle_t fib_acc_handle;
205 	ddi_dma_handle_t fib_dma_handle;
206 	uint64_t fib_phyaddr;	/* physical address of FIB memory */
207 	struct aac_cmd *acp;	/* command using this slot */
208 	struct aac_fib *fibp;	/* virtual address of FIB memory */
209 };
210 
211 /* Flags for attach tracking */
212 #define	AAC_ATTACH_SOFTSTATE_ALLOCED	(1 << 0)
213 #define	AAC_ATTACH_CARD_DETECTED	(1 << 1)
214 #define	AAC_ATTACH_PCI_MEM_MAPPED	(1 << 2)
215 #define	AAC_ATTACH_KMUTEX_INITED	(1 << 3)
216 #define	AAC_ATTACH_HARD_INTR_SETUP	(1 << 4)
217 #define	AAC_ATTACH_SOFT_INTR_SETUP	(1 << 5)
218 #define	AAC_ATTACH_SCSI_TRAN_SETUP	(1 << 6)
219 #define	AAC_ATTACH_COMM_SPACE_SETUP	(1 << 7)
220 #define	AAC_ATTACH_CREATE_DEVCTL	(1 << 8)
221 #define	AAC_ATTACH_CREATE_SCSI		(1 << 9)
222 
223 /* Driver running states */
224 #define	AAC_STATE_STOPPED	0
225 #define	AAC_STATE_RUN		(1 << 0)
226 #define	AAC_STATE_RESET		(1 << 1)
227 #define	AAC_STATE_QUIESCED	(1 << 2)
228 #define	AAC_STATE_DEAD		(1 << 3)
229 
230 /*
231  * Flags for aac firmware
232  * Note: Quirks are only valid for the older cards. These cards only supported
233  * old comm. Thus they are not valid for any cards that support new comm.
234  */
235 #define	AAC_FLAGS_SG_64BIT	(1 << 0) /* Use 64-bit S/G addresses */
236 #define	AAC_FLAGS_4GB_WINDOW	(1 << 1) /* Can access host mem 2-4GB range */
237 #define	AAC_FLAGS_NO4GB	(1 << 2)	/* quirk: FIB addresses must reside */
238 					/*	  between 0x2000 & 0x7FFFFFFF */
239 #define	AAC_FLAGS_256FIBS	(1 << 3) /* quirk: Can only do 256 commands */
240 #define	AAC_FLAGS_NEW_COMM	(1 << 4) /* New comm. interface supported */
241 #define	AAC_FLAGS_RAW_IO	(1 << 5) /* Raw I/O interface */
242 #define	AAC_FLAGS_ARRAY_64BIT	(1 << 6) /* 64-bit array size */
243 #define	AAC_FLAGS_LBA_64BIT	(1 << 7) /* 64-bit LBA supported */
244 #define	AAC_FLAGS_17SG		(1 << 8) /* quirk: 17 scatter gather maximum */
245 #define	AAC_FLAGS_34SG		(1 << 9) /* quirk: 34 scatter gather maximum */
246 #define	AAC_FLAGS_NONDASD	(1 << 10) /* non-DASD device supported */
247 #define	AAC_FLAGS_BRKUP		(1 << 11) /* pkt breakup support */
248 
249 struct aac_softstate;
250 struct aac_interface {
251 	int (*aif_get_fwstatus)(struct aac_softstate *);
252 	int (*aif_get_mailbox)(struct aac_softstate *, int);
253 	void (*aif_set_mailbox)(struct aac_softstate *, uint32_t,
254 	    uint32_t, uint32_t, uint32_t, uint32_t);
255 };
256 
257 struct aac_fib_context {
258 	uint32_t unique;
259 	int ctx_idx;
260 	int ctx_filled;		/* aifq is full for this fib context */
261 	struct aac_fib_context *next, *prev;
262 };
263 
264 typedef void (*aac_cmd_fib_t)(struct aac_softstate *, struct aac_cmd *);
265 
266 #define	AAC_VENDOR_LEN		8
267 #define	AAC_PRODUCT_LEN		16
268 
269 struct aac_softstate {
270 	int card;		/* index to aac_cards */
271 	uint16_t hwif;		/* card chip type: i960 or Rocket */
272 	uint16_t vendid;	/* vendor id */
273 	uint16_t subvendid;	/* sub vendor id */
274 	uint16_t devid;		/* device id */
275 	uint16_t subsysid;	/* sub system id */
276 	char vendor_name[AAC_VENDOR_LEN + 1];
277 	char product_name[AAC_PRODUCT_LEN + 1];
278 	uint32_t support_opt;	/* firmware features */
279 	uint32_t support_opt2;
280 	uint32_t feature_bits;
281 	uint32_t atu_size;	/* actual size of PCI mem space */
282 	uint32_t map_size;	/* mapped PCI mem space size */
283 	uint32_t map_size_min;	/* minimum size of PCI mem that must be */
284 				/* mapped to address the card */
285 	int flags;		/* firmware features enabled */
286 	int instance;
287 	dev_info_t *devinfo_p;
288 	scsi_hba_tran_t *hba_tran;
289 	int slen;
290 	int legacy;		/* legacy device naming */
291 	uint32_t dma_max;	/* for buf breakup */
292 
293 	/* DMA attributes */
294 	ddi_dma_attr_t buf_dma_attr;
295 	ddi_dma_attr_t addr_dma_attr;
296 
297 	/* PCI spaces */
298 	ddi_device_acc_attr_t acc_attr;
299 	ddi_device_acc_attr_t reg_attr;
300 	ddi_acc_handle_t pci_mem_handle;
301 	uint8_t *pci_mem_base_vaddr;
302 	uint32_t pci_mem_base_paddr;
303 
304 	struct aac_interface aac_if;	/* adapter hardware interface */
305 
306 	struct aac_slot sync_slot;	/* sync FIB */
307 
308 	/* Communication space */
309 	struct aac_comm_space *comm_space;
310 	ddi_acc_handle_t comm_space_acc_handle;
311 	ddi_dma_handle_t comm_space_dma_handle;
312 	uint32_t comm_space_phyaddr;
313 
314 	/* Old Comm. interface: message queues */
315 	struct aac_queue_table *qtablep;
316 	struct aac_queue_entry *qentries[AAC_QUEUE_COUNT];
317 
318 	/* New Comm. interface */
319 	uint32_t aac_max_fibs;		/* max. FIB count */
320 	uint32_t aac_max_fib_size;	/* max. FIB size */
321 	uint32_t aac_sg_tablesize;	/* max. sg count from host */
322 	uint32_t aac_max_sectors;	/* max. I/O size from host (blocks) */
323 
324 	aac_cmd_fib_t aac_cmd_fib;	/* IO cmd FIB construct function */
325 	aac_cmd_fib_t aac_cmd_fib_scsi;	/* SRB construct function */
326 
327 	ddi_softintr_t softint_id;	/* soft intr */
328 
329 	kmutex_t io_lock;
330 	int state;			/* driver state */
331 
332 	struct aac_container containers[AAC_MAX_LD];
333 	int container_count;		/* max container id + 1 */
334 	struct aac_nondasd *nondasds;
335 	uint32_t bus_max;		/* max FW buses exposed */
336 	uint32_t tgt_max;		/* max FW target per bus */
337 
338 	/*
339 	 * Command queues
340 	 * Each aac command flows through wait(or wait_sync) queue,
341 	 * busy queue, and complete queue sequentially.
342 	 */
343 	struct aac_cmd_queue q_wait[AAC_CMDQ_NUM];
344 	struct aac_cmd_queue q_busy;	/* outstanding cmd queue */
345 	kmutex_t q_comp_mutex;
346 	struct aac_cmd_queue q_comp;	/* completed io requests */
347 
348 	/* I/O slots and FIBs */
349 	int total_slots;		/* total slots allocated */
350 	int total_fibs;			/* total FIBs allocated */
351 	struct aac_slot *io_slot;	/* static list for allocated slots */
352 	struct aac_slot *free_io_slot_head;
353 
354 	timeout_id_t timeout_id;	/* for timeout daemon */
355 
356 	kcondvar_t event;		/* for ioctl_send_fib() and sync IO */
357 
358 	int bus_ncmds[AAC_CMDQ_NUM];	/* total outstanding async cmds */
359 	int bus_throttle[AAC_CMDQ_NUM];	/* hold IO cmds for the bus */
360 	int ndrains;			/* number of draining threads */
361 	timeout_id_t drain_timeid;	/* for outstanding cmd drain */
362 	kcondvar_t drain_cv;		/* for quiesce drain */
363 
364 	/* AIF */
365 	kmutex_t aifq_mutex;		/* for AIF queue aifq */
366 	kcondvar_t aifv;
367 	union aac_fib_align aifq[AAC_AIFQ_LENGTH];
368 	int aifq_idx;			/* slot for next new AIF */
369 	int aifq_wrap;			/* AIF queue has ever been wrapped */
370 	struct aac_fib_context *fibctx;
371 	int devcfg_wait_on;		/* AIF event waited for rescan */
372 
373 	int fm_capabilities;
374 	ddi_taskq_t *taskq;
375 
376 	/* MSI specific fields */
377 	ddi_intr_handle_t *htable;	/* For array of interrupts */
378 	int intr_type;			/* What type of interrupt */
379 	int intr_cnt;			/* # of intrs count returned */
380 	uint_t intr_pri;		/* Interrupt priority   */
381 	int intr_cap;			/* Interrupt capabilities */
382 
383 #ifdef DEBUG
384 	/* UART trace printf variables */
385 	uint32_t debug_flags;		/* debug print flags bitmap */
386 	uint32_t debug_fib_flags;	/* debug FIB print flags bitmap */
387 	uint32_t debug_fw_flags;	/* FW debug flags */
388 	uint32_t debug_buf_offset;	/* offset from DPMEM start */
389 	uint32_t debug_buf_size;	/* FW debug buffer size in bytes */
390 	uint32_t debug_header_size;	/* size of debug header */
391 #endif
392 };
393 
394 /*
395  * The following data are kept stable because they are only written at driver
396  * initialization, and we do not allow them changed otherwise even at driver
397  * re-initialization.
398  */
399 _NOTE(SCHEME_PROTECTS_DATA("stable data", aac_softstate::{flags slen \
400     buf_dma_attr pci_mem_handle pci_mem_base_vaddr \
401     comm_space_acc_handle comm_space_dma_handle aac_max_fib_size \
402     aac_sg_tablesize aac_cmd_fib aac_cmd_fib_scsi debug_flags bus_max tgt_max}))
403 
404 /*
405  * Scatter-gather list structure defined by HBA hardware
406  */
407 struct aac_sge {
408 	uint32_t bcount;	/* byte count */
409 	union {
410 		uint32_t ad32;	/* 32 bit address */
411 		struct {
412 			uint32_t lo;
413 			uint32_t hi;
414 		} ad64;		/* 64 bit address */
415 	} addr;
416 };
417 
418 /* aac_cmd flags */
419 #define	AAC_CMD_CONSISTENT		(1 << 0)
420 #define	AAC_CMD_DMA_PARTIAL		(1 << 1)
421 #define	AAC_CMD_DMA_VALID		(1 << 2)
422 #define	AAC_CMD_BUF_READ		(1 << 3)
423 #define	AAC_CMD_BUF_WRITE		(1 << 4)
424 #define	AAC_CMD_SYNC			(1 << 5) /* use sync FIB */
425 #define	AAC_CMD_NO_INTR			(1 << 6) /* poll IO, no intr */
426 #define	AAC_CMD_NO_CB			(1 << 7) /* sync IO, no callback */
427 #define	AAC_CMD_NTAG			(1 << 8)
428 #define	AAC_CMD_CMPLT			(1 << 9) /* cmd exec'ed by driver/fw */
429 #define	AAC_CMD_ABORT			(1 << 10)
430 #define	AAC_CMD_TIMEOUT			(1 << 11)
431 #define	AAC_CMD_ERR			(1 << 12)
432 
433 struct aac_cmd {
434 	/*
435 	 * Note: should be the first member for aac_cmd_queue to work
436 	 * correctly.
437 	 */
438 	struct aac_cmd *next;
439 	struct aac_cmd *prev;
440 
441 	struct scsi_pkt *pkt;
442 	int cmdlen;
443 	int flags;
444 	uint32_t timeout; /* time when the cmd should have completed */
445 	struct buf *bp;
446 	ddi_dma_handle_t buf_dma_handle;
447 
448 	/* For non-aligned buffer and SRB */
449 	caddr_t abp;
450 	ddi_acc_handle_t abh;
451 
452 	/* Data transfer state */
453 	ddi_dma_cookie_t cookie;
454 	uint_t left_cookien;
455 	uint_t cur_win;
456 	uint_t total_nwin;
457 	size_t total_xfer;
458 	uint64_t blkno;
459 	uint32_t bcount;	/* buffer size in byte */
460 	struct aac_sge *sgt;	/* sg table */
461 
462 	/* FIB construct function */
463 	aac_cmd_fib_t aac_cmd_fib;
464 	/* Call back function for completed command */
465 	void (*ac_comp)(struct aac_softstate *, struct aac_cmd *);
466 
467 	struct aac_slot *slotp;	/* slot used by this command */
468 	struct aac_device *dvp;	/* target device */
469 
470 	/* FIB for this IO command */
471 	int fib_size; /* size of the FIB xferred to/from the card */
472 	struct aac_fib *fibp;
473 
474 #ifdef DEBUG
475 	uint32_t fib_flags;
476 #endif
477 };
478 
479 #ifdef DEBUG
480 
481 #define	AACDB_FLAGS_MASK		0x0000ffff
482 #define	AACDB_FLAGS_KERNEL_PRINT	0x00000001
483 #define	AACDB_FLAGS_FW_PRINT		0x00000002
484 #define	AACDB_FLAGS_NO_HEADERS		0x00000004
485 
486 #define	AACDB_FLAGS_MISC		0x00000010
487 #define	AACDB_FLAGS_FUNC1		0x00000020
488 #define	AACDB_FLAGS_FUNC2		0x00000040
489 #define	AACDB_FLAGS_SCMD		0x00000080
490 #define	AACDB_FLAGS_AIF			0x00000100
491 #define	AACDB_FLAGS_FIB			0x00000200
492 #define	AACDB_FLAGS_IOCTL		0x00000400
493 
494 /*
495  * Flags for FIB print
496  */
497 /* FIB sources */
498 #define	AACDB_FLAGS_FIB_SCMD		0x00000001
499 #define	AACDB_FLAGS_FIB_IOCTL		0x00000002
500 #define	AACDB_FLAGS_FIB_SRB		0x00000004
501 #define	AACDB_FLAGS_FIB_SYNC		0x00000008
502 /* FIB components */
503 #define	AACDB_FLAGS_FIB_HEADER		0x00000010
504 /* FIB states */
505 #define	AACDB_FLAGS_FIB_TIMEOUT		0x00000100
506 
507 extern uint32_t aac_debug_flags;
508 extern int aac_dbflag_on(struct aac_softstate *, int);
509 extern void aac_printf(struct aac_softstate *, uint_t, const char *, ...);
510 extern void aac_print_fib(struct aac_softstate *, struct aac_slot *);
511 
512 #define	AACDB_PRINT(s, lev, ...) { \
513 	if (aac_dbflag_on((s), AACDB_FLAGS_MISC)) \
514 		aac_printf((s), (lev), __VA_ARGS__); }
515 
516 #define	AACDB_PRINT_IOCTL(s, ...) { \
517 	if (aac_dbflag_on((s), AACDB_FLAGS_IOCTL)) \
518 		aac_printf((s), CE_NOTE, __VA_ARGS__); }
519 
520 #define	AACDB_PRINT_TRAN(s, ...) { \
521 	if (aac_dbflag_on((s), AACDB_FLAGS_SCMD)) \
522 		aac_printf((s), CE_NOTE, __VA_ARGS__); }
523 
524 #define	DBCALLED(s, n) { \
525 	if (aac_dbflag_on((s), AACDB_FLAGS_FUNC ## n)) \
526 		aac_printf((s), CE_NOTE, "--- %s() called ---", __func__); }
527 
528 #define	AACDB_PRINT_SCMD(s, x) { \
529 	if (aac_dbflag_on((s), AACDB_FLAGS_SCMD)) aac_print_scmd((s), (x)); }
530 
531 #define	AACDB_PRINT_AIF(s, x) { \
532 	if (aac_dbflag_on((s), AACDB_FLAGS_AIF)) aac_print_aif((s), (x)); }
533 
534 #define	AACDB_PRINT_FIB(s, x) { \
535 	if (aac_dbflag_on((s), AACDB_FLAGS_FIB)) aac_print_fib((s), (x)); }
536 
537 #else /* DEBUG */
538 
539 #define	AACDB_PRINT(s, lev, ...)
540 #define	AACDB_PRINT_IOCTL(s, ...)
541 #define	AACDB_PRINT_TRAN(s, ...)
542 #define	AACDB_PRINT_FIB(s, x)
543 #define	AACDB_PRINT_SCMD(s, x)
544 #define	AACDB_PRINT_AIF(s, x)
545 #define	DBCALLED(s, n)
546 
547 #endif /* DEBUG */
548 
549 #ifdef	__cplusplus
550 }
551 #endif
552 
553 #endif /* _AAC_H_ */
554