if (!ice_is_switchdev_running(vf->pf))
                return;
 
-       if (is_valid_ether_addr(vf->hw_lan_addr.addr)) {
+       if (is_valid_ether_addr(vf->hw_lan_addr)) {
                err = ice_eswitch_add_vf_mac_rule(vf->pf, vf,
-                                                 vf->hw_lan_addr.addr);
+                                                 vf->hw_lan_addr);
                if (err) {
                        dev_err(ice_pf_to_dev(vf->pf), "Failed to add MAC %pM for VF %d\n, error %d\n",
-                               vf->hw_lan_addr.addr, vf->vf_id, err);
+                               vf->hw_lan_addr, vf->vf_id, err);
                        return;
                }
                vf->num_mac++;
 
-               ether_addr_copy(vf->dev_lan_addr.addr, vf->hw_lan_addr.addr);
+               ether_addr_copy(vf->dev_lan_addr, vf->hw_lan_addr);
        }
 }
 
                ice_vsi_update_security(vsi, ice_vsi_ctx_set_antispoof);
                metadata_dst_free(vf->repr->dst);
                vf->repr->dst = NULL;
-               ice_fltr_add_mac_and_broadcast(vsi, vf->hw_lan_addr.addr,
+               ice_fltr_add_mac_and_broadcast(vsi, vf->hw_lan_addr,
                                               ICE_FWD_TO_VSI);
 
                netif_napi_del(&vf->repr->q_vector->napi);
                                                   GFP_KERNEL);
                if (!vf->repr->dst) {
                        ice_fltr_add_mac_and_broadcast(vsi,
-                                                      vf->hw_lan_addr.addr,
+                                                      vf->hw_lan_addr,
                                                       ICE_FWD_TO_VSI);
                        goto err;
                }
 
                if (ice_vsi_update_security(vsi, ice_vsi_ctx_clear_antispoof)) {
                        ice_fltr_add_mac_and_broadcast(vsi,
-                                                      vf->hw_lan_addr.addr,
+                                                      vf->hw_lan_addr,
                                                       ICE_FWD_TO_VSI);
                        metadata_dst_free(vf->repr->dst);
                        vf->repr->dst = NULL;
 
                if (ice_vsi_add_vlan_zero(vsi)) {
                        ice_fltr_add_mac_and_broadcast(vsi,
-                                                      vf->hw_lan_addr.addr,
+                                                      vf->hw_lan_addr,
                                                       ICE_FWD_TO_VSI);
                        metadata_dst_free(vf->repr->dst);
                        vf->repr->dst = NULL;
 
        ret = ice_vsi_update_security(vsi, ice_vsi_ctx_clear_antispoof);
        if (ret) {
-               ice_fltr_add_mac_and_broadcast(vsi, vf->hw_lan_addr.addr, ICE_FWD_TO_VSI);
+               ice_fltr_add_mac_and_broadcast(vsi, vf->hw_lan_addr, ICE_FWD_TO_VSI);
                dev_err(ice_pf_to_dev(pf), "Failed to update VF %d port representor",
                        vsi->vf->vf_id);
        }
 
                goto out_put_vf;
 
        ivi->vf = vf_id;
-       ether_addr_copy(ivi->mac, vf->hw_lan_addr.addr);
+       ether_addr_copy(ivi->mac, vf->hw_lan_addr);
 
        /* VF configuration for VLAN and applicable QoS */
        ivi->vlan = ice_vf_get_port_vlan_id(vf);
                return -EINVAL;
 
        /* nothing left to do, unicast MAC already set */
-       if (ether_addr_equal(vf->dev_lan_addr.addr, mac) &&
-           ether_addr_equal(vf->hw_lan_addr.addr, mac)) {
+       if (ether_addr_equal(vf->dev_lan_addr, mac) &&
+           ether_addr_equal(vf->hw_lan_addr, mac)) {
                ret = 0;
                goto out_put_vf;
        }
        /* VF is notified of its new MAC via the PF's response to the
         * VIRTCHNL_OP_GET_VF_RESOURCES message after the VF has been reset
         */
-       ether_addr_copy(vf->dev_lan_addr.addr, mac);
-       ether_addr_copy(vf->hw_lan_addr.addr, mac);
+       ether_addr_copy(vf->dev_lan_addr, mac);
+       ether_addr_copy(vf->hw_lan_addr, mac);
        if (is_zero_ether_addr(mac)) {
                /* VF will send VIRTCHNL_OP_ADD_ETH_ADDR message with its MAC */
                vf->pf_set_mac = false;
 
        dev_info(dev, "%d Rx Malicious Driver Detection events detected on PF %d VF %d MAC %pM. mdd-auto-reset-vfs=%s\n",
                 vf->mdd_rx_events.count, pf->hw.pf_id, vf->vf_id,
-                vf->dev_lan_addr.addr,
+                vf->dev_lan_addr,
                 test_bit(ICE_FLAG_MDD_AUTO_RESET_VF, pf->flags)
                          ? "on" : "off");
 }
 
                        dev_info(dev, "%d Tx Malicious Driver Detection events detected on PF %d VF %d MAC %pM.\n",
                                 vf->mdd_tx_events.count, hw->pf_id, vf->vf_id,
-                                vf->dev_lan_addr.addr);
+                                vf->dev_lan_addr);
                }
        }
        mutex_unlock(&pf->vfs.table_lock);
 
                        if (pf_vsi)
                                dev_warn(dev, "VF MAC %pM on PF MAC %pM is generating asynchronous messages and may be overflowing the PF message queue. Please see the Adapter User Guide for more information\n",
-                                        &vf->dev_lan_addr.addr[0],
+                                        &vf->dev_lan_addr[0],
                                         pf_vsi->netdev->dev_addr);
                }
        }
 
 
        vf->num_mac++;
 
