Commit f8c047be authored by Coiby Xu's avatar Coiby Xu Committed by Greg Kroah-Hartman

staging: qlge: use qlge_* prefix to avoid namespace clashes with other qlogic drivers

To avoid namespace clashes with other qlogic drivers and also for the
sake of naming consistency, use the "qlge_" prefix as suggested in
drivers/staging/qlge/TODO,
 - For existing ql_ prefix,
   sed -i "s/ql_/qlge_/g" *.{c,h}
 - for structs not having a prefix
   1. get a list of structs
      grep "struct.*{" qlge.
   2. add qlge_ for each struct, e.g.,
      sed -i "s/ib_ae_iocb_rsp/qlge_ib_ae_iocb_rsp/g" *.{c,h}

Link: https://lore.kernel.org/patchwork/patch/1318503/#1516131Suggested-by: default avatarBenjamin Poirier <benjamin.poirier@gmail.com>
Signed-off-by: default avatarCoiby Xu <coiby.xu@gmail.com>
Link: https://lore.kernel.org/r/20210123104613.38359-2-coiby.xu@gmail.comSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 684ceb81
...@@ -28,10 +28,6 @@ ...@@ -28,10 +28,6 @@
* the driver has a habit of using runtime checks where compile time checks are * the driver has a habit of using runtime checks where compile time checks are
possible (ex. ql_free_rx_buffers(), ql_alloc_rx_buffers()) possible (ex. ql_free_rx_buffers(), ql_alloc_rx_buffers())
* reorder struct members to avoid holes if it doesn't impact performance * reorder struct members to avoid holes if it doesn't impact performance
* in terms of namespace, the driver uses either qlge_, ql_ (used by
other qlogic drivers, with clashes, ex: ql_sem_spinlock) or nothing (with
clashes, ex: struct ob_mac_iocb_req). Rename everything to use the "qlge_"
prefix.
* avoid legacy/deprecated apis (ex. replace pci_dma_*, replace pci_enable_msi, * avoid legacy/deprecated apis (ex. replace pci_dma_*, replace pci_enable_msi,
use pci_iomap) use pci_iomap)
* some "while" loops could be rewritten with simple "for", ex. * some "while" loops could be rewritten with simple "for", ex.
......
...@@ -1081,7 +1081,7 @@ struct tx_buf_desc { ...@@ -1081,7 +1081,7 @@ struct tx_buf_desc {
#define OPCODE_IB_MPI_IOCB 0x21 #define OPCODE_IB_MPI_IOCB 0x21
#define OPCODE_IB_AE_IOCB 0x3f #define OPCODE_IB_AE_IOCB 0x3f
struct ob_mac_iocb_req { struct qlge_ob_mac_iocb_req {
u8 opcode; u8 opcode;
u8 flags1; u8 flags1;
#define OB_MAC_IOCB_REQ_OI 0x01 #define OB_MAC_IOCB_REQ_OI 0x01
...@@ -1104,7 +1104,7 @@ struct ob_mac_iocb_req { ...@@ -1104,7 +1104,7 @@ struct ob_mac_iocb_req {
struct tx_buf_desc tbd[TX_DESC_PER_IOCB]; struct tx_buf_desc tbd[TX_DESC_PER_IOCB];
} __packed; } __packed;
struct ob_mac_iocb_rsp { struct qlge_ob_mac_iocb_rsp {
u8 opcode; /* */ u8 opcode; /* */
u8 flags1; /* */ u8 flags1; /* */
#define OB_MAC_IOCB_RSP_OI 0x01 /* */ #define OB_MAC_IOCB_RSP_OI 0x01 /* */
...@@ -1121,7 +1121,7 @@ struct ob_mac_iocb_rsp { ...@@ -1121,7 +1121,7 @@ struct ob_mac_iocb_rsp {
__le32 reserved[13]; __le32 reserved[13];
} __packed; } __packed;
struct ob_mac_tso_iocb_req { struct qlge_ob_mac_tso_iocb_req {
u8 opcode; u8 opcode;
u8 flags1; u8 flags1;
#define OB_MAC_TSO_IOCB_OI 0x01 #define OB_MAC_TSO_IOCB_OI 0x01
...@@ -1149,7 +1149,7 @@ struct ob_mac_tso_iocb_req { ...@@ -1149,7 +1149,7 @@ struct ob_mac_tso_iocb_req {
struct tx_buf_desc tbd[TX_DESC_PER_IOCB]; struct tx_buf_desc tbd[TX_DESC_PER_IOCB];
} __packed; } __packed;
struct ob_mac_tso_iocb_rsp { struct qlge_ob_mac_tso_iocb_rsp {
u8 opcode; u8 opcode;
u8 flags1; u8 flags1;
#define OB_MAC_TSO_IOCB_RSP_OI 0x01 #define OB_MAC_TSO_IOCB_RSP_OI 0x01
...@@ -1166,7 +1166,7 @@ struct ob_mac_tso_iocb_rsp { ...@@ -1166,7 +1166,7 @@ struct ob_mac_tso_iocb_rsp {
__le32 reserved2[13]; __le32 reserved2[13];
} __packed; } __packed;
struct ib_mac_iocb_rsp { struct qlge_ib_mac_iocb_rsp {
u8 opcode; /* 0x20 */ u8 opcode; /* 0x20 */
u8 flags1; u8 flags1;
#define IB_MAC_IOCB_RSP_OI 0x01 /* Override intr delay */ #define IB_MAC_IOCB_RSP_OI 0x01 /* Override intr delay */
...@@ -1225,7 +1225,7 @@ struct ib_mac_iocb_rsp { ...@@ -1225,7 +1225,7 @@ struct ib_mac_iocb_rsp {
__le64 hdr_addr; /* */ __le64 hdr_addr; /* */
} __packed; } __packed;
struct ib_ae_iocb_rsp { struct qlge_ib_ae_iocb_rsp {
u8 opcode; u8 opcode;
u8 flags1; u8 flags1;
#define IB_AE_IOCB_RSP_OI 0x01 #define IB_AE_IOCB_RSP_OI 0x01
...@@ -1250,7 +1250,7 @@ struct ib_ae_iocb_rsp { ...@@ -1250,7 +1250,7 @@ struct ib_ae_iocb_rsp {
* These three structures are for generic * These three structures are for generic
* handling of ib and ob iocbs. * handling of ib and ob iocbs.
*/ */
struct ql_net_rsp_iocb { struct qlge_net_rsp_iocb {
u8 opcode; u8 opcode;
u8 flags0; u8 flags0;
__le16 length; __le16 length;
...@@ -1258,7 +1258,7 @@ struct ql_net_rsp_iocb { ...@@ -1258,7 +1258,7 @@ struct ql_net_rsp_iocb {
__le32 reserved[14]; __le32 reserved[14];
} __packed; } __packed;
struct net_req_iocb { struct qlge_net_req_iocb {
u8 opcode; u8 opcode;
u8 flags0; u8 flags0;
__le16 flags1; __le16 flags1;
...@@ -1346,7 +1346,7 @@ struct ricb { ...@@ -1346,7 +1346,7 @@ struct ricb {
/* SOFTWARE/DRIVER DATA STRUCTURES. */ /* SOFTWARE/DRIVER DATA STRUCTURES. */
struct oal { struct qlge_oal {
struct tx_buf_desc oal[TX_DESC_PER_OAL]; struct tx_buf_desc oal[TX_DESC_PER_OAL];
}; };
...@@ -1357,9 +1357,9 @@ struct map_list { ...@@ -1357,9 +1357,9 @@ struct map_list {
struct tx_ring_desc { struct tx_ring_desc {
struct sk_buff *skb; struct sk_buff *skb;
struct ob_mac_iocb_req *queue_entry; struct qlge_ob_mac_iocb_req *queue_entry;
u32 index; u32 index;
struct oal oal; struct qlge_oal oal;
struct map_list map[MAX_SKB_FRAGS + 2]; struct map_list map[MAX_SKB_FRAGS + 2];
int map_cnt; int map_cnt;
struct tx_ring_desc *next; struct tx_ring_desc *next;
...@@ -1388,7 +1388,7 @@ struct tx_ring { ...@@ -1388,7 +1388,7 @@ struct tx_ring {
spinlock_t lock; spinlock_t lock;
atomic_t tx_count; /* counts down for every outstanding IO */ atomic_t tx_count; /* counts down for every outstanding IO */
struct delayed_work tx_work; struct delayed_work tx_work;
struct ql_adapter *qdev; struct qlge_adapter *qdev;
u64 tx_packets; u64 tx_packets;
u64 tx_bytes; u64 tx_bytes;
u64 tx_errors; u64 tx_errors;
...@@ -1469,7 +1469,7 @@ struct rx_ring { ...@@ -1469,7 +1469,7 @@ struct rx_ring {
dma_addr_t prod_idx_sh_reg_dma; dma_addr_t prod_idx_sh_reg_dma;
void __iomem *cnsmr_idx_db_reg; /* PCI doorbell mem area + 0 */ void __iomem *cnsmr_idx_db_reg; /* PCI doorbell mem area + 0 */
u32 cnsmr_idx; /* current sw idx */ u32 cnsmr_idx; /* current sw idx */
struct ql_net_rsp_iocb *curr_entry; /* next entry on queue */ struct qlge_net_rsp_iocb *curr_entry; /* next entry on queue */
void __iomem *valid_db_reg; /* PCI doorbell mem area + 0x04 */ void __iomem *valid_db_reg; /* PCI doorbell mem area + 0x04 */
/* Large buffer queue elements. */ /* Large buffer queue elements. */
...@@ -1487,7 +1487,7 @@ struct rx_ring { ...@@ -1487,7 +1487,7 @@ struct rx_ring {
char name[IFNAMSIZ + 5]; char name[IFNAMSIZ + 5];
struct napi_struct napi; struct napi_struct napi;
u8 reserved; u8 reserved;
struct ql_adapter *qdev; struct qlge_adapter *qdev;
u64 rx_packets; u64 rx_packets;
u64 rx_multicast; u64 rx_multicast;
u64 rx_bytes; u64 rx_bytes;
...@@ -1752,14 +1752,14 @@ enum { ...@@ -1752,14 +1752,14 @@ enum {
#define SHADOW_OFFSET 0xb0000000 #define SHADOW_OFFSET 0xb0000000
#define SHADOW_REG_SHIFT 20 #define SHADOW_REG_SHIFT 20
struct ql_nic_misc { struct qlge_nic_misc {
u32 rx_ring_count; u32 rx_ring_count;
u32 tx_ring_count; u32 tx_ring_count;
u32 intr_count; u32 intr_count;
u32 function; u32 function;
}; };
struct ql_reg_dump { struct qlge_reg_dump {
/* segment 0 */ /* segment 0 */
struct mpi_coredump_global_header mpi_global_header; struct mpi_coredump_global_header mpi_global_header;
...@@ -1769,7 +1769,7 @@ struct ql_reg_dump { ...@@ -1769,7 +1769,7 @@ struct ql_reg_dump {
/* segment 30 */ /* segment 30 */
struct mpi_coredump_segment_header misc_nic_seg_hdr; struct mpi_coredump_segment_header misc_nic_seg_hdr;
struct ql_nic_misc misc_nic_info; struct qlge_nic_misc misc_nic_info;
/* segment 31 */ /* segment 31 */
/* one interrupt state for each CQ */ /* one interrupt state for each CQ */
...@@ -1792,7 +1792,7 @@ struct ql_reg_dump { ...@@ -1792,7 +1792,7 @@ struct ql_reg_dump {
u32 ets[8 + 2]; u32 ets[8 + 2];
}; };
struct ql_mpi_coredump { struct qlge_mpi_coredump {
/* segment 0 */ /* segment 0 */
struct mpi_coredump_global_header mpi_global_header; struct mpi_coredump_global_header mpi_global_header;
...@@ -1914,7 +1914,7 @@ struct ql_mpi_coredump { ...@@ -1914,7 +1914,7 @@ struct ql_mpi_coredump {
/* segment 30 */ /* segment 30 */
struct mpi_coredump_segment_header misc_nic_seg_hdr; struct mpi_coredump_segment_header misc_nic_seg_hdr;
struct ql_nic_misc misc_nic_info; struct qlge_nic_misc misc_nic_info;
/* segment 31 */ /* segment 31 */
/* one interrupt state for each CQ */ /* one interrupt state for each CQ */
...@@ -1991,7 +1991,7 @@ struct ql_mpi_coredump { ...@@ -1991,7 +1991,7 @@ struct ql_mpi_coredump {
* irq environment as a context to the ISR. * irq environment as a context to the ISR.
*/ */
struct intr_context { struct intr_context {
struct ql_adapter *qdev; struct qlge_adapter *qdev;
u32 intr; u32 intr;
u32 irq_mask; /* Mask of which rings the vector services. */ u32 irq_mask; /* Mask of which rings the vector services. */
u32 hooked; u32 hooked;
...@@ -2056,15 +2056,15 @@ enum { ...@@ -2056,15 +2056,15 @@ enum {
}; };
struct nic_operations { struct nic_operations {
int (*get_flash)(struct ql_adapter *qdev); int (*get_flash)(struct qlge_adapter *qdev);
int (*port_initialize)(struct ql_adapter *qdev); int (*port_initialize)(struct qlge_adapter *qdev);
}; };
/* /*
* The main Adapter structure definition. * The main Adapter structure definition.
* This structure has all fields relevant to the hardware. * This structure has all fields relevant to the hardware.
*/ */
struct ql_adapter { struct qlge_adapter {
struct ricb ricb; struct ricb ricb;
unsigned long flags; unsigned long flags;
u32 wol; u32 wol;
...@@ -2139,7 +2139,7 @@ struct ql_adapter { ...@@ -2139,7 +2139,7 @@ struct ql_adapter {
u32 port_link_up; u32 port_link_up;
u32 port_init; u32 port_init;
u32 link_status; u32 link_status;
struct ql_mpi_coredump *mpi_coredump; struct qlge_mpi_coredump *mpi_coredump;
u32 core_is_dumped; u32 core_is_dumped;
u32 link_config; u32 link_config;
u32 led_config; u32 led_config;
...@@ -2166,7 +2166,7 @@ struct ql_adapter { ...@@ -2166,7 +2166,7 @@ struct ql_adapter {
/* /*
* Typical Register accessor for memory mapped device. * Typical Register accessor for memory mapped device.
*/ */
static inline u32 ql_read32(const struct ql_adapter *qdev, int reg) static inline u32 qlge_read32(const struct qlge_adapter *qdev, int reg)
{ {
return readl(qdev->reg_base + reg); return readl(qdev->reg_base + reg);
} }
...@@ -2174,7 +2174,7 @@ static inline u32 ql_read32(const struct ql_adapter *qdev, int reg) ...@@ -2174,7 +2174,7 @@ static inline u32 ql_read32(const struct ql_adapter *qdev, int reg)
/* /*
* Typical Register accessor for memory mapped device. * Typical Register accessor for memory mapped device.
*/ */
static inline void ql_write32(const struct ql_adapter *qdev, int reg, u32 val) static inline void qlge_write32(const struct qlge_adapter *qdev, int reg, u32 val)
{ {
writel(val, qdev->reg_base + reg); writel(val, qdev->reg_base + reg);
} }
...@@ -2189,7 +2189,7 @@ static inline void ql_write32(const struct ql_adapter *qdev, int reg, u32 val) ...@@ -2189,7 +2189,7 @@ static inline void ql_write32(const struct ql_adapter *qdev, int reg, u32 val)
* 1 4k chunk of memory. The lower half of the space is for outbound * 1 4k chunk of memory. The lower half of the space is for outbound
* queues. The upper half is for inbound queues. * queues. The upper half is for inbound queues.
*/ */
static inline void ql_write_db_reg(u32 val, void __iomem *addr) static inline void qlge_write_db_reg(u32 val, void __iomem *addr)
{ {
writel(val, addr); writel(val, addr);
} }
...@@ -2205,7 +2205,7 @@ static inline void ql_write_db_reg(u32 val, void __iomem *addr) ...@@ -2205,7 +2205,7 @@ static inline void ql_write_db_reg(u32 val, void __iomem *addr)
* queues. The upper half is for inbound queues. * queues. The upper half is for inbound queues.
* Caller has to guarantee ordering. * Caller has to guarantee ordering.
*/ */
static inline void ql_write_db_reg_relaxed(u32 val, void __iomem *addr) static inline void qlge_write_db_reg_relaxed(u32 val, void __iomem *addr)
{ {
writel_relaxed(val, addr); writel_relaxed(val, addr);
} }
...@@ -2220,7 +2220,7 @@ static inline void ql_write_db_reg_relaxed(u32 val, void __iomem *addr) ...@@ -2220,7 +2220,7 @@ static inline void ql_write_db_reg_relaxed(u32 val, void __iomem *addr)
* update the relevant index register and then copy the value to the * update the relevant index register and then copy the value to the
* shadow register in host memory. * shadow register in host memory.
*/ */
static inline u32 ql_read_sh_reg(__le32 *addr) static inline u32 qlge_read_sh_reg(__le32 *addr)
{ {
u32 reg; u32 reg;
...@@ -2233,51 +2233,51 @@ extern char qlge_driver_name[]; ...@@ -2233,51 +2233,51 @@ extern char qlge_driver_name[];
extern const char qlge_driver_version[]; extern const char qlge_driver_version[];
extern const struct ethtool_ops qlge_ethtool_ops; extern const struct ethtool_ops qlge_ethtool_ops;
int ql_sem_spinlock(struct ql_adapter *qdev, u32 sem_mask); int qlge_sem_spinlock(struct qlge_adapter *qdev, u32 sem_mask);
void ql_sem_unlock(struct ql_adapter *qdev, u32 sem_mask); void qlge_sem_unlock(struct qlge_adapter *qdev, u32 sem_mask);
int ql_read_xgmac_reg(struct ql_adapter *qdev, u32 reg, u32 *data); int qlge_read_xgmac_reg(struct qlge_adapter *qdev, u32 reg, u32 *data);
int ql_get_mac_addr_reg(struct ql_adapter *qdev, u32 type, u16 index, int qlge_get_mac_addr_reg(struct qlge_adapter *qdev, u32 type, u16 index,
u32 *value); u32 *value);
int ql_get_routing_reg(struct ql_adapter *qdev, u32 index, u32 *value); int qlge_get_routing_reg(struct qlge_adapter *qdev, u32 index, u32 *value);
int ql_write_cfg(struct ql_adapter *qdev, void *ptr, int size, u32 bit, int qlge_write_cfg(struct qlge_adapter *qdev, void *ptr, int size, u32 bit,
u16 q_id); u16 q_id);
void ql_queue_fw_error(struct ql_adapter *qdev); void qlge_queue_fw_error(struct qlge_adapter *qdev);
void ql_mpi_work(struct work_struct *work); void qlge_mpi_work(struct work_struct *work);
void ql_mpi_reset_work(struct work_struct *work); void qlge_mpi_reset_work(struct work_struct *work);
void ql_mpi_core_to_log(struct work_struct *work); void qlge_mpi_core_to_log(struct work_struct *work);
int ql_wait_reg_rdy(struct ql_adapter *qdev, u32 reg, u32 bit, u32 ebit); int qlge_wait_reg_rdy(struct qlge_adapter *qdev, u32 reg, u32 bit, u32 ebit);
void ql_queue_asic_error(struct ql_adapter *qdev); void qlge_queue_asic_error(struct qlge_adapter *qdev);
void ql_set_ethtool_ops(struct net_device *ndev); void qlge_set_ethtool_ops(struct net_device *ndev);
int ql_read_xgmac_reg64(struct ql_adapter *qdev, u32 reg, u64 *data); int qlge_read_xgmac_reg64(struct qlge_adapter *qdev, u32 reg, u64 *data);
void ql_mpi_idc_work(struct work_struct *work); void qlge_mpi_idc_work(struct work_struct *work);
void ql_mpi_port_cfg_work(struct work_struct *work); void qlge_mpi_port_cfg_work(struct work_struct *work);
int ql_mb_get_fw_state(struct ql_adapter *qdev); int qlge_mb_get_fw_state(struct qlge_adapter *qdev);
int ql_cam_route_initialize(struct ql_adapter *qdev); int qlge_cam_route_initialize(struct qlge_adapter *qdev);
int ql_read_mpi_reg(struct ql_adapter *qdev, u32 reg, u32 *data); int qlge_read_mpi_reg(struct qlge_adapter *qdev, u32 reg, u32 *data);
int ql_write_mpi_reg(struct ql_adapter *qdev, u32 reg, u32 data); int qlge_write_mpi_reg(struct qlge_adapter *qdev, u32 reg, u32 data);
int ql_unpause_mpi_risc(struct ql_adapter *qdev); int qlge_unpause_mpi_risc(struct qlge_adapter *qdev);
int ql_pause_mpi_risc(struct ql_adapter *qdev); int qlge_pause_mpi_risc(struct qlge_adapter *qdev);
int ql_hard_reset_mpi_risc(struct ql_adapter *qdev); int qlge_hard_reset_mpi_risc(struct qlge_adapter *qdev);
int ql_soft_reset_mpi_risc(struct ql_adapter *qdev); int qlge_soft_reset_mpi_risc(struct qlge_adapter *qdev);
int ql_dump_risc_ram_area(struct ql_adapter *qdev, void *buf, u32 ram_addr, int qlge_dump_risc_ram_area(struct qlge_adapter *qdev, void *buf, u32 ram_addr,
int word_count); int word_count);
int ql_core_dump(struct ql_adapter *qdev, struct ql_mpi_coredump *mpi_coredump); int qlge_core_dump(struct qlge_adapter *qdev, struct qlge_mpi_coredump *mpi_coredump);
int ql_mb_about_fw(struct ql_adapter *qdev); int qlge_mb_about_fw(struct qlge_adapter *qdev);
int ql_mb_wol_set_magic(struct ql_adapter *qdev, u32 enable_wol); int qlge_mb_wol_set_magic(struct qlge_adapter *qdev, u32 enable_wol);
int ql_mb_wol_mode(struct ql_adapter *qdev, u32 wol); int qlge_mb_wol_mode(struct qlge_adapter *qdev, u32 wol);
int ql_mb_set_led_cfg(struct ql_adapter *qdev, u32 led_config); int qlge_mb_set_led_cfg(struct qlge_adapter *qdev, u32 led_config);
int ql_mb_get_led_cfg(struct ql_adapter *qdev); int qlge_mb_get_led_cfg(struct qlge_adapter *qdev);
void ql_link_on(struct ql_adapter *qdev); void qlge_link_on(struct qlge_adapter *qdev);
void ql_link_off(struct ql_adapter *qdev); void qlge_link_off(struct qlge_adapter *qdev);
int ql_mb_set_mgmnt_traffic_ctl(struct ql_adapter *qdev, u32 control); int qlge_mb_set_mgmnt_traffic_ctl(struct qlge_adapter *qdev, u32 control);
int ql_mb_get_port_cfg(struct ql_adapter *qdev); int qlge_mb_get_port_cfg(struct qlge_adapter *qdev);
int ql_mb_set_port_cfg(struct ql_adapter *qdev); int qlge_mb_set_port_cfg(struct qlge_adapter *qdev);
int ql_wait_fifo_empty(struct ql_adapter *qdev); int qlge_wait_fifo_empty(struct qlge_adapter *qdev);
void ql_get_dump(struct ql_adapter *qdev, void *buff); void qlge_get_dump(struct qlge_adapter *qdev, void *buff);
netdev_tx_t ql_lb_send(struct sk_buff *skb, struct net_device *ndev); netdev_tx_t qlge_lb_send(struct sk_buff *skb, struct net_device *ndev);
void ql_check_lb_frame(struct ql_adapter *qdev, struct sk_buff *skb); void qlge_check_lb_frame(struct qlge_adapter *qdev, struct sk_buff *skb);
int ql_own_firmware(struct ql_adapter *qdev); int qlge_own_firmware(struct qlge_adapter *qdev);
int ql_clean_lb_rx_ring(struct rx_ring *rx_ring, int budget); int qlge_clean_lb_rx_ring(struct rx_ring *rx_ring, int budget);
/* #define QL_ALL_DUMP */ /* #define QL_ALL_DUMP */
/* #define QL_REG_DUMP */ /* #define QL_REG_DUMP */
...@@ -2287,12 +2287,12 @@ int ql_clean_lb_rx_ring(struct rx_ring *rx_ring, int budget); ...@@ -2287,12 +2287,12 @@ int ql_clean_lb_rx_ring(struct rx_ring *rx_ring, int budget);
/* #define QL_OB_DUMP */ /* #define QL_OB_DUMP */
#ifdef QL_REG_DUMP #ifdef QL_REG_DUMP
void ql_dump_xgmac_control_regs(struct ql_adapter *qdev); void qlge_dump_xgmac_control_regs(struct qlge_adapter *qdev);
void ql_dump_routing_entries(struct ql_adapter *qdev); void qlge_dump_routing_entries(struct qlge_adapter *qdev);
void ql_dump_regs(struct ql_adapter *qdev); void qlge_dump_regs(struct qlge_adapter *qdev);
#define QL_DUMP_REGS(qdev) ql_dump_regs(qdev) #define QL_DUMP_REGS(qdev) qlge_dump_regs(qdev)
#define QL_DUMP_ROUTE(qdev) ql_dump_routing_entries(qdev) #define QL_DUMP_ROUTE(qdev) qlge_dump_routing_entries(qdev)
#define QL_DUMP_XGMAC_CONTROL_REGS(qdev) ql_dump_xgmac_control_regs(qdev) #define QL_DUMP_XGMAC_CONTROL_REGS(qdev) qlge_dump_xgmac_control_regs(qdev)
#else #else
#define QL_DUMP_REGS(qdev) #define QL_DUMP_REGS(qdev)
#define QL_DUMP_ROUTE(qdev) #define QL_DUMP_ROUTE(qdev)
...@@ -2300,33 +2300,33 @@ void ql_dump_regs(struct ql_adapter *qdev); ...@@ -2300,33 +2300,33 @@ void ql_dump_regs(struct ql_adapter *qdev);
#endif #endif
#ifdef QL_STAT_DUMP #ifdef QL_STAT_DUMP
void ql_dump_stat(struct ql_adapter *qdev); void qlge_dump_stat(struct qlge_adapter *qdev);
#define QL_DUMP_STAT(qdev) ql_dump_stat(qdev) #define QL_DUMP_STAT(qdev) qlge_dump_stat(qdev)
#else #else
#define QL_DUMP_STAT(qdev) #define QL_DUMP_STAT(qdev)
#endif #endif
#ifdef QL_DEV_DUMP #ifdef QL_DEV_DUMP
void ql_dump_qdev(struct ql_adapter *qdev); void qlge_dump_qdev(struct qlge_adapter *qdev);
#define QL_DUMP_QDEV(qdev) ql_dump_qdev(qdev) #define QL_DUMP_QDEV(qdev) qlge_dump_qdev(qdev)
#else #else
#define QL_DUMP_QDEV(qdev) #define QL_DUMP_QDEV(qdev)
#endif #endif
#ifdef QL_CB_DUMP #ifdef QL_CB_DUMP
void ql_dump_wqicb(struct wqicb *wqicb); void qlge_dump_wqicb(struct wqicb *wqicb);
void ql_dump_tx_ring(struct tx_ring *tx_ring); void qlge_dump_tx_ring(struct tx_ring *tx_ring);
void ql_dump_ricb(struct ricb *ricb); void qlge_dump_ricb(struct ricb *ricb);
void ql_dump_cqicb(struct cqicb *cqicb); void qlge_dump_cqicb(struct cqicb *cqicb);
void ql_dump_rx_ring(struct rx_ring *rx_ring); void qlge_dump_rx_ring(struct rx_ring *rx_ring);
void ql_dump_hw_cb(struct ql_adapter *qdev, int size, u32 bit, u16 q_id); void qlge_dump_hw_cb(struct qlge_adapter *qdev, int size, u32 bit, u16 q_id);
#define QL_DUMP_RICB(ricb) ql_dump_ricb(ricb) #define QL_DUMP_RICB(ricb) qlge_dump_ricb(ricb)
#define QL_DUMP_WQICB(wqicb) ql_dump_wqicb(wqicb) #define QL_DUMP_WQICB(wqicb) qlge_dump_wqicb(wqicb)
#define QL_DUMP_TX_RING(tx_ring) ql_dump_tx_ring(tx_ring) #define QL_DUMP_TX_RING(tx_ring) qlge_dump_tx_ring(tx_ring)
#define QL_DUMP_CQICB(cqicb) ql_dump_cqicb(cqicb) #define QL_DUMP_CQICB(cqicb) qlge_dump_cqicb(cqicb)
#define QL_DUMP_RX_RING(rx_ring) ql_dump_rx_ring(rx_ring) #define QL_DUMP_RX_RING(rx_ring) qlge_dump_rx_ring(rx_ring)
#define QL_DUMP_HW_CB(qdev, size, bit, q_id) \ #define QL_DUMP_HW_CB(qdev, size, bit, q_id) \
ql_dump_hw_cb(qdev, size, bit, q_id) qlge_dump_hw_cb(qdev, size, bit, q_id)
#else #else
#define QL_DUMP_RICB(ricb) #define QL_DUMP_RICB(ricb)
#define QL_DUMP_WQICB(wqicb) #define QL_DUMP_WQICB(wqicb)
...@@ -2337,26 +2337,26 @@ void ql_dump_hw_cb(struct ql_adapter *qdev, int size, u32 bit, u16 q_id); ...@@ -2337,26 +2337,26 @@ void ql_dump_hw_cb(struct ql_adapter *qdev, int size, u32 bit, u16 q_id);
#endif #endif
#ifdef QL_OB_DUMP #ifdef QL_OB_DUMP
void ql_dump_tx_desc(struct ql_adapter *qdev, struct tx_buf_desc *tbd); void qlge_dump_tx_desc(struct qlge_adapter *qdev, struct tx_buf_desc *tbd);
void ql_dump_ob_mac_iocb(struct ql_adapter *qdev, struct ob_mac_iocb_req *ob_mac_iocb); void qlge_dump_ob_mac_iocb(struct qlge_adapter *qdev, struct qlge_ob_mac_iocb_req *ob_mac_iocb);
void ql_dump_ob_mac_rsp(struct ql_adapter *qdev, struct ob_mac_iocb_rsp *ob_mac_rsp); void qlge_dump_ob_mac_rsp(struct qlge_adapter *qdev, struct qlge_ob_mac_iocb_rsp *ob_mac_rsp);
#define QL_DUMP_OB_MAC_IOCB(qdev, ob_mac_iocb) ql_dump_ob_mac_iocb(qdev, ob_mac_iocb) #define QL_DUMP_OB_MAC_IOCB(qdev, ob_mac_iocb) qlge_dump_ob_mac_iocb(qdev, ob_mac_iocb)
#define QL_DUMP_OB_MAC_RSP(qdev, ob_mac_rsp) ql_dump_ob_mac_rsp(qdev, ob_mac_rsp) #define QL_DUMP_OB_MAC_RSP(qdev, ob_mac_rsp) qlge_dump_ob_mac_rsp(qdev, ob_mac_rsp)
#else #else
#define QL_DUMP_OB_MAC_IOCB(qdev, ob_mac_iocb) #define QL_DUMP_OB_MAC_IOCB(qdev, ob_mac_iocb)
#define QL_DUMP_OB_MAC_RSP(qdev, ob_mac_rsp) #define QL_DUMP_OB_MAC_RSP(qdev, ob_mac_rsp)
#endif #endif
#ifdef QL_IB_DUMP #ifdef QL_IB_DUMP
void ql_dump_ib_mac_rsp(struct ql_adapter *qdev, struct ib_mac_iocb_rsp *ib_mac_rsp); void qlge_dump_ib_mac_rsp(struct qlge_adapter *qdev, struct qlge_ib_mac_iocb_rsp *ib_mac_rsp);
#define QL_DUMP_IB_MAC_RSP(qdev, ib_mac_rsp) ql_dump_ib_mac_rsp(qdev, ib_mac_rsp) #define QL_DUMP_IB_MAC_RSP(qdev, ib_mac_rsp) qlge_dump_ib_mac_rsp(qdev, ib_mac_rsp)
#else #else
#define QL_DUMP_IB_MAC_RSP(qdev, ib_mac_rsp) #define QL_DUMP_IB_MAC_RSP(qdev, ib_mac_rsp)
#endif #endif
#ifdef QL_ALL_DUMP #ifdef QL_ALL_DUMP
void ql_dump_all(struct ql_adapter *qdev); void qlge_dump_all(struct qlge_adapter *qdev);
#define QL_DUMP_ALL(qdev) ql_dump_all(qdev) #define QL_DUMP_ALL(qdev) qlge_dump_all(qdev)
#else #else
#define QL_DUMP_ALL(qdev) #define QL_DUMP_ALL(qdev)
#endif #endif
......
...@@ -6,8 +6,8 @@ ...@@ -6,8 +6,8 @@
#include "qlge.h" #include "qlge.h"
/* Read a NIC register from the alternate function. */ /* Read a NIC register from the alternate function. */
static u32 ql_read_other_func_reg(struct ql_adapter *qdev, static u32 qlge_read_other_func_reg(struct qlge_adapter *qdev,
u32 reg) u32 reg)
{ {
u32 register_to_read; u32 register_to_read;
u32 reg_val; u32 reg_val;
...@@ -17,7 +17,7 @@ static u32 ql_read_other_func_reg(struct ql_adapter *qdev, ...@@ -17,7 +17,7 @@ static u32 ql_read_other_func_reg(struct ql_adapter *qdev,
| MPI_NIC_READ | MPI_NIC_READ
| (qdev->alt_func << MPI_NIC_FUNCTION_SHIFT) | (qdev->alt_func << MPI_NIC_FUNCTION_SHIFT)
| reg; | reg;
status = ql_read_mpi_reg(qdev, register_to_read, &reg_val); status = qlge_read_mpi_reg(qdev, register_to_read, &reg_val);
if (status != 0) if (status != 0)
return 0xffffffff; return 0xffffffff;
...@@ -25,8 +25,8 @@ static u32 ql_read_other_func_reg(struct ql_adapter *qdev, ...@@ -25,8 +25,8 @@ static u32 ql_read_other_func_reg(struct ql_adapter *qdev,
} }
/* Write a NIC register from the alternate function. */ /* Write a NIC register from the alternate function. */
static int ql_write_other_func_reg(struct ql_adapter *qdev, static int qlge_write_other_func_reg(struct qlge_adapter *qdev,
u32 reg, u32 reg_val) u32 reg, u32 reg_val)
{ {
u32 register_to_read; u32 register_to_read;
...@@ -35,17 +35,17 @@ static int ql_write_other_func_reg(struct ql_adapter *qdev, ...@@ -35,17 +35,17 @@ static int ql_write_other_func_reg(struct ql_adapter *qdev,
| (qdev->alt_func << MPI_NIC_FUNCTION_SHIFT) | (qdev->alt_func << MPI_NIC_FUNCTION_SHIFT)
| reg; | reg;
return ql_write_mpi_reg(qdev, register_to_read, reg_val); return qlge_write_mpi_reg(qdev, register_to_read, reg_val);
} }
static int ql_wait_other_func_reg_rdy(struct ql_adapter *qdev, u32 reg, static int qlge_wait_other_func_reg_rdy(struct qlge_adapter *qdev, u32 reg,
u32 bit, u32 err_bit) u32 bit, u32 err_bit)
{ {
u32 temp; u32 temp;
int count; int count;
for (count = 10; count; count--) { for (count = 10; count; count--) {
temp = ql_read_other_func_reg(qdev, reg); temp = qlge_read_other_func_reg(qdev, reg);
/* check for errors */ /* check for errors */
if (temp & err_bit) if (temp & err_bit)
...@@ -57,80 +57,80 @@ static int ql_wait_other_func_reg_rdy(struct ql_adapter *qdev, u32 reg, ...@@ -57,80 +57,80 @@ static int ql_wait_other_func_reg_rdy(struct ql_adapter *qdev, u32 reg,
return -1; return -1;
} }
static int ql_read_other_func_serdes_reg(struct ql_adapter *qdev, u32 reg, static int qlge_read_other_func_serdes_reg(struct qlge_adapter *qdev, u32 reg,
u32 *data) u32 *data)
{ {
int status; int status;
/* wait for reg to come ready */ /* wait for reg to come ready */
status = ql_wait_other_func_reg_rdy(qdev, XG_SERDES_ADDR / 4, status = qlge_wait_other_func_reg_rdy(qdev, XG_SERDES_ADDR / 4,
XG_SERDES_ADDR_RDY, 0); XG_SERDES_ADDR_RDY, 0);
if (status) if (status)
goto exit; goto exit;
/* set up for reg read */ /* set up for reg read */
ql_write_other_func_reg(qdev, XG_SERDES_ADDR / 4, reg | PROC_ADDR_R); qlge_write_other_func_reg(qdev, XG_SERDES_ADDR / 4, reg | PROC_ADDR_R);
/* wait for reg to come ready */ /* wait for reg to come ready */
status = ql_wait_other_func_reg_rdy(qdev, XG_SERDES_ADDR / 4, status = qlge_wait_other_func_reg_rdy(qdev, XG_SERDES_ADDR / 4,
XG_SERDES_ADDR_RDY, 0); XG_SERDES_ADDR_RDY, 0);
if (status) if (status)
goto exit; goto exit;
/* get the data */ /* get the data */
*data = ql_read_other_func_reg(qdev, (XG_SERDES_DATA / 4)); *data = qlge_read_other_func_reg(qdev, (XG_SERDES_DATA / 4));
exit: exit:
return status; return status;
} }
/* Read out the SERDES registers */ /* Read out the SERDES registers */
static int ql_read_serdes_reg(struct ql_adapter *qdev, u32 reg, u32 *data) static int qlge_read_serdes_reg(struct qlge_adapter *qdev, u32 reg, u32 *data)
{ {
int status; int status;
/* wait for reg to come ready */ /* wait for reg to come ready */
status = ql_wait_reg_rdy(qdev, XG_SERDES_ADDR, XG_SERDES_ADDR_RDY, 0); status = qlge_wait_reg_rdy(qdev, XG_SERDES_ADDR, XG_SERDES_ADDR_RDY, 0);
if (status) if (status)
goto exit; goto exit;
/* set up for reg read */ /* set up for reg read */
ql_write32(qdev, XG_SERDES_ADDR, reg | PROC_ADDR_R); qlge_write32(qdev, XG_SERDES_ADDR, reg | PROC_ADDR_R);
/* wait for reg to come ready */ /* wait for reg to come ready */
status = ql_wait_reg_rdy(qdev, XG_SERDES_ADDR, XG_SERDES_ADDR_RDY, 0); status = qlge_wait_reg_rdy(qdev, XG_SERDES_ADDR, XG_SERDES_ADDR_RDY, 0);
if (status) if (status)
goto exit; goto exit;
/* get the data */ /* get the data */
*data = ql_read32(qdev, XG_SERDES_DATA); *data = qlge_read32(qdev, XG_SERDES_DATA);
exit: exit:
return status; return status;
} }
static void ql_get_both_serdes(struct ql_adapter *qdev, u32 addr, static void qlge_get_both_serdes(struct qlge_adapter *qdev, u32 addr,
u32 *direct_ptr, u32 *indirect_ptr, u32 *direct_ptr, u32 *indirect_ptr,
bool direct_valid, bool indirect_valid) bool direct_valid, bool indirect_valid)
{ {
unsigned int status; unsigned int status;
status = 1; status = 1;
if (direct_valid) if (direct_valid)
status = ql_read_serdes_reg(qdev, addr, direct_ptr); status = qlge_read_serdes_reg(qdev, addr, direct_ptr);
/* Dead fill any failures or invalids. */ /* Dead fill any failures or invalids. */
if (status) if (status)
*direct_ptr = 0xDEADBEEF; *direct_ptr = 0xDEADBEEF;
status = 1; status = 1;
if (indirect_valid) if (indirect_valid)
status = ql_read_other_func_serdes_reg( status = qlge_read_other_func_serdes_reg(qdev, addr,
qdev, addr, indirect_ptr); indirect_ptr);
/* Dead fill any failures or invalids. */ /* Dead fill any failures or invalids. */
if (status) if (status)
*indirect_ptr = 0xDEADBEEF; *indirect_ptr = 0xDEADBEEF;
} }
static int ql_get_serdes_regs(struct ql_adapter *qdev, static int qlge_get_serdes_regs(struct qlge_adapter *qdev,
struct ql_mpi_coredump *mpi_coredump) struct qlge_mpi_coredump *mpi_coredump)
{ {
int status; int status;
bool xfi_direct_valid = false, xfi_indirect_valid = false; bool xfi_direct_valid = false, xfi_indirect_valid = false;
...@@ -140,9 +140,9 @@ static int ql_get_serdes_regs(struct ql_adapter *qdev, ...@@ -140,9 +140,9 @@ static int ql_get_serdes_regs(struct ql_adapter *qdev,
u32 *indirect_ptr; u32 *indirect_ptr;
/* The XAUI needs to be read out per port */ /* The XAUI needs to be read out per port */
status = ql_read_other_func_serdes_reg(qdev, status = qlge_read_other_func_serdes_reg(qdev,
XG_SERDES_XAUI_HSS_PCS_START, XG_SERDES_XAUI_HSS_PCS_START,
&temp); &temp);
if (status) if (status)
temp = XG_SERDES_ADDR_XAUI_PWR_DOWN; temp = XG_SERDES_ADDR_XAUI_PWR_DOWN;
...@@ -150,7 +150,7 @@ static int ql_get_serdes_regs(struct ql_adapter *qdev, ...@@ -150,7 +150,7 @@ static int ql_get_serdes_regs(struct ql_adapter *qdev,
XG_SERDES_ADDR_XAUI_PWR_DOWN) XG_SERDES_ADDR_XAUI_PWR_DOWN)
xaui_indirect_valid = false; xaui_indirect_valid = false;
status = ql_read_serdes_reg(qdev, XG_SERDES_XAUI_HSS_PCS_START, &temp); status = qlge_read_serdes_reg(qdev, XG_SERDES_XAUI_HSS_PCS_START, &temp);
if (status) if (status)
temp = XG_SERDES_ADDR_XAUI_PWR_DOWN; temp = XG_SERDES_ADDR_XAUI_PWR_DOWN;
...@@ -163,7 +163,7 @@ static int ql_get_serdes_regs(struct ql_adapter *qdev, ...@@ -163,7 +163,7 @@ static int ql_get_serdes_regs(struct ql_adapter *qdev,
* XFI register is shared so only need to read one * XFI register is shared so only need to read one
* functions and then check the bits. * functions and then check the bits.
*/ */
status = ql_read_serdes_reg(qdev, XG_SERDES_ADDR_STS, &temp); status = qlge_read_serdes_reg(qdev, XG_SERDES_ADDR_STS, &temp);
if (status) if (status)
temp = 0; temp = 0;
...@@ -198,8 +198,8 @@ static int ql_get_serdes_regs(struct ql_adapter *qdev, ...@@ -198,8 +198,8 @@ static int ql_get_serdes_regs(struct ql_adapter *qdev,
} }
for (i = 0; i <= 0x000000034; i += 4, direct_ptr++, indirect_ptr++) for (i = 0; i <= 0x000000034; i += 4, direct_ptr++, indirect_ptr++)
ql_get_both_serdes(qdev, i, direct_ptr, indirect_ptr, qlge_get_both_serdes(qdev, i, direct_ptr, indirect_ptr,
xaui_direct_valid, xaui_indirect_valid); xaui_direct_valid, xaui_indirect_valid);
/* Get XAUI_HSS_PCS register block. */ /* Get XAUI_HSS_PCS register block. */
if (qdev->func & 1) { if (qdev->func & 1) {
...@@ -215,8 +215,8 @@ static int ql_get_serdes_regs(struct ql_adapter *qdev, ...@@ -215,8 +215,8 @@ static int ql_get_serdes_regs(struct ql_adapter *qdev,
} }
for (i = 0x800; i <= 0x880; i += 4, direct_ptr++, indirect_ptr++) for (i = 0x800; i <= 0x880; i += 4, direct_ptr++, indirect_ptr++)
ql_get_both_serdes(qdev, i, direct_ptr, indirect_ptr, qlge_get_both_serdes(qdev, i, direct_ptr, indirect_ptr,
xaui_direct_valid, xaui_indirect_valid); xaui_direct_valid, xaui_indirect_valid);
/* Get XAUI_XFI_AN register block. */ /* Get XAUI_XFI_AN register block. */
if (qdev->func & 1) { if (qdev->func & 1) {
...@@ -228,8 +228,8 @@ static int ql_get_serdes_regs(struct ql_adapter *qdev, ...@@ -228,8 +228,8 @@ static int ql_get_serdes_regs(struct ql_adapter *qdev,
} }
for (i = 0x1000; i <= 0x1034; i += 4, direct_ptr++, indirect_ptr++) for (i = 0x1000; i <= 0x1034; i += 4, direct_ptr++, indirect_ptr++)
ql_get_both_serdes(qdev, i, direct_ptr, indirect_ptr, qlge_get_both_serdes(qdev, i, direct_ptr, indirect_ptr,
xfi_direct_valid, xfi_indirect_valid); xfi_direct_valid, xfi_indirect_valid);
/* Get XAUI_XFI_TRAIN register block. */ /* Get XAUI_XFI_TRAIN register block. */
if (qdev->func & 1) { if (qdev->func & 1) {
...@@ -243,8 +243,8 @@ static int ql_get_serdes_regs(struct ql_adapter *qdev, ...@@ -243,8 +243,8 @@ static int ql_get_serdes_regs(struct ql_adapter *qdev,
} }
for (i = 0x1050; i <= 0x107c; i += 4, direct_ptr++, indirect_ptr++) for (i = 0x1050; i <= 0x107c; i += 4, direct_ptr++, indirect_ptr++)
ql_get_both_serdes(qdev, i, direct_ptr, indirect_ptr, qlge_get_both_serdes(qdev, i, direct_ptr, indirect_ptr,
xfi_direct_valid, xfi_indirect_valid); xfi_direct_valid, xfi_indirect_valid);
/* Get XAUI_XFI_HSS_PCS register block. */ /* Get XAUI_XFI_HSS_PCS register block. */
if (qdev->func & 1) { if (qdev->func & 1) {
...@@ -260,8 +260,8 @@ static int ql_get_serdes_regs(struct ql_adapter *qdev, ...@@ -260,8 +260,8 @@ static int ql_get_serdes_regs(struct ql_adapter *qdev,
} }
for (i = 0x1800; i <= 0x1838; i += 4, direct_ptr++, indirect_ptr++) for (i = 0x1800; i <= 0x1838; i += 4, direct_ptr++, indirect_ptr++)
ql_get_both_serdes(qdev, i, direct_ptr, indirect_ptr, qlge_get_both_serdes(qdev, i, direct_ptr, indirect_ptr,
xfi_direct_valid, xfi_indirect_valid); xfi_direct_valid, xfi_indirect_valid);
/* Get XAUI_XFI_HSS_TX register block. */ /* Get XAUI_XFI_HSS_TX register block. */
if (qdev->func & 1) { if (qdev->func & 1) {
...@@ -275,8 +275,8 @@ static int ql_get_serdes_regs(struct ql_adapter *qdev, ...@@ -275,8 +275,8 @@ static int ql_get_serdes_regs(struct ql_adapter *qdev,
mpi_coredump->serdes2_xfi_hss_tx; mpi_coredump->serdes2_xfi_hss_tx;
} }
for (i = 0x1c00; i <= 0x1c1f; i++, direct_ptr++, indirect_ptr++) for (i = 0x1c00; i <= 0x1c1f; i++, direct_ptr++, indirect_ptr++)
ql_get_both_serdes(qdev, i, direct_ptr, indirect_ptr, qlge_get_both_serdes(qdev, i, direct_ptr, indirect_ptr,
xfi_direct_valid, xfi_indirect_valid); xfi_direct_valid, xfi_indirect_valid);
/* Get XAUI_XFI_HSS_RX register block. */ /* Get XAUI_XFI_HSS_RX register block. */
if (qdev->func & 1) { if (qdev->func & 1) {
...@@ -291,8 +291,8 @@ static int ql_get_serdes_regs(struct ql_adapter *qdev, ...@@ -291,8 +291,8 @@ static int ql_get_serdes_regs(struct ql_adapter *qdev,
} }
for (i = 0x1c40; i <= 0x1c5f; i++, direct_ptr++, indirect_ptr++) for (i = 0x1c40; i <= 0x1c5f; i++, direct_ptr++, indirect_ptr++)
ql_get_both_serdes(qdev, i, direct_ptr, indirect_ptr, qlge_get_both_serdes(qdev, i, direct_ptr, indirect_ptr,
xfi_direct_valid, xfi_indirect_valid); xfi_direct_valid, xfi_indirect_valid);
/* Get XAUI_XFI_HSS_PLL register block. */ /* Get XAUI_XFI_HSS_PLL register block. */
if (qdev->func & 1) { if (qdev->func & 1) {
...@@ -307,33 +307,33 @@ static int ql_get_serdes_regs(struct ql_adapter *qdev, ...@@ -307,33 +307,33 @@ static int ql_get_serdes_regs(struct ql_adapter *qdev,
mpi_coredump->serdes2_xfi_hss_pll; mpi_coredump->serdes2_xfi_hss_pll;
} }
for (i = 0x1e00; i <= 0x1e1f; i++, direct_ptr++, indirect_ptr++) for (i = 0x1e00; i <= 0x1e1f; i++, direct_ptr++, indirect_ptr++)
ql_get_both_serdes(qdev, i, direct_ptr, indirect_ptr, qlge_get_both_serdes(qdev, i, direct_ptr, indirect_ptr,
xfi_direct_valid, xfi_indirect_valid); xfi_direct_valid, xfi_indirect_valid);
return 0; return 0;
} }
static int ql_read_other_func_xgmac_reg(struct ql_adapter *qdev, u32 reg, static int qlge_read_other_func_xgmac_reg(struct qlge_adapter *qdev, u32 reg,
u32 *data) u32 *data)
{ {
int status = 0; int status = 0;
/* wait for reg to come ready */ /* wait for reg to come ready */
status = ql_wait_other_func_reg_rdy(qdev, XGMAC_ADDR / 4, status = qlge_wait_other_func_reg_rdy(qdev, XGMAC_ADDR / 4,
XGMAC_ADDR_RDY, XGMAC_ADDR_XME); XGMAC_ADDR_RDY, XGMAC_ADDR_XME);
if (status) if (status)
goto exit; goto exit;
/* set up for reg read */ /* set up for reg read */
ql_write_other_func_reg(qdev, XGMAC_ADDR / 4, reg | XGMAC_ADDR_R); qlge_write_other_func_reg(qdev, XGMAC_ADDR / 4, reg | XGMAC_ADDR_R);
/* wait for reg to come ready */ /* wait for reg to come ready */
status = ql_wait_other_func_reg_rdy(qdev, XGMAC_ADDR / 4, status = qlge_wait_other_func_reg_rdy(qdev, XGMAC_ADDR / 4,
XGMAC_ADDR_RDY, XGMAC_ADDR_XME); XGMAC_ADDR_RDY, XGMAC_ADDR_XME);
if (status) if (status)
goto exit; goto exit;
/* get the data */ /* get the data */
*data = ql_read_other_func_reg(qdev, XGMAC_DATA / 4); *data = qlge_read_other_func_reg(qdev, XGMAC_DATA / 4);
exit: exit:
return status; return status;
} }
...@@ -341,8 +341,8 @@ static int ql_read_other_func_xgmac_reg(struct ql_adapter *qdev, u32 reg, ...@@ -341,8 +341,8 @@ static int ql_read_other_func_xgmac_reg(struct ql_adapter *qdev, u32 reg,
/* Read the 400 xgmac control/statistics registers /* Read the 400 xgmac control/statistics registers
* skipping unused locations. * skipping unused locations.
*/ */
static int ql_get_xgmac_regs(struct ql_adapter *qdev, u32 *buf, static int qlge_get_xgmac_regs(struct qlge_adapter *qdev, u32 *buf,
unsigned int other_function) unsigned int other_function)
{ {
int status = 0; int status = 0;
int i; int i;
...@@ -370,9 +370,9 @@ static int ql_get_xgmac_regs(struct ql_adapter *qdev, u32 *buf, ...@@ -370,9 +370,9 @@ static int ql_get_xgmac_regs(struct ql_adapter *qdev, u32 *buf,
(i > 0x000005c8 && i < 0x00000600)) { (i > 0x000005c8 && i < 0x00000600)) {
if (other_function) if (other_function)
status = status =
ql_read_other_func_xgmac_reg(qdev, i, buf); qlge_read_other_func_xgmac_reg(qdev, i, buf);
else else
status = ql_read_xgmac_reg(qdev, i, buf); status = qlge_read_xgmac_reg(qdev, i, buf);
if (status) if (status)
*buf = 0xdeadbeef; *buf = 0xdeadbeef;
...@@ -382,46 +382,46 @@ static int ql_get_xgmac_regs(struct ql_adapter *qdev, u32 *buf, ...@@ -382,46 +382,46 @@ static int ql_get_xgmac_regs(struct ql_adapter *qdev, u32 *buf,
return status; return status;
} }
static int ql_get_ets_regs(struct ql_adapter *qdev, u32 *buf) static int qlge_get_ets_regs(struct qlge_adapter *qdev, u32 *buf)
{ {
int i; int i;
for (i = 0; i < 8; i++, buf++) { for (i = 0; i < 8; i++, buf++) {
ql_write32(qdev, NIC_ETS, i << 29 | 0x08000000); qlge_write32(qdev, NIC_ETS, i << 29 | 0x08000000);
*buf = ql_read32(qdev, NIC_ETS); *buf = qlge_read32(qdev, NIC_ETS);
} }
for (i = 0; i < 2; i++, buf++) { for (i = 0; i < 2; i++, buf++) {
ql_write32(qdev, CNA_ETS, i << 29 | 0x08000000); qlge_write32(qdev, CNA_ETS, i << 29 | 0x08000000);
*buf = ql_read32(qdev, CNA_ETS); *buf = qlge_read32(qdev, CNA_ETS);
} }
return 0; return 0;
} }
static void ql_get_intr_states(struct ql_adapter *qdev, u32 *buf) static void qlge_get_intr_states(struct qlge_adapter *qdev, u32 *buf)
{ {
int i; int i;
for (i = 0; i < qdev->rx_ring_count; i++, buf++) { for (i = 0; i < qdev->rx_ring_count; i++, buf++) {
ql_write32(qdev, INTR_EN, qlge_write32(qdev, INTR_EN,
qdev->intr_context[i].intr_read_mask); qdev->intr_context[i].intr_read_mask);
*buf = ql_read32(qdev, INTR_EN); *buf = qlge_read32(qdev, INTR_EN);
} }
} }
static int ql_get_cam_entries(struct ql_adapter *qdev, u32 *buf) static int qlge_get_cam_entries(struct qlge_adapter *qdev, u32 *buf)
{ {
int i, status; int i, status;
u32 value[3]; u32 value[3];
status = ql_sem_spinlock(qdev, SEM_MAC_ADDR_MASK); status = qlge_sem_spinlock(qdev, SEM_MAC_ADDR_MASK);
if (status) if (status)
return status; return status;
for (i = 0; i < 16; i++) { for (i = 0; i < 16; i++) {
status = ql_get_mac_addr_reg(qdev, status = qlge_get_mac_addr_reg(qdev,
MAC_ADDR_TYPE_CAM_MAC, i, value); MAC_ADDR_TYPE_CAM_MAC, i, value);
if (status) { if (status) {
netif_err(qdev, drv, qdev->ndev, netif_err(qdev, drv, qdev->ndev,
"Failed read of mac index register\n"); "Failed read of mac index register\n");
...@@ -432,8 +432,8 @@ static int ql_get_cam_entries(struct ql_adapter *qdev, u32 *buf) ...@@ -432,8 +432,8 @@ static int ql_get_cam_entries(struct ql_adapter *qdev, u32 *buf)
*buf++ = value[2]; /* output */ *buf++ = value[2]; /* output */
} }
for (i = 0; i < 32; i++) { for (i = 0; i < 32; i++) {
status = ql_get_mac_addr_reg(qdev, status = qlge_get_mac_addr_reg(qdev, MAC_ADDR_TYPE_MULTI_MAC,
MAC_ADDR_TYPE_MULTI_MAC, i, value); i, value);
if (status) { if (status) {
netif_err(qdev, drv, qdev->ndev, netif_err(qdev, drv, qdev->ndev,
"Failed read of mac index register\n"); "Failed read of mac index register\n");
...@@ -443,21 +443,21 @@ static int ql_get_cam_entries(struct ql_adapter *qdev, u32 *buf) ...@@ -443,21 +443,21 @@ static int ql_get_cam_entries(struct ql_adapter *qdev, u32 *buf)
*buf++ = value[1]; /* upper Mcast address */ *buf++ = value[1]; /* upper Mcast address */
} }
err: err:
ql_sem_unlock(qdev, SEM_MAC_ADDR_MASK); qlge_sem_unlock(qdev, SEM_MAC_ADDR_MASK);
return status; return status;
} }
static int ql_get_routing_entries(struct ql_adapter *qdev, u32 *buf) static int qlge_get_routing_entries(struct qlge_adapter *qdev, u32 *buf)
{ {
int status; int status;
u32 value, i; u32 value, i;
status = ql_sem_spinlock(qdev, SEM_RT_IDX_MASK); status = qlge_sem_spinlock(qdev, SEM_RT_IDX_MASK);
if (status) if (status)
return status; return status;
for (i = 0; i < 16; i++) { for (i = 0; i < 16; i++) {
status = ql_get_routing_reg(qdev, i, &value); status = qlge_get_routing_reg(qdev, i, &value);
if (status) { if (status) {
netif_err(qdev, drv, qdev->ndev, netif_err(qdev, drv, qdev->ndev,
"Failed read of routing index register\n"); "Failed read of routing index register\n");
...@@ -467,23 +467,23 @@ static int ql_get_routing_entries(struct ql_adapter *qdev, u32 *buf) ...@@ -467,23 +467,23 @@ static int ql_get_routing_entries(struct ql_adapter *qdev, u32 *buf)
} }
} }
err: err:
ql_sem_unlock(qdev, SEM_RT_IDX_MASK); qlge_sem_unlock(qdev, SEM_RT_IDX_MASK);
return status; return status;
} }
/* Read the MPI Processor shadow registers */ /* Read the MPI Processor shadow registers */
static int ql_get_mpi_shadow_regs(struct ql_adapter *qdev, u32 *buf) static int qlge_get_mpi_shadow_regs(struct qlge_adapter *qdev, u32 *buf)
{ {
u32 i; u32 i;
int status; int status;
for (i = 0; i < MPI_CORE_SH_REGS_CNT; i++, buf++) { for (i = 0; i < MPI_CORE_SH_REGS_CNT; i++, buf++) {
status = ql_write_mpi_reg(qdev, status = qlge_write_mpi_reg(qdev,
RISC_124, RISC_124,
(SHADOW_OFFSET | i << SHADOW_REG_SHIFT)); (SHADOW_OFFSET | i << SHADOW_REG_SHIFT));
if (status) if (status)
goto end; goto end;
status = ql_read_mpi_reg(qdev, RISC_127, buf); status = qlge_read_mpi_reg(qdev, RISC_127, buf);
if (status) if (status)
goto end; goto end;
} }
...@@ -492,13 +492,13 @@ static int ql_get_mpi_shadow_regs(struct ql_adapter *qdev, u32 *buf) ...@@ -492,13 +492,13 @@ static int ql_get_mpi_shadow_regs(struct ql_adapter *qdev, u32 *buf)
} }
/* Read the MPI Processor core registers */ /* Read the MPI Processor core registers */
static int ql_get_mpi_regs(struct ql_adapter *qdev, u32 *buf, static int qlge_get_mpi_regs(struct qlge_adapter *qdev, u32 *buf,
u32 offset, u32 count) u32 offset, u32 count)
{ {
int i, status = 0; int i, status = 0;
for (i = 0; i < count; i++, buf++) { for (i = 0; i < count; i++, buf++) {
status = ql_read_mpi_reg(qdev, offset + i, buf); status = qlge_read_mpi_reg(qdev, offset + i, buf);
if (status) if (status)
return status; return status;
} }
...@@ -506,8 +506,8 @@ static int ql_get_mpi_regs(struct ql_adapter *qdev, u32 *buf, ...@@ -506,8 +506,8 @@ static int ql_get_mpi_regs(struct ql_adapter *qdev, u32 *buf,
} }
/* Read the ASIC probe dump */ /* Read the ASIC probe dump */
static unsigned int *ql_get_probe(struct ql_adapter *qdev, u32 clock, static unsigned int *qlge_get_probe(struct qlge_adapter *qdev, u32 clock,
u32 valid, u32 *buf) u32 valid, u32 *buf)
{ {
u32 module, mux_sel, probe, lo_val, hi_val; u32 module, mux_sel, probe, lo_val, hi_val;
...@@ -519,15 +519,15 @@ static unsigned int *ql_get_probe(struct ql_adapter *qdev, u32 clock, ...@@ -519,15 +519,15 @@ static unsigned int *ql_get_probe(struct ql_adapter *qdev, u32 clock,
| PRB_MX_ADDR_ARE | PRB_MX_ADDR_ARE
| mux_sel | mux_sel
| (module << PRB_MX_ADDR_MOD_SEL_SHIFT); | (module << PRB_MX_ADDR_MOD_SEL_SHIFT);
ql_write32(qdev, PRB_MX_ADDR, probe); qlge_write32(qdev, PRB_MX_ADDR, probe);
lo_val = ql_read32(qdev, PRB_MX_DATA); lo_val = qlge_read32(qdev, PRB_MX_DATA);
if (mux_sel == 0) { if (mux_sel == 0) {
*buf = probe; *buf = probe;
buf++; buf++;
} }
probe |= PRB_MX_ADDR_UP; probe |= PRB_MX_ADDR_UP;
ql_write32(qdev, PRB_MX_ADDR, probe); qlge_write32(qdev, PRB_MX_ADDR, probe);
hi_val = ql_read32(qdev, PRB_MX_DATA); hi_val = qlge_read32(qdev, PRB_MX_DATA);
*buf = lo_val; *buf = lo_val;
buf++; buf++;
*buf = hi_val; *buf = hi_val;
...@@ -537,23 +537,23 @@ static unsigned int *ql_get_probe(struct ql_adapter *qdev, u32 clock, ...@@ -537,23 +537,23 @@ static unsigned int *ql_get_probe(struct ql_adapter *qdev, u32 clock,
return buf; return buf;
} }
static int ql_get_probe_dump(struct ql_adapter *qdev, unsigned int *buf) static int qlge_get_probe_dump(struct qlge_adapter *qdev, unsigned int *buf)
{ {
/* First we have to enable the probe mux */ /* First we have to enable the probe mux */
ql_write_mpi_reg(qdev, MPI_TEST_FUNC_PRB_CTL, MPI_TEST_FUNC_PRB_EN); qlge_write_mpi_reg(qdev, MPI_TEST_FUNC_PRB_CTL, MPI_TEST_FUNC_PRB_EN);
buf = ql_get_probe(qdev, PRB_MX_ADDR_SYS_CLOCK, buf = qlge_get_probe(qdev, PRB_MX_ADDR_SYS_CLOCK,
PRB_MX_ADDR_VALID_SYS_MOD, buf); PRB_MX_ADDR_VALID_SYS_MOD, buf);
buf = ql_get_probe(qdev, PRB_MX_ADDR_PCI_CLOCK, buf = qlge_get_probe(qdev, PRB_MX_ADDR_PCI_CLOCK,
PRB_MX_ADDR_VALID_PCI_MOD, buf); PRB_MX_ADDR_VALID_PCI_MOD, buf);
buf = ql_get_probe(qdev, PRB_MX_ADDR_XGM_CLOCK, buf = qlge_get_probe(qdev, PRB_MX_ADDR_XGM_CLOCK,
PRB_MX_ADDR_VALID_XGM_MOD, buf); PRB_MX_ADDR_VALID_XGM_MOD, buf);
buf = ql_get_probe(qdev, PRB_MX_ADDR_FC_CLOCK, buf = qlge_get_probe(qdev, PRB_MX_ADDR_FC_CLOCK,
PRB_MX_ADDR_VALID_FC_MOD, buf); PRB_MX_ADDR_VALID_FC_MOD, buf);
return 0; return 0;
} }
/* Read out the routing index registers */ /* Read out the routing index registers */
static int ql_get_routing_index_registers(struct ql_adapter *qdev, u32 *buf) static int qlge_get_routing_index_registers(struct qlge_adapter *qdev, u32 *buf)
{ {
int status; int status;
u32 type, index, index_max; u32 type, index, index_max;
...@@ -561,7 +561,7 @@ static int ql_get_routing_index_registers(struct ql_adapter *qdev, u32 *buf) ...@@ -561,7 +561,7 @@ static int ql_get_routing_index_registers(struct ql_adapter *qdev, u32 *buf)
u32 result_data; u32 result_data;
u32 val; u32 val;
status = ql_sem_spinlock(qdev, SEM_RT_IDX_MASK); status = qlge_sem_spinlock(qdev, SEM_RT_IDX_MASK);
if (status) if (status)
return status; return status;
...@@ -574,11 +574,11 @@ static int ql_get_routing_index_registers(struct ql_adapter *qdev, u32 *buf) ...@@ -574,11 +574,11 @@ static int ql_get_routing_index_registers(struct ql_adapter *qdev, u32 *buf)
val = RT_IDX_RS val = RT_IDX_RS
| (type << RT_IDX_TYPE_SHIFT) | (type << RT_IDX_TYPE_SHIFT)
| (index << RT_IDX_IDX_SHIFT); | (index << RT_IDX_IDX_SHIFT);
ql_write32(qdev, RT_IDX, val); qlge_write32(qdev, RT_IDX, val);
result_index = 0; result_index = 0;
while ((result_index & RT_IDX_MR) == 0) while ((result_index & RT_IDX_MR) == 0)
result_index = ql_read32(qdev, RT_IDX); result_index = qlge_read32(qdev, RT_IDX);
result_data = ql_read32(qdev, RT_DATA); result_data = qlge_read32(qdev, RT_DATA);
*buf = type; *buf = type;
buf++; buf++;
*buf = index; *buf = index;
...@@ -589,12 +589,12 @@ static int ql_get_routing_index_registers(struct ql_adapter *qdev, u32 *buf) ...@@ -589,12 +589,12 @@ static int ql_get_routing_index_registers(struct ql_adapter *qdev, u32 *buf)
buf++; buf++;
} }
} }
ql_sem_unlock(qdev, SEM_RT_IDX_MASK); qlge_sem_unlock(qdev, SEM_RT_IDX_MASK);
return status; return status;
} }
/* Read out the MAC protocol registers */ /* Read out the MAC protocol registers */
static void ql_get_mac_protocol_registers(struct ql_adapter *qdev, u32 *buf) static void qlge_get_mac_protocol_registers(struct qlge_adapter *qdev, u32 *buf)
{ {
u32 result_index, result_data; u32 result_index, result_data;
u32 type; u32 type;
...@@ -657,13 +657,13 @@ static void ql_get_mac_protocol_registers(struct ql_adapter *qdev, u32 *buf) ...@@ -657,13 +657,13 @@ static void ql_get_mac_protocol_registers(struct ql_adapter *qdev, u32 *buf)
| (type << MAC_ADDR_TYPE_SHIFT) | (type << MAC_ADDR_TYPE_SHIFT)
| (index << MAC_ADDR_IDX_SHIFT) | (index << MAC_ADDR_IDX_SHIFT)
| (offset); | (offset);
ql_write32(qdev, MAC_ADDR_IDX, val); qlge_write32(qdev, MAC_ADDR_IDX, val);
result_index = 0; result_index = 0;
while ((result_index & MAC_ADDR_MR) == 0) { while ((result_index & MAC_ADDR_MR) == 0) {
result_index = ql_read32(qdev, result_index = qlge_read32(qdev,
MAC_ADDR_IDX); MAC_ADDR_IDX);
} }
result_data = ql_read32(qdev, MAC_ADDR_DATA); result_data = qlge_read32(qdev, MAC_ADDR_DATA);
*buf = result_index; *buf = result_index;
buf++; buf++;
*buf = result_data; *buf = result_data;
...@@ -673,7 +673,7 @@ static void ql_get_mac_protocol_registers(struct ql_adapter *qdev, u32 *buf) ...@@ -673,7 +673,7 @@ static void ql_get_mac_protocol_registers(struct ql_adapter *qdev, u32 *buf)
} }
} }
static void ql_get_sem_registers(struct ql_adapter *qdev, u32 *buf) static void qlge_get_sem_registers(struct qlge_adapter *qdev, u32 *buf)
{ {
u32 func_num, reg, reg_val; u32 func_num, reg, reg_val;
int status; int status;
...@@ -682,7 +682,7 @@ static void ql_get_sem_registers(struct ql_adapter *qdev, u32 *buf) ...@@ -682,7 +682,7 @@ static void ql_get_sem_registers(struct ql_adapter *qdev, u32 *buf)
reg = MPI_NIC_REG_BLOCK reg = MPI_NIC_REG_BLOCK
| (func_num << MPI_NIC_FUNCTION_SHIFT) | (func_num << MPI_NIC_FUNCTION_SHIFT)
| (SEM / 4); | (SEM / 4);
status = ql_read_mpi_reg(qdev, reg, &reg_val); status = qlge_read_mpi_reg(qdev, reg, &reg_val);
*buf = reg_val; *buf = reg_val;
/* if the read failed then dead fill the element. */ /* if the read failed then dead fill the element. */
if (!status) if (!status)
...@@ -692,9 +692,8 @@ static void ql_get_sem_registers(struct ql_adapter *qdev, u32 *buf) ...@@ -692,9 +692,8 @@ static void ql_get_sem_registers(struct ql_adapter *qdev, u32 *buf)
} }
/* Create a coredump segment header */ /* Create a coredump segment header */
static void ql_build_coredump_seg_header( static void qlge_build_coredump_seg_header(struct mpi_coredump_segment_header *seg_hdr,
struct mpi_coredump_segment_header *seg_hdr, u32 seg_number, u32 seg_size, u8 *desc)
u32 seg_number, u32 seg_size, u8 *desc)
{ {
memset(seg_hdr, 0, sizeof(struct mpi_coredump_segment_header)); memset(seg_hdr, 0, sizeof(struct mpi_coredump_segment_header));
seg_hdr->cookie = MPI_COREDUMP_COOKIE; seg_hdr->cookie = MPI_COREDUMP_COOKIE;
...@@ -710,7 +709,7 @@ static void ql_build_coredump_seg_header( ...@@ -710,7 +709,7 @@ static void ql_build_coredump_seg_header(
* space for this function as well as a coredump structure that * space for this function as well as a coredump structure that
* will contain the dump. * will contain the dump.
*/ */
int ql_core_dump(struct ql_adapter *qdev, struct ql_mpi_coredump *mpi_coredump) int qlge_core_dump(struct qlge_adapter *qdev, struct qlge_mpi_coredump *mpi_coredump)
{ {
int status; int status;
int i; int i;
...@@ -724,9 +723,9 @@ int ql_core_dump(struct ql_adapter *qdev, struct ql_mpi_coredump *mpi_coredump) ...@@ -724,9 +723,9 @@ int ql_core_dump(struct ql_adapter *qdev, struct ql_mpi_coredump *mpi_coredump)
* it isn't available. If the firmware died it * it isn't available. If the firmware died it
* might be holding the sem. * might be holding the sem.
*/ */
ql_sem_spinlock(qdev, SEM_PROC_REG_MASK); qlge_sem_spinlock(qdev, SEM_PROC_REG_MASK);
status = ql_pause_mpi_risc(qdev); status = qlge_pause_mpi_risc(qdev);
if (status) { if (status) {
netif_err(qdev, drv, qdev->ndev, netif_err(qdev, drv, qdev->ndev,
"Failed RISC pause. Status = 0x%.08x\n", status); "Failed RISC pause. Status = 0x%.08x\n", status);
...@@ -740,155 +739,155 @@ int ql_core_dump(struct ql_adapter *qdev, struct ql_mpi_coredump *mpi_coredump) ...@@ -740,155 +739,155 @@ int ql_core_dump(struct ql_adapter *qdev, struct ql_mpi_coredump *mpi_coredump)
mpi_coredump->mpi_global_header.header_size = mpi_coredump->mpi_global_header.header_size =
sizeof(struct mpi_coredump_global_header); sizeof(struct mpi_coredump_global_header);
mpi_coredump->mpi_global_header.image_size = mpi_coredump->mpi_global_header.image_size =
sizeof(struct ql_mpi_coredump); sizeof(struct qlge_mpi_coredump);
strncpy(mpi_coredump->mpi_global_header.id_string, "MPI Coredump", strncpy(mpi_coredump->mpi_global_header.id_string, "MPI Coredump",
sizeof(mpi_coredump->mpi_global_header.id_string)); sizeof(mpi_coredump->mpi_global_header.id_string));
/* Get generic NIC reg dump */ /* Get generic NIC reg dump */
ql_build_coredump_seg_header(&mpi_coredump->nic_regs_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->nic_regs_seg_hdr,
NIC1_CONTROL_SEG_NUM, NIC1_CONTROL_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) + sizeof(struct mpi_coredump_segment_header) +
sizeof(mpi_coredump->nic_regs), "NIC1 Registers"); sizeof(mpi_coredump->nic_regs), "NIC1 Registers");
ql_build_coredump_seg_header(&mpi_coredump->nic2_regs_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->nic2_regs_seg_hdr,
NIC2_CONTROL_SEG_NUM, NIC2_CONTROL_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) + sizeof(struct mpi_coredump_segment_header) +
sizeof(mpi_coredump->nic2_regs), "NIC2 Registers"); sizeof(mpi_coredump->nic2_regs), "NIC2 Registers");
/* Get XGMac registers. (Segment 18, Rev C. step 21) */ /* Get XGMac registers. (Segment 18, Rev C. step 21) */
ql_build_coredump_seg_header(&mpi_coredump->xgmac1_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->xgmac1_seg_hdr,
NIC1_XGMAC_SEG_NUM, NIC1_XGMAC_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) + sizeof(struct mpi_coredump_segment_header) +
sizeof(mpi_coredump->xgmac1), "NIC1 XGMac Registers"); sizeof(mpi_coredump->xgmac1), "NIC1 XGMac Registers");
ql_build_coredump_seg_header(&mpi_coredump->xgmac2_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->xgmac2_seg_hdr,
NIC2_XGMAC_SEG_NUM, NIC2_XGMAC_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) + sizeof(struct mpi_coredump_segment_header) +
sizeof(mpi_coredump->xgmac2), "NIC2 XGMac Registers"); sizeof(mpi_coredump->xgmac2), "NIC2 XGMac Registers");
if (qdev->func & 1) { if (qdev->func & 1) {
/* Odd means our function is NIC 2 */ /* Odd means our function is NIC 2 */
for (i = 0; i < NIC_REGS_DUMP_WORD_COUNT; i++) for (i = 0; i < NIC_REGS_DUMP_WORD_COUNT; i++)
mpi_coredump->nic2_regs[i] = mpi_coredump->nic2_regs[i] =
ql_read32(qdev, i * sizeof(u32)); qlge_read32(qdev, i * sizeof(u32));
for (i = 0; i < NIC_REGS_DUMP_WORD_COUNT; i++) for (i = 0; i < NIC_REGS_DUMP_WORD_COUNT; i++)
mpi_coredump->nic_regs[i] = mpi_coredump->nic_regs[i] =
ql_read_other_func_reg(qdev, (i * sizeof(u32)) / 4); qlge_read_other_func_reg(qdev, (i * sizeof(u32)) / 4);
ql_get_xgmac_regs(qdev, &mpi_coredump->xgmac2[0], 0); qlge_get_xgmac_regs(qdev, &mpi_coredump->xgmac2[0], 0);
ql_get_xgmac_regs(qdev, &mpi_coredump->xgmac1[0], 1); qlge_get_xgmac_regs(qdev, &mpi_coredump->xgmac1[0], 1);
} else { } else {
/* Even means our function is NIC 1 */ /* Even means our function is NIC 1 */
for (i = 0; i < NIC_REGS_DUMP_WORD_COUNT; i++) for (i = 0; i < NIC_REGS_DUMP_WORD_COUNT; i++)
mpi_coredump->nic_regs[i] = mpi_coredump->nic_regs[i] =
ql_read32(qdev, i * sizeof(u32)); qlge_read32(qdev, i * sizeof(u32));
for (i = 0; i < NIC_REGS_DUMP_WORD_COUNT; i++) for (i = 0; i < NIC_REGS_DUMP_WORD_COUNT; i++)
mpi_coredump->nic2_regs[i] = mpi_coredump->nic2_regs[i] =
ql_read_other_func_reg(qdev, (i * sizeof(u32)) / 4); qlge_read_other_func_reg(qdev, (i * sizeof(u32)) / 4);
ql_get_xgmac_regs(qdev, &mpi_coredump->xgmac1[0], 0); qlge_get_xgmac_regs(qdev, &mpi_coredump->xgmac1[0], 0);
ql_get_xgmac_regs(qdev, &mpi_coredump->xgmac2[0], 1); qlge_get_xgmac_regs(qdev, &mpi_coredump->xgmac2[0], 1);
} }
/* Rev C. Step 20a */ /* Rev C. Step 20a */
ql_build_coredump_seg_header(&mpi_coredump->xaui_an_hdr, qlge_build_coredump_seg_header(&mpi_coredump->xaui_an_hdr,
XAUI_AN_SEG_NUM, XAUI_AN_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) + sizeof(struct mpi_coredump_segment_header) +
sizeof(mpi_coredump->serdes_xaui_an), sizeof(mpi_coredump->serdes_xaui_an),
"XAUI AN Registers"); "XAUI AN Registers");
/* Rev C. Step 20b */ /* Rev C. Step 20b */
ql_build_coredump_seg_header(&mpi_coredump->xaui_hss_pcs_hdr, qlge_build_coredump_seg_header(&mpi_coredump->xaui_hss_pcs_hdr,
XAUI_HSS_PCS_SEG_NUM, XAUI_HSS_PCS_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) + sizeof(struct mpi_coredump_segment_header) +
sizeof(mpi_coredump->serdes_xaui_hss_pcs), sizeof(mpi_coredump->serdes_xaui_hss_pcs),
"XAUI HSS PCS Registers"); "XAUI HSS PCS Registers");
ql_build_coredump_seg_header(&mpi_coredump->xfi_an_hdr, XFI_AN_SEG_NUM, qlge_build_coredump_seg_header(&mpi_coredump->xfi_an_hdr, XFI_AN_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) + sizeof(struct mpi_coredump_segment_header) +
sizeof(mpi_coredump->serdes_xfi_an), sizeof(mpi_coredump->serdes_xfi_an),
"XFI AN Registers"); "XFI AN Registers");
ql_build_coredump_seg_header(&mpi_coredump->xfi_train_hdr, qlge_build_coredump_seg_header(&mpi_coredump->xfi_train_hdr,
XFI_TRAIN_SEG_NUM, XFI_TRAIN_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) + sizeof(struct mpi_coredump_segment_header) +
sizeof(mpi_coredump->serdes_xfi_train), sizeof(mpi_coredump->serdes_xfi_train),
"XFI TRAIN Registers"); "XFI TRAIN Registers");
ql_build_coredump_seg_header(&mpi_coredump->xfi_hss_pcs_hdr, qlge_build_coredump_seg_header(&mpi_coredump->xfi_hss_pcs_hdr,
XFI_HSS_PCS_SEG_NUM, XFI_HSS_PCS_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) + sizeof(struct mpi_coredump_segment_header) +
sizeof(mpi_coredump->serdes_xfi_hss_pcs), sizeof(mpi_coredump->serdes_xfi_hss_pcs),
"XFI HSS PCS Registers"); "XFI HSS PCS Registers");
ql_build_coredump_seg_header(&mpi_coredump->xfi_hss_tx_hdr, qlge_build_coredump_seg_header(&mpi_coredump->xfi_hss_tx_hdr,
XFI_HSS_TX_SEG_NUM, XFI_HSS_TX_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) + sizeof(struct mpi_coredump_segment_header) +
sizeof(mpi_coredump->serdes_xfi_hss_tx), sizeof(mpi_coredump->serdes_xfi_hss_tx),
"XFI HSS TX Registers"); "XFI HSS TX Registers");
ql_build_coredump_seg_header(&mpi_coredump->xfi_hss_rx_hdr, qlge_build_coredump_seg_header(&mpi_coredump->xfi_hss_rx_hdr,
XFI_HSS_RX_SEG_NUM, XFI_HSS_RX_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) + sizeof(struct mpi_coredump_segment_header) +
sizeof(mpi_coredump->serdes_xfi_hss_rx), sizeof(mpi_coredump->serdes_xfi_hss_rx),
"XFI HSS RX Registers"); "XFI HSS RX Registers");
ql_build_coredump_seg_header(&mpi_coredump->xfi_hss_pll_hdr, qlge_build_coredump_seg_header(&mpi_coredump->xfi_hss_pll_hdr,
XFI_HSS_PLL_SEG_NUM, XFI_HSS_PLL_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) + sizeof(struct mpi_coredump_segment_header) +
sizeof(mpi_coredump->serdes_xfi_hss_pll), sizeof(mpi_coredump->serdes_xfi_hss_pll),
"XFI HSS PLL Registers"); "XFI HSS PLL Registers");
ql_build_coredump_seg_header(&mpi_coredump->xaui2_an_hdr, qlge_build_coredump_seg_header(&mpi_coredump->xaui2_an_hdr,
XAUI2_AN_SEG_NUM, XAUI2_AN_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) + sizeof(struct mpi_coredump_segment_header) +
sizeof(mpi_coredump->serdes2_xaui_an), sizeof(mpi_coredump->serdes2_xaui_an),
"XAUI2 AN Registers"); "XAUI2 AN Registers");
ql_build_coredump_seg_header(&mpi_coredump->xaui2_hss_pcs_hdr, qlge_build_coredump_seg_header(&mpi_coredump->xaui2_hss_pcs_hdr,
XAUI2_HSS_PCS_SEG_NUM, XAUI2_HSS_PCS_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) + sizeof(struct mpi_coredump_segment_header) +
sizeof(mpi_coredump->serdes2_xaui_hss_pcs), sizeof(mpi_coredump->serdes2_xaui_hss_pcs),
"XAUI2 HSS PCS Registers"); "XAUI2 HSS PCS Registers");
ql_build_coredump_seg_header(&mpi_coredump->xfi2_an_hdr, qlge_build_coredump_seg_header(&mpi_coredump->xfi2_an_hdr,
XFI2_AN_SEG_NUM, XFI2_AN_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) + sizeof(struct mpi_coredump_segment_header) +
sizeof(mpi_coredump->serdes2_xfi_an), sizeof(mpi_coredump->serdes2_xfi_an),
"XFI2 AN Registers"); "XFI2 AN Registers");
ql_build_coredump_seg_header(&mpi_coredump->xfi2_train_hdr, qlge_build_coredump_seg_header(&mpi_coredump->xfi2_train_hdr,
XFI2_TRAIN_SEG_NUM, XFI2_TRAIN_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) + sizeof(struct mpi_coredump_segment_header) +
sizeof(mpi_coredump->serdes2_xfi_train), sizeof(mpi_coredump->serdes2_xfi_train),
"XFI2 TRAIN Registers"); "XFI2 TRAIN Registers");
ql_build_coredump_seg_header(&mpi_coredump->xfi2_hss_pcs_hdr, qlge_build_coredump_seg_header(&mpi_coredump->xfi2_hss_pcs_hdr,
XFI2_HSS_PCS_SEG_NUM, XFI2_HSS_PCS_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) + sizeof(struct mpi_coredump_segment_header) +
sizeof(mpi_coredump->serdes2_xfi_hss_pcs), sizeof(mpi_coredump->serdes2_xfi_hss_pcs),
"XFI2 HSS PCS Registers"); "XFI2 HSS PCS Registers");
ql_build_coredump_seg_header(&mpi_coredump->xfi2_hss_tx_hdr, qlge_build_coredump_seg_header(&mpi_coredump->xfi2_hss_tx_hdr,
XFI2_HSS_TX_SEG_NUM, XFI2_HSS_TX_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) + sizeof(struct mpi_coredump_segment_header) +
sizeof(mpi_coredump->serdes2_xfi_hss_tx), sizeof(mpi_coredump->serdes2_xfi_hss_tx),
"XFI2 HSS TX Registers"); "XFI2 HSS TX Registers");
ql_build_coredump_seg_header(&mpi_coredump->xfi2_hss_rx_hdr, qlge_build_coredump_seg_header(&mpi_coredump->xfi2_hss_rx_hdr,
XFI2_HSS_RX_SEG_NUM, XFI2_HSS_RX_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) + sizeof(struct mpi_coredump_segment_header) +
sizeof(mpi_coredump->serdes2_xfi_hss_rx), sizeof(mpi_coredump->serdes2_xfi_hss_rx),
"XFI2 HSS RX Registers"); "XFI2 HSS RX Registers");
ql_build_coredump_seg_header(&mpi_coredump->xfi2_hss_pll_hdr, qlge_build_coredump_seg_header(&mpi_coredump->xfi2_hss_pll_hdr,
XFI2_HSS_PLL_SEG_NUM, XFI2_HSS_PLL_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) + sizeof(struct mpi_coredump_segment_header) +
sizeof(mpi_coredump->serdes2_xfi_hss_pll), sizeof(mpi_coredump->serdes2_xfi_hss_pll),
"XFI2 HSS PLL Registers"); "XFI2 HSS PLL Registers");
status = ql_get_serdes_regs(qdev, mpi_coredump); status = qlge_get_serdes_regs(qdev, mpi_coredump);
if (status) { if (status) {
netif_err(qdev, drv, qdev->ndev, netif_err(qdev, drv, qdev->ndev,
"Failed Dump of Serdes Registers. Status = 0x%.08x\n", "Failed Dump of Serdes Registers. Status = 0x%.08x\n",
...@@ -896,185 +895,185 @@ int ql_core_dump(struct ql_adapter *qdev, struct ql_mpi_coredump *mpi_coredump) ...@@ -896,185 +895,185 @@ int ql_core_dump(struct ql_adapter *qdev, struct ql_mpi_coredump *mpi_coredump)
goto err; goto err;
} }
ql_build_coredump_seg_header(&mpi_coredump->core_regs_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->core_regs_seg_hdr,
CORE_SEG_NUM, CORE_SEG_NUM,
sizeof(mpi_coredump->core_regs_seg_hdr) + sizeof(mpi_coredump->core_regs_seg_hdr) +
sizeof(mpi_coredump->mpi_core_regs) + sizeof(mpi_coredump->mpi_core_regs) +
sizeof(mpi_coredump->mpi_core_sh_regs), sizeof(mpi_coredump->mpi_core_sh_regs),
"Core Registers"); "Core Registers");
/* Get the MPI Core Registers */ /* Get the MPI Core Registers */
status = ql_get_mpi_regs(qdev, &mpi_coredump->mpi_core_regs[0], status = qlge_get_mpi_regs(qdev, &mpi_coredump->mpi_core_regs[0],
MPI_CORE_REGS_ADDR, MPI_CORE_REGS_CNT); MPI_CORE_REGS_ADDR, MPI_CORE_REGS_CNT);
if (status) if (status)
goto err; goto err;
/* Get the 16 MPI shadow registers */ /* Get the 16 MPI shadow registers */
status = ql_get_mpi_shadow_regs(qdev, status = qlge_get_mpi_shadow_regs(qdev,
&mpi_coredump->mpi_core_sh_regs[0]); &mpi_coredump->mpi_core_sh_regs[0]);
if (status) if (status)
goto err; goto err;
/* Get the Test Logic Registers */ /* Get the Test Logic Registers */
ql_build_coredump_seg_header(&mpi_coredump->test_logic_regs_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->test_logic_regs_seg_hdr,
TEST_LOGIC_SEG_NUM, TEST_LOGIC_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->test_logic_regs), + sizeof(mpi_coredump->test_logic_regs),
"Test Logic Regs"); "Test Logic Regs");
status = ql_get_mpi_regs(qdev, &mpi_coredump->test_logic_regs[0], status = qlge_get_mpi_regs(qdev, &mpi_coredump->test_logic_regs[0],
TEST_REGS_ADDR, TEST_REGS_CNT); TEST_REGS_ADDR, TEST_REGS_CNT);
if (status) if (status)
goto err; goto err;
/* Get the RMII Registers */ /* Get the RMII Registers */
ql_build_coredump_seg_header(&mpi_coredump->rmii_regs_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->rmii_regs_seg_hdr,
RMII_SEG_NUM, RMII_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->rmii_regs), + sizeof(mpi_coredump->rmii_regs),
"RMII Registers"); "RMII Registers");
status = ql_get_mpi_regs(qdev, &mpi_coredump->rmii_regs[0], status = qlge_get_mpi_regs(qdev, &mpi_coredump->rmii_regs[0],
RMII_REGS_ADDR, RMII_REGS_CNT); RMII_REGS_ADDR, RMII_REGS_CNT);
if (status) if (status)
goto err; goto err;
/* Get the FCMAC1 Registers */ /* Get the FCMAC1 Registers */
ql_build_coredump_seg_header(&mpi_coredump->fcmac1_regs_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->fcmac1_regs_seg_hdr,
FCMAC1_SEG_NUM, FCMAC1_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->fcmac1_regs), + sizeof(mpi_coredump->fcmac1_regs),
"FCMAC1 Registers"); "FCMAC1 Registers");
status = ql_get_mpi_regs(qdev, &mpi_coredump->fcmac1_regs[0], status = qlge_get_mpi_regs(qdev, &mpi_coredump->fcmac1_regs[0],
FCMAC1_REGS_ADDR, FCMAC_REGS_CNT); FCMAC1_REGS_ADDR, FCMAC_REGS_CNT);
if (status) if (status)
goto err; goto err;
/* Get the FCMAC2 Registers */ /* Get the FCMAC2 Registers */
ql_build_coredump_seg_header(&mpi_coredump->fcmac2_regs_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->fcmac2_regs_seg_hdr,
FCMAC2_SEG_NUM, FCMAC2_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->fcmac2_regs), + sizeof(mpi_coredump->fcmac2_regs),
"FCMAC2 Registers"); "FCMAC2 Registers");
status = ql_get_mpi_regs(qdev, &mpi_coredump->fcmac2_regs[0], status = qlge_get_mpi_regs(qdev, &mpi_coredump->fcmac2_regs[0],
FCMAC2_REGS_ADDR, FCMAC_REGS_CNT); FCMAC2_REGS_ADDR, FCMAC_REGS_CNT);
if (status) if (status)
goto err; goto err;
/* Get the FC1 MBX Registers */ /* Get the FC1 MBX Registers */
ql_build_coredump_seg_header(&mpi_coredump->fc1_mbx_regs_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->fc1_mbx_regs_seg_hdr,
FC1_MBOX_SEG_NUM, FC1_MBOX_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->fc1_mbx_regs), + sizeof(mpi_coredump->fc1_mbx_regs),
"FC1 MBox Regs"); "FC1 MBox Regs");
status = ql_get_mpi_regs(qdev, &mpi_coredump->fc1_mbx_regs[0], status = qlge_get_mpi_regs(qdev, &mpi_coredump->fc1_mbx_regs[0],
FC1_MBX_REGS_ADDR, FC_MBX_REGS_CNT); FC1_MBX_REGS_ADDR, FC_MBX_REGS_CNT);
if (status) if (status)
goto err; goto err;
/* Get the IDE Registers */ /* Get the IDE Registers */
ql_build_coredump_seg_header(&mpi_coredump->ide_regs_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->ide_regs_seg_hdr,
IDE_SEG_NUM, IDE_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->ide_regs), + sizeof(mpi_coredump->ide_regs),
"IDE Registers"); "IDE Registers");
status = ql_get_mpi_regs(qdev, &mpi_coredump->ide_regs[0], status = qlge_get_mpi_regs(qdev, &mpi_coredump->ide_regs[0],
IDE_REGS_ADDR, IDE_REGS_CNT); IDE_REGS_ADDR, IDE_REGS_CNT);
if (status) if (status)
goto err; goto err;
/* Get the NIC1 MBX Registers */ /* Get the NIC1 MBX Registers */
ql_build_coredump_seg_header(&mpi_coredump->nic1_mbx_regs_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->nic1_mbx_regs_seg_hdr,
NIC1_MBOX_SEG_NUM, NIC1_MBOX_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->nic1_mbx_regs), + sizeof(mpi_coredump->nic1_mbx_regs),
"NIC1 MBox Regs"); "NIC1 MBox Regs");
status = ql_get_mpi_regs(qdev, &mpi_coredump->nic1_mbx_regs[0], status = qlge_get_mpi_regs(qdev, &mpi_coredump->nic1_mbx_regs[0],
NIC1_MBX_REGS_ADDR, NIC_MBX_REGS_CNT); NIC1_MBX_REGS_ADDR, NIC_MBX_REGS_CNT);
if (status) if (status)
goto err; goto err;
/* Get the SMBus Registers */ /* Get the SMBus Registers */
ql_build_coredump_seg_header(&mpi_coredump->smbus_regs_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->smbus_regs_seg_hdr,
SMBUS_SEG_NUM, SMBUS_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->smbus_regs), + sizeof(mpi_coredump->smbus_regs),
"SMBus Registers"); "SMBus Registers");
status = ql_get_mpi_regs(qdev, &mpi_coredump->smbus_regs[0], status = qlge_get_mpi_regs(qdev, &mpi_coredump->smbus_regs[0],
SMBUS_REGS_ADDR, SMBUS_REGS_CNT); SMBUS_REGS_ADDR, SMBUS_REGS_CNT);
if (status) if (status)
goto err; goto err;
/* Get the FC2 MBX Registers */ /* Get the FC2 MBX Registers */
ql_build_coredump_seg_header(&mpi_coredump->fc2_mbx_regs_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->fc2_mbx_regs_seg_hdr,
FC2_MBOX_SEG_NUM, FC2_MBOX_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->fc2_mbx_regs), + sizeof(mpi_coredump->fc2_mbx_regs),
"FC2 MBox Regs"); "FC2 MBox Regs");
status = ql_get_mpi_regs(qdev, &mpi_coredump->fc2_mbx_regs[0], status = qlge_get_mpi_regs(qdev, &mpi_coredump->fc2_mbx_regs[0],
FC2_MBX_REGS_ADDR, FC_MBX_REGS_CNT); FC2_MBX_REGS_ADDR, FC_MBX_REGS_CNT);
if (status) if (status)
goto err; goto err;
/* Get the NIC2 MBX Registers */ /* Get the NIC2 MBX Registers */
ql_build_coredump_seg_header(&mpi_coredump->nic2_mbx_regs_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->nic2_mbx_regs_seg_hdr,
NIC2_MBOX_SEG_NUM, NIC2_MBOX_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->nic2_mbx_regs), + sizeof(mpi_coredump->nic2_mbx_regs),
"NIC2 MBox Regs"); "NIC2 MBox Regs");
status = ql_get_mpi_regs(qdev, &mpi_coredump->nic2_mbx_regs[0], status = qlge_get_mpi_regs(qdev, &mpi_coredump->nic2_mbx_regs[0],
NIC2_MBX_REGS_ADDR, NIC_MBX_REGS_CNT); NIC2_MBX_REGS_ADDR, NIC_MBX_REGS_CNT);
if (status) if (status)
goto err; goto err;
/* Get the I2C Registers */ /* Get the I2C Registers */
ql_build_coredump_seg_header(&mpi_coredump->i2c_regs_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->i2c_regs_seg_hdr,
I2C_SEG_NUM, I2C_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->i2c_regs), + sizeof(mpi_coredump->i2c_regs),
"I2C Registers"); "I2C Registers");
status = ql_get_mpi_regs(qdev, &mpi_coredump->i2c_regs[0], status = qlge_get_mpi_regs(qdev, &mpi_coredump->i2c_regs[0],
I2C_REGS_ADDR, I2C_REGS_CNT); I2C_REGS_ADDR, I2C_REGS_CNT);
if (status) if (status)
goto err; goto err;
/* Get the MEMC Registers */ /* Get the MEMC Registers */
ql_build_coredump_seg_header(&mpi_coredump->memc_regs_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->memc_regs_seg_hdr,
MEMC_SEG_NUM, MEMC_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->memc_regs), + sizeof(mpi_coredump->memc_regs),
"MEMC Registers"); "MEMC Registers");
status = ql_get_mpi_regs(qdev, &mpi_coredump->memc_regs[0], status = qlge_get_mpi_regs(qdev, &mpi_coredump->memc_regs[0],
MEMC_REGS_ADDR, MEMC_REGS_CNT); MEMC_REGS_ADDR, MEMC_REGS_CNT);
if (status) if (status)
goto err; goto err;
/* Get the PBus Registers */ /* Get the PBus Registers */
ql_build_coredump_seg_header(&mpi_coredump->pbus_regs_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->pbus_regs_seg_hdr,
PBUS_SEG_NUM, PBUS_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->pbus_regs), + sizeof(mpi_coredump->pbus_regs),
"PBUS Registers"); "PBUS Registers");
status = ql_get_mpi_regs(qdev, &mpi_coredump->pbus_regs[0], status = qlge_get_mpi_regs(qdev, &mpi_coredump->pbus_regs[0],
PBUS_REGS_ADDR, PBUS_REGS_CNT); PBUS_REGS_ADDR, PBUS_REGS_CNT);
if (status) if (status)
goto err; goto err;
/* Get the MDE Registers */ /* Get the MDE Registers */
ql_build_coredump_seg_header(&mpi_coredump->mde_regs_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->mde_regs_seg_hdr,
MDE_SEG_NUM, MDE_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->mde_regs), + sizeof(mpi_coredump->mde_regs),
"MDE Registers"); "MDE Registers");
status = ql_get_mpi_regs(qdev, &mpi_coredump->mde_regs[0], status = qlge_get_mpi_regs(qdev, &mpi_coredump->mde_regs[0],
MDE_REGS_ADDR, MDE_REGS_CNT); MDE_REGS_ADDR, MDE_REGS_CNT);
if (status) if (status)
goto err; goto err;
ql_build_coredump_seg_header(&mpi_coredump->misc_nic_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->misc_nic_seg_hdr,
MISC_NIC_INFO_SEG_NUM, MISC_NIC_INFO_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->misc_nic_info), + sizeof(mpi_coredump->misc_nic_info),
"MISC NIC INFO"); "MISC NIC INFO");
mpi_coredump->misc_nic_info.rx_ring_count = qdev->rx_ring_count; mpi_coredump->misc_nic_info.rx_ring_count = qdev->rx_ring_count;
mpi_coredump->misc_nic_info.tx_ring_count = qdev->tx_ring_count; mpi_coredump->misc_nic_info.tx_ring_count = qdev->tx_ring_count;
mpi_coredump->misc_nic_info.intr_count = qdev->intr_count; mpi_coredump->misc_nic_info.intr_count = qdev->intr_count;
...@@ -1082,79 +1081,79 @@ int ql_core_dump(struct ql_adapter *qdev, struct ql_mpi_coredump *mpi_coredump) ...@@ -1082,79 +1081,79 @@ int ql_core_dump(struct ql_adapter *qdev, struct ql_mpi_coredump *mpi_coredump)
/* Segment 31 */ /* Segment 31 */
/* Get indexed register values. */ /* Get indexed register values. */
ql_build_coredump_seg_header(&mpi_coredump->intr_states_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->intr_states_seg_hdr,
INTR_STATES_SEG_NUM, INTR_STATES_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->intr_states), + sizeof(mpi_coredump->intr_states),
"INTR States"); "INTR States");
ql_get_intr_states(qdev, &mpi_coredump->intr_states[0]); qlge_get_intr_states(qdev, &mpi_coredump->intr_states[0]);
ql_build_coredump_seg_header(&mpi_coredump->cam_entries_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->cam_entries_seg_hdr,
CAM_ENTRIES_SEG_NUM, CAM_ENTRIES_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->cam_entries), + sizeof(mpi_coredump->cam_entries),
"CAM Entries"); "CAM Entries");
status = ql_get_cam_entries(qdev, &mpi_coredump->cam_entries[0]); status = qlge_get_cam_entries(qdev, &mpi_coredump->cam_entries[0]);
if (status) if (status)
goto err; goto err;
ql_build_coredump_seg_header(&mpi_coredump->nic_routing_words_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->nic_routing_words_seg_hdr,
ROUTING_WORDS_SEG_NUM, ROUTING_WORDS_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->nic_routing_words), + sizeof(mpi_coredump->nic_routing_words),
"Routing Words"); "Routing Words");
status = ql_get_routing_entries(qdev, status = qlge_get_routing_entries(qdev,
&mpi_coredump->nic_routing_words[0]); &mpi_coredump->nic_routing_words[0]);
if (status) if (status)
goto err; goto err;
/* Segment 34 (Rev C. step 23) */ /* Segment 34 (Rev C. step 23) */
ql_build_coredump_seg_header(&mpi_coredump->ets_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->ets_seg_hdr,
ETS_SEG_NUM, ETS_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->ets), + sizeof(mpi_coredump->ets),
"ETS Registers"); "ETS Registers");
status = ql_get_ets_regs(qdev, &mpi_coredump->ets[0]); status = qlge_get_ets_regs(qdev, &mpi_coredump->ets[0]);
if (status) if (status)
goto err; goto err;
ql_build_coredump_seg_header(&mpi_coredump->probe_dump_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->probe_dump_seg_hdr,
PROBE_DUMP_SEG_NUM, PROBE_DUMP_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->probe_dump), + sizeof(mpi_coredump->probe_dump),
"Probe Dump"); "Probe Dump");
ql_get_probe_dump(qdev, &mpi_coredump->probe_dump[0]); qlge_get_probe_dump(qdev, &mpi_coredump->probe_dump[0]);
ql_build_coredump_seg_header(&mpi_coredump->routing_reg_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->routing_reg_seg_hdr,
ROUTING_INDEX_SEG_NUM, ROUTING_INDEX_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->routing_regs), + sizeof(mpi_coredump->routing_regs),
"Routing Regs"); "Routing Regs");
status = ql_get_routing_index_registers(qdev, status = qlge_get_routing_index_registers(qdev,
&mpi_coredump->routing_regs[0]); &mpi_coredump->routing_regs[0]);
if (status) if (status)
goto err; goto err;
ql_build_coredump_seg_header(&mpi_coredump->mac_prot_reg_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->mac_prot_reg_seg_hdr,
MAC_PROTOCOL_SEG_NUM, MAC_PROTOCOL_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->mac_prot_regs), + sizeof(mpi_coredump->mac_prot_regs),
"MAC Prot Regs"); "MAC Prot Regs");
ql_get_mac_protocol_registers(qdev, &mpi_coredump->mac_prot_regs[0]); qlge_get_mac_protocol_registers(qdev, &mpi_coredump->mac_prot_regs[0]);
/* Get the semaphore registers for all 5 functions */ /* Get the semaphore registers for all 5 functions */
ql_build_coredump_seg_header(&mpi_coredump->sem_regs_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->sem_regs_seg_hdr,
SEM_REGS_SEG_NUM, SEM_REGS_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) + sizeof(struct mpi_coredump_segment_header) +
sizeof(mpi_coredump->sem_regs), "Sem Registers"); sizeof(mpi_coredump->sem_regs), "Sem Registers");
ql_get_sem_registers(qdev, &mpi_coredump->sem_regs[0]); qlge_get_sem_registers(qdev, &mpi_coredump->sem_regs[0]);
/* Prevent the mpi restarting while we dump the memory.*/ /* Prevent the mpi restarting while we dump the memory.*/
ql_write_mpi_reg(qdev, MPI_TEST_FUNC_RST_STS, MPI_TEST_FUNC_RST_FRC); qlge_write_mpi_reg(qdev, MPI_TEST_FUNC_RST_STS, MPI_TEST_FUNC_RST_FRC);
/* clear the pause */ /* clear the pause */
status = ql_unpause_mpi_risc(qdev); status = qlge_unpause_mpi_risc(qdev);
if (status) { if (status) {
netif_err(qdev, drv, qdev->ndev, netif_err(qdev, drv, qdev->ndev,
"Failed RISC unpause. Status = 0x%.08x\n", status); "Failed RISC unpause. Status = 0x%.08x\n", status);
...@@ -1162,20 +1161,20 @@ int ql_core_dump(struct ql_adapter *qdev, struct ql_mpi_coredump *mpi_coredump) ...@@ -1162,20 +1161,20 @@ int ql_core_dump(struct ql_adapter *qdev, struct ql_mpi_coredump *mpi_coredump)
} }
/* Reset the RISC so we can dump RAM */ /* Reset the RISC so we can dump RAM */
status = ql_hard_reset_mpi_risc(qdev); status = qlge_hard_reset_mpi_risc(qdev);
if (status) { if (status) {
netif_err(qdev, drv, qdev->ndev, netif_err(qdev, drv, qdev->ndev,
"Failed RISC reset. Status = 0x%.08x\n", status); "Failed RISC reset. Status = 0x%.08x\n", status);
goto err; goto err;
} }
ql_build_coredump_seg_header(&mpi_coredump->code_ram_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->code_ram_seg_hdr,
WCS_RAM_SEG_NUM, WCS_RAM_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->code_ram), + sizeof(mpi_coredump->code_ram),
"WCS RAM"); "WCS RAM");
status = ql_dump_risc_ram_area(qdev, &mpi_coredump->code_ram[0], status = qlge_dump_risc_ram_area(qdev, &mpi_coredump->code_ram[0],
CODE_RAM_ADDR, CODE_RAM_CNT); CODE_RAM_ADDR, CODE_RAM_CNT);
if (status) { if (status) {
netif_err(qdev, drv, qdev->ndev, netif_err(qdev, drv, qdev->ndev,
"Failed Dump of CODE RAM. Status = 0x%.08x\n", "Failed Dump of CODE RAM. Status = 0x%.08x\n",
...@@ -1184,13 +1183,13 @@ int ql_core_dump(struct ql_adapter *qdev, struct ql_mpi_coredump *mpi_coredump) ...@@ -1184,13 +1183,13 @@ int ql_core_dump(struct ql_adapter *qdev, struct ql_mpi_coredump *mpi_coredump)
} }
/* Insert the segment header */ /* Insert the segment header */
ql_build_coredump_seg_header(&mpi_coredump->memc_ram_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->memc_ram_seg_hdr,
MEMC_RAM_SEG_NUM, MEMC_RAM_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->memc_ram), + sizeof(mpi_coredump->memc_ram),
"MEMC RAM"); "MEMC RAM");
status = ql_dump_risc_ram_area(qdev, &mpi_coredump->memc_ram[0], status = qlge_dump_risc_ram_area(qdev, &mpi_coredump->memc_ram[0],
MEMC_RAM_ADDR, MEMC_RAM_CNT); MEMC_RAM_ADDR, MEMC_RAM_CNT);
if (status) { if (status) {
netif_err(qdev, drv, qdev->ndev, netif_err(qdev, drv, qdev->ndev,
"Failed Dump of MEMC RAM. Status = 0x%.08x\n", "Failed Dump of MEMC RAM. Status = 0x%.08x\n",
...@@ -1198,13 +1197,13 @@ int ql_core_dump(struct ql_adapter *qdev, struct ql_mpi_coredump *mpi_coredump) ...@@ -1198,13 +1197,13 @@ int ql_core_dump(struct ql_adapter *qdev, struct ql_mpi_coredump *mpi_coredump)
goto err; goto err;
} }
err: err:
ql_sem_unlock(qdev, SEM_PROC_REG_MASK); /* does flush too */ qlge_sem_unlock(qdev, SEM_PROC_REG_MASK); /* does flush too */
return status; return status;
} }
static void ql_get_core_dump(struct ql_adapter *qdev) static void qlge_get_core_dump(struct qlge_adapter *qdev)
{ {
if (!ql_own_firmware(qdev)) { if (!qlge_own_firmware(qdev)) {
netif_err(qdev, drv, qdev->ndev, "Don't own firmware!\n"); netif_err(qdev, drv, qdev->ndev, "Don't own firmware!\n");
return; return;
} }
...@@ -1214,11 +1213,11 @@ static void ql_get_core_dump(struct ql_adapter *qdev) ...@@ -1214,11 +1213,11 @@ static void ql_get_core_dump(struct ql_adapter *qdev)
"Force Coredump can only be done from interface that is up\n"); "Force Coredump can only be done from interface that is up\n");
return; return;
} }
ql_queue_fw_error(qdev); qlge_queue_fw_error(qdev);
} }
static void ql_gen_reg_dump(struct ql_adapter *qdev, static void qlge_gen_reg_dump(struct qlge_adapter *qdev,
struct ql_reg_dump *mpi_coredump) struct qlge_reg_dump *mpi_coredump)
{ {
int i, status; int i, status;
...@@ -1228,71 +1227,71 @@ static void ql_gen_reg_dump(struct ql_adapter *qdev, ...@@ -1228,71 +1227,71 @@ static void ql_gen_reg_dump(struct ql_adapter *qdev,
mpi_coredump->mpi_global_header.header_size = mpi_coredump->mpi_global_header.header_size =
sizeof(struct mpi_coredump_global_header); sizeof(struct mpi_coredump_global_header);
mpi_coredump->mpi_global_header.image_size = mpi_coredump->mpi_global_header.image_size =
sizeof(struct ql_reg_dump); sizeof(struct qlge_reg_dump);
strncpy(mpi_coredump->mpi_global_header.id_string, "MPI Coredump", strncpy(mpi_coredump->mpi_global_header.id_string, "MPI Coredump",
sizeof(mpi_coredump->mpi_global_header.id_string)); sizeof(mpi_coredump->mpi_global_header.id_string));
/* segment 16 */ /* segment 16 */
ql_build_coredump_seg_header(&mpi_coredump->misc_nic_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->misc_nic_seg_hdr,
MISC_NIC_INFO_SEG_NUM, MISC_NIC_INFO_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->misc_nic_info), + sizeof(mpi_coredump->misc_nic_info),
"MISC NIC INFO"); "MISC NIC INFO");
mpi_coredump->misc_nic_info.rx_ring_count = qdev->rx_ring_count; mpi_coredump->misc_nic_info.rx_ring_count = qdev->rx_ring_count;
mpi_coredump->misc_nic_info.tx_ring_count = qdev->tx_ring_count; mpi_coredump->misc_nic_info.tx_ring_count = qdev->tx_ring_count;
mpi_coredump->misc_nic_info.intr_count = qdev->intr_count; mpi_coredump->misc_nic_info.intr_count = qdev->intr_count;
mpi_coredump->misc_nic_info.function = qdev->func; mpi_coredump->misc_nic_info.function = qdev->func;
/* Segment 16, Rev C. Step 18 */ /* Segment 16, Rev C. Step 18 */
ql_build_coredump_seg_header(&mpi_coredump->nic_regs_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->nic_regs_seg_hdr,
NIC1_CONTROL_SEG_NUM, NIC1_CONTROL_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->nic_regs), + sizeof(mpi_coredump->nic_regs),
"NIC Registers"); "NIC Registers");
/* Get generic reg dump */ /* Get generic reg dump */
for (i = 0; i < 64; i++) for (i = 0; i < 64; i++)
mpi_coredump->nic_regs[i] = ql_read32(qdev, i * sizeof(u32)); mpi_coredump->nic_regs[i] = qlge_read32(qdev, i * sizeof(u32));
/* Segment 31 */ /* Segment 31 */
/* Get indexed register values. */ /* Get indexed register values. */
ql_build_coredump_seg_header(&mpi_coredump->intr_states_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->intr_states_seg_hdr,
INTR_STATES_SEG_NUM, INTR_STATES_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->intr_states), + sizeof(mpi_coredump->intr_states),
"INTR States"); "INTR States");
ql_get_intr_states(qdev, &mpi_coredump->intr_states[0]); qlge_get_intr_states(qdev, &mpi_coredump->intr_states[0]);
ql_build_coredump_seg_header(&mpi_coredump->cam_entries_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->cam_entries_seg_hdr,
CAM_ENTRIES_SEG_NUM, CAM_ENTRIES_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->cam_entries), + sizeof(mpi_coredump->cam_entries),
"CAM Entries"); "CAM Entries");
status = ql_get_cam_entries(qdev, &mpi_coredump->cam_entries[0]); status = qlge_get_cam_entries(qdev, &mpi_coredump->cam_entries[0]);
if (status) if (status)
return; return;
ql_build_coredump_seg_header(&mpi_coredump->nic_routing_words_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->nic_routing_words_seg_hdr,
ROUTING_WORDS_SEG_NUM, ROUTING_WORDS_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->nic_routing_words), + sizeof(mpi_coredump->nic_routing_words),
"Routing Words"); "Routing Words");
status = ql_get_routing_entries(qdev, status = qlge_get_routing_entries(qdev,
&mpi_coredump->nic_routing_words[0]); &mpi_coredump->nic_routing_words[0]);
if (status) if (status)
return; return;
/* Segment 34 (Rev C. step 23) */ /* Segment 34 (Rev C. step 23) */
ql_build_coredump_seg_header(&mpi_coredump->ets_seg_hdr, qlge_build_coredump_seg_header(&mpi_coredump->ets_seg_hdr,
ETS_SEG_NUM, ETS_SEG_NUM,
sizeof(struct mpi_coredump_segment_header) sizeof(struct mpi_coredump_segment_header)
+ sizeof(mpi_coredump->ets), + sizeof(mpi_coredump->ets),
"ETS Registers"); "ETS Registers");
status = ql_get_ets_regs(qdev, &mpi_coredump->ets[0]); status = qlge_get_ets_regs(qdev, &mpi_coredump->ets[0]);
if (status) if (status)
return; return;
} }
void ql_get_dump(struct ql_adapter *qdev, void *buff) void qlge_get_dump(struct qlge_adapter *qdev, void *buff)
{ {
/* /*
* If the dump has already been taken and is stored * If the dump has already been taken and is stored
...@@ -1304,21 +1303,21 @@ void ql_get_dump(struct ql_adapter *qdev, void *buff) ...@@ -1304,21 +1303,21 @@ void ql_get_dump(struct ql_adapter *qdev, void *buff)
*/ */
if (!test_bit(QL_FRC_COREDUMP, &qdev->flags)) { if (!test_bit(QL_FRC_COREDUMP, &qdev->flags)) {
if (!ql_core_dump(qdev, buff)) if (!qlge_core_dump(qdev, buff))
ql_soft_reset_mpi_risc(qdev); qlge_soft_reset_mpi_risc(qdev);
else else
netif_err(qdev, drv, qdev->ndev, "coredump failed!\n"); netif_err(qdev, drv, qdev->ndev, "coredump failed!\n");
} else { } else {
ql_gen_reg_dump(qdev, buff); qlge_gen_reg_dump(qdev, buff);
ql_get_core_dump(qdev); qlge_get_core_dump(qdev);
} }
} }
/* Coredump to messages log file using separate worker thread */ /* Coredump to messages log file using separate worker thread */
void ql_mpi_core_to_log(struct work_struct *work) void qlge_mpi_core_to_log(struct work_struct *work)
{ {
struct ql_adapter *qdev = struct qlge_adapter *qdev =
container_of(work, struct ql_adapter, mpi_core_to_log.work); container_of(work, struct qlge_adapter, mpi_core_to_log.work);
print_hex_dump(KERN_DEBUG, "Core is dumping to log file!\n", print_hex_dump(KERN_DEBUG, "Core is dumping to log file!\n",
DUMP_PREFIX_OFFSET, 32, 4, qdev->mpi_coredump, DUMP_PREFIX_OFFSET, 32, 4, qdev->mpi_coredump,
...@@ -1326,29 +1325,29 @@ void ql_mpi_core_to_log(struct work_struct *work) ...@@ -1326,29 +1325,29 @@ void ql_mpi_core_to_log(struct work_struct *work)
} }
#ifdef QL_REG_DUMP #ifdef QL_REG_DUMP
static void ql_dump_intr_states(struct ql_adapter *qdev) static void qlge_dump_intr_states(struct qlge_adapter *qdev)
{ {
int i; int i;
u32 value; u32 value;
for (i = 0; i < qdev->intr_count; i++) { for (i = 0; i < qdev->intr_count; i++) {
ql_write32(qdev, INTR_EN, qdev->intr_context[i].intr_read_mask); qlge_write32(qdev, INTR_EN, qdev->intr_context[i].intr_read_mask);
value = ql_read32(qdev, INTR_EN); value = qlge_read32(qdev, INTR_EN);
netdev_err(qdev->ndev, "Interrupt %d is %s\n", i, netdev_err(qdev->ndev, "Interrupt %d is %s\n", i,
(value & INTR_EN_EN ? "enabled" : "disabled")); (value & INTR_EN_EN ? "enabled" : "disabled"));
} }
} }
#define DUMP_XGMAC(qdev, reg) \ #define DUMP_XGMAC(qdev, reg) \
do { \ do { \
u32 data; \ u32 data; \
ql_read_xgmac_reg(qdev, reg, &data); \ qlge_read_xgmac_reg(qdev, reg, &data); \
netdev_err(qdev->ndev, "%s = 0x%.08x\n", #reg, data); \ netdev_err(qdev->ndev, "%s = 0x%.08x\n", #reg, data); \
} while (0) } while (0)
void ql_dump_xgmac_control_regs(struct ql_adapter *qdev) void qlge_dump_xgmac_control_regs(struct qlge_adapter *qdev)
{ {
if (ql_sem_spinlock(qdev, qdev->xg_sem_mask)) { if (qlge_sem_spinlock(qdev, qdev->xg_sem_mask)) {
netdev_err(qdev->ndev, "%s: Couldn't get xgmac sem\n", netdev_err(qdev->ndev, "%s: Couldn't get xgmac sem\n",
__func__); __func__);
return; return;
...@@ -1370,23 +1369,23 @@ void ql_dump_xgmac_control_regs(struct ql_adapter *qdev) ...@@ -1370,23 +1369,23 @@ void ql_dump_xgmac_control_regs(struct ql_adapter *qdev)
DUMP_XGMAC(qdev, MAC_MGMT_INT); DUMP_XGMAC(qdev, MAC_MGMT_INT);
DUMP_XGMAC(qdev, MAC_MGMT_IN_MASK); DUMP_XGMAC(qdev, MAC_MGMT_IN_MASK);
DUMP_XGMAC(qdev, EXT_ARB_MODE); DUMP_XGMAC(qdev, EXT_ARB_MODE);
ql_sem_unlock(qdev, qdev->xg_sem_mask); qlge_sem_unlock(qdev, qdev->xg_sem_mask);
} }
static void ql_dump_ets_regs(struct ql_adapter *qdev) static void qlge_dump_ets_regs(struct qlge_adapter *qdev)
{ {
} }
static void ql_dump_cam_entries(struct ql_adapter *qdev) static void qlge_dump_cam_entries(struct qlge_adapter *qdev)
{ {
int i; int i;
u32 value[3]; u32 value[3];
i = ql_sem_spinlock(qdev, SEM_MAC_ADDR_MASK); i = qlge_sem_spinlock(qdev, SEM_MAC_ADDR_MASK);
if (i) if (i)
return; return;
for (i = 0; i < 4; i++) { for (i = 0; i < 4; i++) {
if (ql_get_mac_addr_reg(qdev, MAC_ADDR_TYPE_CAM_MAC, i, value)) { if (qlge_get_mac_addr_reg(qdev, MAC_ADDR_TYPE_CAM_MAC, i, value)) {
netdev_err(qdev->ndev, netdev_err(qdev->ndev,
"%s: Failed read of mac index register\n", "%s: Failed read of mac index register\n",
__func__); __func__);
...@@ -1398,7 +1397,7 @@ static void ql_dump_cam_entries(struct ql_adapter *qdev) ...@@ -1398,7 +1397,7 @@ static void ql_dump_cam_entries(struct ql_adapter *qdev)
i, value[1], value[0], value[2]); i, value[1], value[0], value[2]);
} }
for (i = 0; i < 32; i++) { for (i = 0; i < 32; i++) {
if (ql_get_mac_addr_reg if (qlge_get_mac_addr_reg
(qdev, MAC_ADDR_TYPE_MULTI_MAC, i, value)) { (qdev, MAC_ADDR_TYPE_MULTI_MAC, i, value)) {
netdev_err(qdev->ndev, netdev_err(qdev->ndev,
"%s: Failed read of mac index register\n", "%s: Failed read of mac index register\n",
...@@ -1410,20 +1409,20 @@ static void ql_dump_cam_entries(struct ql_adapter *qdev) ...@@ -1410,20 +1409,20 @@ static void ql_dump_cam_entries(struct ql_adapter *qdev)
"MCAST index %d CAM Lookup Lower = 0x%.08x:%.08x\n", "MCAST index %d CAM Lookup Lower = 0x%.08x:%.08x\n",
i, value[1], value[0]); i, value[1], value[0]);
} }
ql_sem_unlock(qdev, SEM_MAC_ADDR_MASK); qlge_sem_unlock(qdev, SEM_MAC_ADDR_MASK);
} }
void ql_dump_routing_entries(struct ql_adapter *qdev) void qlge_dump_routing_entries(struct qlge_adapter *qdev)
{ {
int i; int i;
u32 value; u32 value;
i = ql_sem_spinlock(qdev, SEM_RT_IDX_MASK); i = qlge_sem_spinlock(qdev, SEM_RT_IDX_MASK);
if (i) if (i)
return; return;
for (i = 0; i < 16; i++) { for (i = 0; i < 16; i++) {
value = 0; value = 0;
if (ql_get_routing_reg(qdev, i, &value)) { if (qlge_get_routing_reg(qdev, i, &value)) {
netdev_err(qdev->ndev, netdev_err(qdev->ndev,
"%s: Failed read of routing index register\n", "%s: Failed read of routing index register\n",
__func__); __func__);
...@@ -1434,13 +1433,13 @@ void ql_dump_routing_entries(struct ql_adapter *qdev) ...@@ -1434,13 +1433,13 @@ void ql_dump_routing_entries(struct ql_adapter *qdev)
"Routing Mask %d = 0x%.08x\n", "Routing Mask %d = 0x%.08x\n",
i, value); i, value);
} }
ql_sem_unlock(qdev, SEM_RT_IDX_MASK); qlge_sem_unlock(qdev, SEM_RT_IDX_MASK);
} }
#define DUMP_REG(qdev, reg) \ #define DUMP_REG(qdev, reg) \
netdev_err(qdev->ndev, "%-32s= 0x%x\n", #reg, ql_read32(qdev, reg)) netdev_err(qdev->ndev, "%-32s= 0x%x\n", #reg, qlge_read32(qdev, reg))
void ql_dump_regs(struct ql_adapter *qdev) void qlge_dump_regs(struct qlge_adapter *qdev)
{ {
netdev_err(qdev->ndev, "reg dump for function #%d\n", qdev->func); netdev_err(qdev->ndev, "reg dump for function #%d\n", qdev->func);
DUMP_REG(qdev, SYS); DUMP_REG(qdev, SYS);
...@@ -1496,11 +1495,11 @@ void ql_dump_regs(struct ql_adapter *qdev) ...@@ -1496,11 +1495,11 @@ void ql_dump_regs(struct ql_adapter *qdev)
DUMP_REG(qdev, XG_SERDES_DATA); DUMP_REG(qdev, XG_SERDES_DATA);
DUMP_REG(qdev, PRB_MX_ADDR); DUMP_REG(qdev, PRB_MX_ADDR);
DUMP_REG(qdev, PRB_MX_DATA); DUMP_REG(qdev, PRB_MX_DATA);
ql_dump_intr_states(qdev); qlge_dump_intr_states(qdev);
ql_dump_xgmac_control_regs(qdev); qlge_dump_xgmac_control_regs(qdev);
ql_dump_ets_regs(qdev); qlge_dump_ets_regs(qdev);
ql_dump_cam_entries(qdev); qlge_dump_cam_entries(qdev);
ql_dump_routing_entries(qdev); qlge_dump_routing_entries(qdev);
} }
#endif #endif
...@@ -1510,7 +1509,7 @@ void ql_dump_regs(struct ql_adapter *qdev) ...@@ -1510,7 +1509,7 @@ void ql_dump_regs(struct ql_adapter *qdev)
netdev_err(qdev->ndev, "%s = %ld\n", #stat, \ netdev_err(qdev->ndev, "%s = %ld\n", #stat, \
(unsigned long)(qdev)->nic_stats.stat) (unsigned long)(qdev)->nic_stats.stat)
void ql_dump_stat(struct ql_adapter *qdev) void qlge_dump_stat(struct qlge_adapter *qdev)
{ {
netdev_err(qdev->ndev, "%s: Enter\n", __func__); netdev_err(qdev->ndev, "%s: Enter\n", __func__);
DUMP_STAT(qdev, tx_pkts); DUMP_STAT(qdev, tx_pkts);
...@@ -1567,8 +1566,8 @@ void ql_dump_stat(struct ql_adapter *qdev) ...@@ -1567,8 +1566,8 @@ void ql_dump_stat(struct ql_adapter *qdev)
(unsigned long long)qdev->field) (unsigned long long)qdev->field)
#define DUMP_QDEV_ARRAY(qdev, type, array, index, field) \ #define DUMP_QDEV_ARRAY(qdev, type, array, index, field) \
netdev_err(qdev->ndev, "%s[%d].%s = " type "\n", \ netdev_err(qdev->ndev, "%s[%d].%s = " type "\n", \
#array, index, #field, (qdev)->array[index].field) #array, index, #field, (qdev)->array[index].field)
void ql_dump_qdev(struct ql_adapter *qdev) void qlge_dump_qdev(struct qlge_adapter *qdev)
{ {
int i; int i;
...@@ -1615,10 +1614,10 @@ void ql_dump_qdev(struct ql_adapter *qdev) ...@@ -1615,10 +1614,10 @@ void ql_dump_qdev(struct ql_adapter *qdev)
#endif #endif
#ifdef QL_CB_DUMP #ifdef QL_CB_DUMP
void ql_dump_wqicb(struct wqicb *wqicb) void qlge_dump_wqicb(struct wqicb *wqicb)
{ {
struct tx_ring *tx_ring = container_of(wqicb, struct tx_ring, wqicb); struct tx_ring *tx_ring = container_of(wqicb, struct tx_ring, wqicb);
struct ql_adapter *qdev = tx_ring->qdev; struct qlge_adapter *qdev = tx_ring->qdev;
netdev_err(qdev->ndev, "Dumping wqicb stuff...\n"); netdev_err(qdev->ndev, "Dumping wqicb stuff...\n");
netdev_err(qdev->ndev, "wqicb->len = 0x%x\n", le16_to_cpu(wqicb->len)); netdev_err(qdev->ndev, "wqicb->len = 0x%x\n", le16_to_cpu(wqicb->len));
...@@ -1633,9 +1632,9 @@ void ql_dump_wqicb(struct wqicb *wqicb) ...@@ -1633,9 +1632,9 @@ void ql_dump_wqicb(struct wqicb *wqicb)
(unsigned long long)le64_to_cpu(wqicb->cnsmr_idx_addr)); (unsigned long long)le64_to_cpu(wqicb->cnsmr_idx_addr));
} }
void ql_dump_tx_ring(struct tx_ring *tx_ring) void qlge_dump_tx_ring(struct tx_ring *tx_ring)
{ {
struct ql_adapter *qdev = tx_ring->qdev; struct qlge_adapter *qdev = tx_ring->qdev;
netdev_err(qdev->ndev, "===================== Dumping tx_ring %d ===============\n", netdev_err(qdev->ndev, "===================== Dumping tx_ring %d ===============\n",
tx_ring->wq_id); tx_ring->wq_id);
...@@ -1645,7 +1644,7 @@ void ql_dump_tx_ring(struct tx_ring *tx_ring) ...@@ -1645,7 +1644,7 @@ void ql_dump_tx_ring(struct tx_ring *tx_ring)
netdev_err(qdev->ndev, "tx_ring->cnsmr_idx_sh_reg, addr = 0x%p, value = %d\n", netdev_err(qdev->ndev, "tx_ring->cnsmr_idx_sh_reg, addr = 0x%p, value = %d\n",
tx_ring->cnsmr_idx_sh_reg, tx_ring->cnsmr_idx_sh_reg,
tx_ring->cnsmr_idx_sh_reg tx_ring->cnsmr_idx_sh_reg
? ql_read_sh_reg(tx_ring->cnsmr_idx_sh_reg) : 0); ? qlge_read_sh_reg(tx_ring->cnsmr_idx_sh_reg) : 0);
netdev_err(qdev->ndev, "tx_ring->size = %d\n", tx_ring->wq_size); netdev_err(qdev->ndev, "tx_ring->size = %d\n", tx_ring->wq_size);
netdev_err(qdev->ndev, "tx_ring->len = %d\n", tx_ring->wq_len); netdev_err(qdev->ndev, "tx_ring->len = %d\n", tx_ring->wq_len);
netdev_err(qdev->ndev, "tx_ring->prod_idx_db_reg = %p\n", tx_ring->prod_idx_db_reg); netdev_err(qdev->ndev, "tx_ring->prod_idx_db_reg = %p\n", tx_ring->prod_idx_db_reg);
...@@ -1657,11 +1656,11 @@ void ql_dump_tx_ring(struct tx_ring *tx_ring) ...@@ -1657,11 +1656,11 @@ void ql_dump_tx_ring(struct tx_ring *tx_ring)
netdev_err(qdev->ndev, "tx_ring->tx_count = %d\n", atomic_read(&tx_ring->tx_count)); netdev_err(qdev->ndev, "tx_ring->tx_count = %d\n", atomic_read(&tx_ring->tx_count));
} }
void ql_dump_ricb(struct ricb *ricb) void qlge_dump_ricb(struct ricb *ricb)
{ {
int i; int i;
struct ql_adapter *qdev = struct qlge_adapter *qdev =
container_of(ricb, struct ql_adapter, ricb); container_of(ricb, struct qlge_adapter, ricb);
netdev_err(qdev->ndev, "===================== Dumping ricb ===============\n"); netdev_err(qdev->ndev, "===================== Dumping ricb ===============\n");
netdev_err(qdev->ndev, "Dumping ricb stuff...\n"); netdev_err(qdev->ndev, "Dumping ricb stuff...\n");
...@@ -1689,10 +1688,10 @@ void ql_dump_ricb(struct ricb *ricb) ...@@ -1689,10 +1688,10 @@ void ql_dump_ricb(struct ricb *ricb)
le32_to_cpu(ricb->ipv4_hash_key[i])); le32_to_cpu(ricb->ipv4_hash_key[i]));
} }
void ql_dump_cqicb(struct cqicb *cqicb) void qlge_dump_cqicb(struct cqicb *cqicb)
{ {
struct rx_ring *rx_ring = container_of(cqicb, struct rx_ring, cqicb); struct rx_ring *rx_ring = container_of(cqicb, struct rx_ring, cqicb);
struct ql_adapter *qdev = rx_ring->qdev; struct qlge_adapter *qdev = rx_ring->qdev;
netdev_err(qdev->ndev, "Dumping cqicb stuff...\n"); netdev_err(qdev->ndev, "Dumping cqicb stuff...\n");
...@@ -1723,7 +1722,7 @@ void ql_dump_cqicb(struct cqicb *cqicb) ...@@ -1723,7 +1722,7 @@ void ql_dump_cqicb(struct cqicb *cqicb)
static const char *qlge_rx_ring_type_name(struct rx_ring *rx_ring) static const char *qlge_rx_ring_type_name(struct rx_ring *rx_ring)
{ {
struct ql_adapter *qdev = rx_ring->qdev; struct qlge_adapter *qdev = rx_ring->qdev;
if (rx_ring->cq_id < qdev->rss_ring_count) if (rx_ring->cq_id < qdev->rss_ring_count)
return "RX COMPLETION"; return "RX COMPLETION";
...@@ -1731,9 +1730,9 @@ static const char *qlge_rx_ring_type_name(struct rx_ring *rx_ring) ...@@ -1731,9 +1730,9 @@ static const char *qlge_rx_ring_type_name(struct rx_ring *rx_ring)
return "TX COMPLETION"; return "TX COMPLETION";
}; };
void ql_dump_rx_ring(struct rx_ring *rx_ring) void qlge_dump_rx_ring(struct rx_ring *rx_ring)
{ {
struct ql_adapter *qdev = rx_ring->qdev; struct qlge_adapter *qdev = rx_ring->qdev;
netdev_err(qdev->ndev, netdev_err(qdev->ndev,
"===================== Dumping rx_ring %d ===============\n", "===================== Dumping rx_ring %d ===============\n",
...@@ -1750,7 +1749,7 @@ void ql_dump_rx_ring(struct rx_ring *rx_ring) ...@@ -1750,7 +1749,7 @@ void ql_dump_rx_ring(struct rx_ring *rx_ring)
netdev_err(qdev->ndev, netdev_err(qdev->ndev,
"rx_ring->prod_idx_sh_reg, addr = 0x%p, value = %d\n", "rx_ring->prod_idx_sh_reg, addr = 0x%p, value = %d\n",
rx_ring->prod_idx_sh_reg, rx_ring->prod_idx_sh_reg,
rx_ring->prod_idx_sh_reg ? ql_read_sh_reg(rx_ring->prod_idx_sh_reg) : 0); rx_ring->prod_idx_sh_reg ? qlge_read_sh_reg(rx_ring->prod_idx_sh_reg) : 0);
netdev_err(qdev->ndev, "rx_ring->prod_idx_sh_reg_dma = %llx\n", netdev_err(qdev->ndev, "rx_ring->prod_idx_sh_reg_dma = %llx\n",
(unsigned long long)rx_ring->prod_idx_sh_reg_dma); (unsigned long long)rx_ring->prod_idx_sh_reg_dma);
netdev_err(qdev->ndev, "rx_ring->cnsmr_idx_db_reg = %p\n", netdev_err(qdev->ndev, "rx_ring->cnsmr_idx_db_reg = %p\n",
...@@ -1790,7 +1789,7 @@ void ql_dump_rx_ring(struct rx_ring *rx_ring) ...@@ -1790,7 +1789,7 @@ void ql_dump_rx_ring(struct rx_ring *rx_ring)
netdev_err(qdev->ndev, "rx_ring->qdev = %p\n", rx_ring->qdev); netdev_err(qdev->ndev, "rx_ring->qdev = %p\n", rx_ring->qdev);
} }
void ql_dump_hw_cb(struct ql_adapter *qdev, int size, u32 bit, u16 q_id) void qlge_dump_hw_cb(struct qlge_adapter *qdev, int size, u32 bit, u16 q_id)
{ {
void *ptr; void *ptr;
...@@ -1800,19 +1799,19 @@ void ql_dump_hw_cb(struct ql_adapter *qdev, int size, u32 bit, u16 q_id) ...@@ -1800,19 +1799,19 @@ void ql_dump_hw_cb(struct ql_adapter *qdev, int size, u32 bit, u16 q_id)
if (!ptr) if (!ptr)
return; return;
if (ql_write_cfg(qdev, ptr, size, bit, q_id)) { if (qlge_write_cfg(qdev, ptr, size, bit, q_id)) {
netdev_err(qdev->ndev, "%s: Failed to upload control block!\n", __func__); netdev_err(qdev->ndev, "%s: Failed to upload control block!\n", __func__);
goto fail_it; goto fail_it;
} }
switch (bit) { switch (bit) {
case CFG_DRQ: case CFG_DRQ:
ql_dump_wqicb((struct wqicb *)ptr); qlge_dump_wqicb((struct wqicb *)ptr);
break; break;
case CFG_DCQ: case CFG_DCQ:
ql_dump_cqicb((struct cqicb *)ptr); qlge_dump_cqicb((struct cqicb *)ptr);
break; break;
case CFG_DR: case CFG_DR:
ql_dump_ricb((struct ricb *)ptr); qlge_dump_ricb((struct ricb *)ptr);
break; break;
default: default:
netdev_err(qdev->ndev, "%s: Invalid bit value = %x\n", __func__, bit); netdev_err(qdev->ndev, "%s: Invalid bit value = %x\n", __func__, bit);
...@@ -1824,7 +1823,7 @@ void ql_dump_hw_cb(struct ql_adapter *qdev, int size, u32 bit, u16 q_id) ...@@ -1824,7 +1823,7 @@ void ql_dump_hw_cb(struct ql_adapter *qdev, int size, u32 bit, u16 q_id)
#endif #endif
#ifdef QL_OB_DUMP #ifdef QL_OB_DUMP
void ql_dump_tx_desc(struct ql_adapter *qdev, struct tx_buf_desc *tbd) void qlge_dump_tx_desc(struct qlge_adapter *qdev, struct tx_buf_desc *tbd)
{ {
netdev_err(qdev->ndev, "tbd->addr = 0x%llx\n", netdev_err(qdev->ndev, "tbd->addr = 0x%llx\n",
le64_to_cpu((u64)tbd->addr)); le64_to_cpu((u64)tbd->addr));
...@@ -1851,10 +1850,10 @@ void ql_dump_tx_desc(struct ql_adapter *qdev, struct tx_buf_desc *tbd) ...@@ -1851,10 +1850,10 @@ void ql_dump_tx_desc(struct ql_adapter *qdev, struct tx_buf_desc *tbd)
tbd->len & TX_DESC_E ? "E" : "."); tbd->len & TX_DESC_E ? "E" : ".");
} }
void ql_dump_ob_mac_iocb(struct ql_adapter *qdev, struct ob_mac_iocb_req *ob_mac_iocb) void qlge_dump_ob_mac_iocb(struct qlge_adapter *qdev, struct qlge_ob_mac_iocb_req *ob_mac_iocb)
{ {
struct ob_mac_tso_iocb_req *ob_mac_tso_iocb = struct qlge_ob_mac_tso_iocb_req *ob_mac_tso_iocb =
(struct ob_mac_tso_iocb_req *)ob_mac_iocb; (struct qlge_ob_mac_tso_iocb_req *)ob_mac_iocb;
struct tx_buf_desc *tbd; struct tx_buf_desc *tbd;
u16 frame_len; u16 frame_len;
...@@ -1894,16 +1893,16 @@ void ql_dump_ob_mac_iocb(struct ql_adapter *qdev, struct ob_mac_iocb_req *ob_mac ...@@ -1894,16 +1893,16 @@ void ql_dump_ob_mac_iocb(struct ql_adapter *qdev, struct ob_mac_iocb_req *ob_mac
frame_len = le16_to_cpu(ob_mac_iocb->frame_len); frame_len = le16_to_cpu(ob_mac_iocb->frame_len);
} }
tbd = &ob_mac_iocb->tbd[0]; tbd = &ob_mac_iocb->tbd[0];
ql_dump_tx_desc(qdev, tbd); qlge_dump_tx_desc(qdev, tbd);
} }
void ql_dump_ob_mac_rsp(struct ql_adapter *qdev, struct ob_mac_iocb_rsp *ob_mac_rsp) void qlge_dump_ob_mac_rsp(struct qlge_adapter *qdev, struct qlge_ob_mac_iocb_rsp *ob_mac_rsp)
{ {
netdev_err(qdev->ndev, "%s\n", __func__); netdev_err(qdev->ndev, "%s\n", __func__);
netdev_err(qdev->ndev, "opcode = %d\n", ob_mac_rsp->opcode); netdev_err(qdev->ndev, "opcode = %d\n", ob_mac_rsp->opcode);
netdev_err(qdev->ndev, "flags = %s %s %s %s %s %s %s\n", netdev_err(qdev->ndev, "flags = %s %s %s %s %s %s %s\n",
ob_mac_rsp->flags1 & OB_MAC_IOCB_RSP_OI ? ob_mac_rsp->flags1 & OB_MAC_IOCB_RSP_OI ?
"OI" : ".", ob_mac_rsp->flags1 & OB_MAC_IOCB_RSP_I ? "I" : ".", "OI" : ".", ob_mac_rsp->flags1 & OB_MAC_IOCB_RSP_I ? "I" : ".",
ob_mac_rsp->flags1 & OB_MAC_IOCB_RSP_E ? "E" : ".", ob_mac_rsp->flags1 & OB_MAC_IOCB_RSP_E ? "E" : ".",
ob_mac_rsp->flags1 & OB_MAC_IOCB_RSP_S ? "S" : ".", ob_mac_rsp->flags1 & OB_MAC_IOCB_RSP_S ? "S" : ".",
ob_mac_rsp->flags1 & OB_MAC_IOCB_RSP_L ? "L" : ".", ob_mac_rsp->flags1 & OB_MAC_IOCB_RSP_L ? "L" : ".",
...@@ -1914,7 +1913,7 @@ void ql_dump_ob_mac_rsp(struct ql_adapter *qdev, struct ob_mac_iocb_rsp *ob_mac_ ...@@ -1914,7 +1913,7 @@ void ql_dump_ob_mac_rsp(struct ql_adapter *qdev, struct ob_mac_iocb_rsp *ob_mac_
#endif #endif
#ifdef QL_IB_DUMP #ifdef QL_IB_DUMP
void ql_dump_ib_mac_rsp(struct ql_adapter *qdev, struct ib_mac_iocb_rsp *ib_mac_rsp) void qlge_dump_ib_mac_rsp(struct qlge_adapter *qdev, struct qlge_ib_mac_iocb_rsp *ib_mac_rsp)
{ {
netdev_err(qdev->ndev, "%s\n", __func__); netdev_err(qdev->ndev, "%s\n", __func__);
netdev_err(qdev->ndev, "opcode = 0x%x\n", ib_mac_rsp->opcode); netdev_err(qdev->ndev, "opcode = 0x%x\n", ib_mac_rsp->opcode);
...@@ -1996,7 +1995,7 @@ void ql_dump_ib_mac_rsp(struct ql_adapter *qdev, struct ib_mac_iocb_rsp *ib_mac_ ...@@ -1996,7 +1995,7 @@ void ql_dump_ib_mac_rsp(struct ql_adapter *qdev, struct ib_mac_iocb_rsp *ib_mac_
#endif #endif
#ifdef QL_ALL_DUMP #ifdef QL_ALL_DUMP
void ql_dump_all(struct ql_adapter *qdev) void qlge_dump_all(struct qlge_adapter *qdev)
{ {
int i; int i;
......
...@@ -34,16 +34,16 @@ ...@@ -34,16 +34,16 @@
#include "qlge.h" #include "qlge.h"
struct ql_stats { struct qlge_stats {
char stat_string[ETH_GSTRING_LEN]; char stat_string[ETH_GSTRING_LEN];
int sizeof_stat; int sizeof_stat;
int stat_offset; int stat_offset;
}; };
#define QL_SIZEOF(m) sizeof_field(struct ql_adapter, m) #define QL_SIZEOF(m) sizeof_field(struct qlge_adapter, m)
#define QL_OFF(m) offsetof(struct ql_adapter, m) #define QL_OFF(m) offsetof(struct qlge_adapter, m)
static const struct ql_stats ql_gstrings_stats[] = { static const struct qlge_stats qlge_gstrings_stats[] = {
{"tx_pkts", QL_SIZEOF(nic_stats.tx_pkts), QL_OFF(nic_stats.tx_pkts)}, {"tx_pkts", QL_SIZEOF(nic_stats.tx_pkts), QL_OFF(nic_stats.tx_pkts)},
{"tx_bytes", QL_SIZEOF(nic_stats.tx_bytes), QL_OFF(nic_stats.tx_bytes)}, {"tx_bytes", QL_SIZEOF(nic_stats.tx_bytes), QL_OFF(nic_stats.tx_bytes)},
{"tx_mcast_pkts", QL_SIZEOF(nic_stats.tx_mcast_pkts), {"tx_mcast_pkts", QL_SIZEOF(nic_stats.tx_mcast_pkts),
...@@ -175,15 +175,15 @@ static const struct ql_stats ql_gstrings_stats[] = { ...@@ -175,15 +175,15 @@ static const struct ql_stats ql_gstrings_stats[] = {
QL_OFF(nic_stats.rx_nic_fifo_drop)}, QL_OFF(nic_stats.rx_nic_fifo_drop)},
}; };
static const char ql_gstrings_test[][ETH_GSTRING_LEN] = { static const char qlge_gstrings_test[][ETH_GSTRING_LEN] = {
"Loopback test (offline)" "Loopback test (offline)"
}; };
#define QLGE_TEST_LEN (sizeof(ql_gstrings_test) / ETH_GSTRING_LEN) #define QLGE_TEST_LEN (sizeof(qlge_gstrings_test) / ETH_GSTRING_LEN)
#define QLGE_STATS_LEN ARRAY_SIZE(ql_gstrings_stats) #define QLGE_STATS_LEN ARRAY_SIZE(qlge_gstrings_stats)
#define QLGE_RCV_MAC_ERR_STATS 7 #define QLGE_RCV_MAC_ERR_STATS 7
static int ql_update_ring_coalescing(struct ql_adapter *qdev) static int qlge_update_ring_coalescing(struct qlge_adapter *qdev)
{ {
int i, status = 0; int i, status = 0;
struct rx_ring *rx_ring; struct rx_ring *rx_ring;
...@@ -203,10 +203,10 @@ static int ql_update_ring_coalescing(struct ql_adapter *qdev) ...@@ -203,10 +203,10 @@ static int ql_update_ring_coalescing(struct ql_adapter *qdev)
cqicb = (struct cqicb *)rx_ring; cqicb = (struct cqicb *)rx_ring;
cqicb->irq_delay = cpu_to_le16(qdev->tx_coalesce_usecs); cqicb->irq_delay = cpu_to_le16(qdev->tx_coalesce_usecs);
cqicb->pkt_delay = cqicb->pkt_delay =
cpu_to_le16(qdev->tx_max_coalesced_frames); cpu_to_le16(qdev->tx_max_coalesced_frames);
cqicb->flags = FLAGS_LI; cqicb->flags = FLAGS_LI;
status = ql_write_cfg(qdev, cqicb, sizeof(*cqicb), status = qlge_write_cfg(qdev, cqicb, sizeof(*cqicb),
CFG_LCQ, rx_ring->cq_id); CFG_LCQ, rx_ring->cq_id);
if (status) { if (status) {
netif_err(qdev, ifup, qdev->ndev, netif_err(qdev, ifup, qdev->ndev,
"Failed to load CQICB.\n"); "Failed to load CQICB.\n");
...@@ -224,10 +224,10 @@ static int ql_update_ring_coalescing(struct ql_adapter *qdev) ...@@ -224,10 +224,10 @@ static int ql_update_ring_coalescing(struct ql_adapter *qdev)
cqicb = (struct cqicb *)rx_ring; cqicb = (struct cqicb *)rx_ring;
cqicb->irq_delay = cpu_to_le16(qdev->rx_coalesce_usecs); cqicb->irq_delay = cpu_to_le16(qdev->rx_coalesce_usecs);
cqicb->pkt_delay = cqicb->pkt_delay =
cpu_to_le16(qdev->rx_max_coalesced_frames); cpu_to_le16(qdev->rx_max_coalesced_frames);
cqicb->flags = FLAGS_LI; cqicb->flags = FLAGS_LI;
status = ql_write_cfg(qdev, cqicb, sizeof(*cqicb), status = qlge_write_cfg(qdev, cqicb, sizeof(*cqicb),
CFG_LCQ, rx_ring->cq_id); CFG_LCQ, rx_ring->cq_id);
if (status) { if (status) {
netif_err(qdev, ifup, qdev->ndev, netif_err(qdev, ifup, qdev->ndev,
"Failed to load CQICB.\n"); "Failed to load CQICB.\n");
...@@ -239,14 +239,14 @@ static int ql_update_ring_coalescing(struct ql_adapter *qdev) ...@@ -239,14 +239,14 @@ static int ql_update_ring_coalescing(struct ql_adapter *qdev)
return status; return status;
} }
static void ql_update_stats(struct ql_adapter *qdev) static void qlge_update_stats(struct qlge_adapter *qdev)
{ {
u32 i; u32 i;
u64 data; u64 data;
u64 *iter = &qdev->nic_stats.tx_pkts; u64 *iter = &qdev->nic_stats.tx_pkts;
spin_lock(&qdev->stats_lock); spin_lock(&qdev->stats_lock);
if (ql_sem_spinlock(qdev, qdev->xg_sem_mask)) { if (qlge_sem_spinlock(qdev, qdev->xg_sem_mask)) {
netif_err(qdev, drv, qdev->ndev, netif_err(qdev, drv, qdev->ndev,
"Couldn't get xgmac sem.\n"); "Couldn't get xgmac sem.\n");
goto quit; goto quit;
...@@ -255,7 +255,7 @@ static void ql_update_stats(struct ql_adapter *qdev) ...@@ -255,7 +255,7 @@ static void ql_update_stats(struct ql_adapter *qdev)
* Get TX statistics. * Get TX statistics.
*/ */
for (i = 0x200; i < 0x280; i += 8) { for (i = 0x200; i < 0x280; i += 8) {
if (ql_read_xgmac_reg64(qdev, i, &data)) { if (qlge_read_xgmac_reg64(qdev, i, &data)) {
netif_err(qdev, drv, qdev->ndev, netif_err(qdev, drv, qdev->ndev,
"Error reading status register 0x%.04x.\n", "Error reading status register 0x%.04x.\n",
i); i);
...@@ -270,7 +270,7 @@ static void ql_update_stats(struct ql_adapter *qdev) ...@@ -270,7 +270,7 @@ static void ql_update_stats(struct ql_adapter *qdev)
* Get RX statistics. * Get RX statistics.
*/ */
for (i = 0x300; i < 0x3d0; i += 8) { for (i = 0x300; i < 0x3d0; i += 8) {
if (ql_read_xgmac_reg64(qdev, i, &data)) { if (qlge_read_xgmac_reg64(qdev, i, &data)) {
netif_err(qdev, drv, qdev->ndev, netif_err(qdev, drv, qdev->ndev,
"Error reading status register 0x%.04x.\n", "Error reading status register 0x%.04x.\n",
i); i);
...@@ -288,7 +288,7 @@ static void ql_update_stats(struct ql_adapter *qdev) ...@@ -288,7 +288,7 @@ static void ql_update_stats(struct ql_adapter *qdev)
* Get Per-priority TX pause frame counter statistics. * Get Per-priority TX pause frame counter statistics.
*/ */
for (i = 0x500; i < 0x540; i += 8) { for (i = 0x500; i < 0x540; i += 8) {
if (ql_read_xgmac_reg64(qdev, i, &data)) { if (qlge_read_xgmac_reg64(qdev, i, &data)) {
netif_err(qdev, drv, qdev->ndev, netif_err(qdev, drv, qdev->ndev,
"Error reading status register 0x%.04x.\n", "Error reading status register 0x%.04x.\n",
i); i);
...@@ -303,7 +303,7 @@ static void ql_update_stats(struct ql_adapter *qdev) ...@@ -303,7 +303,7 @@ static void ql_update_stats(struct ql_adapter *qdev)
* Get Per-priority RX pause frame counter statistics. * Get Per-priority RX pause frame counter statistics.
*/ */
for (i = 0x568; i < 0x5a8; i += 8) { for (i = 0x568; i < 0x5a8; i += 8) {
if (ql_read_xgmac_reg64(qdev, i, &data)) { if (qlge_read_xgmac_reg64(qdev, i, &data)) {
netif_err(qdev, drv, qdev->ndev, netif_err(qdev, drv, qdev->ndev,
"Error reading status register 0x%.04x.\n", "Error reading status register 0x%.04x.\n",
i); i);
...@@ -317,7 +317,7 @@ static void ql_update_stats(struct ql_adapter *qdev) ...@@ -317,7 +317,7 @@ static void ql_update_stats(struct ql_adapter *qdev)
/* /*
* Get RX NIC FIFO DROP statistics. * Get RX NIC FIFO DROP statistics.
*/ */
if (ql_read_xgmac_reg64(qdev, 0x5b8, &data)) { if (qlge_read_xgmac_reg64(qdev, 0x5b8, &data)) {
netif_err(qdev, drv, qdev->ndev, netif_err(qdev, drv, qdev->ndev,
"Error reading status register 0x%.04x.\n", i); "Error reading status register 0x%.04x.\n", i);
goto end; goto end;
...@@ -325,32 +325,32 @@ static void ql_update_stats(struct ql_adapter *qdev) ...@@ -325,32 +325,32 @@ static void ql_update_stats(struct ql_adapter *qdev)
*iter = data; *iter = data;
} }
end: end:
ql_sem_unlock(qdev, qdev->xg_sem_mask); qlge_sem_unlock(qdev, qdev->xg_sem_mask);
quit: quit:
spin_unlock(&qdev->stats_lock); spin_unlock(&qdev->stats_lock);
QL_DUMP_STAT(qdev); QL_DUMP_STAT(qdev);
} }
static void ql_get_strings(struct net_device *dev, u32 stringset, u8 *buf) static void qlge_get_strings(struct net_device *dev, u32 stringset, u8 *buf)
{ {
int index; int index;
switch (stringset) { switch (stringset) {
case ETH_SS_TEST: case ETH_SS_TEST:
memcpy(buf, *ql_gstrings_test, QLGE_TEST_LEN * ETH_GSTRING_LEN); memcpy(buf, *qlge_gstrings_test, QLGE_TEST_LEN * ETH_GSTRING_LEN);
break; break;
case ETH_SS_STATS: case ETH_SS_STATS:
for (index = 0; index < QLGE_STATS_LEN; index++) { for (index = 0; index < QLGE_STATS_LEN; index++) {
memcpy(buf + index * ETH_GSTRING_LEN, memcpy(buf + index * ETH_GSTRING_LEN,
ql_gstrings_stats[index].stat_string, qlge_gstrings_stats[index].stat_string,
ETH_GSTRING_LEN); ETH_GSTRING_LEN);
} }
break; break;
} }
} }
static int ql_get_sset_count(struct net_device *dev, int sset) static int qlge_get_sset_count(struct net_device *dev, int sset)
{ {
switch (sset) { switch (sset) {
case ETH_SS_TEST: case ETH_SS_TEST:
...@@ -363,34 +363,34 @@ static int ql_get_sset_count(struct net_device *dev, int sset) ...@@ -363,34 +363,34 @@ static int ql_get_sset_count(struct net_device *dev, int sset)
} }
static void static void
ql_get_ethtool_stats(struct net_device *ndev, qlge_get_ethtool_stats(struct net_device *ndev,
struct ethtool_stats *stats, u64 *data) struct ethtool_stats *stats, u64 *data)
{ {
struct ql_adapter *qdev = netdev_priv(ndev); struct qlge_adapter *qdev = netdev_priv(ndev);
int index, length; int index, length;
length = QLGE_STATS_LEN; length = QLGE_STATS_LEN;
ql_update_stats(qdev); qlge_update_stats(qdev);
for (index = 0; index < length; index++) { for (index = 0; index < length; index++) {
char *p = (char *)qdev + char *p = (char *)qdev +
ql_gstrings_stats[index].stat_offset; qlge_gstrings_stats[index].stat_offset;
*data++ = (ql_gstrings_stats[index].sizeof_stat == *data++ = (qlge_gstrings_stats[index].sizeof_stat ==
sizeof(u64)) ? *(u64 *)p : (*(u32 *)p); sizeof(u64)) ? *(u64 *)p : (*(u32 *)p);
} }
} }
static int ql_get_link_ksettings(struct net_device *ndev, static int qlge_get_link_ksettings(struct net_device *ndev,
struct ethtool_link_ksettings *ecmd) struct ethtool_link_ksettings *ecmd)
{ {
struct ql_adapter *qdev = netdev_priv(ndev); struct qlge_adapter *qdev = netdev_priv(ndev);
u32 supported, advertising; u32 supported, advertising;
supported = SUPPORTED_10000baseT_Full; supported = SUPPORTED_10000baseT_Full;
advertising = ADVERTISED_10000baseT_Full; advertising = ADVERTISED_10000baseT_Full;
if ((qdev->link_status & STS_LINK_TYPE_MASK) == if ((qdev->link_status & STS_LINK_TYPE_MASK) ==
STS_LINK_TYPE_10GBASET) { STS_LINK_TYPE_10GBASET) {
supported |= (SUPPORTED_TP | SUPPORTED_Autoneg); supported |= (SUPPORTED_TP | SUPPORTED_Autoneg);
advertising |= (ADVERTISED_TP | ADVERTISED_Autoneg); advertising |= (ADVERTISED_TP | ADVERTISED_Autoneg);
ecmd->base.port = PORT_TP; ecmd->base.port = PORT_TP;
...@@ -412,10 +412,10 @@ static int ql_get_link_ksettings(struct net_device *ndev, ...@@ -412,10 +412,10 @@ static int ql_get_link_ksettings(struct net_device *ndev,
return 0; return 0;
} }
static void ql_get_drvinfo(struct net_device *ndev, static void qlge_get_drvinfo(struct net_device *ndev,
struct ethtool_drvinfo *drvinfo) struct ethtool_drvinfo *drvinfo)
{ {
struct ql_adapter *qdev = netdev_priv(ndev); struct qlge_adapter *qdev = netdev_priv(ndev);
strlcpy(drvinfo->driver, qlge_driver_name, sizeof(drvinfo->driver)); strlcpy(drvinfo->driver, qlge_driver_name, sizeof(drvinfo->driver));
strlcpy(drvinfo->version, qlge_driver_version, strlcpy(drvinfo->version, qlge_driver_version,
...@@ -429,9 +429,9 @@ static void ql_get_drvinfo(struct net_device *ndev, ...@@ -429,9 +429,9 @@ static void ql_get_drvinfo(struct net_device *ndev,
sizeof(drvinfo->bus_info)); sizeof(drvinfo->bus_info));
} }
static void ql_get_wol(struct net_device *ndev, struct ethtool_wolinfo *wol) static void qlge_get_wol(struct net_device *ndev, struct ethtool_wolinfo *wol)
{ {
struct ql_adapter *qdev = netdev_priv(ndev); struct qlge_adapter *qdev = netdev_priv(ndev);
unsigned short ssys_dev = qdev->pdev->subsystem_device; unsigned short ssys_dev = qdev->pdev->subsystem_device;
/* WOL is only supported for mezz card. */ /* WOL is only supported for mezz card. */
...@@ -442,9 +442,9 @@ static void ql_get_wol(struct net_device *ndev, struct ethtool_wolinfo *wol) ...@@ -442,9 +442,9 @@ static void ql_get_wol(struct net_device *ndev, struct ethtool_wolinfo *wol)
} }
} }
static int ql_set_wol(struct net_device *ndev, struct ethtool_wolinfo *wol) static int qlge_set_wol(struct net_device *ndev, struct ethtool_wolinfo *wol)
{ {
struct ql_adapter *qdev = netdev_priv(ndev); struct qlge_adapter *qdev = netdev_priv(ndev);
unsigned short ssys_dev = qdev->pdev->subsystem_device; unsigned short ssys_dev = qdev->pdev->subsystem_device;
/* WOL is only supported for mezz card. */ /* WOL is only supported for mezz card. */
...@@ -462,25 +462,25 @@ static int ql_set_wol(struct net_device *ndev, struct ethtool_wolinfo *wol) ...@@ -462,25 +462,25 @@ static int ql_set_wol(struct net_device *ndev, struct ethtool_wolinfo *wol)
return 0; return 0;
} }
static int ql_set_phys_id(struct net_device *ndev, static int qlge_set_phys_id(struct net_device *ndev,
enum ethtool_phys_id_state state) enum ethtool_phys_id_state state)
{ {
struct ql_adapter *qdev = netdev_priv(ndev); struct qlge_adapter *qdev = netdev_priv(ndev);
switch (state) { switch (state) {
case ETHTOOL_ID_ACTIVE: case ETHTOOL_ID_ACTIVE:
/* Save the current LED settings */ /* Save the current LED settings */
if (ql_mb_get_led_cfg(qdev)) if (qlge_mb_get_led_cfg(qdev))
return -EIO; return -EIO;
/* Start blinking */ /* Start blinking */
ql_mb_set_led_cfg(qdev, QL_LED_BLINK); qlge_mb_set_led_cfg(qdev, QL_LED_BLINK);
return 0; return 0;
case ETHTOOL_ID_INACTIVE: case ETHTOOL_ID_INACTIVE:
/* Restore LED settings */ /* Restore LED settings */
if (ql_mb_set_led_cfg(qdev, qdev->led_config)) if (qlge_mb_set_led_cfg(qdev, qdev->led_config))
return -EIO; return -EIO;
return 0; return 0;
...@@ -489,7 +489,7 @@ static int ql_set_phys_id(struct net_device *ndev, ...@@ -489,7 +489,7 @@ static int ql_set_phys_id(struct net_device *ndev,
} }
} }
static int ql_start_loopback(struct ql_adapter *qdev) static int qlge_start_loopback(struct qlge_adapter *qdev)
{ {
if (netif_carrier_ok(qdev->ndev)) { if (netif_carrier_ok(qdev->ndev)) {
set_bit(QL_LB_LINK_UP, &qdev->flags); set_bit(QL_LB_LINK_UP, &qdev->flags);
...@@ -498,21 +498,21 @@ static int ql_start_loopback(struct ql_adapter *qdev) ...@@ -498,21 +498,21 @@ static int ql_start_loopback(struct ql_adapter *qdev)
clear_bit(QL_LB_LINK_UP, &qdev->flags); clear_bit(QL_LB_LINK_UP, &qdev->flags);
} }
qdev->link_config |= CFG_LOOPBACK_PCS; qdev->link_config |= CFG_LOOPBACK_PCS;
return ql_mb_set_port_cfg(qdev); return qlge_mb_set_port_cfg(qdev);
} }
static void ql_stop_loopback(struct ql_adapter *qdev) static void qlge_stop_loopback(struct qlge_adapter *qdev)
{ {
qdev->link_config &= ~CFG_LOOPBACK_PCS; qdev->link_config &= ~CFG_LOOPBACK_PCS;
ql_mb_set_port_cfg(qdev); qlge_mb_set_port_cfg(qdev);
if (test_bit(QL_LB_LINK_UP, &qdev->flags)) { if (test_bit(QL_LB_LINK_UP, &qdev->flags)) {
netif_carrier_on(qdev->ndev); netif_carrier_on(qdev->ndev);
clear_bit(QL_LB_LINK_UP, &qdev->flags); clear_bit(QL_LB_LINK_UP, &qdev->flags);
} }
} }
static void ql_create_lb_frame(struct sk_buff *skb, static void qlge_create_lb_frame(struct sk_buff *skb,
unsigned int frame_size) unsigned int frame_size)
{ {
memset(skb->data, 0xFF, frame_size); memset(skb->data, 0xFF, frame_size);
frame_size &= ~1; frame_size &= ~1;
...@@ -521,8 +521,8 @@ static void ql_create_lb_frame(struct sk_buff *skb, ...@@ -521,8 +521,8 @@ static void ql_create_lb_frame(struct sk_buff *skb,
skb->data[frame_size / 2 + 12] = (unsigned char)0xAF; skb->data[frame_size / 2 + 12] = (unsigned char)0xAF;
} }
void ql_check_lb_frame(struct ql_adapter *qdev, void qlge_check_lb_frame(struct qlge_adapter *qdev,
struct sk_buff *skb) struct sk_buff *skb)
{ {
unsigned int frame_size = skb->len; unsigned int frame_size = skb->len;
...@@ -534,7 +534,7 @@ void ql_check_lb_frame(struct ql_adapter *qdev, ...@@ -534,7 +534,7 @@ void ql_check_lb_frame(struct ql_adapter *qdev,
} }
} }
static int ql_run_loopback_test(struct ql_adapter *qdev) static int qlge_run_loopback_test(struct qlge_adapter *qdev)
{ {
int i; int i;
netdev_tx_t rc; netdev_tx_t rc;
...@@ -548,33 +548,33 @@ static int ql_run_loopback_test(struct ql_adapter *qdev) ...@@ -548,33 +548,33 @@ static int ql_run_loopback_test(struct ql_adapter *qdev)
skb->queue_mapping = 0; skb->queue_mapping = 0;
skb_put(skb, size); skb_put(skb, size);
ql_create_lb_frame(skb, size); qlge_create_lb_frame(skb, size);
rc = ql_lb_send(skb, qdev->ndev); rc = qlge_lb_send(skb, qdev->ndev);
if (rc != NETDEV_TX_OK) if (rc != NETDEV_TX_OK)
return -EPIPE; return -EPIPE;
atomic_inc(&qdev->lb_count); atomic_inc(&qdev->lb_count);
} }
/* Give queue time to settle before testing results. */ /* Give queue time to settle before testing results. */
msleep(2); msleep(2);
ql_clean_lb_rx_ring(&qdev->rx_ring[0], 128); qlge_clean_lb_rx_ring(&qdev->rx_ring[0], 128);
return atomic_read(&qdev->lb_count) ? -EIO : 0; return atomic_read(&qdev->lb_count) ? -EIO : 0;
} }
static int ql_loopback_test(struct ql_adapter *qdev, u64 *data) static int qlge_loopback_test(struct qlge_adapter *qdev, u64 *data)
{ {
*data = ql_start_loopback(qdev); *data = qlge_start_loopback(qdev);
if (*data) if (*data)
goto out; goto out;
*data = ql_run_loopback_test(qdev); *data = qlge_run_loopback_test(qdev);
out: out:
ql_stop_loopback(qdev); qlge_stop_loopback(qdev);
return *data; return *data;
} }
static void ql_self_test(struct net_device *ndev, static void qlge_self_test(struct net_device *ndev,
struct ethtool_test *eth_test, u64 *data) struct ethtool_test *eth_test, u64 *data)
{ {
struct ql_adapter *qdev = netdev_priv(ndev); struct qlge_adapter *qdev = netdev_priv(ndev);
memset(data, 0, sizeof(u64) * QLGE_TEST_LEN); memset(data, 0, sizeof(u64) * QLGE_TEST_LEN);
...@@ -582,7 +582,7 @@ static void ql_self_test(struct net_device *ndev, ...@@ -582,7 +582,7 @@ static void ql_self_test(struct net_device *ndev,
set_bit(QL_SELFTEST, &qdev->flags); set_bit(QL_SELFTEST, &qdev->flags);
if (eth_test->flags == ETH_TEST_FL_OFFLINE) { if (eth_test->flags == ETH_TEST_FL_OFFLINE) {
/* Offline tests */ /* Offline tests */
if (ql_loopback_test(qdev, &data[0])) if (qlge_loopback_test(qdev, &data[0]))
eth_test->flags |= ETH_TEST_FL_FAILED; eth_test->flags |= ETH_TEST_FL_FAILED;
} else { } else {
...@@ -601,32 +601,32 @@ static void ql_self_test(struct net_device *ndev, ...@@ -601,32 +601,32 @@ static void ql_self_test(struct net_device *ndev,
} }
} }
static int ql_get_regs_len(struct net_device *ndev) static int qlge_get_regs_len(struct net_device *ndev)
{ {
struct ql_adapter *qdev = netdev_priv(ndev); struct qlge_adapter *qdev = netdev_priv(ndev);
if (!test_bit(QL_FRC_COREDUMP, &qdev->flags)) if (!test_bit(QL_FRC_COREDUMP, &qdev->flags))
return sizeof(struct ql_mpi_coredump); return sizeof(struct qlge_mpi_coredump);
else else
return sizeof(struct ql_reg_dump); return sizeof(struct qlge_reg_dump);
} }
static void ql_get_regs(struct net_device *ndev, static void qlge_get_regs(struct net_device *ndev,
struct ethtool_regs *regs, void *p) struct ethtool_regs *regs, void *p)
{ {
struct ql_adapter *qdev = netdev_priv(ndev); struct qlge_adapter *qdev = netdev_priv(ndev);
ql_get_dump(qdev, p); qlge_get_dump(qdev, p);
qdev->core_is_dumped = 0; qdev->core_is_dumped = 0;
if (!test_bit(QL_FRC_COREDUMP, &qdev->flags)) if (!test_bit(QL_FRC_COREDUMP, &qdev->flags))
regs->len = sizeof(struct ql_mpi_coredump); regs->len = sizeof(struct qlge_mpi_coredump);
else else
regs->len = sizeof(struct ql_reg_dump); regs->len = sizeof(struct qlge_reg_dump);
} }
static int ql_get_coalesce(struct net_device *dev, struct ethtool_coalesce *c) static int qlge_get_coalesce(struct net_device *dev, struct ethtool_coalesce *c)
{ {
struct ql_adapter *qdev = netdev_priv(dev); struct qlge_adapter *qdev = netdev_priv(dev);
c->rx_coalesce_usecs = qdev->rx_coalesce_usecs; c->rx_coalesce_usecs = qdev->rx_coalesce_usecs;
c->tx_coalesce_usecs = qdev->tx_coalesce_usecs; c->tx_coalesce_usecs = qdev->tx_coalesce_usecs;
...@@ -647,14 +647,14 @@ static int ql_get_coalesce(struct net_device *dev, struct ethtool_coalesce *c) ...@@ -647,14 +647,14 @@ static int ql_get_coalesce(struct net_device *dev, struct ethtool_coalesce *c)
return 0; return 0;
} }
static int ql_set_coalesce(struct net_device *ndev, struct ethtool_coalesce *c) static int qlge_set_coalesce(struct net_device *ndev, struct ethtool_coalesce *c)
{ {
struct ql_adapter *qdev = netdev_priv(ndev); struct qlge_adapter *qdev = netdev_priv(ndev);
/* Validate user parameters. */ /* Validate user parameters. */
if (c->rx_coalesce_usecs > qdev->rx_ring_size / 2) if (c->rx_coalesce_usecs > qdev->rx_ring_size / 2)
return -EINVAL; return -EINVAL;
/* Don't wait more than 10 usec. */ /* Don't wait more than 10 usec. */
if (c->rx_max_coalesced_frames > MAX_INTER_FRAME_WAIT) if (c->rx_max_coalesced_frames > MAX_INTER_FRAME_WAIT)
return -EINVAL; return -EINVAL;
if (c->tx_coalesce_usecs > qdev->tx_ring_size / 2) if (c->tx_coalesce_usecs > qdev->tx_ring_size / 2)
...@@ -674,25 +674,25 @@ static int ql_set_coalesce(struct net_device *ndev, struct ethtool_coalesce *c) ...@@ -674,25 +674,25 @@ static int ql_set_coalesce(struct net_device *ndev, struct ethtool_coalesce *c)
qdev->rx_max_coalesced_frames = c->rx_max_coalesced_frames; qdev->rx_max_coalesced_frames = c->rx_max_coalesced_frames;
qdev->tx_max_coalesced_frames = c->tx_max_coalesced_frames; qdev->tx_max_coalesced_frames = c->tx_max_coalesced_frames;
return ql_update_ring_coalescing(qdev); return qlge_update_ring_coalescing(qdev);
} }
static void ql_get_pauseparam(struct net_device *netdev, static void qlge_get_pauseparam(struct net_device *netdev,
struct ethtool_pauseparam *pause) struct ethtool_pauseparam *pause)
{ {
struct ql_adapter *qdev = netdev_priv(netdev); struct qlge_adapter *qdev = netdev_priv(netdev);
ql_mb_get_port_cfg(qdev); qlge_mb_get_port_cfg(qdev);
if (qdev->link_config & CFG_PAUSE_STD) { if (qdev->link_config & CFG_PAUSE_STD) {
pause->rx_pause = 1; pause->rx_pause = 1;
pause->tx_pause = 1; pause->tx_pause = 1;
} }
} }
static int ql_set_pauseparam(struct net_device *netdev, static int qlge_set_pauseparam(struct net_device *netdev,
struct ethtool_pauseparam *pause) struct ethtool_pauseparam *pause)
{ {
struct ql_adapter *qdev = netdev_priv(netdev); struct qlge_adapter *qdev = netdev_priv(netdev);
if ((pause->rx_pause) && (pause->tx_pause)) if ((pause->rx_pause) && (pause->tx_pause))
qdev->link_config |= CFG_PAUSE_STD; qdev->link_config |= CFG_PAUSE_STD;
...@@ -701,19 +701,19 @@ static int ql_set_pauseparam(struct net_device *netdev, ...@@ -701,19 +701,19 @@ static int ql_set_pauseparam(struct net_device *netdev,
else else
return -EINVAL; return -EINVAL;
return ql_mb_set_port_cfg(qdev); return qlge_mb_set_port_cfg(qdev);
} }
static u32 ql_get_msglevel(struct net_device *ndev) static u32 qlge_get_msglevel(struct net_device *ndev)
{ {
struct ql_adapter *qdev = netdev_priv(ndev); struct qlge_adapter *qdev = netdev_priv(ndev);
return qdev->msg_enable; return qdev->msg_enable;
} }
static void ql_set_msglevel(struct net_device *ndev, u32 value) static void qlge_set_msglevel(struct net_device *ndev, u32 value)
{ {
struct ql_adapter *qdev = netdev_priv(ndev); struct qlge_adapter *qdev = netdev_priv(ndev);
qdev->msg_enable = value; qdev->msg_enable = value;
} }
...@@ -721,23 +721,23 @@ static void ql_set_msglevel(struct net_device *ndev, u32 value) ...@@ -721,23 +721,23 @@ static void ql_set_msglevel(struct net_device *ndev, u32 value)
const struct ethtool_ops qlge_ethtool_ops = { const struct ethtool_ops qlge_ethtool_ops = {
.supported_coalesce_params = ETHTOOL_COALESCE_USECS | .supported_coalesce_params = ETHTOOL_COALESCE_USECS |
ETHTOOL_COALESCE_MAX_FRAMES, ETHTOOL_COALESCE_MAX_FRAMES,
.get_drvinfo = ql_get_drvinfo, .get_drvinfo = qlge_get_drvinfo,
.get_wol = ql_get_wol, .get_wol = qlge_get_wol,
.set_wol = ql_set_wol, .set_wol = qlge_set_wol,
.get_regs_len = ql_get_regs_len, .get_regs_len = qlge_get_regs_len,
.get_regs = ql_get_regs, .get_regs = qlge_get_regs,
.get_msglevel = ql_get_msglevel, .get_msglevel = qlge_get_msglevel,
.set_msglevel = ql_set_msglevel, .set_msglevel = qlge_set_msglevel,
.get_link = ethtool_op_get_link, .get_link = ethtool_op_get_link,
.set_phys_id = ql_set_phys_id, .set_phys_id = qlge_set_phys_id,
.self_test = ql_self_test, .self_test = qlge_self_test,
.get_pauseparam = ql_get_pauseparam, .get_pauseparam = qlge_get_pauseparam,
.set_pauseparam = ql_set_pauseparam, .set_pauseparam = qlge_set_pauseparam,
.get_coalesce = ql_get_coalesce, .get_coalesce = qlge_get_coalesce,
.set_coalesce = ql_set_coalesce, .set_coalesce = qlge_set_coalesce,
.get_sset_count = ql_get_sset_count, .get_sset_count = qlge_get_sset_count,
.get_strings = ql_get_strings, .get_strings = qlge_get_strings,
.get_ethtool_stats = ql_get_ethtool_stats, .get_ethtool_stats = qlge_get_ethtool_stats,
.get_link_ksettings = ql_get_link_ksettings, .get_link_ksettings = qlge_get_link_ksettings,
}; };
This source diff could not be displayed because it is too large. You can view the blob instead.
// SPDX-License-Identifier: GPL-2.0 // SPDX-License-Identifier: GPL-2.0
#include "qlge.h" #include "qlge.h"
int ql_unpause_mpi_risc(struct ql_adapter *qdev) int qlge_unpause_mpi_risc(struct qlge_adapter *qdev)
{ {
u32 tmp; u32 tmp;
/* Un-pause the RISC */ /* Un-pause the RISC */
tmp = ql_read32(qdev, CSR); tmp = qlge_read32(qdev, CSR);
if (!(tmp & CSR_RP)) if (!(tmp & CSR_RP))
return -EIO; return -EIO;
ql_write32(qdev, CSR, CSR_CMD_CLR_PAUSE); qlge_write32(qdev, CSR, CSR_CMD_CLR_PAUSE);
return 0; return 0;
} }
int ql_pause_mpi_risc(struct ql_adapter *qdev) int qlge_pause_mpi_risc(struct qlge_adapter *qdev)
{ {
u32 tmp; u32 tmp;
int count; int count;
/* Pause the RISC */ /* Pause the RISC */
ql_write32(qdev, CSR, CSR_CMD_SET_PAUSE); qlge_write32(qdev, CSR, CSR_CMD_SET_PAUSE);
for (count = UDELAY_COUNT; count; count--) { for (count = UDELAY_COUNT; count; count--) {
tmp = ql_read32(qdev, CSR); tmp = qlge_read32(qdev, CSR);
if (tmp & CSR_RP) if (tmp & CSR_RP)
break; break;
mdelay(UDELAY_DELAY); mdelay(UDELAY_DELAY);
...@@ -30,17 +30,17 @@ int ql_pause_mpi_risc(struct ql_adapter *qdev) ...@@ -30,17 +30,17 @@ int ql_pause_mpi_risc(struct ql_adapter *qdev)
return (count == 0) ? -ETIMEDOUT : 0; return (count == 0) ? -ETIMEDOUT : 0;
} }
int ql_hard_reset_mpi_risc(struct ql_adapter *qdev) int qlge_hard_reset_mpi_risc(struct qlge_adapter *qdev)
{ {
u32 tmp; u32 tmp;
int count; int count;
/* Reset the RISC */ /* Reset the RISC */
ql_write32(qdev, CSR, CSR_CMD_SET_RST); qlge_write32(qdev, CSR, CSR_CMD_SET_RST);
for (count = UDELAY_COUNT; count; count--) { for (count = UDELAY_COUNT; count; count--) {
tmp = ql_read32(qdev, CSR); tmp = qlge_read32(qdev, CSR);
if (tmp & CSR_RR) { if (tmp & CSR_RR) {
ql_write32(qdev, CSR, CSR_CMD_CLR_RST); qlge_write32(qdev, CSR, CSR_CMD_CLR_RST);
break; break;
} }
mdelay(UDELAY_DELAY); mdelay(UDELAY_DELAY);
...@@ -48,47 +48,47 @@ int ql_hard_reset_mpi_risc(struct ql_adapter *qdev) ...@@ -48,47 +48,47 @@ int ql_hard_reset_mpi_risc(struct ql_adapter *qdev)
return (count == 0) ? -ETIMEDOUT : 0; return (count == 0) ? -ETIMEDOUT : 0;
} }
int ql_read_mpi_reg(struct ql_adapter *qdev, u32 reg, u32 *data) int qlge_read_mpi_reg(struct qlge_adapter *qdev, u32 reg, u32 *data)
{ {
int status; int status;
/* wait for reg to come ready */ /* wait for reg to come ready */
status = ql_wait_reg_rdy(qdev, PROC_ADDR, PROC_ADDR_RDY, PROC_ADDR_ERR); status = qlge_wait_reg_rdy(qdev, PROC_ADDR, PROC_ADDR_RDY, PROC_ADDR_ERR);
if (status) if (status)
goto exit; goto exit;
/* set up for reg read */ /* set up for reg read */
ql_write32(qdev, PROC_ADDR, reg | PROC_ADDR_R); qlge_write32(qdev, PROC_ADDR, reg | PROC_ADDR_R);
/* wait for reg to come ready */ /* wait for reg to come ready */
status = ql_wait_reg_rdy(qdev, PROC_ADDR, PROC_ADDR_RDY, PROC_ADDR_ERR); status = qlge_wait_reg_rdy(qdev, PROC_ADDR, PROC_ADDR_RDY, PROC_ADDR_ERR);
if (status) if (status)
goto exit; goto exit;
/* get the data */ /* get the data */
*data = ql_read32(qdev, PROC_DATA); *data = qlge_read32(qdev, PROC_DATA);
exit: exit:
return status; return status;
} }
int ql_write_mpi_reg(struct ql_adapter *qdev, u32 reg, u32 data) int qlge_write_mpi_reg(struct qlge_adapter *qdev, u32 reg, u32 data)
{ {
int status = 0; int status = 0;
/* wait for reg to come ready */ /* wait for reg to come ready */
status = ql_wait_reg_rdy(qdev, PROC_ADDR, PROC_ADDR_RDY, PROC_ADDR_ERR); status = qlge_wait_reg_rdy(qdev, PROC_ADDR, PROC_ADDR_RDY, PROC_ADDR_ERR);
if (status) if (status)
goto exit; goto exit;
/* write the data to the data reg */ /* write the data to the data reg */
ql_write32(qdev, PROC_DATA, data); qlge_write32(qdev, PROC_DATA, data);
/* trigger the write */ /* trigger the write */
ql_write32(qdev, PROC_ADDR, reg); qlge_write32(qdev, PROC_ADDR, reg);
/* wait for reg to come ready */ /* wait for reg to come ready */
status = ql_wait_reg_rdy(qdev, PROC_ADDR, PROC_ADDR_RDY, PROC_ADDR_ERR); status = qlge_wait_reg_rdy(qdev, PROC_ADDR, PROC_ADDR_RDY, PROC_ADDR_ERR);
if (status) if (status)
goto exit; goto exit;
exit: exit:
return status; return status;
} }
int ql_soft_reset_mpi_risc(struct ql_adapter *qdev) int qlge_soft_reset_mpi_risc(struct qlge_adapter *qdev)
{ {
return ql_write_mpi_reg(qdev, 0x00001010, 1); return qlge_write_mpi_reg(qdev, 0x00001010, 1);
} }
/* Determine if we are in charge of the firmware. If /* Determine if we are in charge of the firmware. If
...@@ -96,7 +96,7 @@ int ql_soft_reset_mpi_risc(struct ql_adapter *qdev) ...@@ -96,7 +96,7 @@ int ql_soft_reset_mpi_risc(struct ql_adapter *qdev)
* we are the higher function and the lower function * we are the higher function and the lower function
* is not enabled. * is not enabled.
*/ */
int ql_own_firmware(struct ql_adapter *qdev) int qlge_own_firmware(struct qlge_adapter *qdev)
{ {
u32 temp; u32 temp;
...@@ -112,43 +112,43 @@ int ql_own_firmware(struct ql_adapter *qdev) ...@@ -112,43 +112,43 @@ int ql_own_firmware(struct ql_adapter *qdev)
* enabled, then we are responsible for * enabled, then we are responsible for
* core dump and firmware reset after an error. * core dump and firmware reset after an error.
*/ */
temp = ql_read32(qdev, STS); temp = qlge_read32(qdev, STS);
if (!(temp & (1 << (8 + qdev->alt_func)))) if (!(temp & (1 << (8 + qdev->alt_func))))
return 1; return 1;
return 0; return 0;
} }
static int ql_get_mb_sts(struct ql_adapter *qdev, struct mbox_params *mbcp) static int qlge_get_mb_sts(struct qlge_adapter *qdev, struct mbox_params *mbcp)
{ {
int i, status; int i, status;
status = ql_sem_spinlock(qdev, SEM_PROC_REG_MASK); status = qlge_sem_spinlock(qdev, SEM_PROC_REG_MASK);
if (status) if (status)
return -EBUSY; return -EBUSY;
for (i = 0; i < mbcp->out_count; i++) { for (i = 0; i < mbcp->out_count; i++) {
status = status =
ql_read_mpi_reg(qdev, qdev->mailbox_out + i, qlge_read_mpi_reg(qdev, qdev->mailbox_out + i,
&mbcp->mbox_out[i]); &mbcp->mbox_out[i]);
if (status) { if (status) {
netif_err(qdev, drv, qdev->ndev, "Failed mailbox read.\n"); netif_err(qdev, drv, qdev->ndev, "Failed mailbox read.\n");
break; break;
} }
} }
ql_sem_unlock(qdev, SEM_PROC_REG_MASK); /* does flush too */ qlge_sem_unlock(qdev, SEM_PROC_REG_MASK); /* does flush too */
return status; return status;
} }
/* Wait for a single mailbox command to complete. /* Wait for a single mailbox command to complete.
* Returns zero on success. * Returns zero on success.
*/ */
static int ql_wait_mbx_cmd_cmplt(struct ql_adapter *qdev) static int qlge_wait_mbx_cmd_cmplt(struct qlge_adapter *qdev)
{ {
int count; int count;
u32 value; u32 value;
for (count = 100; count; count--) { for (count = 100; count; count--) {
value = ql_read32(qdev, STS); value = qlge_read32(qdev, STS);
if (value & STS_PI) if (value & STS_PI)
return 0; return 0;
mdelay(UDELAY_DELAY); /* 100ms */ mdelay(UDELAY_DELAY); /* 100ms */
...@@ -159,7 +159,7 @@ static int ql_wait_mbx_cmd_cmplt(struct ql_adapter *qdev) ...@@ -159,7 +159,7 @@ static int ql_wait_mbx_cmd_cmplt(struct ql_adapter *qdev)
/* Execute a single mailbox command. /* Execute a single mailbox command.
* Caller must hold PROC_ADDR semaphore. * Caller must hold PROC_ADDR semaphore.
*/ */
static int ql_exec_mb_cmd(struct ql_adapter *qdev, struct mbox_params *mbcp) static int qlge_exec_mb_cmd(struct qlge_adapter *qdev, struct mbox_params *mbcp)
{ {
int i, status; int i, status;
...@@ -167,10 +167,10 @@ static int ql_exec_mb_cmd(struct ql_adapter *qdev, struct mbox_params *mbcp) ...@@ -167,10 +167,10 @@ static int ql_exec_mb_cmd(struct ql_adapter *qdev, struct mbox_params *mbcp)
* Make sure there's nothing pending. * Make sure there's nothing pending.
* This shouldn't happen. * This shouldn't happen.
*/ */
if (ql_read32(qdev, CSR) & CSR_HRI) if (qlge_read32(qdev, CSR) & CSR_HRI)
return -EIO; return -EIO;
status = ql_sem_spinlock(qdev, SEM_PROC_REG_MASK); status = qlge_sem_spinlock(qdev, SEM_PROC_REG_MASK);
if (status) if (status)
return status; return status;
...@@ -178,17 +178,17 @@ static int ql_exec_mb_cmd(struct ql_adapter *qdev, struct mbox_params *mbcp) ...@@ -178,17 +178,17 @@ static int ql_exec_mb_cmd(struct ql_adapter *qdev, struct mbox_params *mbcp)
* Fill the outbound mailboxes. * Fill the outbound mailboxes.
*/ */
for (i = 0; i < mbcp->in_count; i++) { for (i = 0; i < mbcp->in_count; i++) {
status = ql_write_mpi_reg(qdev, qdev->mailbox_in + i, status = qlge_write_mpi_reg(qdev, qdev->mailbox_in + i,
mbcp->mbox_in[i]); mbcp->mbox_in[i]);
if (status) if (status)
goto end; goto end;
} }
/* /*
* Wake up the MPI firmware. * Wake up the MPI firmware.
*/ */
ql_write32(qdev, CSR, CSR_CMD_SET_H2R_INT); qlge_write32(qdev, CSR, CSR_CMD_SET_H2R_INT);
end: end:
ql_sem_unlock(qdev, SEM_PROC_REG_MASK); qlge_sem_unlock(qdev, SEM_PROC_REG_MASK);
return status; return status;
} }
...@@ -199,7 +199,7 @@ static int ql_exec_mb_cmd(struct ql_adapter *qdev, struct mbox_params *mbcp) ...@@ -199,7 +199,7 @@ static int ql_exec_mb_cmd(struct ql_adapter *qdev, struct mbox_params *mbcp)
* to handler processing this since a mailbox command * to handler processing this since a mailbox command
* will need to be sent to ACK the request. * will need to be sent to ACK the request.
*/ */
static int ql_idc_req_aen(struct ql_adapter *qdev) static int qlge_idc_req_aen(struct qlge_adapter *qdev)
{ {
int status; int status;
struct mbox_params *mbcp = &qdev->idc_mbc; struct mbox_params *mbcp = &qdev->idc_mbc;
...@@ -209,17 +209,17 @@ static int ql_idc_req_aen(struct ql_adapter *qdev) ...@@ -209,17 +209,17 @@ static int ql_idc_req_aen(struct ql_adapter *qdev)
* handle the request. * handle the request.
*/ */
mbcp->out_count = 4; mbcp->out_count = 4;
status = ql_get_mb_sts(qdev, mbcp); status = qlge_get_mb_sts(qdev, mbcp);
if (status) { if (status) {
netif_err(qdev, drv, qdev->ndev, netif_err(qdev, drv, qdev->ndev,
"Could not read MPI, resetting ASIC!\n"); "Could not read MPI, resetting ASIC!\n");
ql_queue_asic_error(qdev); qlge_queue_asic_error(qdev);
} else { } else {
/* Begin polled mode early so /* Begin polled mode early so
* we don't get another interrupt * we don't get another interrupt
* when we leave mpi_worker. * when we leave mpi_worker.
*/ */
ql_write32(qdev, INTR_MASK, (INTR_MASK_PI << 16)); qlge_write32(qdev, INTR_MASK, (INTR_MASK_PI << 16));
queue_delayed_work(qdev->workqueue, &qdev->mpi_idc_work, 0); queue_delayed_work(qdev->workqueue, &qdev->mpi_idc_work, 0);
} }
return status; return status;
...@@ -228,17 +228,17 @@ static int ql_idc_req_aen(struct ql_adapter *qdev) ...@@ -228,17 +228,17 @@ static int ql_idc_req_aen(struct ql_adapter *qdev)
/* Process an inter-device event completion. /* Process an inter-device event completion.
* If good, signal the caller's completion. * If good, signal the caller's completion.
*/ */
static int ql_idc_cmplt_aen(struct ql_adapter *qdev) static int qlge_idc_cmplt_aen(struct qlge_adapter *qdev)
{ {
int status; int status;
struct mbox_params *mbcp = &qdev->idc_mbc; struct mbox_params *mbcp = &qdev->idc_mbc;
mbcp->out_count = 4; mbcp->out_count = 4;
status = ql_get_mb_sts(qdev, mbcp); status = qlge_get_mb_sts(qdev, mbcp);
if (status) { if (status) {
netif_err(qdev, drv, qdev->ndev, netif_err(qdev, drv, qdev->ndev,
"Could not read MPI, resetting RISC!\n"); "Could not read MPI, resetting RISC!\n");
ql_queue_fw_error(qdev); qlge_queue_fw_error(qdev);
} else { } else {
/* Wake up the sleeping mpi_idc_work thread that is /* Wake up the sleeping mpi_idc_work thread that is
* waiting for this event. * waiting for this event.
...@@ -248,13 +248,13 @@ static int ql_idc_cmplt_aen(struct ql_adapter *qdev) ...@@ -248,13 +248,13 @@ static int ql_idc_cmplt_aen(struct ql_adapter *qdev)
return status; return status;
} }
static void ql_link_up(struct ql_adapter *qdev, struct mbox_params *mbcp) static void qlge_link_up(struct qlge_adapter *qdev, struct mbox_params *mbcp)
{ {
int status; int status;
mbcp->out_count = 2; mbcp->out_count = 2;
status = ql_get_mb_sts(qdev, mbcp); status = qlge_get_mb_sts(qdev, mbcp);
if (status) { if (status) {
netif_err(qdev, drv, qdev->ndev, netif_err(qdev, drv, qdev->ndev,
"%s: Could not get mailbox status.\n", __func__); "%s: Could not get mailbox status.\n", __func__);
...@@ -268,7 +268,7 @@ static void ql_link_up(struct ql_adapter *qdev, struct mbox_params *mbcp) ...@@ -268,7 +268,7 @@ static void ql_link_up(struct ql_adapter *qdev, struct mbox_params *mbcp)
* then set up the CAM and frame routing. * then set up the CAM and frame routing.
*/ */
if (test_bit(QL_CAM_RT_SET, &qdev->flags)) { if (test_bit(QL_CAM_RT_SET, &qdev->flags)) {
status = ql_cam_route_initialize(qdev); status = qlge_cam_route_initialize(qdev);
if (status) { if (status) {
netif_err(qdev, ifup, qdev->ndev, netif_err(qdev, ifup, qdev->ndev,
"Failed to init CAM/Routing tables.\n"); "Failed to init CAM/Routing tables.\n");
...@@ -288,34 +288,34 @@ static void ql_link_up(struct ql_adapter *qdev, struct mbox_params *mbcp) ...@@ -288,34 +288,34 @@ static void ql_link_up(struct ql_adapter *qdev, struct mbox_params *mbcp)
* we don't get another interrupt * we don't get another interrupt
* when we leave mpi_worker dpc. * when we leave mpi_worker dpc.
*/ */
ql_write32(qdev, INTR_MASK, (INTR_MASK_PI << 16)); qlge_write32(qdev, INTR_MASK, (INTR_MASK_PI << 16));
queue_delayed_work(qdev->workqueue, queue_delayed_work(qdev->workqueue,
&qdev->mpi_port_cfg_work, 0); &qdev->mpi_port_cfg_work, 0);
} }
ql_link_on(qdev); qlge_link_on(qdev);
} }
static void ql_link_down(struct ql_adapter *qdev, struct mbox_params *mbcp) static void qlge_link_down(struct qlge_adapter *qdev, struct mbox_params *mbcp)
{ {
int status; int status;
mbcp->out_count = 3; mbcp->out_count = 3;
status = ql_get_mb_sts(qdev, mbcp); status = qlge_get_mb_sts(qdev, mbcp);
if (status) if (status)
netif_err(qdev, drv, qdev->ndev, "Link down AEN broken!\n"); netif_err(qdev, drv, qdev->ndev, "Link down AEN broken!\n");
ql_link_off(qdev); qlge_link_off(qdev);
} }
static int ql_sfp_in(struct ql_adapter *qdev, struct mbox_params *mbcp) static int qlge_sfp_in(struct qlge_adapter *qdev, struct mbox_params *mbcp)
{ {
int status; int status;
mbcp->out_count = 5; mbcp->out_count = 5;
status = ql_get_mb_sts(qdev, mbcp); status = qlge_get_mb_sts(qdev, mbcp);
if (status) if (status)
netif_err(qdev, drv, qdev->ndev, "SFP in AEN broken!\n"); netif_err(qdev, drv, qdev->ndev, "SFP in AEN broken!\n");
else else
...@@ -324,13 +324,13 @@ static int ql_sfp_in(struct ql_adapter *qdev, struct mbox_params *mbcp) ...@@ -324,13 +324,13 @@ static int ql_sfp_in(struct ql_adapter *qdev, struct mbox_params *mbcp)
return status; return status;
} }
static int ql_sfp_out(struct ql_adapter *qdev, struct mbox_params *mbcp) static int qlge_sfp_out(struct qlge_adapter *qdev, struct mbox_params *mbcp)
{ {
int status; int status;
mbcp->out_count = 1; mbcp->out_count = 1;
status = ql_get_mb_sts(qdev, mbcp); status = qlge_get_mb_sts(qdev, mbcp);
if (status) if (status)
netif_err(qdev, drv, qdev->ndev, "SFP out AEN broken!\n"); netif_err(qdev, drv, qdev->ndev, "SFP out AEN broken!\n");
else else
...@@ -339,13 +339,13 @@ static int ql_sfp_out(struct ql_adapter *qdev, struct mbox_params *mbcp) ...@@ -339,13 +339,13 @@ static int ql_sfp_out(struct ql_adapter *qdev, struct mbox_params *mbcp)
return status; return status;
} }
static int ql_aen_lost(struct ql_adapter *qdev, struct mbox_params *mbcp) static int qlge_aen_lost(struct qlge_adapter *qdev, struct mbox_params *mbcp)
{ {
int status; int status;
mbcp->out_count = 6; mbcp->out_count = 6;
status = ql_get_mb_sts(qdev, mbcp); status = qlge_get_mb_sts(qdev, mbcp);
if (status) { if (status) {
netif_err(qdev, drv, qdev->ndev, "Lost AEN broken!\n"); netif_err(qdev, drv, qdev->ndev, "Lost AEN broken!\n");
} else { } else {
...@@ -360,20 +360,20 @@ static int ql_aen_lost(struct ql_adapter *qdev, struct mbox_params *mbcp) ...@@ -360,20 +360,20 @@ static int ql_aen_lost(struct ql_adapter *qdev, struct mbox_params *mbcp)
return status; return status;
} }
static void ql_init_fw_done(struct ql_adapter *qdev, struct mbox_params *mbcp) static void qlge_init_fw_done(struct qlge_adapter *qdev, struct mbox_params *mbcp)
{ {
int status; int status;
mbcp->out_count = 2; mbcp->out_count = 2;
status = ql_get_mb_sts(qdev, mbcp); status = qlge_get_mb_sts(qdev, mbcp);
if (status) { if (status) {
netif_err(qdev, drv, qdev->ndev, "Firmware did not initialize!\n"); netif_err(qdev, drv, qdev->ndev, "Firmware did not initialize!\n");
} else { } else {
netif_err(qdev, drv, qdev->ndev, "Firmware Revision = 0x%.08x.\n", netif_err(qdev, drv, qdev->ndev, "Firmware Revision = 0x%.08x.\n",
mbcp->mbox_out[1]); mbcp->mbox_out[1]);
qdev->fw_rev_id = mbcp->mbox_out[1]; qdev->fw_rev_id = mbcp->mbox_out[1];
status = ql_cam_route_initialize(qdev); status = qlge_cam_route_initialize(qdev);
if (status) if (status)
netif_err(qdev, ifup, qdev->ndev, netif_err(qdev, ifup, qdev->ndev,
"Failed to init CAM/Routing tables.\n"); "Failed to init CAM/Routing tables.\n");
...@@ -387,26 +387,26 @@ static void ql_init_fw_done(struct ql_adapter *qdev, struct mbox_params *mbcp) ...@@ -387,26 +387,26 @@ static void ql_init_fw_done(struct ql_adapter *qdev, struct mbox_params *mbcp)
* It also gets called when a mailbox command is polling for * It also gets called when a mailbox command is polling for
* it's completion. * it's completion.
*/ */
static int ql_mpi_handler(struct ql_adapter *qdev, struct mbox_params *mbcp) static int qlge_mpi_handler(struct qlge_adapter *qdev, struct mbox_params *mbcp)
{ {
int status; int status;
int orig_count = mbcp->out_count; int orig_count = mbcp->out_count;
/* Just get mailbox zero for now. */ /* Just get mailbox zero for now. */
mbcp->out_count = 1; mbcp->out_count = 1;
status = ql_get_mb_sts(qdev, mbcp); status = qlge_get_mb_sts(qdev, mbcp);
if (status) { if (status) {
netif_err(qdev, drv, qdev->ndev, netif_err(qdev, drv, qdev->ndev,
"Could not read MPI, resetting ASIC!\n"); "Could not read MPI, resetting ASIC!\n");
ql_queue_asic_error(qdev); qlge_queue_asic_error(qdev);
goto end; goto end;
} }
switch (mbcp->mbox_out[0]) { switch (mbcp->mbox_out[0]) {
/* This case is only active when we arrive here /* This case is only active when we arrive here
* as a result of issuing a mailbox command to * as a result of issuing a mailbox command to
* the firmware. * the firmware.
*/ */
case MB_CMD_STS_INTRMDT: case MB_CMD_STS_INTRMDT:
case MB_CMD_STS_GOOD: case MB_CMD_STS_GOOD:
case MB_CMD_STS_INVLD_CMD: case MB_CMD_STS_INVLD_CMD:
...@@ -421,34 +421,34 @@ static int ql_mpi_handler(struct ql_adapter *qdev, struct mbox_params *mbcp) ...@@ -421,34 +421,34 @@ static int ql_mpi_handler(struct ql_adapter *qdev, struct mbox_params *mbcp)
* command completion. * command completion.
*/ */
mbcp->out_count = orig_count; mbcp->out_count = orig_count;
status = ql_get_mb_sts(qdev, mbcp); status = qlge_get_mb_sts(qdev, mbcp);
return status; return status;
/* We are being asked by firmware to accept /* We are being asked by firmware to accept
* a change to the port. This is only * a change to the port. This is only
* a change to max frame sizes (Tx/Rx), pause * a change to max frame sizes (Tx/Rx), pause
* parameters, or loopback mode. * parameters, or loopback mode.
*/ */
case AEN_IDC_REQ: case AEN_IDC_REQ:
status = ql_idc_req_aen(qdev); status = qlge_idc_req_aen(qdev);
break; break;
/* Process and inbound IDC event. /* Process and inbound IDC event.
* This will happen when we're trying to * This will happen when we're trying to
* change tx/rx max frame size, change pause * change tx/rx max frame size, change pause
* parameters or loopback mode. * parameters or loopback mode.
*/ */
case AEN_IDC_CMPLT: case AEN_IDC_CMPLT:
case AEN_IDC_EXT: case AEN_IDC_EXT:
status = ql_idc_cmplt_aen(qdev); status = qlge_idc_cmplt_aen(qdev);
break; break;
case AEN_LINK_UP: case AEN_LINK_UP:
ql_link_up(qdev, mbcp); qlge_link_up(qdev, mbcp);
break; break;
case AEN_LINK_DOWN: case AEN_LINK_DOWN:
ql_link_down(qdev, mbcp); qlge_link_down(qdev, mbcp);
break; break;
case AEN_FW_INIT_DONE: case AEN_FW_INIT_DONE:
...@@ -457,48 +457,48 @@ static int ql_mpi_handler(struct ql_adapter *qdev, struct mbox_params *mbcp) ...@@ -457,48 +457,48 @@ static int ql_mpi_handler(struct ql_adapter *qdev, struct mbox_params *mbcp)
*/ */
if (mbcp->mbox_in[0] == MB_CMD_EX_FW) { if (mbcp->mbox_in[0] == MB_CMD_EX_FW) {
mbcp->out_count = orig_count; mbcp->out_count = orig_count;
status = ql_get_mb_sts(qdev, mbcp); status = qlge_get_mb_sts(qdev, mbcp);
mbcp->mbox_out[0] = MB_CMD_STS_GOOD; mbcp->mbox_out[0] = MB_CMD_STS_GOOD;
return status; return status;
} }
ql_init_fw_done(qdev, mbcp); qlge_init_fw_done(qdev, mbcp);
break; break;
case AEN_AEN_SFP_IN: case AEN_AEN_SFP_IN:
ql_sfp_in(qdev, mbcp); qlge_sfp_in(qdev, mbcp);
break; break;
case AEN_AEN_SFP_OUT: case AEN_AEN_SFP_OUT:
ql_sfp_out(qdev, mbcp); qlge_sfp_out(qdev, mbcp);
break; break;
/* This event can arrive at boot time or after an /* This event can arrive at boot time or after an
* MPI reset if the firmware failed to initialize. * MPI reset if the firmware failed to initialize.
*/ */
case AEN_FW_INIT_FAIL: case AEN_FW_INIT_FAIL:
/* If we're in process on executing the firmware, /* If we're in process on executing the firmware,
* then convert the status to normal mailbox status. * then convert the status to normal mailbox status.
*/ */
if (mbcp->mbox_in[0] == MB_CMD_EX_FW) { if (mbcp->mbox_in[0] == MB_CMD_EX_FW) {
mbcp->out_count = orig_count; mbcp->out_count = orig_count;
status = ql_get_mb_sts(qdev, mbcp); status = qlge_get_mb_sts(qdev, mbcp);
mbcp->mbox_out[0] = MB_CMD_STS_ERR; mbcp->mbox_out[0] = MB_CMD_STS_ERR;
return status; return status;
} }
netif_err(qdev, drv, qdev->ndev, netif_err(qdev, drv, qdev->ndev,
"Firmware initialization failed.\n"); "Firmware initialization failed.\n");
status = -EIO; status = -EIO;
ql_queue_fw_error(qdev); qlge_queue_fw_error(qdev);
break; break;
case AEN_SYS_ERR: case AEN_SYS_ERR:
netif_err(qdev, drv, qdev->ndev, "System Error.\n"); netif_err(qdev, drv, qdev->ndev, "System Error.\n");
ql_queue_fw_error(qdev); qlge_queue_fw_error(qdev);
status = -EIO; status = -EIO;
break; break;
case AEN_AEN_LOST: case AEN_AEN_LOST:
ql_aen_lost(qdev, mbcp); qlge_aen_lost(qdev, mbcp);
break; break;
case AEN_DCBX_CHG: case AEN_DCBX_CHG:
...@@ -510,7 +510,7 @@ static int ql_mpi_handler(struct ql_adapter *qdev, struct mbox_params *mbcp) ...@@ -510,7 +510,7 @@ static int ql_mpi_handler(struct ql_adapter *qdev, struct mbox_params *mbcp)
/* Clear the MPI firmware status. */ /* Clear the MPI firmware status. */
} }
end: end:
ql_write32(qdev, CSR, CSR_CMD_CLR_R2PCI_INT); qlge_write32(qdev, CSR, CSR_CMD_CLR_R2PCI_INT);
/* Restore the original mailbox count to /* Restore the original mailbox count to
* what the caller asked for. This can get * what the caller asked for. This can get
* changed when a mailbox command is waiting * changed when a mailbox command is waiting
...@@ -526,7 +526,7 @@ static int ql_mpi_handler(struct ql_adapter *qdev, struct mbox_params *mbcp) ...@@ -526,7 +526,7 @@ static int ql_mpi_handler(struct ql_adapter *qdev, struct mbox_params *mbcp)
* element in the array contains the value for it's * element in the array contains the value for it's
* respective mailbox register. * respective mailbox register.
*/ */
static int ql_mailbox_command(struct ql_adapter *qdev, struct mbox_params *mbcp) static int qlge_mailbox_command(struct qlge_adapter *qdev, struct mbox_params *mbcp)
{ {
int status; int status;
unsigned long count; unsigned long count;
...@@ -534,10 +534,10 @@ static int ql_mailbox_command(struct ql_adapter *qdev, struct mbox_params *mbcp) ...@@ -534,10 +534,10 @@ static int ql_mailbox_command(struct ql_adapter *qdev, struct mbox_params *mbcp)
mutex_lock(&qdev->mpi_mutex); mutex_lock(&qdev->mpi_mutex);
/* Begin polled mode for MPI */ /* Begin polled mode for MPI */
ql_write32(qdev, INTR_MASK, (INTR_MASK_PI << 16)); qlge_write32(qdev, INTR_MASK, (INTR_MASK_PI << 16));
/* Load the mailbox registers and wake up MPI RISC. */ /* Load the mailbox registers and wake up MPI RISC. */
status = ql_exec_mb_cmd(qdev, mbcp); status = qlge_exec_mb_cmd(qdev, mbcp);
if (status) if (status)
goto end; goto end;
...@@ -556,7 +556,7 @@ static int ql_mailbox_command(struct ql_adapter *qdev, struct mbox_params *mbcp) ...@@ -556,7 +556,7 @@ static int ql_mailbox_command(struct ql_adapter *qdev, struct mbox_params *mbcp)
count = jiffies + HZ * MAILBOX_TIMEOUT; count = jiffies + HZ * MAILBOX_TIMEOUT;
do { do {
/* Wait for the interrupt to come in. */ /* Wait for the interrupt to come in. */
status = ql_wait_mbx_cmd_cmplt(qdev); status = qlge_wait_mbx_cmd_cmplt(qdev);
if (status) if (status)
continue; continue;
...@@ -565,7 +565,7 @@ static int ql_mailbox_command(struct ql_adapter *qdev, struct mbox_params *mbcp) ...@@ -565,7 +565,7 @@ static int ql_mailbox_command(struct ql_adapter *qdev, struct mbox_params *mbcp)
* will be spawned. If it's our completion * will be spawned. If it's our completion
* we will catch it below. * we will catch it below.
*/ */
status = ql_mpi_handler(qdev, mbcp); status = qlge_mpi_handler(qdev, mbcp);
if (status) if (status)
goto end; goto end;
...@@ -574,9 +574,9 @@ static int ql_mailbox_command(struct ql_adapter *qdev, struct mbox_params *mbcp) ...@@ -574,9 +574,9 @@ static int ql_mailbox_command(struct ql_adapter *qdev, struct mbox_params *mbcp)
* completion then get out. * completion then get out.
*/ */
if (((mbcp->mbox_out[0] & 0x0000f000) == if (((mbcp->mbox_out[0] & 0x0000f000) ==
MB_CMD_STS_GOOD) || MB_CMD_STS_GOOD) ||
((mbcp->mbox_out[0] & 0x0000f000) == ((mbcp->mbox_out[0] & 0x0000f000) ==
MB_CMD_STS_INTRMDT)) MB_CMD_STS_INTRMDT))
goto done; goto done;
} while (time_before(jiffies, count)); } while (time_before(jiffies, count));
...@@ -590,17 +590,17 @@ static int ql_mailbox_command(struct ql_adapter *qdev, struct mbox_params *mbcp) ...@@ -590,17 +590,17 @@ static int ql_mailbox_command(struct ql_adapter *qdev, struct mbox_params *mbcp)
/* Now we can clear the interrupt condition /* Now we can clear the interrupt condition
* and look at our status. * and look at our status.
*/ */
ql_write32(qdev, CSR, CSR_CMD_CLR_R2PCI_INT); qlge_write32(qdev, CSR, CSR_CMD_CLR_R2PCI_INT);
if (((mbcp->mbox_out[0] & 0x0000f000) != if (((mbcp->mbox_out[0] & 0x0000f000) !=
MB_CMD_STS_GOOD) && MB_CMD_STS_GOOD) &&
((mbcp->mbox_out[0] & 0x0000f000) != ((mbcp->mbox_out[0] & 0x0000f000) !=
MB_CMD_STS_INTRMDT)) { MB_CMD_STS_INTRMDT)) {
status = -EIO; status = -EIO;
} }
end: end:
/* End polled mode for MPI */ /* End polled mode for MPI */
ql_write32(qdev, INTR_MASK, (INTR_MASK_PI << 16) | INTR_MASK_PI); qlge_write32(qdev, INTR_MASK, (INTR_MASK_PI << 16) | INTR_MASK_PI);
mutex_unlock(&qdev->mpi_mutex); mutex_unlock(&qdev->mpi_mutex);
return status; return status;
} }
...@@ -609,7 +609,7 @@ static int ql_mailbox_command(struct ql_adapter *qdev, struct mbox_params *mbcp) ...@@ -609,7 +609,7 @@ static int ql_mailbox_command(struct ql_adapter *qdev, struct mbox_params *mbcp)
* driver banner and for ethtool info. * driver banner and for ethtool info.
* Returns zero on success. * Returns zero on success.
*/ */
int ql_mb_about_fw(struct ql_adapter *qdev) int qlge_mb_about_fw(struct qlge_adapter *qdev)
{ {
struct mbox_params mbc; struct mbox_params mbc;
struct mbox_params *mbcp = &mbc; struct mbox_params *mbcp = &mbc;
...@@ -622,7 +622,7 @@ int ql_mb_about_fw(struct ql_adapter *qdev) ...@@ -622,7 +622,7 @@ int ql_mb_about_fw(struct ql_adapter *qdev)
mbcp->mbox_in[0] = MB_CMD_ABOUT_FW; mbcp->mbox_in[0] = MB_CMD_ABOUT_FW;
status = ql_mailbox_command(qdev, mbcp); status = qlge_mailbox_command(qdev, mbcp);
if (status) if (status)
return status; return status;
...@@ -641,7 +641,7 @@ int ql_mb_about_fw(struct ql_adapter *qdev) ...@@ -641,7 +641,7 @@ int ql_mb_about_fw(struct ql_adapter *qdev)
/* Get functional state for MPI firmware. /* Get functional state for MPI firmware.
* Returns zero on success. * Returns zero on success.
*/ */
int ql_mb_get_fw_state(struct ql_adapter *qdev) int qlge_mb_get_fw_state(struct qlge_adapter *qdev)
{ {
struct mbox_params mbc; struct mbox_params mbc;
struct mbox_params *mbcp = &mbc; struct mbox_params *mbcp = &mbc;
...@@ -654,7 +654,7 @@ int ql_mb_get_fw_state(struct ql_adapter *qdev) ...@@ -654,7 +654,7 @@ int ql_mb_get_fw_state(struct ql_adapter *qdev)
mbcp->mbox_in[0] = MB_CMD_GET_FW_STATE; mbcp->mbox_in[0] = MB_CMD_GET_FW_STATE;
status = ql_mailbox_command(qdev, mbcp); status = qlge_mailbox_command(qdev, mbcp);
if (status) if (status)
return status; return status;
...@@ -680,7 +680,7 @@ int ql_mb_get_fw_state(struct ql_adapter *qdev) ...@@ -680,7 +680,7 @@ int ql_mb_get_fw_state(struct ql_adapter *qdev)
/* Send and ACK mailbox command to the firmware to /* Send and ACK mailbox command to the firmware to
* let it continue with the change. * let it continue with the change.
*/ */
static int ql_mb_idc_ack(struct ql_adapter *qdev) static int qlge_mb_idc_ack(struct qlge_adapter *qdev)
{ {
struct mbox_params mbc; struct mbox_params mbc;
struct mbox_params *mbcp = &mbc; struct mbox_params *mbcp = &mbc;
...@@ -697,7 +697,7 @@ static int ql_mb_idc_ack(struct ql_adapter *qdev) ...@@ -697,7 +697,7 @@ static int ql_mb_idc_ack(struct ql_adapter *qdev)
mbcp->mbox_in[3] = qdev->idc_mbc.mbox_out[3]; mbcp->mbox_in[3] = qdev->idc_mbc.mbox_out[3];
mbcp->mbox_in[4] = qdev->idc_mbc.mbox_out[4]; mbcp->mbox_in[4] = qdev->idc_mbc.mbox_out[4];
status = ql_mailbox_command(qdev, mbcp); status = qlge_mailbox_command(qdev, mbcp);
if (status) if (status)
return status; return status;
...@@ -712,7 +712,7 @@ static int ql_mb_idc_ack(struct ql_adapter *qdev) ...@@ -712,7 +712,7 @@ static int ql_mb_idc_ack(struct ql_adapter *qdev)
* for the current port. * for the current port.
* Most likely will block. * Most likely will block.
*/ */
int ql_mb_set_port_cfg(struct ql_adapter *qdev) int qlge_mb_set_port_cfg(struct qlge_adapter *qdev)
{ {
struct mbox_params mbc; struct mbox_params mbc;
struct mbox_params *mbcp = &mbc; struct mbox_params *mbcp = &mbc;
...@@ -727,7 +727,7 @@ int ql_mb_set_port_cfg(struct ql_adapter *qdev) ...@@ -727,7 +727,7 @@ int ql_mb_set_port_cfg(struct ql_adapter *qdev)
mbcp->mbox_in[1] = qdev->link_config; mbcp->mbox_in[1] = qdev->link_config;
mbcp->mbox_in[2] = qdev->max_frame_size; mbcp->mbox_in[2] = qdev->max_frame_size;
status = ql_mailbox_command(qdev, mbcp); status = qlge_mailbox_command(qdev, mbcp);
if (status) if (status)
return status; return status;
...@@ -742,8 +742,8 @@ int ql_mb_set_port_cfg(struct ql_adapter *qdev) ...@@ -742,8 +742,8 @@ int ql_mb_set_port_cfg(struct ql_adapter *qdev)
return status; return status;
} }
static int ql_mb_dump_ram(struct ql_adapter *qdev, u64 req_dma, u32 addr, static int qlge_mb_dump_ram(struct qlge_adapter *qdev, u64 req_dma, u32 addr,
u32 size) u32 size)
{ {
int status = 0; int status = 0;
struct mbox_params mbc; struct mbox_params mbc;
...@@ -764,7 +764,7 @@ static int ql_mb_dump_ram(struct ql_adapter *qdev, u64 req_dma, u32 addr, ...@@ -764,7 +764,7 @@ static int ql_mb_dump_ram(struct ql_adapter *qdev, u64 req_dma, u32 addr,
mbcp->mbox_in[7] = LSW(MSD(req_dma)); mbcp->mbox_in[7] = LSW(MSD(req_dma));
mbcp->mbox_in[8] = MSW(addr); mbcp->mbox_in[8] = MSW(addr);
status = ql_mailbox_command(qdev, mbcp); status = qlge_mailbox_command(qdev, mbcp);
if (status) if (status)
return status; return status;
...@@ -776,8 +776,8 @@ static int ql_mb_dump_ram(struct ql_adapter *qdev, u64 req_dma, u32 addr, ...@@ -776,8 +776,8 @@ static int ql_mb_dump_ram(struct ql_adapter *qdev, u64 req_dma, u32 addr,
} }
/* Issue a mailbox command to dump RISC RAM. */ /* Issue a mailbox command to dump RISC RAM. */
int ql_dump_risc_ram_area(struct ql_adapter *qdev, void *buf, int qlge_dump_risc_ram_area(struct qlge_adapter *qdev, void *buf,
u32 ram_addr, int word_count) u32 ram_addr, int word_count)
{ {
int status; int status;
char *my_buf; char *my_buf;
...@@ -789,7 +789,7 @@ int ql_dump_risc_ram_area(struct ql_adapter *qdev, void *buf, ...@@ -789,7 +789,7 @@ int ql_dump_risc_ram_area(struct ql_adapter *qdev, void *buf,
if (!my_buf) if (!my_buf)
return -EIO; return -EIO;
status = ql_mb_dump_ram(qdev, buf_dma, ram_addr, word_count); status = qlge_mb_dump_ram(qdev, buf_dma, ram_addr, word_count);
if (!status) if (!status)
memcpy(buf, my_buf, word_count * sizeof(u32)); memcpy(buf, my_buf, word_count * sizeof(u32));
...@@ -802,7 +802,7 @@ int ql_dump_risc_ram_area(struct ql_adapter *qdev, void *buf, ...@@ -802,7 +802,7 @@ int ql_dump_risc_ram_area(struct ql_adapter *qdev, void *buf,
* for the current port. * for the current port.
* Most likely will block. * Most likely will block.
*/ */
int ql_mb_get_port_cfg(struct ql_adapter *qdev) int qlge_mb_get_port_cfg(struct qlge_adapter *qdev)
{ {
struct mbox_params mbc; struct mbox_params mbc;
struct mbox_params *mbcp = &mbc; struct mbox_params *mbcp = &mbc;
...@@ -815,7 +815,7 @@ int ql_mb_get_port_cfg(struct ql_adapter *qdev) ...@@ -815,7 +815,7 @@ int ql_mb_get_port_cfg(struct ql_adapter *qdev)
mbcp->mbox_in[0] = MB_CMD_GET_PORT_CFG; mbcp->mbox_in[0] = MB_CMD_GET_PORT_CFG;
status = ql_mailbox_command(qdev, mbcp); status = qlge_mailbox_command(qdev, mbcp);
if (status) if (status)
return status; return status;
...@@ -832,7 +832,7 @@ int ql_mb_get_port_cfg(struct ql_adapter *qdev) ...@@ -832,7 +832,7 @@ int ql_mb_get_port_cfg(struct ql_adapter *qdev)
return status; return status;
} }
int ql_mb_wol_mode(struct ql_adapter *qdev, u32 wol) int qlge_mb_wol_mode(struct qlge_adapter *qdev, u32 wol)
{ {
struct mbox_params mbc; struct mbox_params mbc;
struct mbox_params *mbcp = &mbc; struct mbox_params *mbcp = &mbc;
...@@ -846,7 +846,7 @@ int ql_mb_wol_mode(struct ql_adapter *qdev, u32 wol) ...@@ -846,7 +846,7 @@ int ql_mb_wol_mode(struct ql_adapter *qdev, u32 wol)
mbcp->mbox_in[0] = MB_CMD_SET_WOL_MODE; mbcp->mbox_in[0] = MB_CMD_SET_WOL_MODE;
mbcp->mbox_in[1] = wol; mbcp->mbox_in[1] = wol;
status = ql_mailbox_command(qdev, mbcp); status = qlge_mailbox_command(qdev, mbcp);
if (status) if (status)
return status; return status;
...@@ -857,7 +857,7 @@ int ql_mb_wol_mode(struct ql_adapter *qdev, u32 wol) ...@@ -857,7 +857,7 @@ int ql_mb_wol_mode(struct ql_adapter *qdev, u32 wol)
return status; return status;
} }
int ql_mb_wol_set_magic(struct ql_adapter *qdev, u32 enable_wol) int qlge_mb_wol_set_magic(struct qlge_adapter *qdev, u32 enable_wol)
{ {
struct mbox_params mbc; struct mbox_params mbc;
struct mbox_params *mbcp = &mbc; struct mbox_params *mbcp = &mbc;
...@@ -888,7 +888,7 @@ int ql_mb_wol_set_magic(struct ql_adapter *qdev, u32 enable_wol) ...@@ -888,7 +888,7 @@ int ql_mb_wol_set_magic(struct ql_adapter *qdev, u32 enable_wol)
mbcp->mbox_in[7] = 0; mbcp->mbox_in[7] = 0;
} }
status = ql_mailbox_command(qdev, mbcp); status = qlge_mailbox_command(qdev, mbcp);
if (status) if (status)
return status; return status;
...@@ -906,7 +906,7 @@ int ql_mb_wol_set_magic(struct ql_adapter *qdev, u32 enable_wol) ...@@ -906,7 +906,7 @@ int ql_mb_wol_set_magic(struct ql_adapter *qdev, u32 enable_wol)
* The firmware will complete the request if the other * The firmware will complete the request if the other
* function doesn't respond. * function doesn't respond.
*/ */
static int ql_idc_wait(struct ql_adapter *qdev) static int qlge_idc_wait(struct qlge_adapter *qdev)
{ {
int status = -ETIMEDOUT; int status = -ETIMEDOUT;
struct mbox_params *mbcp = &qdev->idc_mbc; struct mbox_params *mbcp = &qdev->idc_mbc;
...@@ -947,7 +947,7 @@ static int ql_idc_wait(struct ql_adapter *qdev) ...@@ -947,7 +947,7 @@ static int ql_idc_wait(struct ql_adapter *qdev)
return status; return status;
} }
int ql_mb_set_led_cfg(struct ql_adapter *qdev, u32 led_config) int qlge_mb_set_led_cfg(struct qlge_adapter *qdev, u32 led_config)
{ {
struct mbox_params mbc; struct mbox_params mbc;
struct mbox_params *mbcp = &mbc; struct mbox_params *mbcp = &mbc;
...@@ -961,7 +961,7 @@ int ql_mb_set_led_cfg(struct ql_adapter *qdev, u32 led_config) ...@@ -961,7 +961,7 @@ int ql_mb_set_led_cfg(struct ql_adapter *qdev, u32 led_config)
mbcp->mbox_in[0] = MB_CMD_SET_LED_CFG; mbcp->mbox_in[0] = MB_CMD_SET_LED_CFG;
mbcp->mbox_in[1] = led_config; mbcp->mbox_in[1] = led_config;
status = ql_mailbox_command(qdev, mbcp); status = qlge_mailbox_command(qdev, mbcp);
if (status) if (status)
return status; return status;
...@@ -974,7 +974,7 @@ int ql_mb_set_led_cfg(struct ql_adapter *qdev, u32 led_config) ...@@ -974,7 +974,7 @@ int ql_mb_set_led_cfg(struct ql_adapter *qdev, u32 led_config)
return status; return status;
} }
int ql_mb_get_led_cfg(struct ql_adapter *qdev) int qlge_mb_get_led_cfg(struct qlge_adapter *qdev)
{ {
struct mbox_params mbc; struct mbox_params mbc;
struct mbox_params *mbcp = &mbc; struct mbox_params *mbcp = &mbc;
...@@ -987,7 +987,7 @@ int ql_mb_get_led_cfg(struct ql_adapter *qdev) ...@@ -987,7 +987,7 @@ int ql_mb_get_led_cfg(struct ql_adapter *qdev)
mbcp->mbox_in[0] = MB_CMD_GET_LED_CFG; mbcp->mbox_in[0] = MB_CMD_GET_LED_CFG;
status = ql_mailbox_command(qdev, mbcp); status = qlge_mailbox_command(qdev, mbcp);
if (status) if (status)
return status; return status;
...@@ -1001,7 +1001,7 @@ int ql_mb_get_led_cfg(struct ql_adapter *qdev) ...@@ -1001,7 +1001,7 @@ int ql_mb_get_led_cfg(struct ql_adapter *qdev)
return status; return status;
} }
int ql_mb_set_mgmnt_traffic_ctl(struct ql_adapter *qdev, u32 control) int qlge_mb_set_mgmnt_traffic_ctl(struct qlge_adapter *qdev, u32 control)
{ {
struct mbox_params mbc; struct mbox_params mbc;
struct mbox_params *mbcp = &mbc; struct mbox_params *mbcp = &mbc;
...@@ -1015,7 +1015,7 @@ int ql_mb_set_mgmnt_traffic_ctl(struct ql_adapter *qdev, u32 control) ...@@ -1015,7 +1015,7 @@ int ql_mb_set_mgmnt_traffic_ctl(struct ql_adapter *qdev, u32 control)
mbcp->mbox_in[0] = MB_CMD_SET_MGMNT_TFK_CTL; mbcp->mbox_in[0] = MB_CMD_SET_MGMNT_TFK_CTL;
mbcp->mbox_in[1] = control; mbcp->mbox_in[1] = control;
status = ql_mailbox_command(qdev, mbcp); status = qlge_mailbox_command(qdev, mbcp);
if (status) if (status)
return status; return status;
...@@ -1038,7 +1038,7 @@ int ql_mb_set_mgmnt_traffic_ctl(struct ql_adapter *qdev, u32 control) ...@@ -1038,7 +1038,7 @@ int ql_mb_set_mgmnt_traffic_ctl(struct ql_adapter *qdev, u32 control)
} }
/* Returns a negative error code or the mailbox command status. */ /* Returns a negative error code or the mailbox command status. */
static int ql_mb_get_mgmnt_traffic_ctl(struct ql_adapter *qdev, u32 *control) static int qlge_mb_get_mgmnt_traffic_ctl(struct qlge_adapter *qdev, u32 *control)
{ {
struct mbox_params mbc; struct mbox_params mbc;
struct mbox_params *mbcp = &mbc; struct mbox_params *mbcp = &mbc;
...@@ -1052,7 +1052,7 @@ static int ql_mb_get_mgmnt_traffic_ctl(struct ql_adapter *qdev, u32 *control) ...@@ -1052,7 +1052,7 @@ static int ql_mb_get_mgmnt_traffic_ctl(struct ql_adapter *qdev, u32 *control)
mbcp->mbox_in[0] = MB_CMD_GET_MGMNT_TFK_CTL; mbcp->mbox_in[0] = MB_CMD_GET_MGMNT_TFK_CTL;
status = ql_mailbox_command(qdev, mbcp); status = qlge_mailbox_command(qdev, mbcp);
if (status) if (status)
return status; return status;
...@@ -1073,15 +1073,15 @@ static int ql_mb_get_mgmnt_traffic_ctl(struct ql_adapter *qdev, u32 *control) ...@@ -1073,15 +1073,15 @@ static int ql_mb_get_mgmnt_traffic_ctl(struct ql_adapter *qdev, u32 *control)
return status; return status;
} }
int ql_wait_fifo_empty(struct ql_adapter *qdev) int qlge_wait_fifo_empty(struct qlge_adapter *qdev)
{ {
int count; int count;
u32 mgmnt_fifo_empty; u32 mgmnt_fifo_empty;
u32 nic_fifo_empty; u32 nic_fifo_empty;
for (count = 6; count; count--) { for (count = 6; count; count--) {
nic_fifo_empty = ql_read32(qdev, STS) & STS_NFE; nic_fifo_empty = qlge_read32(qdev, STS) & STS_NFE;
ql_mb_get_mgmnt_traffic_ctl(qdev, &mgmnt_fifo_empty); qlge_mb_get_mgmnt_traffic_ctl(qdev, &mgmnt_fifo_empty);
mgmnt_fifo_empty &= MB_GET_MPI_TFK_FIFO_EMPTY; mgmnt_fifo_empty &= MB_GET_MPI_TFK_FIFO_EMPTY;
if (nic_fifo_empty && mgmnt_fifo_empty) if (nic_fifo_empty && mgmnt_fifo_empty)
return 0; return 0;
...@@ -1093,14 +1093,14 @@ int ql_wait_fifo_empty(struct ql_adapter *qdev) ...@@ -1093,14 +1093,14 @@ int ql_wait_fifo_empty(struct ql_adapter *qdev)
/* API called in work thread context to set new TX/RX /* API called in work thread context to set new TX/RX
* maximum frame size values to match MTU. * maximum frame size values to match MTU.
*/ */
static int ql_set_port_cfg(struct ql_adapter *qdev) static int qlge_set_port_cfg(struct qlge_adapter *qdev)
{ {
int status; int status;
status = ql_mb_set_port_cfg(qdev); status = qlge_mb_set_port_cfg(qdev);
if (status) if (status)
return status; return status;
status = ql_idc_wait(qdev); status = qlge_idc_wait(qdev);
return status; return status;
} }
...@@ -1112,13 +1112,13 @@ static int ql_set_port_cfg(struct ql_adapter *qdev) ...@@ -1112,13 +1112,13 @@ static int ql_set_port_cfg(struct ql_adapter *qdev)
* from the firmware and, if necessary, changes them to match * from the firmware and, if necessary, changes them to match
* the MTU setting. * the MTU setting.
*/ */
void ql_mpi_port_cfg_work(struct work_struct *work) void qlge_mpi_port_cfg_work(struct work_struct *work)
{ {
struct ql_adapter *qdev = struct qlge_adapter *qdev =
container_of(work, struct ql_adapter, mpi_port_cfg_work.work); container_of(work, struct qlge_adapter, mpi_port_cfg_work.work);
int status; int status;
status = ql_mb_get_port_cfg(qdev); status = qlge_mb_get_port_cfg(qdev);
if (status) { if (status) {
netif_err(qdev, drv, qdev->ndev, netif_err(qdev, drv, qdev->ndev,
"Bug: Failed to get port config data.\n"); "Bug: Failed to get port config data.\n");
...@@ -1131,7 +1131,7 @@ void ql_mpi_port_cfg_work(struct work_struct *work) ...@@ -1131,7 +1131,7 @@ void ql_mpi_port_cfg_work(struct work_struct *work)
qdev->link_config |= CFG_JUMBO_FRAME_SIZE; qdev->link_config |= CFG_JUMBO_FRAME_SIZE;
qdev->max_frame_size = CFG_DEFAULT_MAX_FRAME_SIZE; qdev->max_frame_size = CFG_DEFAULT_MAX_FRAME_SIZE;
status = ql_set_port_cfg(qdev); status = qlge_set_port_cfg(qdev);
if (status) { if (status) {
netif_err(qdev, drv, qdev->ndev, netif_err(qdev, drv, qdev->ndev,
"Bug: Failed to set port config data.\n"); "Bug: Failed to set port config data.\n");
...@@ -1141,7 +1141,7 @@ void ql_mpi_port_cfg_work(struct work_struct *work) ...@@ -1141,7 +1141,7 @@ void ql_mpi_port_cfg_work(struct work_struct *work)
clear_bit(QL_PORT_CFG, &qdev->flags); clear_bit(QL_PORT_CFG, &qdev->flags);
return; return;
err: err:
ql_queue_fw_error(qdev); qlge_queue_fw_error(qdev);
goto end; goto end;
} }
...@@ -1151,10 +1151,10 @@ void ql_mpi_port_cfg_work(struct work_struct *work) ...@@ -1151,10 +1151,10 @@ void ql_mpi_port_cfg_work(struct work_struct *work)
* has been made and then send a mailbox command ACKing * has been made and then send a mailbox command ACKing
* the change request. * the change request.
*/ */
void ql_mpi_idc_work(struct work_struct *work) void qlge_mpi_idc_work(struct work_struct *work)
{ {
struct ql_adapter *qdev = struct qlge_adapter *qdev =
container_of(work, struct ql_adapter, mpi_idc_work.work); container_of(work, struct qlge_adapter, mpi_idc_work.work);
int status; int status;
struct mbox_params *mbcp = &qdev->idc_mbc; struct mbox_params *mbcp = &qdev->idc_mbc;
u32 aen; u32 aen;
...@@ -1170,7 +1170,7 @@ void ql_mpi_idc_work(struct work_struct *work) ...@@ -1170,7 +1170,7 @@ void ql_mpi_idc_work(struct work_struct *work)
break; break;
case MB_CMD_PORT_RESET: case MB_CMD_PORT_RESET:
case MB_CMD_STOP_FW: case MB_CMD_STOP_FW:
ql_link_off(qdev); qlge_link_off(qdev);
fallthrough; fallthrough;
case MB_CMD_SET_PORT_CFG: case MB_CMD_SET_PORT_CFG:
/* Signal the resulting link up AEN /* Signal the resulting link up AEN
...@@ -1180,7 +1180,7 @@ void ql_mpi_idc_work(struct work_struct *work) ...@@ -1180,7 +1180,7 @@ void ql_mpi_idc_work(struct work_struct *work)
set_bit(QL_CAM_RT_SET, &qdev->flags); set_bit(QL_CAM_RT_SET, &qdev->flags);
/* Do ACK if required */ /* Do ACK if required */
if (timeout) { if (timeout) {
status = ql_mb_idc_ack(qdev); status = qlge_mb_idc_ack(qdev);
if (status) if (status)
netif_err(qdev, drv, qdev->ndev, netif_err(qdev, drv, qdev->ndev,
"Bug: No pending IDC!\n"); "Bug: No pending IDC!\n");
...@@ -1191,18 +1191,18 @@ void ql_mpi_idc_work(struct work_struct *work) ...@@ -1191,18 +1191,18 @@ void ql_mpi_idc_work(struct work_struct *work)
} }
break; break;
/* These sub-commands issued by another (FCoE) /* These sub-commands issued by another (FCoE)
* function are requesting to do an operation * function are requesting to do an operation
* on the shared resource (MPI environment). * on the shared resource (MPI environment).
* We currently don't issue these so we just * We currently don't issue these so we just
* ACK the request. * ACK the request.
*/ */
case MB_CMD_IOP_RESTART_MPI: case MB_CMD_IOP_RESTART_MPI:
case MB_CMD_IOP_PREP_LINK_DOWN: case MB_CMD_IOP_PREP_LINK_DOWN:
/* Drop the link, reload the routing /* Drop the link, reload the routing
* table when link comes up. * table when link comes up.
*/ */
ql_link_off(qdev); qlge_link_off(qdev);
set_bit(QL_CAM_RT_SET, &qdev->flags); set_bit(QL_CAM_RT_SET, &qdev->flags);
fallthrough; fallthrough;
case MB_CMD_IOP_DVR_START: case MB_CMD_IOP_DVR_START:
...@@ -1213,7 +1213,7 @@ void ql_mpi_idc_work(struct work_struct *work) ...@@ -1213,7 +1213,7 @@ void ql_mpi_idc_work(struct work_struct *work)
case MB_CMD_IOP_NONE: /* an IDC without params */ case MB_CMD_IOP_NONE: /* an IDC without params */
/* Do ACK if required */ /* Do ACK if required */
if (timeout) { if (timeout) {
status = ql_mb_idc_ack(qdev); status = qlge_mb_idc_ack(qdev);
if (status) if (status)
netif_err(qdev, drv, qdev->ndev, netif_err(qdev, drv, qdev->ndev,
"Bug: No pending IDC!\n"); "Bug: No pending IDC!\n");
...@@ -1226,54 +1226,54 @@ void ql_mpi_idc_work(struct work_struct *work) ...@@ -1226,54 +1226,54 @@ void ql_mpi_idc_work(struct work_struct *work)
} }
} }
void ql_mpi_work(struct work_struct *work) void qlge_mpi_work(struct work_struct *work)
{ {
struct ql_adapter *qdev = struct qlge_adapter *qdev =
container_of(work, struct ql_adapter, mpi_work.work); container_of(work, struct qlge_adapter, mpi_work.work);
struct mbox_params mbc; struct mbox_params mbc;
struct mbox_params *mbcp = &mbc; struct mbox_params *mbcp = &mbc;
int err = 0; int err = 0;
mutex_lock(&qdev->mpi_mutex); mutex_lock(&qdev->mpi_mutex);
/* Begin polled mode for MPI */ /* Begin polled mode for MPI */
ql_write32(qdev, INTR_MASK, (INTR_MASK_PI << 16)); qlge_write32(qdev, INTR_MASK, (INTR_MASK_PI << 16));
while (ql_read32(qdev, STS) & STS_PI) { while (qlge_read32(qdev, STS) & STS_PI) {
memset(mbcp, 0, sizeof(struct mbox_params)); memset(mbcp, 0, sizeof(struct mbox_params));
mbcp->out_count = 1; mbcp->out_count = 1;
/* Don't continue if an async event /* Don't continue if an async event
* did not complete properly. * did not complete properly.
*/ */
err = ql_mpi_handler(qdev, mbcp); err = qlge_mpi_handler(qdev, mbcp);
if (err) if (err)
break; break;
} }
/* End polled mode for MPI */ /* End polled mode for MPI */
ql_write32(qdev, INTR_MASK, (INTR_MASK_PI << 16) | INTR_MASK_PI); qlge_write32(qdev, INTR_MASK, (INTR_MASK_PI << 16) | INTR_MASK_PI);
mutex_unlock(&qdev->mpi_mutex); mutex_unlock(&qdev->mpi_mutex);
} }
void ql_mpi_reset_work(struct work_struct *work) void qlge_mpi_reset_work(struct work_struct *work)
{ {
struct ql_adapter *qdev = struct qlge_adapter *qdev =
container_of(work, struct ql_adapter, mpi_reset_work.work); container_of(work, struct qlge_adapter, mpi_reset_work.work);
cancel_delayed_work_sync(&qdev->mpi_work); cancel_delayed_work_sync(&qdev->mpi_work);
cancel_delayed_work_sync(&qdev->mpi_port_cfg_work); cancel_delayed_work_sync(&qdev->mpi_port_cfg_work);
cancel_delayed_work_sync(&qdev->mpi_idc_work); cancel_delayed_work_sync(&qdev->mpi_idc_work);
/* If we're not the dominant NIC function, /* If we're not the dominant NIC function,
* then there is nothing to do. * then there is nothing to do.
*/ */
if (!ql_own_firmware(qdev)) { if (!qlge_own_firmware(qdev)) {
netif_err(qdev, drv, qdev->ndev, "Don't own firmware!\n"); netif_err(qdev, drv, qdev->ndev, "Don't own firmware!\n");
return; return;
} }
if (qdev->mpi_coredump && !ql_core_dump(qdev, qdev->mpi_coredump)) { if (qdev->mpi_coredump && !qlge_core_dump(qdev, qdev->mpi_coredump)) {
netif_err(qdev, drv, qdev->ndev, "Core is dumped!\n"); netif_err(qdev, drv, qdev->ndev, "Core is dumped!\n");
qdev->core_is_dumped = 1; qdev->core_is_dumped = 1;
queue_delayed_work(qdev->workqueue, queue_delayed_work(qdev->workqueue,
&qdev->mpi_core_to_log, 5 * HZ); &qdev->mpi_core_to_log, 5 * HZ);
} }
ql_soft_reset_mpi_risc(qdev); qlge_soft_reset_mpi_risc(qdev);
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment