Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp1841988pxu; Fri, 27 Nov 2020 17:16:38 -0800 (PST) X-Google-Smtp-Source: ABdhPJw1RMbZEgl9XNS41MhmfUsnws2miK56S7ybwowr9J23JeN0KeoVzNQOA/eGs+RCIWDlwWgM X-Received: by 2002:a17:906:adcd:: with SMTP id lb13mr10452233ejb.362.1606526198499; Fri, 27 Nov 2020 17:16:38 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1606526198; cv=none; d=google.com; s=arc-20160816; b=e9tsvPeMI3GygiN70aaB6+CFdY5+3mwpVHhqhtP+/f5koICo0Lr7rICVPP9SMZqZrW XeuF7Fr0d0qLoLb7RHidAaoz+KArhnS+9D/dxnOuzAOeJr8MmpV9aoz0EcetzqgLlMLk jS15w8qWxuwg5/tCwLy6Z0uDA/Oa9leiX6x2Gh2ZMl3vElTdoF8CaFmN88LgNrron2Wb I93J6yWlwK6ITCHjc+GaJB7aCSUMH55ovsvj0xTdvR+3lAZPBeBnYmjHTlpXJmu7i2lP AePLp/5t9HAKkSGazB1aToSvPiq5Q3xj+W/zlKDVyDl7uPr+bdahML8xIvRba5kIrdmp mXUw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject; bh=fEDHinXqcp8zWj5UjJ8aG2KUs6lK+I3qGAkL6bx9Twk=; b=HQZ3edyRN37WMrq0WmwQAzmGld1N+fJc4NjnlMRYkkU84HKpoZ3EqhSrJN241X63rl AUM1dO5YJ1w6oY5oB06QaUuoyLGlJ6p2GycYBmJMnkbf5Foz/a5foS7WnIy+ED7YZ4bq v1ydHsVYoF92r6mgXBXSwt1mpUDr5kqR9RlAMoxxGSDGH/pQTmHrLrvPh6p/rGn6oxr+ lripzFBPrMHapBrSLQq0xqKb8dAAPxzj6P7bc8TlWUGS0ESZ5iNiqx/ztnuFEzL65UgW LwyeSaYawS3scXt3raXmOa20LVWY1kEIJ8/8jjP9ZZId3R+OZ35kZHy0+D1lXYmjjSrM QRiA== 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=canonical.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id e1si6360824ejf.335.2020.11.27.17.16.15; Fri, 27 Nov 2020 17:16:38 -0800 (PST) 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=canonical.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730194AbgK1Ahg (ORCPT + 99 others); Fri, 27 Nov 2020 19:37:36 -0500 Received: from youngberry.canonical.com ([91.189.89.112]:57389 "EHLO youngberry.canonical.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729872AbgK0UBY (ORCPT ); Fri, 27 Nov 2020 15:01:24 -0500 Received: from 1.general.cking.uk.vpn ([10.172.193.212]) by youngberry.canonical.com with esmtpsa (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.86_2) (envelope-from ) id 1kijPh-00030L-9O; Fri, 27 Nov 2020 19:28:13 +0000 Subject: ACK: [PATCH 1/1] efi/efi_test: read RuntimeServicesSupported To: Heinrich Schuchardt , Ivan Hu , Ard Biesheuvel Cc: linux-efi@vger.kernel.org, linux-kernel@vger.kernel.org, fwts-devel@lists.ubuntu.com References: <20201127192051.1430-1-xypron.glpk@gmx.de> From: Colin Ian King Message-ID: <98faddb2-5acc-c228-d002-71341d1c558e@canonical.com> Date: Fri, 27 Nov 2020 19:28:12 +0000 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.5.0 MIME-Version: 1.0 In-Reply-To: <20201127192051.1430-1-xypron.glpk@gmx.de> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 27/11/2020 19:20, Heinrich Schuchardt wrote: > Since the UEFI 2.8A specification the UEFI enabled firmware provides a > configuration table EFI_RT_PROPERTIES_TABLE which indicates which runtime > services are enabled. The EFI stub reads this table and saves the value of > the field RuntimeServicesSupported internally. > > The Firmware Test Suite requires the value to determine if UEFI runtime > services are correctly implemented. > > With this patch an IOCTL call is provided to read the value of the field > RuntimeServicesSupported, e.g. > > #define EFI_RUNTIME_GET_SUPPORTED_MASK \ > _IOR('p', 0x0C, unsigned int) > unsigned int mask; > fd = open("/dev/efi_test", O_RDWR); > ret = ioctl(fd, EFI_RUNTIME_GET_SUPPORTED_MASK, &mask); > > Signed-off-by: Heinrich Schuchardt > --- > drivers/firmware/efi/test/efi_test.c | 16 ++++++++++++++++ > drivers/firmware/efi/test/efi_test.h | 3 +++ > 2 files changed, 19 insertions(+) > > diff --git a/drivers/firmware/efi/test/efi_test.c b/drivers/firmware/efi/test/efi_test.c > index ddf9eae396fe..47d67bb0a516 100644 > --- a/drivers/firmware/efi/test/efi_test.c > +++ b/drivers/firmware/efi/test/efi_test.c > @@ -663,6 +663,19 @@ static long efi_runtime_query_capsulecaps(unsigned long arg) > return rv; > } > > +static long efi_runtime_get_supported_mask(unsigned long arg) > +{ > + unsigned int __user *supported_mask; > + int rv = 0; > + > + supported_mask = (unsigned int *)arg; > + > + if (put_user(efi.runtime_supported_mask, supported_mask)) > + rv = -EFAULT; > + > + return rv; > +} > + > static long efi_test_ioctl(struct file *file, unsigned int cmd, > unsigned long arg) > { > @@ -699,6 +712,9 @@ static long efi_test_ioctl(struct file *file, unsigned int cmd, > > case EFI_RUNTIME_RESET_SYSTEM: > return efi_runtime_reset_system(arg); > + > + case EFI_RUNTIME_GET_SUPPORTED_MASK: > + return efi_runtime_get_supported_mask(arg); > } > > return -ENOTTY; > diff --git a/drivers/firmware/efi/test/efi_test.h b/drivers/firmware/efi/test/efi_test.h > index f2446aa1c2e3..117349e57993 100644 > --- a/drivers/firmware/efi/test/efi_test.h > +++ b/drivers/firmware/efi/test/efi_test.h > @@ -118,4 +118,7 @@ struct efi_resetsystem { > #define EFI_RUNTIME_RESET_SYSTEM \ > _IOW('p', 0x0B, struct efi_resetsystem) > > +#define EFI_RUNTIME_GET_SUPPORTED_MASK \ > + _IOR('p', 0x0C, unsigned int) > + > #endif /* _DRIVERS_FIRMWARE_EFI_TEST_H_ */ > -- > 2.29.2 > Looks good to me. Thanks Heinrich. The EFI driver needs to be also updated in the linux kernel - has that fix been submitted or do you require the fwts team to do that? Colin