-       if (is_valid_ether_addr(vf->hw_lan_addr.addr)) {
-               status = ice_fltr_add_mac(vsi, vf->hw_lan_addr.addr,
+       if (is_valid_ether_addr(vf->hw_lan_addr)) {
+               status = ice_fltr_add_mac(vsi, vf->hw_lan_addr,
                                          ICE_FWD_TO_VSI);
                if (status) {
                        dev_err(dev, "failed to add default unicast MAC filter %pM for VF %u, error %d\n",
-                               &vf->hw_lan_addr.addr[0], vf->vf_id,
+                               &vf->hw_lan_addr[0], vf->vf_id,
                                status);
                        return status;
                }
                vf->num_mac++;
 
-               ether_addr_copy(vf->dev_lan_addr.addr, vf->hw_lan_addr.addr);
+               ether_addr_copy(vf->dev_lan_addr, vf->hw_lan_addr);
        }
 
        return 0;
 
        struct ice_sw *vf_sw_id;        /* switch ID the VF VSIs connect to */
        struct virtchnl_version_info vf_ver;
        u32 driver_caps;                /* reported by VF driver */
-       struct virtchnl_ether_addr dev_lan_addr;
-       struct virtchnl_ether_addr hw_lan_addr;
+       u8 dev_lan_addr[ETH_ALEN];
+       u8 hw_lan_addr[ETH_ALEN];
        struct ice_time_mac legacy_last_added_umac;
        DECLARE_BITMAP(txq_ena, ICE_MAX_RSS_QS_PER_VF);
        DECLARE_BITMAP(rxq_ena, ICE_MAX_RSS_QS_PER_VF);
 
        vfres->vsi_res[0].vsi_type = VIRTCHNL_VSI_SRIOV;
        vfres->vsi_res[0].num_queue_pairs = vsi->num_txq;
        ether_addr_copy(vfres->vsi_res[0].default_mac_addr,
-                       vf->hw_lan_addr.addr);
+                       vf->hw_lan_addr);
 
        /* match guest capabilities */
        vf->driver_caps = vfres->vf_cap_flags;
         * was correctly specified over VIRTCHNL
         */
        if ((ice_is_vc_addr_legacy(vc_ether_addr) &&
-            is_zero_ether_addr(vf->hw_lan_addr.addr)) ||
+            is_zero_ether_addr(vf->hw_lan_addr)) ||
            ice_is_vc_addr_primary(vc_ether_addr)) {
-               ether_addr_copy(vf->dev_lan_addr.addr, mac_addr);
-               ether_addr_copy(vf->hw_lan_addr.addr, mac_addr);
+               ether_addr_copy(vf->dev_lan_addr, mac_addr);
+               ether_addr_copy(vf->hw_lan_addr, mac_addr);
        }
 
        /* hardware and device MACs are already set, but its possible that the
        int ret;
 
        /* device MAC already added */
-       if (ether_addr_equal(mac_addr, vf->dev_lan_addr.addr))
+       if (ether_addr_equal(mac_addr, vf->dev_lan_addr))
                return 0;
 
        if (is_unicast_ether_addr(mac_addr) && !ice_can_vf_change_mac(vf)) {
            ice_is_legacy_umac_expired(&vf->legacy_last_added_umac))
                return;
 
-       ether_addr_copy(vf->dev_lan_addr.addr, vf->legacy_last_added_umac.addr);
-       ether_addr_copy(vf->hw_lan_addr.addr, vf->legacy_last_added_umac.addr);
+       ether_addr_copy(vf->dev_lan_addr, vf->legacy_last_added_umac.addr);
+       ether_addr_copy(vf->hw_lan_addr, vf->legacy_last_added_umac.addr);
 }
 
 /**
        u8 *mac_addr = vc_ether_addr->addr;
 
        if (!is_valid_ether_addr(mac_addr) ||
-           !ether_addr_equal(vf->dev_lan_addr.addr, mac_addr))
+           !ether_addr_equal(vf->dev_lan_addr, mac_addr))
                return;
 
        /* allow the device MAC to be repopulated in the add flow and don't
-        * clear the hardware MAC (i.e. hw_lan_addr.addr) here as that is meant
+        * clear the hardware MAC (i.e. hw_lan_addr) here as that is meant
         * to be persistent on VM reboot and across driver unload/load, which
         * won't work if we clear the hardware MAC here
         */
-       eth_zero_addr(vf->dev_lan_addr.addr);
+       eth_zero_addr(vf->dev_lan_addr);
 
        ice_update_legacy_cached_mac(vf, vc_ether_addr);
 }
        int status;
 
        if (!ice_can_vf_change_mac(vf) &&
-           ether_addr_equal(vf->dev_lan_addr.addr, mac_addr))
+           ether_addr_equal(vf->dev_lan_addr, mac_addr))
                return 0;
 
        status = ice_fltr_remove_mac(vsi, mac_addr, ICE_FWD_TO_VSI);
                int result;
 
                if (!is_unicast_ether_addr(mac_addr) ||
-                   ether_addr_equal(mac_addr, vf->hw_lan_addr.addr))
+                   ether_addr_equal(mac_addr, vf->hw_lan_addr))
                        continue;
 
                if (vf->pf_set_mac) {