Received: by 2002:a05:6a10:a841:0:0:0:0 with SMTP id d1csp181018pxy; Wed, 28 Apr 2021 02:01:05 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxSSXe5u2uPz6zSgio9mxdUsFLpfZTyOZHW89fEDvh58dhm4TQJvMwpUD3PZa1XRiomNyvW X-Received: by 2002:a17:907:3e13:: with SMTP id hp19mr27187853ejc.276.1619600465358; Wed, 28 Apr 2021 02:01:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1619600465; cv=none; d=google.com; s=arc-20160816; b=dVQlbVKNWZKfHbg1XZfMZ4Oj1z+/odcFxF71AY313/6x/8PW5sZOvSJIX4zAlmTTtD gULOIUHIXEI4QeOc3fdqNl8PCKs2I3yrAMixUqqsnod3YwFLp5iUEQeV12U9YjVOW8h+ jvEJ75jdubg1XuhUuJSYKVenxi4rw8nKkVI3GLTdr3kAEcE7QzXWIoyGDNImTWYWzXqu mGZZP54MnwGLcjFkv00LZA6CQNKoHyqsvDbnSvDcTKtWOYf7FpJcRpwbF7NDAioXXXz0 WtHTnvw33wC0YPwTzsGT/wcI5veSck4fyQCfE1P6QbgHJyY9rtv3DbWVP6VxO1QuL3/o WmmA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-language:content-transfer-encoding :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:ironport-sdr:ironport-sdr; bh=+T0AT2DDmkLuOEEvcCvcYotWP/XDppcA3NjbB6Uf+gY=; b=V4kEp/kUBi6926qC5jp1ivi+4eKcf9Io1lilFumLJZ9bPJET610XJhwjug43T7Zxz7 /U2eittKjyshRQQDg+M0PswALceQ7cpWRgjz8DNEf1EjlKL+AddVO4JqNGNwx1XWMNbK gKMegf/B6Whgz6WYb5ETGtWWv5bAX90Ds4usNAKUyxgbYBnH7MfSCPxoysvFhUbjNDv1 DLZ9ajaa9WRLJjKICb8NebkI1xzWLN4Pgzzb+QQXbpNxWvo7YA6wY8Jk/mdX+8RGj3CW ucsFBB06HjPkf3GIdzlDPNWzQwi7iU0ubeMQ96M0lvIE9vlvtQcQ8SEsQOpuV1IJot4Q wm7w== 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=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id qt4si2448088ejb.126.2021.04.28.02.00.41; Wed, 28 Apr 2021 02:01:05 -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=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237915AbhD1JAP (ORCPT + 99 others); Wed, 28 Apr 2021 05:00:15 -0400 Received: from mga04.intel.com ([192.55.52.120]:10439 "EHLO mga04.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230191AbhD1JAO (ORCPT ); Wed, 28 Apr 2021 05:00:14 -0400 IronPort-SDR: L+MS+lYa6iXp1Eu4UQpRvwQRZZ0LKlKdZahTEW+O7KcF5V9dbC8AqqSJKUcbyhfuVS+zgz0dGo kNf3sX36YEEg== X-IronPort-AV: E=McAfee;i="6200,9189,9967"; a="194578168" X-IronPort-AV: E=Sophos;i="5.82,257,1613462400"; d="scan'208";a="194578168" Received: from fmsmga008.fm.intel.com ([10.253.24.58]) by fmsmga104.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 28 Apr 2021 01:59:30 -0700 IronPort-SDR: /bV5FFoRO+Z6/L7jzTEagZTchp/QERVU7eUnbaEtz1zq57djeZbukmJh51NuYDFnfJDkg6smLI ikoeMdXuf1KQ== X-IronPort-AV: E=Sophos;i="5.82,257,1613462400"; d="scan'208";a="423434858" Received: from lingshan-mobl5.ccr.corp.intel.com (HELO [10.254.209.93]) ([10.254.209.93]) by fmsmga008-auth.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 28 Apr 2021 01:59:28 -0700 Subject: Re: [PATCH 2/2] vDPA/ifcvf: implement doorbell mapping for ifcvf To: Jason Wang , mst@redhat.com Cc: virtualization@lists.linux-foundation.org, netdev@vger.kernel.org, kvm@vger.kernel.org, linux-kernel@vger.kernel.org References: <20210428082133.6766-1-lingshan.zhu@intel.com> <20210428082133.6766-3-lingshan.zhu@intel.com> From: "Zhu, Lingshan" Message-ID: <5052fced-cd9a-e453-5cb2-39cdde60a208@intel.com> Date: Wed, 28 Apr 2021 16:59:26 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.9.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 4/28/2021 4:42 PM, Jason Wang wrote: > > 在 2021/4/28 下午4:21, Zhu Lingshan 写道: >> This commit implements doorbell mapping feature for ifcvf. >> This feature maps the notify page to userspace, to eliminate >> vmexit when kick a vq. >> >> Signed-off-by: Zhu Lingshan >> --- >>   drivers/vdpa/ifcvf/ifcvf_main.c | 18 ++++++++++++++++++ >>   1 file changed, 18 insertions(+) >> >> diff --git a/drivers/vdpa/ifcvf/ifcvf_main.c >> b/drivers/vdpa/ifcvf/ifcvf_main.c >> index e48e6b74fe2e..afcb71bc0f51 100644 >> --- a/drivers/vdpa/ifcvf/ifcvf_main.c >> +++ b/drivers/vdpa/ifcvf/ifcvf_main.c >> @@ -413,6 +413,23 @@ static int ifcvf_vdpa_get_vq_irq(struct >> vdpa_device *vdpa_dev, >>       return vf->vring[qid].irq; >>   } >>   +static struct vdpa_notification_area >> ifcvf_get_vq_notification(struct vdpa_device *vdpa_dev, >> +                                   u16 idx) >> +{ >> +    struct ifcvf_hw *vf = vdpa_to_vf(vdpa_dev); >> +    struct vdpa_notification_area area; >> + >> +    if (vf->notify_pa % PAGE_SIZE) { >> +        area.addr = 0; >> +        area.size = 0; > > > We don't need this since: > > 1) there's a check in the vhost vDPA I think you mean this code block in vdpa.c         notify = ops->get_vq_notification(vdpa, index);         if (notify.addr & (PAGE_SIZE - 1))                 return -EINVAL; This should work, however, I think the parent driver should ensure it passes a PAGE_SIZE aligned address to userspace, to be robust, to be reliable. > 2) device is unaware of the bound driver, non page aligned doorbell > doesn't necessarily meant it can be used Yes, non page aligned doorbell can not be used, so there is a check. Thanks Zhu Lingshan > > Let's leave those polices to the driver. > > Thanks > > >> +    } else { >> +        area.addr = vf->notify_pa; >> +        area.size = PAGE_SIZE; >> +    } >> + >> +    return area; >> +} >> + >>   /* >>    * IFCVF currently does't have on-chip IOMMU, so not >>    * implemented set_map()/dma_map()/dma_unmap() >> @@ -440,6 +457,7 @@ static const struct vdpa_config_ops ifc_vdpa_ops = { >>       .get_config    = ifcvf_vdpa_get_config, >>       .set_config    = ifcvf_vdpa_set_config, >>       .set_config_cb  = ifcvf_vdpa_set_config_cb, >> +    .get_vq_notification = ifcvf_get_vq_notification, >>   }; >>     static int ifcvf_probe(struct pci_dev *pdev, const struct >> pci_device_id *id) >