Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp329678pxb; Fri, 15 Oct 2021 06:24:37 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzqHO8U9PvYQ2I3xpo/3Wn43ISK77Vd5gUQG+polbXwrjEBA1oy2DLqn9eBg/rWEoVWR7HO X-Received: by 2002:a17:90a:718c:: with SMTP id i12mr28020205pjk.182.1634304277473; Fri, 15 Oct 2021 06:24:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1634304277; cv=none; d=google.com; s=arc-20160816; b=QVQLSHBBI9WJAIFSa4Vr077caIrLEwVCtEab026HaIIp7G/jhjcB6489LiPJaxrp0r YW5+/HWOIh4Df40AilLy9ypyt7XkFFWnpVu4MdwDpSH2N6xAkNvy5r/R+cFTVhCEfLwk 6hyPTD1vVPda/cyKjSEyqf2G30SbEE/6iBQZWlZC2FwsMExwgEaUWdHLoqkJYIIhXJIk w2Y/4/u0q2r+QH1qLKCzjIAYogYt81Ev6nnb0qqmFU8QpCMjCjGhbS+SuNtLki6o9yQI M2MT2/RzYdatIqM0hsBOpP8lhM062098NhvoCDRPg/Vlee7VOC3Q0vYj5tvKwQ6QxcLk H2AQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=FMR6s7mmTDyrV5E0xl3xVLFxkb+/n+ZzGC2JfciI6Cw=; b=qKIa0Ec6sOnXPfjc7XgJmjK690wIgdtng50GUWzcl3qTAKi2FwT1tGn6LkjVrQLmKu PG6DzWF7rzw62Rpr5i+9WB+8ldvY36fpxMiQ4p/ZY5PQBJDls7b5UvV+qbJNUtYaMroZ qkltkWkI4EPMcD1hZGFyu+whrT8GC4JWu6jIItZqVUlBjY4wK70ylsjZ3m1w3KvzkJv1 xcOYcNhQHtNJuwqUh8/Lj5dq/P1x/cAGcUkdFFK7V4SbqjO712uQOjTs+Vij9+N8qYUN ZKx5E6ruC5BhTd38e+3oQCzQGtEnkPchMGxbWJza0UEg3eZjNu7gquOK1XxXjMNUSqH2 +zDw== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id u136si7774817pgc.587.2021.10.15.06.24.22; Fri, 15 Oct 2021 06:24:37 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235980AbhJOHRb (ORCPT + 99 others); Fri, 15 Oct 2021 03:17:31 -0400 Received: from out30-42.freemail.mail.aliyun.com ([115.124.30.42]:41538 "EHLO out30-42.freemail.mail.aliyun.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235954AbhJOHRZ (ORCPT ); Fri, 15 Oct 2021 03:17:25 -0400 X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R611e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=e01e01424;MF=wuzongyong@linux.alibaba.com;NM=1;PH=DS;RN=6;SR=0;TI=SMTPD_---0Us6A078_1634282107; Received: from localhost.localdomain(mailfrom:wuzongyong@linux.alibaba.com fp:SMTPD_---0Us6A078_1634282107) by smtp.aliyun-inc.com(127.0.0.1); Fri, 15 Oct 2021 15:15:18 +0800 From: Wu Zongyong To: wuzongyong@linux.alibaba.com, jasowang@redhat.com, virtualization@lists.linux-foundation.org, linux-kernel@vger.kernel.org, mst@redhat.com Cc: wei.yang1@linux.alibaba.com Subject: [PATCH v5 7/8] vdpa: add new attribute VDPA_ATTR_DEV_MIN_VQ_SIZE Date: Fri, 15 Oct 2021 15:15:00 +0800 Message-Id: <4a59796b78f57a4b58d6571340999a69930719c6.1634281805.git.wuzongyong@linux.alibaba.com> X-Mailer: git-send-email 2.31.1 In-Reply-To: References: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This attribute advertises the min value of virtqueue size. The value is 0 by default. Signed-off-by: Wu Zongyong --- drivers/vdpa/vdpa.c | 5 +++++ include/uapi/linux/vdpa.h | 1 + 2 files changed, 6 insertions(+) diff --git a/drivers/vdpa/vdpa.c b/drivers/vdpa/vdpa.c index fd014ecec711..4aeb1458b924 100644 --- a/drivers/vdpa/vdpa.c +++ b/drivers/vdpa/vdpa.c @@ -500,6 +500,7 @@ vdpa_dev_fill(struct vdpa_device *vdev, struct sk_buff *msg, u32 portid, u32 seq int flags, struct netlink_ext_ack *extack) { u16 max_vq_size; + u16 min_vq_size = 0; u32 device_id; u32 vendor_id; void *hdr; @@ -516,6 +517,8 @@ vdpa_dev_fill(struct vdpa_device *vdev, struct sk_buff *msg, u32 portid, u32 seq device_id = vdev->config->get_device_id(vdev); vendor_id = vdev->config->get_vendor_id(vdev); max_vq_size = vdev->config->get_vq_num_max(vdev); + if (vdev->config->get_vq_num_min) + min_vq_size = vdev->config->get_vq_num_min(vdev); err = -EMSGSIZE; if (nla_put_string(msg, VDPA_ATTR_DEV_NAME, dev_name(&vdev->dev))) @@ -528,6 +531,8 @@ vdpa_dev_fill(struct vdpa_device *vdev, struct sk_buff *msg, u32 portid, u32 seq goto msg_err; if (nla_put_u16(msg, VDPA_ATTR_DEV_MAX_VQ_SIZE, max_vq_size)) goto msg_err; + if (nla_put_u16(msg, VDPA_ATTR_DEV_MIN_VQ_SIZE, min_vq_size)) + goto msg_err; genlmsg_end(msg, hdr); return 0; diff --git a/include/uapi/linux/vdpa.h b/include/uapi/linux/vdpa.h index 66a41e4ec163..e3b87879514c 100644 --- a/include/uapi/linux/vdpa.h +++ b/include/uapi/linux/vdpa.h @@ -32,6 +32,7 @@ enum vdpa_attr { VDPA_ATTR_DEV_VENDOR_ID, /* u32 */ VDPA_ATTR_DEV_MAX_VQS, /* u32 */ VDPA_ATTR_DEV_MAX_VQ_SIZE, /* u16 */ + VDPA_ATTR_DEV_MIN_VQ_SIZE, /* u16 */ /* new attributes must be added above here */ VDPA_ATTR_MAX, -- 2.31.1