Thread (12 messages) 12 messages, 5 authors, 2021-10-11

Re: [PATCH net-next 1/5] ethernet: forcedeth: remove direct netdev->dev_addr writes

From: Zhu Yanjun <zyjzyj2000@gmail.com>
Date: 2021-10-09 02:22:44

On Sat, Oct 9, 2021 at 1:59 AM Jakub Kicinski [off-list ref] wrote:
forcedeth writes to dev_addr byte by byte, make it use
a local buffer instead. Commit the changes with
eth_hw_addr_set() at the end.

Signed-off-by: Jakub Kicinski <kuba@kernel.org>
---
CC: Rain River <rain.1986.08.12@gmail.com>
CC: Zhu Yanjun <zyjzyj2000@gmail.com>
Thanks & Regards.

Reviewed-by: Zhu Yanjun <zyjzyj2000@gmail.com>

Zhu Yanjun
quoted hunk ↗ jump to hunk
---
 drivers/net/ethernet/nvidia/forcedeth.c | 49 +++++++++++++------------
 1 file changed, 26 insertions(+), 23 deletions(-)
diff --git a/drivers/net/ethernet/nvidia/forcedeth.c b/drivers/net/ethernet/nvidia/forcedeth.c
index 3f269f914dac..9b530d7509a4 100644
--- a/drivers/net/ethernet/nvidia/forcedeth.c
+++ b/drivers/net/ethernet/nvidia/forcedeth.c
@@ -5711,6 +5711,7 @@ static int nv_probe(struct pci_dev *pci_dev, const struct pci_device_id *id)
        u32 phystate_orig = 0, phystate;
        int phyinitialized = 0;
        static int printed_version;
+       u8 mac[ETH_ALEN];

        if (!printed_version++)
                pr_info("Reverse Engineered nForce ethernet driver. Version %s.\n",
@@ -5884,50 +5885,52 @@ static int nv_probe(struct pci_dev *pci_dev, const struct pci_device_id *id)
        txreg = readl(base + NvRegTransmitPoll);
        if (id->driver_data & DEV_HAS_CORRECT_MACADDR) {
                /* mac address is already in correct order */
-               dev->dev_addr[0] = (np->orig_mac[0] >>  0) & 0xff;
-               dev->dev_addr[1] = (np->orig_mac[0] >>  8) & 0xff;
-               dev->dev_addr[2] = (np->orig_mac[0] >> 16) & 0xff;
-               dev->dev_addr[3] = (np->orig_mac[0] >> 24) & 0xff;
-               dev->dev_addr[4] = (np->orig_mac[1] >>  0) & 0xff;
-               dev->dev_addr[5] = (np->orig_mac[1] >>  8) & 0xff;
+               mac[0] = (np->orig_mac[0] >>  0) & 0xff;
+               mac[1] = (np->orig_mac[0] >>  8) & 0xff;
+               mac[2] = (np->orig_mac[0] >> 16) & 0xff;
+               mac[3] = (np->orig_mac[0] >> 24) & 0xff;
+               mac[4] = (np->orig_mac[1] >>  0) & 0xff;
+               mac[5] = (np->orig_mac[1] >>  8) & 0xff;
        } else if (txreg & NVREG_TRANSMITPOLL_MAC_ADDR_REV) {
                /* mac address is already in correct order */
-               dev->dev_addr[0] = (np->orig_mac[0] >>  0) & 0xff;
-               dev->dev_addr[1] = (np->orig_mac[0] >>  8) & 0xff;
-               dev->dev_addr[2] = (np->orig_mac[0] >> 16) & 0xff;
-               dev->dev_addr[3] = (np->orig_mac[0] >> 24) & 0xff;
-               dev->dev_addr[4] = (np->orig_mac[1] >>  0) & 0xff;
-               dev->dev_addr[5] = (np->orig_mac[1] >>  8) & 0xff;
+               mac[0] = (np->orig_mac[0] >>  0) & 0xff;
+               mac[1] = (np->orig_mac[0] >>  8) & 0xff;
+               mac[2] = (np->orig_mac[0] >> 16) & 0xff;
+               mac[3] = (np->orig_mac[0] >> 24) & 0xff;
+               mac[4] = (np->orig_mac[1] >>  0) & 0xff;
+               mac[5] = (np->orig_mac[1] >>  8) & 0xff;
                /*
                 * Set orig mac address back to the reversed version.
                 * This flag will be cleared during low power transition.
                 * Therefore, we should always put back the reversed address.
                 */
-               np->orig_mac[0] = (dev->dev_addr[5] << 0) + (dev->dev_addr[4] << 8) +
-                       (dev->dev_addr[3] << 16) + (dev->dev_addr[2] << 24);
-               np->orig_mac[1] = (dev->dev_addr[1] << 0) + (dev->dev_addr[0] << 8);
+               np->orig_mac[0] = (mac[5] << 0) + (mac[4] << 8) +
+                       (mac[3] << 16) + (mac[2] << 24);
+               np->orig_mac[1] = (mac[1] << 0) + (mac[0] << 8);
        } else {
                /* need to reverse mac address to correct order */
-               dev->dev_addr[0] = (np->orig_mac[1] >>  8) & 0xff;
-               dev->dev_addr[1] = (np->orig_mac[1] >>  0) & 0xff;
-               dev->dev_addr[2] = (np->orig_mac[0] >> 24) & 0xff;
-               dev->dev_addr[3] = (np->orig_mac[0] >> 16) & 0xff;
-               dev->dev_addr[4] = (np->orig_mac[0] >>  8) & 0xff;
-               dev->dev_addr[5] = (np->orig_mac[0] >>  0) & 0xff;
+               mac[0] = (np->orig_mac[1] >>  8) & 0xff;
+               mac[1] = (np->orig_mac[1] >>  0) & 0xff;
+               mac[2] = (np->orig_mac[0] >> 24) & 0xff;
+               mac[3] = (np->orig_mac[0] >> 16) & 0xff;
+               mac[4] = (np->orig_mac[0] >>  8) & 0xff;
+               mac[5] = (np->orig_mac[0] >>  0) & 0xff;
                writel(txreg|NVREG_TRANSMITPOLL_MAC_ADDR_REV, base + NvRegTransmitPoll);
                dev_dbg(&pci_dev->dev,
                        "%s: set workaround bit for reversed mac addr\n",
                        __func__);
        }

-       if (!is_valid_ether_addr(dev->dev_addr)) {
+       if (is_valid_ether_addr(mac)) {
+               eth_hw_addr_set(dev, mac);
+       } else {
                /*
                 * Bad mac address. At least one bios sets the mac address
                 * to 01:23:45:67:89:ab
                 */
                dev_err(&pci_dev->dev,
                        "Invalid MAC address detected: %pM - Please complain to your hardware vendor.\n",
-                       dev->dev_addr);
+                       mac);
                eth_hw_addr_random(dev);
                dev_err(&pci_dev->dev,
                        "Using random MAC address: %pM\n", dev->dev_addr);
--
2.31.1
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help