xref: /openbmc/linux/drivers/net/ethernet/wangxun/ngbe/ngbe_hw.c (revision ac73d4bf2cdaf2cb8a43df8ee4a5c066d2c5d7b4)
1 // SPDX-License-Identifier: GPL-2.0
2 /* Copyright (c) 2019 - 2022 Beijing WangXun Technology Co., Ltd. */
3 
4 #include <linux/etherdevice.h>
5 #include <linux/iopoll.h>
6 #include <linux/pci.h>
7 
8 #include "../libwx/wx_type.h"
9 #include "../libwx/wx_hw.h"
10 #include "ngbe_type.h"
11 #include "ngbe_hw.h"
12 #include "ngbe.h"
13 
14 int ngbe_eeprom_chksum_hostif(struct ngbe_hw *hw)
15 {
16 	struct wx_hic_read_shadow_ram buffer;
17 	struct wx_hw *wxhw = &hw->wxhw;
18 	int status;
19 	int tmp;
20 
21 	buffer.hdr.req.cmd = NGBE_FW_EEPROM_CHECKSUM_CMD;
22 	buffer.hdr.req.buf_lenh = 0;
23 	buffer.hdr.req.buf_lenl = 0;
24 	buffer.hdr.req.checksum = NGBE_FW_CMD_DEFAULT_CHECKSUM;
25 	/* convert offset from words to bytes */
26 	buffer.address = 0;
27 	/* one word */
28 	buffer.length = 0;
29 
30 	status = wx_host_interface_command(wxhw, (u32 *)&buffer, sizeof(buffer),
31 					   WX_HI_COMMAND_TIMEOUT, false);
32 
33 	if (status < 0)
34 		return status;
35 	tmp = rd32a(wxhw, WX_MNG_MBOX, 1);
36 	if (tmp == NGBE_FW_CMD_ST_PASS)
37 		return 0;
38 	return -EIO;
39 }
40 
41 static int ngbe_reset_misc(struct ngbe_hw *hw)
42 {
43 	struct wx_hw *wxhw = &hw->wxhw;
44 
45 	wx_reset_misc(wxhw);
46 	if (hw->mac_type == ngbe_mac_type_rgmii)
47 		wr32(wxhw, NGBE_MDIO_CLAUSE_SELECT, 0xF);
48 	if (hw->gpio_ctrl) {
49 		/* gpio0 is used to power on/off control*/
50 		wr32(wxhw, NGBE_GPIO_DDR, 0x1);
51 		wr32(wxhw, NGBE_GPIO_DR, NGBE_GPIO_DR_0);
52 	}
53 	return 0;
54 }
55 
56 /**
57  *  ngbe_reset_hw - Perform hardware reset
58  *  @hw: pointer to hardware structure
59  *
60  *  Resets the hardware by resetting the transmit and receive units, masks
61  *  and clears all interrupts, perform a PHY reset, and perform a link (MAC)
62  *  reset.
63  **/
64 int ngbe_reset_hw(struct ngbe_hw *hw)
65 {
66 	struct wx_hw *wxhw = &hw->wxhw;
67 	int status = 0;
68 	u32 reset = 0;
69 
70 	/* Call adapter stop to disable tx/rx and clear interrupts */
71 	status = wx_stop_adapter(wxhw);
72 	if (status != 0)
73 		return status;
74 	reset = WX_MIS_RST_LAN_RST(wxhw->bus.func);
75 	wr32(wxhw, WX_MIS_RST, reset | rd32(wxhw, WX_MIS_RST));
76 	ngbe_reset_misc(hw);
77 
78 	/* Store the permanent mac address */
79 	wx_get_mac_addr(wxhw, wxhw->mac.perm_addr);
80 
81 	/* reset num_rar_entries to 128 */
82 	wxhw->mac.num_rar_entries = NGBE_RAR_ENTRIES;
83 	wx_init_rx_addrs(wxhw);
84 	pci_set_master(wxhw->pdev);
85 
86 	return 0;
87 }
88