Received: by 2002:a5b:505:0:0:0:0:0 with SMTP id o5csp5755196ybp; Tue, 15 Oct 2019 04:40:12 -0700 (PDT) X-Google-Smtp-Source: APXvYqxEG2aXt3dS3X6xmQGcZ9ml9InAZkup8XE7+LIUwf7vfhJopL+I/vdzH+18TYvZJ906h8sx X-Received: by 2002:a05:6402:120c:: with SMTP id c12mr12096002edw.119.1571139612720; Tue, 15 Oct 2019 04:40:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1571139612; cv=none; d=google.com; s=arc-20160816; b=H5XhD0GI2sXkyDFT6Su3UYAkfTNPfYj+6ZtAfGiHY5bdU8ozOHBNjUcF4Yjb2mu9mU ISEMQKHO411PSCZIrf0U9627o/N+rUTGiDiR2O37sg7Tg6Y9x2fhNHRv7r/s69hnt1El uCYOV7ycCu27PT0SP2zNSntdzVjA5rmpQasLsqex4K4GKdDV090kaS0S6WH6YAsAxyRW MbypBFQIwFm1+pdNbGfXmpHFuTEaAR5Ni1A6gdRHyszfvkLr3K+r1q3yzYB/NGiJ9Rob bI6bIkqxITaR+/6VouYCC+W/9U9tiLBhmUA+ya6VyC/xXwSj4fUQLPRLstxEXNG9GRSz EjUg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :organization:references:in-reply-to:message-id:subject:cc:to:from :date; bh=mCXyTpHUZpJjtau/q7gJ+nEVXP3e6F6w7zYxNDp5/iQ=; b=l6qfvKYMOGmWJBu4wlYieU1ObCKnpfkOOG5EVnfWz2sCc901RDJ0yGqYhTyEwJE88y y/Vdh/qHd4hxVCAy/qSqWMXYKzQ2WXSaO3C5egh22jiy0Ov+PbFfaPsmt61S3B6z8sun 8Pi6n84vQU69CKk+CA0I/TBnkiDdhN4yOXjJrCv0PJGtIehlBuEv2rr/rYJXc597zag6 GItGUhvy6AQg7LUIEGUzvXKQJeXZUl7vuSY0j/w55RNmyiYd7iiyE0oe7YYcywovjnV+ zxr4jfMOTI9Pa2f5T4XBP16WDjpK1jeUo91tji7VzVVPZ15tIzx2QKMbk3vXKte3+/aq 9Xiw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id v26si13273461ejw.276.2019.10.15.04.39.49; Tue, 15 Oct 2019 04:40:12 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730626AbfJOK01 (ORCPT + 99 others); Tue, 15 Oct 2019 06:26:27 -0400 Received: from mx1.redhat.com ([209.132.183.28]:50072 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726508AbfJOK00 (ORCPT ); Tue, 15 Oct 2019 06:26:26 -0400 Received: from smtp.corp.redhat.com (int-mx04.intmail.prod.int.phx2.redhat.com [10.5.11.14]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id C3DBA306F4AB; Tue, 15 Oct 2019 10:26:22 +0000 (UTC) Received: from gondolin (dhcp-192-233.str.redhat.com [10.33.192.233]) by smtp.corp.redhat.com (Postfix) with ESMTP id 6ACB65DA8C; Tue, 15 Oct 2019 10:26:09 +0000 (UTC) Date: Tue, 15 Oct 2019 12:26:07 +0200 From: Cornelia Huck To: Jason Wang Cc: kvm@vger.kernel.org, linux-s390@vger.kernel.org, linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, intel-gfx@lists.freedesktop.org, intel-gvt-dev@lists.freedesktop.org, kwankhede@nvidia.com, alex.williamson@redhat.com, mst@redhat.com, tiwei.bie@intel.com, virtualization@lists.linux-foundation.org, netdev@vger.kernel.org, maxime.coquelin@redhat.com, cunming.liang@intel.com, zhihong.wang@intel.com, rob.miller@broadcom.com, xiao.w.wang@intel.com, haotian.wang@sifive.com, zhenyuw@linux.intel.com, zhi.a.wang@intel.com, jani.nikula@linux.intel.com, joonas.lahtinen@linux.intel.com, rodrigo.vivi@intel.com, airlied@linux.ie, daniel@ffwll.ch, farman@linux.ibm.com, pasic@linux.ibm.com, sebott@linux.ibm.com, oberpar@linux.ibm.com, heiko.carstens@de.ibm.com, gor@linux.ibm.com, borntraeger@de.ibm.com, akrowiak@linux.ibm.com, freude@linux.ibm.com, lingshan.zhu@intel.com, idos@mellanox.com, eperezma@redhat.com, lulu@redhat.com, parav@mellanox.com, christophe.de.dinechin@gmail.com, kevin.tian@intel.com Subject: Re: [PATCH V3 1/7] mdev: class id support Message-ID: <20191015122607.126e3960.cohuck@redhat.com> In-Reply-To: <20191011081557.28302-2-jasowang@redhat.com> References: <20191011081557.28302-1-jasowang@redhat.com> <20191011081557.28302-2-jasowang@redhat.com> Organization: Red Hat GmbH MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit X-Scanned-By: MIMEDefang 2.79 on 10.5.11.14 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.42]); Tue, 15 Oct 2019 10:26:26 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, 11 Oct 2019 16:15:51 +0800 Jason Wang wrote: > Mdev bus only supports vfio driver right now, so it doesn't implement > match method. But in the future, we may add drivers other than vfio, > the first driver could be virtio-mdev. This means we need to add > device class id support in bus match method to pair the mdev device > and mdev driver correctly. > > So this patch adds id_table to mdev_driver and class_id for mdev > device with the match method for mdev bus. > > Signed-off-by: Jason Wang > --- > Documentation/driver-api/vfio-mediated-device.rst | 7 ++++++- > drivers/gpu/drm/i915/gvt/kvmgt.c | 1 + > drivers/s390/cio/vfio_ccw_ops.c | 1 + > drivers/s390/crypto/vfio_ap_ops.c | 1 + > drivers/vfio/mdev/mdev_core.c | 11 +++++++++++ > drivers/vfio/mdev/mdev_driver.c | 14 ++++++++++++++ > drivers/vfio/mdev/mdev_private.h | 1 + > drivers/vfio/mdev/vfio_mdev.c | 6 ++++++ > include/linux/mdev.h | 8 ++++++++ > include/linux/mod_devicetable.h | 8 ++++++++ > samples/vfio-mdev/mbochs.c | 1 + > samples/vfio-mdev/mdpy.c | 1 + > samples/vfio-mdev/mtty.c | 1 + > 13 files changed, 60 insertions(+), 1 deletion(-) > > diff --git a/Documentation/driver-api/vfio-mediated-device.rst b/Documentation/driver-api/vfio-mediated-device.rst > index 25eb7d5b834b..2035e48da7b2 100644 > --- a/Documentation/driver-api/vfio-mediated-device.rst > +++ b/Documentation/driver-api/vfio-mediated-device.rst > @@ -102,12 +102,14 @@ structure to represent a mediated device's driver:: > * @probe: called when new device created > * @remove: called when device removed > * @driver: device driver structure > + * @id_table: the ids serviced by this driver > */ > struct mdev_driver { > const char *name; > int (*probe) (struct device *dev); > void (*remove) (struct device *dev); > struct device_driver driver; > + const struct mdev_class_id *id_table; > }; > > A mediated bus driver for mdev should use this structure in the function calls > @@ -165,12 +167,15 @@ register itself with the mdev core driver:: > extern int mdev_register_device(struct device *dev, > const struct mdev_parent_ops *ops); > > +It is also required to specify the class_id through:: > + > + extern int mdev_set_class(struct device *dev, u16 id); Should the document state explicitly that this should be done in the ->create() callback? Also, I think that the class_id might be different for different mdevs (even if the parent is the same) -- should that be mentioned explicitly? > + > However, the mdev_parent_ops structure is not required in the function call > that a driver should use to unregister itself with the mdev core driver:: > > extern void mdev_unregister_device(struct device *dev); > > - > Mediated Device Management Interface Through sysfs > ================================================== > (...) Looks reasonable to me.