3 * Copyright (C) 2002 Intersil Americas Inc.
4 * Copyright (C) 2003 Luis R. Rodriguez <mcgrof@ruslug.rutgers.edu>
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this program; if not, write to the Free Software
17 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
24 #include <linux/wireless.h>
25 #include <linux/skbuff.h>
28 * Function definitions
31 #define K_DEBUG(f, m, args...) do { if(f & m) printk(KERN_DEBUG args); } while(0)
32 #define DEBUG(f, args...) K_DEBUG(f, pc_debug, args)
34 #define TRACE(devname) K_DEBUG(SHOW_TRACING, VERBOSE, "%s: -> " __FUNCTION__ "()\n", devname)
37 #define init_wds 0 /* help compiler optimize away dead code */
40 /* General driver definitions */
41 #define PCIVENDOR_INTERSIL 0x1260UL
42 #define PCIVENDOR_3COM 0x10b7UL
43 #define PCIVENDOR_DLINK 0x1186UL
44 #define PCIVENDOR_I4 0x17cfUL
45 #define PCIVENDOR_IODATA 0x10fcUL
46 #define PCIVENDOR_NETGEAR 0x1385UL
47 #define PCIVENDOR_SMC 0x10b8UL
48 #define PCIVENDOR_ACCTON 0x1113UL
50 #define PCIDEVICE_ISL3877 0x3877UL
51 #define PCIDEVICE_ISL3890 0x3890UL
52 #define PCIDEVICE_3COM6001 0x6001UL
53 #define PCIDEVICE_LATENCY_TIMER_MIN 0x40
54 #define PCIDEVICE_LATENCY_TIMER_VAL 0x50
56 /* Debugging verbose definitions */
57 #define SHOW_NOTHING 0x00 /* overrules everything */
58 #define SHOW_ANYTHING 0xFF
59 #define SHOW_ERROR_MESSAGES 0x01
60 #define SHOW_TRAPS 0x02
61 #define SHOW_FUNCTION_CALLS 0x04
62 #define SHOW_TRACING 0x08
63 #define SHOW_QUEUE_INDEXES 0x10
64 #define SHOW_PIMFOR_FRAMES 0x20
65 #define SHOW_BUFFER_CONTENTS 0x40
68 /* Default card definitions */
69 #define CARD_DEFAULT_CHANNEL 6
70 #define CARD_DEFAULT_MODE INL_MODE_CLIENT
71 #define CARD_DEFAULT_IW_MODE IW_MODE_INFRA
72 #define CARD_DEFAULT_BSSTYPE DOT11_BSSTYPE_INFRA
73 #define CARD_DEFAULT_CLIENT_SSID ""
74 #define CARD_DEFAULT_AP_SSID "default"
75 #define CARD_DEFAULT_KEY1 "default_key_1"
76 #define CARD_DEFAULT_KEY2 "default_key_2"
77 #define CARD_DEFAULT_KEY3 "default_key_3"
78 #define CARD_DEFAULT_KEY4 "default_key_4"
79 #define CARD_DEFAULT_WEP 0
80 #define CARD_DEFAULT_FILTER 0
81 #define CARD_DEFAULT_WDS 0
82 #define CARD_DEFAULT_AUTHEN DOT11_AUTH_OS
83 #define CARD_DEFAULT_DOT1X 0
84 #define CARD_DEFAULT_MLME_MODE DOT11_MLME_AUTO
85 #define CARD_DEFAULT_CONFORMANCE OID_INL_CONFORMANCE_NONE
86 #define CARD_DEFAULT_PROFILE DOT11_PROFILE_MIXED_G_WIFI
87 #define CARD_DEFAULT_MAXFRAMEBURST DOT11_MAXFRAMEBURST_MIXED_SAFE
89 /* PIMFOR package definitions */
90 #define PIMFOR_ETHERTYPE 0x8828
91 #define PIMFOR_HEADER_SIZE 12
92 #define PIMFOR_VERSION 1
93 #define PIMFOR_OP_GET 0
94 #define PIMFOR_OP_SET 1
95 #define PIMFOR_OP_RESPONSE 2
96 #define PIMFOR_OP_ERROR 3
97 #define PIMFOR_OP_TRAP 4
98 #define PIMFOR_OP_RESERVED 5 /* till 255 */
99 #define PIMFOR_DEV_ID_MHLI_MIB 0
100 #define PIMFOR_FLAG_APPLIC_ORIGIN 0x01
101 #define PIMFOR_FLAG_LITTLE_ENDIAN 0x02
104 add_le32p(u32 * le_number, u32 add)
106 *le_number = cpu_to_le32(le32_to_cpup(le_number) + add);
109 void display_buffer(char *, int);
112 * Type definition section
114 * the structure defines only the header allowing copyless
124 } __attribute__ ((packed))
127 /* A received and interrupt-processed management frame, either for
128 * schedule_work(prism54_process_trap) or for priv->mgmt_received,
129 * processed by islpci_mgt_transaction(). */
130 struct islpci_mgmtframe {
131 struct net_device *ndev; /* pointer to network device */
132 pimfor_header_t *header; /* payload header, points into buf */
133 void *data; /* payload ex header, points into buf */
134 struct work_struct ws; /* argument for schedule_work() */
135 char buf[0]; /* fragment buffer */
139 islpci_mgt_receive(struct net_device *ndev);
142 islpci_mgmt_rx_fill(struct net_device *ndev);
145 islpci_mgt_cleanup_transmit(struct net_device *ndev);
148 islpci_mgt_transaction(struct net_device *ndev,
149 int operation, unsigned long oid,
150 void *senddata, int sendlen,
151 struct islpci_mgmtframe **recvframe);
154 islpci_mgt_release(struct islpci_mgmtframe *frame)
159 #endif /* _ISLPCI_MGT_H */