| /*--------------------------------------------------------------------------- |
| FT1000 driver for Flarion Flash OFDM NIC Device |
| |
| Copyright (C) 2002 Flarion Technologies, All rights reserved. |
| |
| This program is free software; you can redistribute it and/or modify it |
| under the terms of the GNU General Public License as published by the Free |
| Software Foundation; either version 2 of the License, or (at your option) any |
| later version. This program is distributed in the hope that it will be useful, |
| but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY |
| or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for |
| more details. You should have received a copy of the GNU General Public |
| License along with this program; if not, write to the |
| Free Software Foundation, Inc., 59 Temple Place - |
| Suite 330, Boston, MA 02111-1307, USA. |
| --------------------------------------------------------------------------- |
| Description: Common structures and defines |
| ---------------------------------------------------------------------------*/ |
| #ifndef _FT1000H_ |
| #define _FT1000H_ |
| |
| #include "../ft1000.h" |
| |
| #define FT1000_DRV_VER 0x01010300 |
| |
| #define FT1000_DPRAM_BASE 0x0000 /* Dual Port RAM starting offset */ |
| |
| /* Maximum number of occurrence of pseudo header errors before resetting PC Card. */ |
| #define MAX_PH_ERR 300 |
| |
| #define SUCCESS 0x00 |
| #define FAILURE 0x01 |
| |
| struct ft1000_info { |
| struct net_device_stats stats; |
| u16 DrvErrNum; |
| u16 AsicID; |
| int PktIntfErr; |
| int CardReady; |
| int registered; |
| int mediastate; |
| u16 packetseqnum; |
| u8 squeseqnum; /* sequence number on slow queue */ |
| spinlock_t dpram_lock; |
| u16 fifo_cnt; |
| u8 DspVer[DSPVERSZ]; /* DSP version number */ |
| u8 HwSerNum[HWSERNUMSZ]; /* Hardware Serial Number */ |
| u8 Sku[SKUSZ]; /* SKU */ |
| u8 eui64[EUISZ]; /* EUI64 */ |
| time_t ConTm; /* Connection Time */ |
| u16 LedStat; |
| u16 ConStat; |
| u16 ProgConStat; |
| u8 ProductMode[MODESZ]; |
| u8 RfCalVer[CALVERSZ]; |
| u8 RfCalDate[CALDATESZ]; |
| u16 DSP_TIME[4]; |
| struct list_head prov_list; |
| u16 DSPInfoBlklen; |
| int (*ft1000_reset)(void *); |
| void *link; |
| u16 DSPInfoBlk[MAX_DSP_SESS_REC]; |
| union { |
| u16 Rec[MAX_DSP_SESS_REC]; |
| u32 MagRec[MAX_DSP_SESS_REC/2]; |
| } DSPSess; |
| struct proc_dir_entry *proc_ft1000; |
| char netdevname[IFNAMSIZ]; |
| }; |
| |
| struct pcmcia_device; |
| struct net_device; |
| extern struct net_device *init_ft1000_card(struct pcmcia_device *link, |
| void *ft1000_reset); |
| extern void stop_ft1000_card(struct net_device *dev); |
| extern int card_download(struct net_device *dev, const u8 *pFileStart, |
| size_t FileLength); |
| extern void ft1000InitProc(struct net_device *dev); |
| extern void ft1000CleanupProc(struct net_device *dev); |
| |
| extern u16 ft1000_read_dpram(struct net_device *dev, int offset); |
| extern void card_bootload(struct net_device *dev); |
| extern u16 ft1000_read_dpram_mag_16(struct net_device *dev, int offset, int Index); |
| extern u32 ft1000_read_dpram_mag_32(struct net_device *dev, int offset); |
| void ft1000_write_dpram_mag_32(struct net_device *dev, int offset, u32 value); |
| |
| /* Read the value of a given ASIC register. */ |
| static inline u16 ft1000_read_reg(struct net_device *dev, u16 offset) |
| { |
| return inw(dev->base_addr + offset); |
| } |
| |
| /* Set the value of a given ASIC register. */ |
| static inline void ft1000_write_reg(struct net_device *dev, u16 offset, u16 value) |
| { |
| outw(value, dev->base_addr + offset); |
| } |
| |
| #endif |