[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20080909204300.43e38187@osprey.hogchain.net>
Date: Tue, 9 Sep 2008 20:43:00 -0500
From: Jay Cliburn <jcliburn@...il.com>
To: Chris Snook <csnook@...hat.com>
Cc: jeff@...zik.org, netdev@...r.kernel.org,
atl2-test@...ts.sourceforge.net, csnook@...hat.com
Subject: Re: [PATCH 2/4] atlx: add atl2.h
On Tue, 9 Sep 2008 02:19:45 -0400
Chris Snook <csnook@...hat.com> wrote:
> From: Chris Snook <csnook@...hat.com>
>
> Header file for atl2 support.
>
> Signed-off-by: Chris Snook <csnook@...hat.com>
Checkpatch.pl reports some coding style and whitespace issues.
total: 83 errors, 46 warnings, 482 lines checked
>
> diff --git a/drivers/net/atlx/atl2.h b/drivers/net/atlx/atl2.h
> new file mode 100644
> index 0000000..76f4453
> --- /dev/null
> +++ b/drivers/net/atlx/atl2.h
> @@ -0,0 +1,482 @@
> +/* atl2.h -- atl2 driver definitions
> + *
> + * Copyright(c) 2007 Atheros Corporation. All rights reserved.
> + * Copyright(c) 2006 xiong huang <xiong.huang@...eros.com>
> + * Copyright(c) 2007 Chris Snook <csnook@...hat.com>
> + *
> + * Derived from Intel e1000 driver
> + * Copyright(c) 1999 - 2005 Intel Corporation. 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.
> + */
> +
> +#ifndef _ATL2_H_
> +#define _ATL2_H_
> +
> +#include <asm/atomic.h>
> +#include <linux/netdevice.h>
> +
> +#ifndef _ATL2_HW_H_
> +#define _ATL2_HW_H_
> +
> +#ifndef _ATL2_OSDEP_H_
> +#define _ATL2_OSDEP_H_
> +
> +#include <linux/pci.h>
> +#include <linux/delay.h>
> +#include <linux/interrupt.h>
> +#include <linux/if_ether.h>
> +
> +#include "atlx.h"
> +
> +#define PCI_COMMAND_REGISTER PCI_COMMAND
> +#define CMD_MEM_WRT_INVALIDATE PCI_COMMAND_INVALIDATE
> +#define ETH_ADDR_LEN ETH_ALEN
> +
> +#define ATL2_WRITE_REG(a, reg, value) (iowrite32((value),
> ((a)->hw_addr + (reg)))) +
> +#define ATL2_WRITE_FLUSH(a) (ioread32((a)->hw_addr))
> +
> +#define ATL2_READ_REG(a, reg) (ioread32((a)->hw_addr + (reg)))
> +
> +#define ATL2_WRITE_REGB(a, reg, value) (iowrite8((value),
> ((a)->hw_addr + (reg)))) +
> +#define ATL2_READ_REGB(a, reg) (ioread8((a)->hw_addr + (reg)))
> +
> +#define ATL2_WRITE_REGW(a, reg, value) (iowrite16((value),
> ((a)->hw_addr + (reg)))) +
> +#define ATL2_READ_REGW(a, reg) (ioread16((a)->hw_addr + (reg)))
> +
> +#define ATL2_WRITE_REG_ARRAY(a, reg, offset, value) \
> + (iowrite32((value), (((a)->hw_addr + (reg)) + ((offset) <<
> 2)))) +
> +#define ATL2_READ_REG_ARRAY(a, reg, offset) \
> + (ioread32(((a)->hw_addr + (reg)) + ((offset) << 2)))
> +
> +#endif /* _ATL2_OSDEP_H_ */
> +
> +struct atl2_adapter;
> +struct atl2_hw;
> +
> +/* function prototype */
> +static s32 atl2_reset_hw(struct atl2_hw *hw);
> +static s32 atl2_read_mac_addr(struct atl2_hw *hw);
> +static s32 atl2_init_hw(struct atl2_hw *hw);
> +static s32 atl2_get_speed_and_duplex(struct atl2_hw *hw, u16 *speed,
> u16 *duplex); +static u32 atl2_hash_mc_addr(struct atl2_hw *hw, u8
> *mc_addr); +static void atl2_hash_set(struct atl2_hw *hw, u32
> hash_value); +static s32 atl2_read_phy_reg(struct atl2_hw *hw, u16
> reg_addr, u16 *phy_data); +static s32 atl2_write_phy_reg(struct
> atl2_hw *hw, u32 reg_addr, u16 phy_data); +static void
> atl2_read_pci_cfg(struct atl2_hw *hw, u32 reg, u16 *value); +static
> void atl2_write_pci_cfg(struct atl2_hw *hw, u32 reg, u16 *value);
> +static void atl2_set_mac_addr(struct atl2_hw *hw); +static bool
> atl2_read_eeprom(struct atl2_hw *hw, u32 Offset, u32 *pValue);
> +static bool atl2_write_eeprom(struct atl2_hw *hw, u32 offset, u32
> value); +static s32 atl2_phy_init(struct atl2_hw *hw); +static int
> atl2_check_eeprom_exist(struct atl2_hw *hw); +static void
> atl2_force_ps(struct atl2_hw *hw); +
> +/* register definition */
> +
> +/* Block IDLE Status Register */
> +#define IDLE_STATUS_RXMAC 1 /* 1: RXMAC is non-IDLE */
> +#define IDLE_STATUS_TXMAC 2 /* 1: TXMAC is non-IDLE */
> +#define IDLE_STATUS_DMAR 8 /* 1: DMAR is non-IDLE */
> +#define IDLE_STATUS_DMAW 4 /* 1: DMAW is non-IDLE */
> +
> +/* MDIO Control Register */
> +#define MDIO_WAIT_TIMES 10
> +
> +/* MAC Control Register */
> +#define MAC_CTRL_DBG_TX_BKPRESURE 0x100000 /* 1: TX
> max backoff */ +#define MAC_CTRL_MACLP_CLK_PHY
> 0x8000000 /* 1: 25MHz from phy */ +#define
> MAC_CTRL_HALF_LEFT_BUF_SHIFT 28 +#define
> MAC_CTRL_HALF_LEFT_BUF_MASK 0xF /* MAC retry
> buf x32B */ + +/* Internal SRAM Partition Register */
> +#define REG_SRAM_TXRAM_END 0x1500 /* Internal tail
> address of TXRAM default: 2byte*1024 */ +#define
> REG_SRAM_RXRAM_END 0x1502 /* Internal tail address of
> RXRAM default: 2byte*1024 */ + +/* Descriptor Control register */
> +#define REG_TXD_BASE_ADDR_LO 0x1544 /* The base
> address of the Transmit Data Memory low 32-bit(dword align) */
> +#define REG_TXD_MEM_SIZE 0x1548 /* Transmit Data
> Memory size(by double word , max 256KB) */ +#define
> REG_TXS_BASE_ADDR_LO 0x154C /* The base address of the
> Transmit Status Memory low 32-bit(dword word align) */ +#define
> REG_TXS_MEM_SIZE 0x1550 /* double word unit, max 4*2047
> bytes. */ +#define REG_RXD_BASE_ADDR_LO 0x1554 /* The
> base address of the Transmit Status Memory low 32-bit(unit 8 bytes)
> */ +#define REG_RXD_BUF_NUM 0x1558 /* Receive
> Data & Status Memory buffer number (unit 1536bytes, max 1536*2047) */
> + +/* DMAR Control Register */ +#define REG_DMAR 0x1580
> +#define DMAR_EN 0x1 /* 1: Enable DMAR */ + +/* TX
> Cur-Through (early tx threshold) Control Register */ +#define
> REG_TX_CUT_THRESH 0x1590 /* TxMac begin transmit packet
> threshold(unit word) */ + +/* DMAW Control Register */ +#define
> REG_DMAW 0x15A0 +#define DMAW_EN 0x1
> +
> +/* Flow control register */
> +#define REG_PAUSE_ON_TH 0x15A8 /* RXD high
> watermark of overflow threshold configuration register */ +#define
> REG_PAUSE_OFF_TH 0x15AA /* RXD lower watermark of
> overflow threshold configuration register */ + +/* Mailbox Register */
> +#define REG_MB_TXD_WR_IDX 0x15f0 /* double word align
> */ +#define REG_MB_RXD_RD_IDX 0x15F4 /* RXD Read index
> (unit: 1536byets) */ +
> +/* Interrupt Status Register */
> +#define ISR_TIMER 1 /* Interrupt when Timer is counted
> down to zero */ +#define ISR_MANUAL 2 /* Software
> manual interrupt, for debug. Set when SW_MAN_INT_EN is set in Table
> 51 Selene Master Control Register (Offset 0x1400). */ +#define
> ISR_RXF_OV 4 /* RXF overflow interrupt */ +#define
> ISR_TXF_UR 8 /* TXF underrun interrupt */ +#define
> ISR_TXS_OV 0x10 /* Internal transmit status buffer full
> interrupt */ +#define ISR_RXS_OV 0x20 /* Internal
> receive status buffer ful interrupt */ +#define ISR_LINK_CHG
> 0x40 /* Link Status Change Interrupt */ +#define
> ISR_HOST_TXD_UR 0x80 +#define ISR_HOST_RXD_OV
> 0x100 /* Host rx data memory full , one pulse */ +#define
> ISR_DMAR_TO_RST 0x200 /* DMAR op timeout interrupt. SW
> should do Reset */ +#define ISR_DMAW_TO_RST 0x400 +#define
> ISR_PHY 0x800 /* phy interrupt */ +#define
> ISR_TS_UPDATE 0x10000 /* interrupt after new tx pkt
> status written to host */ +#define ISR_RS_UPDATE
> 0x20000 /* interrupt ater new rx pkt status written to host.
> */ +#define ISR_TX_EARLY 0x40000 /* interrupt when
> txmac begin transmit one packet */ + +#define ISR_TX_EVENT
> (ISR_TXF_UR|ISR_TXS_OV|ISR_HOST_TXD_UR|ISR_TS_UPDATE|ISR_TX_EARLY)
> +#define ISR_RX_EVENT
> (ISR_RXF_OV|ISR_RXS_OV|ISR_HOST_RXD_OV|ISR_RS_UPDATE) + +#define
> IMR_NORMAL_MASK (\
> + /*ISR_LINK_CHG |*/\
> + ISR_MANUAL |\
> + ISR_DMAR_TO_RST |\
> + ISR_DMAW_TO_RST |\
> + ISR_PHY |\
> + ISR_PHY_LINKDOWN |\
> + ISR_TS_UPDATE |\
> + ISR_RS_UPDATE )
> +
> +/* Receive MAC Statistics Registers */
> +#define REG_STS_RX_PAUSE 0x1700 /* The number of Pause
> packet received */ +#define REG_STS_RXD_OV
> 0x1704 /* The number of frame dropped due to occurrence of RX
> FIFO overflow */ +#define REG_STS_RXS_OV
> 0x1708 /* The number of frame dropped due to occerrence of RX
> Status Buffer Overflow */ +#define REG_STS_RX_FILTER
> 0x170C /* The number of packet dropped due to address
> filtering */ + +/* MII definitions */ + +/* PHY Common Register */
> +#define MII_SMARTSPEED 0x14
> +#define MII_DBG_ADDR 0x1D
> +#define MII_DBG_DATA 0x1E
> +
> +/* PCI Command Register Bit Definitions */
> +#define PCI_REG_COMMAND 0x04
> +#define CMD_IO_SPACE 0x0001
> +#define CMD_MEMORY_SPACE 0x0002
> +#define CMD_BUS_MASTER 0x0004
> +
> +#define MEDIA_TYPE_100M_FULL 1
> +#define MEDIA_TYPE_100M_HALF 2
> +#define MEDIA_TYPE_10M_FULL 3
> +#define MEDIA_TYPE_10M_HALF 4
> +
> +#define AUTONEG_ADVERTISE_SPEED_DEFAULT 0x000F /*
> Everything */ +
> +/* The size (in bytes) of a ethernet packet */
> +#define ENET_HEADER_SIZE 14
> +#define MAXIMUM_ETHERNET_FRAME_SIZE 1518 /* with FCS */
> +#define MINIMUM_ETHERNET_FRAME_SIZE 64 /* with FCS */
> +#define ETHERNET_FCS_SIZE 4
> +#define MAX_JUMBO_FRAME_SIZE 0x2000
> +#define VLAN_SIZE 4
> +
> +typedef struct _tx_pkt_header {
> + unsigned pkt_size : 11;
> + unsigned : 4; // reserved
> + unsigned ins_vlan : 1; // txmac should insert
> vlan
> + unsigned short vlan ; // vlan tag
> +} tx_pkt_header_t;
> +/* FIXME: replace above bitfields with MASK/SHIFT defines below */
> +#define TX_PKT_HEADER_SIZE_MASK 0x7FF
> +#define TX_PKT_HEADER_SIZE_SHIFT 0
> +#define TX_PKT_HEADER_INS_VLAN_MASK 0x1
> +#define TX_PKT_HEADER_INS_VLAN_SHIFT 15
> +#define TX_PKT_HEADER_VLAN_TAG_MASK 0xFFFF
> +#define TX_PKT_HEADER_VLAN_TAG_SHIFT 16
> +
> +typedef struct _tx_pkt_status {
> + unsigned pkt_size : 11;
> + unsigned : 5; // reserved
> + unsigned ok : 1; // current packet is
> transmitted ok without error
> + unsigned bcast : 1; // current packet is
> broadcast
> + unsigned mcast : 1; // current packet is
> multicast
> + unsigned pause : 1; // transmiited a pause
> frame
> + unsigned ctrl : 1;
> + unsigned defer : 1; // current packet is
> xmitted with defer.
> + unsigned exc_defer : 1;
> + unsigned single_col : 1;
> + unsigned multi_col : 1;
> + unsigned late_col : 1;
> + unsigned abort_col : 1;
> + unsigned underun : 1; // current packet is
> abort due to txram underrun.
> + unsigned : 3; // reserved
> + unsigned update : 1; // always 1'b1 in
> tx_status_buf. +} tx_pkt_status_t;
> +/* FIXME: replace above bitfields with MASK/SHIFT defines below */
> +#define TX_PKT_STATUS_SIZE_MASK 0x7FF
> +#define TX_PKT_STATUS_SIZE_SHIFT 0
> +#define TX_PKT_STATUS_OK_MASK 0x1
> +#define TX_PKT_STATUS_OK_SHIFT 16
> +#define TX_PKT_STATUS_BCAST_MASK 0x1
> +#define TX_PKT_STATUS_BCAST_SHIFT 17
> +#define TX_PKT_STATUS_MCAST_MASK 0x1
> +#define TX_PKT_STATUS_MCAST_SHIFT 18
> +#define TX_PKT_STATUS_PAUSE_MASK 0x1
> +#define TX_PKT_STATUS_PAUSE_SHIFT 19
> +#define TX_PKT_STATUS_CTRL_MASK 0x1
> +#define TX_PKT_STATUS_CTRL_SHIFT 20
> +#define TX_PKT_STATUS_DEFER_MASK 0x1
> +#define TX_PKT_STATUS_DEFER_SHIFT 21
> +#define TX_PKT_STATUS_EXC_DEFER_MASK 0x1
> +#define TX_PKT_STATUS_EXC_DEFER_SHIFT 22
> +#define TX_PKT_STATUS_SINGLE_COL_MASK 0x1
> +#define TX_PKT_STATUS_SINGLE_COL_SHIFT 23
> +#define TX_PKT_STATUS_MULTI_COL_MASK 0x1
> +#define TX_PKT_STATUS_MULTI_COL_SHIFT 24
> +#define TX_PKT_STATUS_LATE_COL_MASK 0x1
> +#define TX_PKT_STATUS_LATE_COL_SHIFT 25
> +#define TX_PKT_STATUS_ABORT_COL_MASK 0x1
> +#define TX_PKT_STATUS_ABORT_COL_SHIFT 26
> +#define TX_PKT_STATUS_UNDERRUN_MASK 0x1
> +#define TX_PKT_STATUS_UNDERRUN_SHIFT 27
> +#define TX_PKT_STATUS_UPDATE_MASK 0x1
> +#define TX_PKT_STATUS_UPDATE_SHIFT 31
> +
> +typedef struct _rx_pkt_status {
> + unsigned pkt_size : 11; // packet size, max
> 2047bytes
> + unsigned : 5; // reserved
> + unsigned ok : 1; // current packet is
> received ok without error.
> + unsigned bcast : 1; // current packet is
> broadcast.
> + unsigned mcast : 1; // current packet is
> multicast.
> + unsigned pause : 1;
> + unsigned ctrl : 1;
> + unsigned crc : 1; // received a packet
> with crc error.
> + unsigned code : 1; // received a packet
> with code error.
> + unsigned runt : 1; // received a packet
> less than 64bytes with good crc
> + unsigned frag :
> 1; // ....................................with bad crc
> + unsigned trunc : 1; // current frame is
> cutted due to rxram full.
> + unsigned align : 1; // this packet is
> alignment error.
> + unsigned vlan : 1; // this packet has vlan
> + unsigned : 3; // reserved
> + unsigned update : 1;
> + unsigned short vtag ; // vlan tag
> + unsigned : 16;
> +} rx_pkt_status_t;
> +/* FIXME: replace above bitfields with MASK/SHIFT defines below */
> +#define RX_PKT_STATUS_SIZE_MASK 0x7FF
> +#define RX_PKT_STATUS_SIZE_SHIFT 0
> +#define RX_PKT_STATUS_OK_MASK 0x1
> +#define RX_PKT_STATUS_OK_SHIFT 16
> +#define RX_PKT_STATUS_BCAST_MASK 0x1
> +#define RX_PKT_STATUS_BCAST_SHIFT 17
> +#define RX_PKT_STATUS_MCAST_MASK 0x1
> +#define RX_PKT_STATUS_MCAST_SHIFT 18
> +#define RX_PKT_STATUS_PAUSE_MASK 0x1
> +#define RX_PKT_STATUS_PAUSE_SHIFT 19
> +#define RX_PKT_STATUS_CTRL_MASK 0x1
> +#define RX_PKT_STATUS_CTRL_SHIFT 20
> +#define RX_PKT_STATUS_CRC_MASK 0x1
> +#define RX_PKT_STATUS_CRC_SHIFT 21
> +#define RX_PKT_STATUS_CODE_MASK 0x1
> +#define RX_PKT_STATUS_CODE_SHIFT 22
> +#define RX_PKT_STATUS_RUNT_MASK 0x1
> +#define RX_PKT_STATUS_RUNT_SHIFT 23
> +#define RX_PKT_STATUS_FRAG_MASK 0x1
> +#define RX_PKT_STATUS_FRAG_SHIFT 24
> +#define RX_PKT_STATUS_TRUNK_MASK 0x1
> +#define RX_PKT_STATUS_TRUNK_SHIFT 25
> +#define RX_PKT_STATUS_ALIGN_MASK 0x1
> +#define RX_PKT_STATUS_ALIGN_SHIFT 26
> +#define RX_PKT_STATUS_VLAN_MASK 0x1
> +#define RX_PKT_STATUS_VLAN_SHIFT 27
> +#define RX_PKT_STATUS_UPDATE_MASK 0x1
> +#define RX_PKT_STATUS_UPDATE_SHIFT 31
> +#define RX_PKT_STATUS_VLAN_TAG_MASK 0xFFFF
> +#define RX_PKT_STATUS_VLAN_TAG_SHIFT 32
> +
> +typedef struct _rx_desc {
> + rx_pkt_status_t status;
> + unsigned char packet[1536-sizeof(rx_pkt_status_t)];
> +} rx_desc_t;
> +
> +typedef enum {
> + atl2_10_half = 0,
> + atl2_10_full = 1,
> + atl2_100_half = 2,
> + atl2_100_full = 3
> +} atl2_speed_duplex_type;
> +
> +struct atl2_spi_flash_dev {
> + const char *manu_name; /* manufacturer id */
> + /* op-code */
> + u8 cmdWRSR;
> + u8 cmdREAD;
> + u8 cmdPROGRAM;
> + u8 cmdWREN;
> + u8 cmdWRDI;
> + u8 cmdRDSR;
> + u8 cmdRDID;
> + u8 cmdSECTOR_ERASE;
> + u8 cmdCHIP_ERASE;
> +};
> +
> +/* Structure containing variables used by the shared code
> (atl2_hw.c) */ +struct atl2_hw {
> + u8 __iomem *hw_addr;
> + void *back;
> +
> + u8 preamble_len;
> + u8 max_retry; // Retransmission maximum ,
> afterwards the packet will be discarded.
> + u8 jam_ipg; // IPG to start JAM for collision
> based flow control in half-duplex mode. In unit of 8-bit time.
> + u8 ipgt; // Desired back to back inter-packet
> gap. The default is 96-bit time.
> + u8 min_ifg; // Minimum number of IFG to enforce
> in between RX frames. Frame gap below such IFP is dropped.
> + u8 ipgr1; // 64bit Carrier-Sense window
> + u8 ipgr2; // 96-bit IPG window
> + u8 retry_buf; // When half-duplex mode, should hold
> some bytes for mac retry . (8*4bytes unit)
> +
> + u16 fc_rxd_hi;
> + u16 fc_rxd_lo;
> + u16 lcol; // Collision Window
> + u16 max_frame_size;
> +
> + u16 MediaType;
> + u16 autoneg_advertised;
> + u16 pci_cmd_word;
> +
> + u16 mii_autoneg_adv_reg;
> +
> + u32 mem_rang;
> + u32 txcw;
> + u32 mc_filter_type;
> + u32 num_mc_addrs;
> + u32 collision_delta;
> + u32 tx_packet_delta;
> + u16 phy_spd_default;
> +
> + u16 device_id;
> + u16 vendor_id;
> + u16 subsystem_id;
> + u16 subsystem_vendor_id;
> + u8 revision_id;
> +
> + // spi flash
> + u8 flash_vendor;
> +
> + u8 dma_fairness;
> + u8 mac_addr[NODE_ADDRESS_SIZE];
> + u8 perm_mac_addr[NODE_ADDRESS_SIZE];
> +
> + // bool phy_preamble_sup;
> + bool phy_configured;
> +};
> +
> +#endif /* _ATL2_HW_H_ */
> +
> +struct atl2_ring_header {
> + /* pointer to the descriptor ring memory */
> + void *desc;
> + /* physical adress of the descriptor ring */
> + dma_addr_t dma;
> + /* length of descriptor ring in bytes */
> + unsigned int size;
> +};
> +
> +/* board specific private data structure */
> +struct atl2_adapter {
> + /* OS defined structs */
> + struct net_device *netdev;
> + struct pci_dev *pdev;
> + struct net_device_stats net_stats;
> +#ifdef NETIF_F_HW_VLAN_TX
> + struct vlan_group *vlgrp;
> +#endif
> + u32 wol;
> + u16 link_speed;
> + u16 link_duplex;
> +
> + spinlock_t stats_lock;
> + spinlock_t tx_lock;
> +
> + struct work_struct reset_task;
> + struct work_struct link_chg_task;
> + struct timer_list watchdog_timer;
> + struct timer_list phy_config_timer;
> +
> + unsigned long cfg_phy;
> + bool mac_disabled;
> +
> + /* All Descriptor memory */
> + dma_addr_t ring_dma;
> + void *ring_vir_addr;
> + int ring_size;
> +
> + tx_pkt_header_t *txd_ring;
> + dma_addr_t txd_dma;
> +
> + tx_pkt_status_t *txs_ring;
> + dma_addr_t txs_dma;
> +
> + rx_desc_t *rxd_ring;
> + dma_addr_t rxd_dma;
> +
> + u32 txd_ring_size; // bytes per unit
> + u32 txs_ring_size; // dwords per unit
> + u32 rxd_ring_size; // 1536bytes per unit
> +
> + // read /write ptr:
> + // host
> + u32 txd_write_ptr;
> + u32 txs_next_clear;
> + u32 rxd_read_ptr;
> +
> + // nic
> + atomic_t txd_read_ptr;
> + atomic_t txs_write_ptr;
> + u32 rxd_write_ptr;
> +
> + /* Interrupt Moderator timer ( 2us resolution) */
> + u16 imt;
> + /* Interrupt Clear timer (2us resolution) */
> + u16 ict;
> +
> + unsigned long flags;
> + /* structs defined in atl2_hw.h */
> + u32 bd_number; // board number;
> + bool pci_using_64;
> + bool have_msi;
> + struct atl2_hw hw;
> +
> + u32 usr_cmd;
> +// u32 regs_buff[ATL2_REGS_LEN];
> + u32 pci_state[16];
> +
> + u32 *config_space;
> +};
> +
> +enum atl2_state_t {
> + __ATL2_TESTING,
> + __ATL2_RESETTING,
> + __ATL2_DOWN
> +};
> +
> +#endif /* _ATL2_H_ */
> --
> To unsubscribe from this list: send the line "unsubscribe netdev" in
> the body of a message to majordomo@...r.kernel.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists