1 /*---------------------------------------------------------------------------
2 FT1000 driver for Flarion Flash OFDM NIC Device
4 Copyright (C) 2002 Flarion Technologies, All rights reserved.
6 This program is free software; you can redistribute it and/or modify it
7 under the terms of the GNU General Public License as published by the Free
8 Software Foundation; either version 2 of the License, or (at your option) any
9 later version. This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
11 or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
12 more details. You should have received a copy of the GNU General Public
13 License along with this program; if not, write to the
14 Free Software Foundation, Inc., 59 Temple Place -
15 Suite 330, Boston, MA 02111-1307, USA.
16 ---------------------------------------------------------------------------
17 Description: Common structures and defines
18 ---------------------------------------------------------------------------*/
22 #include "../ft1000.h"
24 #define FT1000_DRV_VER 0x01010300
26 #define FT1000_DPRAM_BASE 0x0000 /* Dual Port RAM starting offset */
28 /* Maximum number of occurrence of pseudo header errors before resetting PC Card. */
29 #define MAX_PH_ERR 300
35 struct net_device_stats stats
;
43 u8 squeseqnum
; /* sequence number on slow queue */
44 spinlock_t dpram_lock
;
46 u8 DspVer
[DSPVERSZ
]; /* DSP version number */
47 u8 HwSerNum
[HWSERNUMSZ
]; /* Hardware Serial Number */
48 u8 Sku
[SKUSZ
]; /* SKU */
49 u8 eui64
[EUISZ
]; /* EUI64 */
50 time_t ConTm
; /* Connection Time */
54 u8 ProductMode
[MODESZ
];
55 u8 RfCalVer
[CALVERSZ
];
56 u8 RfCalDate
[CALDATESZ
];
58 struct list_head prov_list
;
60 int (*ft1000_reset
)(void *);
62 u16 DSPInfoBlk
[MAX_DSP_SESS_REC
];
64 u16 Rec
[MAX_DSP_SESS_REC
];
65 u32 MagRec
[MAX_DSP_SESS_REC
/2];
67 struct proc_dir_entry
*proc_ft1000
;
68 char netdevname
[IFNAMSIZ
];
71 extern u16
ft1000_read_dpram(struct net_device
*dev
, int offset
);
72 extern void card_bootload(struct net_device
*dev
);
73 extern u16
ft1000_read_dpram_mag_16(struct net_device
*dev
, int offset
, int Index
);
74 extern u32
ft1000_read_dpram_mag_32(struct net_device
*dev
, int offset
);
75 void ft1000_write_dpram_mag_32(struct net_device
*dev
, int offset
, u32 value
);
77 /* Read the value of a given ASIC register. */
78 static inline u16
ft1000_read_reg(struct net_device
*dev
, u16 offset
)
80 return inw(dev
->base_addr
+ offset
);
83 /* Set the value of a given ASIC register. */
84 static inline void ft1000_write_reg(struct net_device
*dev
, u16 offset
, u16 value
)
86 outw(value
, dev
->base_addr
+ offset
);