Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp4441407ybi; Mon, 3 Jun 2019 10:54:59 -0700 (PDT) X-Google-Smtp-Source: APXvYqznfeVO+vDoVwsIocrfBEgC5/Rjqw+1k9T1mDj331h5owwfanKCd+c1iELVsy/hR/hWkATA X-Received: by 2002:a17:902:9a49:: with SMTP id x9mr10897542plv.282.1559584499240; Mon, 03 Jun 2019 10:54:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1559584499; cv=none; d=google.com; s=arc-20160816; b=jZT0bg4QTTqG+6zEcyI2/y8neHmL2w+dG1NE7OEvAWYCU3OEQC0VxHF1GyXFQTVRhv bqbVLyFtIyWSWmfnNpv8T9w0CSMdhmnQz3IgIpflcm1QVDZ9ssgP9SHsUfcs97FFof8l N3X6d1N4GetcqSGGW295z7O45Da47a3dzfAr64P/s8IcyyPZC73lmz5+q/yQvUWeytF0 2VzT5NUs5tb7kOSkfPOsV3ujjiO9kBCkEGNjrAguZ1Sb162H97EI4mdP+APBtTZFyNJh gQH6/lSDj7k0fUpnt+yX+ngpZTXIY6YcmYe24baIlKGFkU6cz32U1SOanpPCuSGPBUfu X1Aw== 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=ZkFzmPnd9cW2w09iz4CvRCSk5Oa8ZpujJhS9ofQ8sn0=; b=gUH++Guaaiwy0iHVmC/0ZtkR5GOb8GEbXKYb+ac3WBWAWEv0KWsQc76OScuEVMncHa ZCY7jGTtfvSB1yKGEV2TFUaJ5pmxc41+YwYbO3dmt9wrqkB3mf37ErS6tj9SAS3gRjXl 0+fsIdZLwutLILIEXzz+TsAO/twWxd5bezuigSkw8aitS7NakQjqWrZ7tSBqtZ7Y1CiY nRArBkN4CliUy4lerZfKRrYZte+c+c4l1adt/rZsX9WPskiRjA/sU36EbG0dIaYqO/l+ LTZZUCx3fljLJTjrDSCoC6sInw+xWwdAJ5ubYvwKSMzN+QcB4TsdsNTywfgRqmFGwoHD mrhw== 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 f10si19479769pgg.348.2019.06.03.10.54.43; Mon, 03 Jun 2019 10:54:59 -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 S1729390AbfFCRTS (ORCPT + 99 others); Mon, 3 Jun 2019 13:19:18 -0400 Received: from usa-sjc-mx-foss1.foss.arm.com ([217.140.101.70]:56306 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726711AbfFCRTQ (ORCPT ); Mon, 3 Jun 2019 13:19:16 -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 3258480D; Mon, 3 Jun 2019 10:19:16 -0700 (PDT) Received: from donnerap.cambridge.arm.com (usa-sjc-imap-foss1.foss.arm.com [10.72.51.249]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id C0D223F5AF; Mon, 3 Jun 2019 10:19:13 -0700 (PDT) Date: Mon, 3 Jun 2019 18:18:56 +0100 From: Andre Przywara To: Sudeep Holla Cc: Florian Fainelli , , , , , , , , , , , , Subject: Re: [PATCH V2 1/2] DT: mailbox: add binding doc for the ARM SMC mailbox Message-ID: <20190603181856.34996aaa@donnerap.cambridge.arm.com> In-Reply-To: <20190603165651.GA12196@e107155-lin> References: <20190603083005.4304-1-peng.fan@nxp.com> <20190603083005.4304-2-peng.fan@nxp.com> <20190603165651.GA12196@e107155-lin> Organization: ARM X-Mailer: Claws Mail 3.17.3 (GTK+ 2.24.32; aarch64-unknown-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, 3 Jun 2019 17:56:51 +0100 Sudeep Holla wrote: Hi, > On Mon, Jun 03, 2019 at 09:22:16AM -0700, Florian Fainelli wrote: > > On 6/3/19 1:30 AM, peng.fan@nxp.com wrote: > > > From: Peng Fan > > > > > > The ARM SMC mailbox binding describes a firmware interface to trigger > > > actions in software layers running in the EL2 or EL3 exception levels. > > > The term "ARM" here relates to the SMC instruction as part of the ARM > > > instruction set, not as a standard endorsed by ARM Ltd. > > > > > > Signed-off-by: Peng Fan > > > --- > > > > > > V2: > > > Introduce interrupts as a property. > > > > > > V1: > > > arm,func-ids is still kept as an optional property, because there is no > > > defined SMC funciton id passed from SCMI. So in my test, I still use > > > arm,func-ids for ARM SIP service. > > > > > > .../devicetree/bindings/mailbox/arm-smc.txt | 101 +++++++++++++++++++++ > > > 1 file changed, 101 insertions(+) > > > create mode 100644 Documentation/devicetree/bindings/mailbox/arm-smc.txt > > > > > > diff --git a/Documentation/devicetree/bindings/mailbox/arm-smc.txt b/Documentation/devicetree/bindings/mailbox/arm-smc.txt > > > new file mode 100644 > > > index 000000000000..401887118c09 > > > --- /dev/null > > > +++ b/Documentation/devicetree/bindings/mailbox/arm-smc.txt > > > @@ -0,0 +1,101 @@ > > [...] > > > > +Optional properties: > > > +- arm,func-ids An array of 32-bit values specifying the function > > > + IDs used by each mailbox channel. Those function IDs > > > + follow the ARM SMC calling convention standard [1]. > > > + There is one identifier per channel and the number > > > + of supported channels is determined by the length > > > + of this array. > > > +- interrupts SPI interrupts may be listed for notification, > > > + each channel should use a dedicated interrupt > > > + line. > > > > I would not go about defining a specific kind of interrupt, since SPI is > > a GIC terminology, this firmware interface could be used in premise with > > any parent interrupt controller, for which the concept of a SPI/PPI/SGI > > may not be relevant. > > > > While I agree the binding document may not contain specifics, I still > don't see how to use SGI with this. Also note it's generally reserved > for OS future use(IPC) and using this for other than IPC may be bit > challenging IMO. It opens up lots of questions. Well, a PPI might be possible to use, although it's somewhat dodgy to hijack the GIC's (re-)distributor from EL3 to write to GICD_ISPENDR. Need to ask Marc about his feelings towards this. But it's definitely possible from a hypervisor to inject arbitrary interrupts into a guest. But more importantly: is there any actual reason this needs to be a GIC interrupt? If I understand the code correctly, this could just be any interrupt, including one of an interrupt combiner or a GPIO chip. So why not just use the standard wording of: "exactly one interrupt specifier for each channel"? By the way: Shouldn't new bindings use the YAML format instead? Cheers, Andre.