Merge to Fedora kernel-2.6.7-1.441
[linux-2.6.git] / drivers / net / wireless / prism54 / islpci_mgt.h
1 /*
2  *  
3  *  Copyright (C) 2002 Intersil Americas Inc.
4  *  Copyright (C) 2003 Luis R. Rodriguez <mcgrof@ruslug.rutgers.edu>
5  *
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
9  *
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.
14  *
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
18  *
19  */
20
21 #ifndef _ISLPCI_MGT_H
22 #define _ISLPCI_MGT_H
23
24 #include <linux/wireless.h>
25 #include <linux/skbuff.h>
26
27 /*
28  *  Function definitions
29  */
30
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)
33
34 #define TRACE(devname)   K_DEBUG(SHOW_TRACING, VERBOSE, "%s:  -> " __FUNCTION__ "()\n", devname)
35
36 extern int pc_debug;
37 #define init_wds 0      /* help compiler optimize away dead code */
38
39
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
49
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
55
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
66 #define VERBOSE                                 0x01
67
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
88
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
102
103 static inline void
104 add_le32p(u32 * le_number, u32 add)
105 {
106         *le_number = cpu_to_le32(le32_to_cpup(le_number) + add);
107 }
108
109 void display_buffer(char *, int);
110
111 /*
112  *  Type definition section
113  *
114  *  the structure defines only the header allowing copyless
115  *  frame handling
116  */
117 typedef struct {
118         u8 version;
119         u8 operation;
120         u32 oid;
121         u8 device_id;
122         u8 flags;
123         u32 length;
124 } __attribute__ ((packed))
125 pimfor_header_t;
126
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 */
136 };
137
138 int
139 islpci_mgt_receive(struct net_device *ndev);
140
141 int
142 islpci_mgmt_rx_fill(struct net_device *ndev);
143
144 void
145 islpci_mgt_cleanup_transmit(struct net_device *ndev);
146
147 int
148 islpci_mgt_transaction(struct net_device *ndev,
149                        int operation, unsigned long oid,
150                        void *senddata, int sendlen,
151                        struct islpci_mgmtframe **recvframe);
152
153 static inline void
154 islpci_mgt_release(struct islpci_mgmtframe *frame)
155 {
156         kfree(frame);
157 }
158
159 #endif                          /* _ISLPCI_MGT_H */