2 * Device driver for Specialix range (SI/XIO) of serial line multiplexors.
4 * Copyright (C) 2000, Peter Wemm <peter@netplex.com.au>
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
9 * 1. Redistributions of source code must retain the above copyright
10 * notices, this list of conditions and the following disclaimer.
11 * 2. Redistributions in binary form must reproduce the above copyright
12 * notices, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
15 * THIS SOFTWARE IS PROVIDED BY ``AS IS'' AND ANY EXPRESS OR IMPLIED
16 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
17 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN
18 * NO EVENT SHALL THE AUTHORS BE LIABLE.
24 int siattach(device_t dev);
27 extern devclass_t si_devclass;
29 /* where the firmware lives; defined in si2_z280.c and si3_t225.c */
31 extern unsigned char si2_z280_download[];
32 extern unsigned short si2_z280_downloadaddr;
33 extern int si2_z280_dsize;
35 extern unsigned char si3_t225_download[];
36 extern unsigned short si3_t225_downloadaddr;
37 extern int si3_t225_dsize;
38 extern unsigned char si3_t225_bootstrap[];
39 extern unsigned short si3_t225_bootloadaddr;
40 extern int si3_t225_bsize;
43 int sc_type; /* adapter type */
44 const char *sc_typename; /* adapter type string */
46 struct si_port *sc_ports; /* port structures for this card */
48 caddr_t sc_paddr; /* physical addr of iomem */
49 caddr_t sc_maddr; /* kvaddr of iomem */
50 int sc_nport; /* # ports on this card */
51 int sc_irq; /* copy of attach irq */
52 int sc_iobase; /* EISA io port address */
53 struct resource *sc_port_res;
54 struct resource *sc_irq_res;
55 struct resource *sc_mem_res;
66 * debugging stuff - manipulated using siconfig(8)
69 void si_dprintf(struct si_port *pp, int flags, const char *fmt, ...);
71 #define DPRINT(x) si_dprintf x
74 * Extensive debugging stuff - manipulated using siconfig(8)
76 #define DBG_ENTRY 0x00000001
77 #define DBG_DRAIN 0x00000002
78 #define DBG_OPEN 0x00000004
79 #define DBG_CLOSE 0x00000008
80 #define DBG_READ 0x00000010
81 #define DBG_WRITE 0x00000020
82 #define DBG_PARAM 0x00000040
83 #define DBG_INTR 0x00000080
84 #define DBG_IOCTL 0x00000100
86 #define DBG_SELECT 0x00000400
87 #define DBG_OPTIM 0x00000800
88 #define DBG_START 0x00001000
89 #define DBG_EXIT 0x00002000
90 #define DBG_FAIL 0x00004000
91 #define DBG_STOP 0x00008000
92 #define DBG_AUTOBOOT 0x00010000
93 #define DBG_MODEM 0x00020000
94 #define DBG_DOWNLOAD 0x00040000
95 #define DBG_LSTART 0x00080000
96 #define DBG_POLL 0x00100000
97 #define DBG_ALL 0xffffffff
100 #define DPRINT(x) /* void */
113 #define SI_ISJET(x) (((x) == SIJETPCI) || ((x) == SIJETISA))