xref: /OK3568_Linux_fs/kernel/drivers/net/ethernet/broadcom/bnxt/bnxt_ethtool.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
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