Received: by 10.192.165.148 with SMTP id m20csp3326732imm; Mon, 23 Apr 2018 04:48:56 -0700 (PDT) X-Google-Smtp-Source: AIpwx4+NibbmnKm+mX8rW596rx7nrSpyUKdXl1RbtVwGVJ9XAG5zJgofg+V2ygMaG0+y0XBfBCuW X-Received: by 10.99.105.195 with SMTP id e186mr7068773pgc.353.1524484135940; Mon, 23 Apr 2018 04:48:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1524484135; cv=none; d=google.com; s=arc-20160816; b=XKoThb9Gw8ulYOzTE/+PtPBO/65w54blTyiZzALn0FJPSsq3oXGssT2AfN47lYeMxO vdBL80jvESS0PkO2zYkltiJexNegpP3WQIHenNnxz4VnXSAkFaOde7x4+5tVXOT9IjF6 QNTfl/rCVv+28t38P0uXd5CTBW8l0VdXH7/teTC15ujogzgkabaGlK/IZ0b+RTAXO0yT Xq9Q1oPRj3JAL9u3UplDeQf6GitzmjkHcLvU1h4x8d+WuztbchVsbVO421Uv1aqqy+GA 7PTZtsHwd74WPNDlPblZX1ao8sswHyt9uHRvnwmdmTQ4RrhHLnB5DEMKb/iNoNJIh6Pe taYQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:content-language:thread-index :thread-topic:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date :arc-authentication-results; bh=xqlOA0mjV2/4p81LazP48YU5Zs1C4N7K0LeQNGpdtpU=; b=zdrns0BKS8qOfwbADU13gizP95bZK5ovPV2J0smqzjxhc4Jxe7nPBuyBitsn6EwrBg Ht0CbuGzbUqZnwO/P9eMj2Oo7rZitV6xaOEGvx5Rj4K15XX6HUarv27m4tfPKQx8AG0H 7YCmZtITESMLxWPdzjbvksQbgznu/sXGztva3YBkMYpGukpefMuNr1VtHpssnBUe9+ya cW1lVg9f3pQU+HL/UQSe4evBZm06VrHCqu23qoTK4HmwvcOaLTL9lTbsmpBu0NwODTwj 61PlJN4goP8mPrluwt8mr4k7IkpZrPaCEth7zuL+vXUFtMlaFmzKQjBrl+EN9XbQtwKz RYtQ== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id j3-v6si11601606pld.300.2018.04.23.04.48.41; Mon, 23 Apr 2018 04:48:55 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754804AbeDWLrX (ORCPT + 99 others); Mon, 23 Apr 2018 07:47:23 -0400 Received: from usa-sjc-mx-foss1.foss.arm.com ([217.140.101.70]:39972 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754710AbeDWLrS (ORCPT ); Mon, 23 Apr 2018 07:47:18 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 43FDE1435; Mon, 23 Apr 2018 04:47:18 -0700 (PDT) Received: from ostrya.localdomain (ostrya.cambridge.arm.com [10.1.210.33]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id E15143F4FF; Mon, 23 Apr 2018 04:47:15 -0700 (PDT) Date: Mon, 23 Apr 2018 12:47:10 +0100 From: Jean-Philippe Brucker To: Jacob Pan Cc: "iommu@lists.linux-foundation.org" , LKML , Joerg Roedel , David Woodhouse , Greg Kroah-Hartman , Alex Williamson , Rafael Wysocki , "Liu, Yi L" , "Tian, Kevin" , Raj Ashok , Jean Delvare , Christoph Hellwig , Lu Baolu Subject: Re: [PATCH v4 13/22] iommu: introduce page response function Message-ID: References: <1523915351-54415-1-git-send-email-jacob.jun.pan@linux.intel.com> <1523915351-54415-14-git-send-email-jacob.jun.pan@linux.intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <1523915351-54415-14-git-send-email-jacob.jun.pan@linux.intel.com> Thread-Topic: [PATCH v4 13/22] iommu: introduce page response function Thread-Index: AQHT1cxu8kW67km5zU+xjMwxhEr75KQOSI0A X-MS-Exchange-MessageSentRepresentingType: 1 Content-Language: en-US X-MS-Exchange-Organization-RecordReviewCfmType: 0 x-ms-exchange-imapappendstamp: AM4PR0802MB2369.eurprd08.prod.outlook.com (15.20.0696.003) User-Agent: Mutt/1.9.4 (2018-02-28) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Apr 16, 2018 at 10:49:02PM +0100, Jacob Pan wrote: [...] > + /* > + * Check if we have a matching page request pending to respond, > + * otherwise return -EINVAL > + */ > + list_for_each_entry_safe(evt, iter, ¶m->fault_param->faults, list) { I don't think you need the "_safe" iterator if you're exiting the loop right after removing the event. > + if (evt->pasid == msg->pasid && > + msg->page_req_group_id == evt->page_req_group_id) { > + msg->private_data = evt->iommu_private; Ah sorry, I missed this bit in my review of 10/22. I thought private_data would be for evt->device_private. In this case I guess we can drop device_private, or do you plan to use it? > + ret = domain->ops->page_response(dev, msg); > + list_del(&evt->list); > + kfree(evt); > + break; > + } > + } > + > +done_unlock: > + mutex_unlock(¶m->fault_param->lock); > + return ret; > +} > +EXPORT_SYMBOL_GPL(iommu_page_response); > + > static void __iommu_detach_device(struct iommu_domain *domain, > struct device *dev) > { > diff --git a/include/linux/iommu.h b/include/linux/iommu.h > index 32435f9..058b552 100644 > --- a/include/linux/iommu.h > +++ b/include/linux/iommu.h > @@ -163,6 +163,55 @@ struct iommu_resv_region { > #ifdef CONFIG_IOMMU_API > > /** > + * enum page_response_code - Return status of fault handlers, telling the IOMMU > + * driver how to proceed with the fault. > + * > + * @IOMMU_FAULT_STATUS_SUCCESS: Fault has been handled and the page tables > + * populated, retry the access. This is "Success" in PCI PRI. > + * @IOMMU_FAULT_STATUS_FAILURE: General error. Drop all subsequent faults from > + * this device if possible. This is "Response Failure" in PCI PRI. > + * @IOMMU_FAULT_STATUS_INVALID: Could not handle this fault, don't retry the > + * access. This is "Invalid Request" in PCI PRI. > + */ > +enum page_response_code { > + IOMMU_PAGE_RESP_SUCCESS = 0, > + IOMMU_PAGE_RESP_INVALID, > + IOMMU_PAGE_RESP_FAILURE, > +}; Field names aren't consistent with the comment. I'd go with IOMMU_PAGE_RESP_* > + > +/** > + * enum page_request_handle_t - Return page request/response handler status > + * > + * @IOMMU_FAULT_STATUS_HANDLED: Stop processing the fault, and do not send a > + * reply to the device. > + * @IOMMU_FAULT_STATUS_CONTINUE: Fault was not handled. Call the next handler, > + * or terminate. > + */ > +enum page_request_handle_t { > + IOMMU_PAGE_RESP_HANDLED = 0, > + IOMMU_PAGE_RESP_CONTINUE, Same here regarding the comment. Here I'd prefer "iommu_fault_status_t" for the enum and IOMMU_FAULT_STATUS_* for the fields, because they can be used for unrecoverable faults as well. But since you're not using these values in your patches, I guess you can drop this enum? At the moment the return value of fault handler is 0 (as specified at iommu_register_device_fault_handler), meaning that the handler always takes ownership of the fault. It will be easy to extend once we introduce multiple fault handlers that can either take the fault or pass it to the next one. Existing implementations will still return 0 - HANDLED, and new ones will return either HANDLED or CONTINUE. > +/** > + * Generic page response information based on PCI ATS and PASID spec. > + * @addr: servicing page address > + * @pasid: contains process address space ID > + * @resp_code: response code > + * @page_req_group_id: page request group index > + * @type: group or stream/single page response @type isn't in the structure > + * @private_data: uniquely identify device-specific private data for an > + * individual page response IOMMU-specific? If it is set by iommu.c, I think we should comment about it, something like "This field is written by the IOMMU core". Maybe also rename it to iommu_private to be consistent with iommu_fault_event > + */ > +struct page_response_msg { > + u64 addr; > + u32 pasid; > + enum page_response_code resp_code; > + u32 pasid_present:1; > + u32 page_req_group_id; > + u64 private_data; > +}; > + > +/** > * struct iommu_ops - iommu ops and capabilities > * @capable: check capability > * @domain_alloc: allocate iommu domain > @@ -195,6 +244,7 @@ struct iommu_resv_region { > * @bind_pasid_table: bind pasid table pointer for guest SVM > * @unbind_pasid_table: unbind pasid table pointer and restore defaults > * @sva_invalidate: invalidate translation caches of shared virtual address > + * @page_response: handle page request response > */ > struct iommu_ops { > bool (*capable)(enum iommu_cap); > @@ -250,6 +300,7 @@ struct iommu_ops { > struct device *dev); > int (*sva_invalidate)(struct iommu_domain *domain, > struct device *dev, struct tlb_invalidate_info *inv_info); > + int (*page_response)(struct device *dev, struct page_response_msg *msg); > > unsigned long pgsize_bitmap; > }; > @@ -471,6 +522,7 @@ extern int iommu_unregister_device_fault_handler(struct device *dev); > > extern int iommu_report_device_fault(struct device *dev, struct iommu_fault_event *evt); > > +extern int iommu_page_response(struct device *dev, struct page_response_msg *msg); Please also define a -ENODEV function for !CONFIG_IOMMU_API, otherwise it doesn't build. And I think struct page_response_msg and the enums should be declared outside #ifdef CONFIG_IOMMU_API. Same for struct iommu_fault_event and the enums in patch 10/22. Otherwise device drivers will have to add #ifdefs everywhere their code accesses these structures. Thanks, Jean > extern int iommu_group_id(struct iommu_group *group); > extern struct iommu_group *iommu_group_get_for_dev(struct device *dev); > extern struct iommu_domain *iommu_group_default_domain(struct iommu_group *); > -- > 2.7.4 >