1*4882a593Smuzhiyun /* Broadcom NetXtreme-C/E network driver. 2*4882a593Smuzhiyun * 3*4882a593Smuzhiyun * Copyright (c) 2014-2016 Broadcom Corporation 4*4882a593Smuzhiyun * Copyright (c) 2016-2017 Broadcom Limited 5*4882a593Smuzhiyun * 6*4882a593Smuzhiyun * This program is free software; you can redistribute it and/or modify 7*4882a593Smuzhiyun * it under the terms of the GNU General Public License as published by 8*4882a593Smuzhiyun * the Free Software Foundation. 9*4882a593Smuzhiyun */ 10*4882a593Smuzhiyun 11*4882a593Smuzhiyun #ifndef BNXT_ETHTOOL_H 12*4882a593Smuzhiyun #define BNXT_ETHTOOL_H 13*4882a593Smuzhiyun 14*4882a593Smuzhiyun struct bnxt_led_cfg { 15*4882a593Smuzhiyun u8 led_id; 16*4882a593Smuzhiyun u8 led_state; 17*4882a593Smuzhiyun u8 led_color; 18*4882a593Smuzhiyun u8 unused; 19*4882a593Smuzhiyun __le16 led_blink_on; 20*4882a593Smuzhiyun __le16 led_blink_off; 21*4882a593Smuzhiyun u8 led_group_id; 22*4882a593Smuzhiyun u8 rsvd; 23*4882a593Smuzhiyun }; 24*4882a593Smuzhiyun 25*4882a593Smuzhiyun #define COREDUMP_LIST_BUF_LEN 2048 26*4882a593Smuzhiyun #define COREDUMP_RETRIEVE_BUF_LEN 4096 27*4882a593Smuzhiyun 28*4882a593Smuzhiyun struct bnxt_coredump { 29*4882a593Smuzhiyun void *data; 30*4882a593Smuzhiyun int data_size; 31*4882a593Smuzhiyun u16 total_segs; 32*4882a593Smuzhiyun }; 33*4882a593Smuzhiyun 34*4882a593Smuzhiyun #define BNXT_COREDUMP_BUF_LEN(len) ((len) - sizeof(struct bnxt_coredump_record)) 35*4882a593Smuzhiyun 36*4882a593Smuzhiyun struct bnxt_hwrm_dbg_dma_info { 37*4882a593Smuzhiyun void *dest_buf; 38*4882a593Smuzhiyun int dest_buf_size; 39*4882a593Smuzhiyun u16 dma_len; 40*4882a593Smuzhiyun u16 seq_off; 41*4882a593Smuzhiyun u16 data_len_off; 42*4882a593Smuzhiyun u16 segs; 43*4882a593Smuzhiyun u32 seg_start; 44*4882a593Smuzhiyun u32 buf_len; 45*4882a593Smuzhiyun }; 46*4882a593Smuzhiyun 47*4882a593Smuzhiyun struct hwrm_dbg_cmn_input { 48*4882a593Smuzhiyun __le16 req_type; 49*4882a593Smuzhiyun __le16 cmpl_ring; 50*4882a593Smuzhiyun __le16 seq_id; 51*4882a593Smuzhiyun __le16 target_id; 52*4882a593Smuzhiyun __le64 resp_addr; 53*4882a593Smuzhiyun __le64 host_dest_addr; 54*4882a593Smuzhiyun __le32 host_buf_len; 55*4882a593Smuzhiyun }; 56*4882a593Smuzhiyun 57*4882a593Smuzhiyun struct hwrm_dbg_cmn_output { 58*4882a593Smuzhiyun __le16 error_code; 59*4882a593Smuzhiyun __le16 req_type; 60*4882a593Smuzhiyun __le16 seq_id; 61*4882a593Smuzhiyun __le16 resp_len; 62*4882a593Smuzhiyun u8 flags; 63*4882a593Smuzhiyun #define HWRM_DBG_CMN_FLAGS_MORE 1 64*4882a593Smuzhiyun }; 65*4882a593Smuzhiyun 66*4882a593Smuzhiyun #define BNXT_CRASH_DUMP_LEN (8 << 20) 67*4882a593Smuzhiyun 68*4882a593Smuzhiyun #define BNXT_LED_DFLT_ENA \ 69*4882a593Smuzhiyun (PORT_LED_CFG_REQ_ENABLES_LED0_ID | \ 70*4882a593Smuzhiyun PORT_LED_CFG_REQ_ENABLES_LED0_STATE | \ 71*4882a593Smuzhiyun PORT_LED_CFG_REQ_ENABLES_LED0_BLINK_ON | \ 72*4882a593Smuzhiyun PORT_LED_CFG_REQ_ENABLES_LED0_BLINK_OFF | \ 73*4882a593Smuzhiyun PORT_LED_CFG_REQ_ENABLES_LED0_GROUP_ID) 74*4882a593Smuzhiyun 75*4882a593Smuzhiyun #define BNXT_LED_DFLT_ENA_SHIFT 6 76*4882a593Smuzhiyun 77*4882a593Smuzhiyun #define BNXT_LED_DFLT_ENABLES(x) \ 78*4882a593Smuzhiyun cpu_to_le32(BNXT_LED_DFLT_ENA << (BNXT_LED_DFLT_ENA_SHIFT * (x))) 79*4882a593Smuzhiyun 80*4882a593Smuzhiyun #define BNXT_FW_RESET_AP (ETH_RESET_AP << ETH_RESET_SHARED_SHIFT) 81*4882a593Smuzhiyun #define BNXT_FW_RESET_CHIP ((ETH_RESET_MGMT | ETH_RESET_IRQ | \ 82*4882a593Smuzhiyun ETH_RESET_DMA | ETH_RESET_FILTER | \ 83*4882a593Smuzhiyun ETH_RESET_OFFLOAD | ETH_RESET_MAC | \ 84*4882a593Smuzhiyun ETH_RESET_PHY | ETH_RESET_RAM) \ 85*4882a593Smuzhiyun << ETH_RESET_SHARED_SHIFT) 86*4882a593Smuzhiyun 87*4882a593Smuzhiyun #define BNXT_PXP_REG_LEN 0x3110 88*4882a593Smuzhiyun 89*4882a593Smuzhiyun extern const struct ethtool_ops bnxt_ethtool_ops; 90*4882a593Smuzhiyun 91*4882a593Smuzhiyun u32 bnxt_get_rxfh_indir_size(struct net_device *dev); 92*4882a593Smuzhiyun u32 _bnxt_fw_to_ethtool_adv_spds(u16, u8); 93*4882a593Smuzhiyun u32 bnxt_fw_to_ethtool_speed(u16); 94*4882a593Smuzhiyun u16 bnxt_get_fw_auto_link_speeds(u32); 95*4882a593Smuzhiyun int bnxt_hwrm_nvm_get_dev_info(struct bnxt *bp, 96*4882a593Smuzhiyun struct hwrm_nvm_get_dev_info_output *nvm_dev_info); 97*4882a593Smuzhiyun int bnxt_flash_package_from_file(struct net_device *dev, const char *filename, 98*4882a593Smuzhiyun u32 install_type); 99*4882a593Smuzhiyun void bnxt_ethtool_init(struct bnxt *bp); 100*4882a593Smuzhiyun void bnxt_ethtool_free(struct bnxt *bp); 101*4882a593Smuzhiyun 102*4882a593Smuzhiyun #endif 103