On Thu, Apr 17, 2025 at 6:25 PM Cindy Lu <l...@redhat.com> wrote:
>
> For VDPA devices, Allow configurations where the hardware MAC address
> is non-zero while the MAC address in the QEMU command line is zero.
> In this case, QEMU will use the hardware MAC address from the device.
>
> Signed-off-by: Cindy Lu <l...@redhat.com>
> ---
>  hw/net/virtio-net.c | 14 ++++++++++++++
>  1 file changed, 14 insertions(+)
>
> diff --git a/hw/net/virtio-net.c b/hw/net/virtio-net.c
> index 0b6a4e5634..808a2fe4d4 100644
> --- a/hw/net/virtio-net.c
> +++ b/hw/net/virtio-net.c
> @@ -3757,6 +3757,20 @@ static bool virtio_net_check_vdpa_mac(VirtIONet *n, 
> uint8_t *hwmac,
>          if ((memcmp(hwmac, cmdline_mac, sizeof(MACAddr)) == 0)) {
>              return true;
>          }
> +        /*
> +         * 2. The hardware MAC address is NOT 0 and the MAC address in
> +         *  the QEMU command line is 0.
> +         *  In this case,qemu will use the hardware MAC address overwrite
> +         *  the QEMU command line MAC address saved in VirtIONet->mac[0].
> +         *  In the following process, QEMU will use this MAC address
> +         *  to complete the initialization.
> +         */
> +        if (memcmp(cmdline_mac, &zero, sizeof(MACAddr)) == 0) {
> +            /* overwrite the mac address with hardware address */
> +            memcpy(&n->mac[0], hwmac, sizeof(n->mac));
> +            memcpy(&n->nic_conf.macaddr, hwmac, sizeof(n->mac));

I'm not sure I get here, shouldn't we need to call get_config() here?

Thanks

> +            return true;
> +        }
>      }
>
>      return false;
> --
> 2.45.0
>


Reply via email to