Received: by 2002:a05:6a10:17d3:0:0:0:0 with SMTP id hz19csp575584pxb; Thu, 15 Apr 2021 01:14:40 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwoXnB7Q4hJZfy8+4h2RNr5MpHZhz95sNLRQyoK6sJP9o9X6srhCyA8qOVQvUFVWkXbstUk X-Received: by 2002:a17:90a:2847:: with SMTP id p7mr2652930pjf.1.1618474480202; Thu, 15 Apr 2021 01:14:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1618474480; cv=none; d=google.com; s=arc-20160816; b=BGrX4vVSwKJPRTuADuFBjG2R/Dv22lvAaJkbfc+RnKMk3BASKiDxcgT4IAG36NR6BZ 2V2Q7KqN7Sw8qn0bHcPYgzT8nK1sjXsHRfjCxuzbj/CMlaKiDzvZu4QIoBA2tcWfBApu jSP3sJZtNhYfASyx1t3VC8R/hqF+HZ3ApcQYTOmf0gWB8P1f8ciHxInblH8nRWbs7o5y ZB5OICUxp03p/KSnvk+j/9E4C20nhi3nN/IiD3no0b+U0LhO09xaMS+ZhFdzdlCCpVIq 6E/2Wa3lRik3pPMW7R3ftdfRyyP0A+OAQL2s5LJfr84/4VFBXQa0jiX+45YpF76Iipfs uRXg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=Uok685ar2aRiyh2dl0JSULm/jJ/D8RgjO+Fo8IDWGJU=; b=s04JhHYFGa7uqcS2/s1TABPVTsbQieKy1XVwxAF+e06+ihisQKpkwjJCvAibQOh1Fo Ag9VoXPpkl3diKt9RWOM79FsO86Rdh4BVC+RAv/2P6nOwZIJzlG/xSOAT1q7Ld/4xLmR e4+7btUO+NdHwRnzy6psgZUdl5FAcM8TtLOUZoICfU1vWyZJdysQ0940c+Wqe59QLZdq qPzr6X0qiIIKBsHxL3uUFfTxamUeVWXsT6jKhmjugG+S237ng6LLWRu4IcGePcGxTTK0 MQ9cfx5l7SAgg5cYB1YR1YMzriGJCVOQ14lpt+06hiTrX14nEvUyrMtWT4pBq+joqhmo B7kg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=F1to4fHk; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id a13si2414454pgv.60.2021.04.15.01.14.27; Thu, 15 Apr 2021 01:14:40 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=F1to4fHk; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231584AbhDOINJ (ORCPT + 99 others); Thu, 15 Apr 2021 04:13:09 -0400 Received: from us-smtp-delivery-124.mimecast.com ([216.205.24.124]:21251 "EHLO us-smtp-delivery-124.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231491AbhDOING (ORCPT ); Thu, 15 Apr 2021 04:13:06 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1618474363; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: in-reply-to:in-reply-to:references:references; bh=Uok685ar2aRiyh2dl0JSULm/jJ/D8RgjO+Fo8IDWGJU=; b=F1to4fHkRSVSwCWgacu5lLLKwN53UwxsnpIAdY0hTCv/QAM1elIzrq3wBhvrvHKo9DXvH3 sTaI41Bk7MUjaptBL4XNjnUfymUgqM7b+JrkfKnuTtVtFMUHCE9nXolJQgd0UP0RTqQKDC 5Ln2gQ4zsGjpSC1taUbfV6Baq/n+uCQ= Received: from mail-ed1-f69.google.com (mail-ed1-f69.google.com [209.85.208.69]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-65-441zAtnHOhOxfmRE3-f8AA-1; Thu, 15 Apr 2021 04:12:40 -0400 X-MC-Unique: 441zAtnHOhOxfmRE3-f8AA-1 Received: by mail-ed1-f69.google.com with SMTP id b9-20020a05640202c9b029038276b571ddso4763820edx.11 for ; Thu, 15 Apr 2021 01:12:39 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to; bh=Uok685ar2aRiyh2dl0JSULm/jJ/D8RgjO+Fo8IDWGJU=; b=gROxUMhdFztxfIa9HtamzbbrwZEwt4wlv8HRAUEREW4eSN1dhchtxFr7UmkHtf33JB XRdIBWMuE4DQv8nzmw8ZnG/+FyHx9bvHbmQo/KBZq+VKWxs5g92W/+VYJ4Tj2JdwfUlE 2MRK7BL3K1V0zjBdm+dxuGFAGPxTCPE9iG9rKOnK1KuNuzCsvElizhe4t62CY3OsZtqt 5YKTjUlTTQsUBZqCFIBU3g74+vFc52xIdJ1J+6cHUyCu+paua3m+GTfb4Tp5fTur6yYJ 7vzgV7VO+sOZ5BMJDNBnI2Z6ku7h8KW0ImAtGQ9EmySxQuaEc3EJdZApv786xmokQJxQ cliA== X-Gm-Message-State: AOAM533plYVj9lgPU5F9+7/O4oeSm8nq9uvDFDloXIIl0oN9/6fvjtyo ANMtN89b199uUW1BzNwXbS4dHQY+GWkxiDbb+8jm9AaVzlG4FhjRaXb7K7JAz0kOx1t6RYx5taz Vddkbx9x2XiqPbUQqQ+Q4bw82 X-Received: by 2002:a17:906:d110:: with SMTP id b16mr2182977ejz.146.1618474358962; Thu, 15 Apr 2021 01:12:38 -0700 (PDT) X-Received: by 2002:a17:906:d110:: with SMTP id b16mr2182957ejz.146.1618474358784; Thu, 15 Apr 2021 01:12:38 -0700 (PDT) Received: from steredhat (host-79-34-249-199.business.telecomitalia.it. [79.34.249.199]) by smtp.gmail.com with ESMTPSA id w13sm911888edx.80.2021.04.15.01.12.37 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 15 Apr 2021 01:12:38 -0700 (PDT) Date: Thu, 15 Apr 2021 10:12:36 +0200 From: Stefano Garzarella To: Zhu Lingshan Cc: jasowang@redhat.com, mst@redhat.com, lulu@redhat.com, leonro@nvidia.com, virtualization@lists.linux-foundation.org, netdev@vger.kernel.org, kvm@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH 3/3] vDPA/ifcvf: get_config_size should return dev specific config size Message-ID: <20210415081236.anbssqtsyjnmiaby@steredhat> References: <20210414091832.5132-1-lingshan.zhu@intel.com> <20210414091832.5132-4-lingshan.zhu@intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii; format=flowed Content-Disposition: inline In-Reply-To: <20210414091832.5132-4-lingshan.zhu@intel.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Apr 14, 2021 at 05:18:32PM +0800, Zhu Lingshan wrote: >get_config_size() should return the size based on the decected >device type. > >Signed-off-by: Zhu Lingshan >--- > drivers/vdpa/ifcvf/ifcvf_main.c | 11 ++++++++++- > 1 file changed, 10 insertions(+), 1 deletion(-) > >diff --git a/drivers/vdpa/ifcvf/ifcvf_main.c b/drivers/vdpa/ifcvf/ifcvf_main.c >index 9b6a38b798fa..b48b9789b69e 100644 >--- a/drivers/vdpa/ifcvf/ifcvf_main.c >+++ b/drivers/vdpa/ifcvf/ifcvf_main.c >@@ -347,7 +347,16 @@ static u32 ifcvf_vdpa_get_vq_align(struct vdpa_device *vdpa_dev) > > static size_t ifcvf_vdpa_get_config_size(struct vdpa_device *vdpa_dev) > { >- return sizeof(struct virtio_net_config); >+ struct ifcvf_hw *vf = vdpa_to_vf(vdpa_dev); >+ size_t size; >+ >+ if (vf->dev_type == VIRTIO_ID_NET) >+ size = sizeof(struct virtio_net_config); >+ >+ if (vf->dev_type == VIRTIO_ID_BLOCK) >+ size = sizeof(struct virtio_blk_config); >+ >+ return size; I'm not familiar with the ifcvf details, but can it happen that the device is not block or net? Should we set `size` to 0 by default to handle this case or are we sure it's one of the two? Maybe we should add a comment or a warning message in this case, to prevent some analysis tool or compiler from worrying that `size` might be uninitialized. I was thinking something like this: switch(vf->dev_type) { case VIRTIO_ID_NET: size = sizeof(struct virtio_net_config); break; case VIRTIO_ID_BLOCK: size = sizeof(struct virtio_blk_config); break; default: /* or WARN(1, "") if dev_warn() not apply */ dev_warn(... , "virtio ID [0x%x] not supported\n") size = 0; } Thanks, Stefano