xref: /linux/drivers/net/ethernet/huawei/hinic3/hinic3_netdev_ops.c (revision ab93e0dd72c37d378dd936f031ffb83ff2bd87ce)
1*17fcb3dcSFan Gong // SPDX-License-Identifier: GPL-2.0
2*17fcb3dcSFan Gong // Copyright (c) Huawei Technologies Co., Ltd. 2025. All rights reserved.
3*17fcb3dcSFan Gong 
4*17fcb3dcSFan Gong #include <linux/etherdevice.h>
5*17fcb3dcSFan Gong #include <linux/netdevice.h>
6*17fcb3dcSFan Gong 
7*17fcb3dcSFan Gong #include "hinic3_hwif.h"
8*17fcb3dcSFan Gong #include "hinic3_nic_cfg.h"
9*17fcb3dcSFan Gong #include "hinic3_nic_dev.h"
10*17fcb3dcSFan Gong #include "hinic3_nic_io.h"
11*17fcb3dcSFan Gong #include "hinic3_rx.h"
12*17fcb3dcSFan Gong #include "hinic3_tx.h"
13*17fcb3dcSFan Gong 
hinic3_open(struct net_device * netdev)14*17fcb3dcSFan Gong static int hinic3_open(struct net_device *netdev)
15*17fcb3dcSFan Gong {
16*17fcb3dcSFan Gong 	/* Completed by later submission due to LoC limit. */
17*17fcb3dcSFan Gong 	return -EFAULT;
18*17fcb3dcSFan Gong }
19*17fcb3dcSFan Gong 
hinic3_close(struct net_device * netdev)20*17fcb3dcSFan Gong static int hinic3_close(struct net_device *netdev)
21*17fcb3dcSFan Gong {
22*17fcb3dcSFan Gong 	/* Completed by later submission due to LoC limit. */
23*17fcb3dcSFan Gong 	return -EFAULT;
24*17fcb3dcSFan Gong }
25*17fcb3dcSFan Gong 
hinic3_change_mtu(struct net_device * netdev,int new_mtu)26*17fcb3dcSFan Gong static int hinic3_change_mtu(struct net_device *netdev, int new_mtu)
27*17fcb3dcSFan Gong {
28*17fcb3dcSFan Gong 	int err;
29*17fcb3dcSFan Gong 
30*17fcb3dcSFan Gong 	err = hinic3_set_port_mtu(netdev, new_mtu);
31*17fcb3dcSFan Gong 	if (err) {
32*17fcb3dcSFan Gong 		netdev_err(netdev, "Failed to change port mtu to %d\n",
33*17fcb3dcSFan Gong 			   new_mtu);
34*17fcb3dcSFan Gong 		return err;
35*17fcb3dcSFan Gong 	}
36*17fcb3dcSFan Gong 
37*17fcb3dcSFan Gong 	netdev_dbg(netdev, "Change mtu from %u to %d\n", netdev->mtu, new_mtu);
38*17fcb3dcSFan Gong 	WRITE_ONCE(netdev->mtu, new_mtu);
39*17fcb3dcSFan Gong 
40*17fcb3dcSFan Gong 	return 0;
41*17fcb3dcSFan Gong }
42*17fcb3dcSFan Gong 
hinic3_set_mac_addr(struct net_device * netdev,void * addr)43*17fcb3dcSFan Gong static int hinic3_set_mac_addr(struct net_device *netdev, void *addr)
44*17fcb3dcSFan Gong {
45*17fcb3dcSFan Gong 	struct hinic3_nic_dev *nic_dev = netdev_priv(netdev);
46*17fcb3dcSFan Gong 	struct sockaddr *saddr = addr;
47*17fcb3dcSFan Gong 	int err;
48*17fcb3dcSFan Gong 
49*17fcb3dcSFan Gong 	if (!is_valid_ether_addr(saddr->sa_data))
50*17fcb3dcSFan Gong 		return -EADDRNOTAVAIL;
51*17fcb3dcSFan Gong 
52*17fcb3dcSFan Gong 	if (ether_addr_equal(netdev->dev_addr, saddr->sa_data))
53*17fcb3dcSFan Gong 		return 0;
54*17fcb3dcSFan Gong 
55*17fcb3dcSFan Gong 	err = hinic3_update_mac(nic_dev->hwdev, netdev->dev_addr,
56*17fcb3dcSFan Gong 				saddr->sa_data, 0,
57*17fcb3dcSFan Gong 				hinic3_global_func_id(nic_dev->hwdev));
58*17fcb3dcSFan Gong 
59*17fcb3dcSFan Gong 	if (err)
60*17fcb3dcSFan Gong 		return err;
61*17fcb3dcSFan Gong 
62*17fcb3dcSFan Gong 	eth_hw_addr_set(netdev, saddr->sa_data);
63*17fcb3dcSFan Gong 
64*17fcb3dcSFan Gong 	return 0;
65*17fcb3dcSFan Gong }
66*17fcb3dcSFan Gong 
67*17fcb3dcSFan Gong static const struct net_device_ops hinic3_netdev_ops = {
68*17fcb3dcSFan Gong 	.ndo_open             = hinic3_open,
69*17fcb3dcSFan Gong 	.ndo_stop             = hinic3_close,
70*17fcb3dcSFan Gong 	.ndo_change_mtu       = hinic3_change_mtu,
71*17fcb3dcSFan Gong 	.ndo_set_mac_address  = hinic3_set_mac_addr,
72*17fcb3dcSFan Gong 	.ndo_start_xmit       = hinic3_xmit_frame,
73*17fcb3dcSFan Gong };
74*17fcb3dcSFan Gong 
hinic3_set_netdev_ops(struct net_device * netdev)75*17fcb3dcSFan Gong void hinic3_set_netdev_ops(struct net_device *netdev)
76*17fcb3dcSFan Gong {
77*17fcb3dcSFan Gong 	netdev->netdev_ops = &hinic3_netdev_ops;
78*17fcb3dcSFan Gong }
79