Received: by 2002:a4a:301c:0:0:0:0:0 with SMTP id q28-v6csp1223623oof; Tue, 25 Sep 2018 09:49:47 -0700 (PDT) X-Google-Smtp-Source: ACcGV62KYVzzMuveZOSGvWsdxbQSQf8/uZXa7UzWy6cED3ti6SPOEgxVZ4ojgJBnmFjrDSdQIMmg X-Received: by 2002:a62:280a:: with SMTP id o10-v6mr1976754pfo.129.1537894187023; Tue, 25 Sep 2018 09:49:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1537894186; cv=none; d=google.com; s=arc-20160816; b=nCXRf6N1VVuxi/2FD83Tbm6dFrna1s1+jlXcl9w4t5ANlyuQiVKBShG5jvyIhyiipg 8heYAV8O4hOt5kn/FTOySITTXxItxc9x636XY660lHXjQhemdjDZgXtY+MRNz6GHqEH9 Lla77MoozzsewFb7bEF/Y+wSDJPwMJkhcMy5Lx7UCSgz4x86NjmCsxGtVF8fo3edSqlT qHD0+Nfy88KFNk5ShPaP9ssnBzdP+ZWhGSKPfH2bqALrygqdXer/j+MCj2QDkTbH9PPr +ReUf+4hsMt3Nj0exEXCoh4ilGkk1FE8wVaBcMdCuM7BdjhDdTF5pA8AMO1ajsYTsuLt hsIw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=heFU0DwODxNUQSJoQ1v1t0hhE/RqcskE8/GO2iG7PKQ=; b=mKIR4aL2eZuHzpmHx9hwqTe3NhwRWdml91et2UHToog637IWq1C0UwiM2iy+0sGr6W kg17xLrp2uNSajHkgMVvP1w8GdBCUijzbV4aOaLO553V3TokonwrVrcXuhWeXX6MmhmI e+WjLtNR3yZK9xqgYzlVHsVOTtc1Mejvyf6EO2EAOmTjapF7efrzKV2jsVx1tUFbWZxj svoXt3mccaxoPk/ZtmdrhMB3IJu2C6NI98QcI7mYDk2+/RsRnkAFMZ6dyOcP6p7vX5W7 fAREbfOp2rjj+EQxso7eK9tTS+j1iExEbsi5imJEOfKCvBy9EVePk425XFhSK/0Zogw3 jX8w== 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 m7-v6si2811899pll.181.2018.09.25.09.49.31; Tue, 25 Sep 2018 09:49:46 -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 S1727347AbeIYW5N (ORCPT + 99 others); Tue, 25 Sep 2018 18:57:13 -0400 Received: from mail.skyhub.de ([5.9.137.197]:39092 "EHLO mail.skyhub.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726664AbeIYW5M (ORCPT ); Tue, 25 Sep 2018 18:57:12 -0400 X-Virus-Scanned: Nedap ESD1 at mail.skyhub.de Received: from mail.skyhub.de ([127.0.0.1]) by localhost (blast.alien8.de [127.0.0.1]) (amavisd-new, port 10026) with ESMTP id Jaqwt54nZjnL; Tue, 25 Sep 2018 18:48:51 +0200 (CEST) Received: from zn.tnic (p200300EC2BC69500329C23FFFEA6A903.dip0.t-ipconnect.de [IPv6:2003:ec:2bc6:9500:329c:23ff:fea6:a903]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.skyhub.de (SuperMail on ZX Spectrum 128k) with ESMTPSA id D74CC1EC0311; Tue, 25 Sep 2018 18:48:50 +0200 (CEST) Date: Tue, 25 Sep 2018 18:48:54 +0200 From: Borislav Petkov To: Jarkko Sakkinen Cc: x86@kernel.org, platform-driver-x86@vger.kernel.org, dave.hansen@intel.com, sean.j.christopherson@intel.com, nhorman@redhat.com, npmccallum@redhat.com, serge.ayoun@intel.com, shay.katz-zamir@intel.com, linux-sgx@vger.kernel.org, andriy.shevchenko@linux.intel.com, Thomas Gleixner , Ingo Molnar , "H. Peter Anvin" , Konrad Rzeszutek Wilk , David Woodhouse , David Wang , "Kirill A. Shutemov" , "Levin, Alexander (Sasha Levin)" , Jia Zhang , "open list:X86 ARCHITECTURE (32-BIT AND 64-BIT)" Subject: Re: [PATCH v14 04/19] x86/cpufeatures: Add SGX feature bits Message-ID: <20180925164854.GF23986@zn.tnic> References: <20180925130845.9962-1-jarkko.sakkinen@linux.intel.com> <20180925130845.9962-5-jarkko.sakkinen@linux.intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <20180925130845.9962-5-jarkko.sakkinen@linux.intel.com> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Sep 25, 2018 at 04:06:41PM +0300, Jarkko Sakkinen wrote: > From: Sean Christopherson > > Add SGX feature bits as part of the Linux defined leaf 8, which > currently contains virtualization flags. There are currently four > documented SGX feature bits, with more expected in the not-too-distant > future. ... > +static void detect_sgx(struct cpuinfo_x86 *c) > +{ > +#define _X86_FEATURE_SGX1 BIT(0) > +#define _X86_FEATURE_SGX2 BIT(1) > +#define _X86_FEATURE_SGX_ENCLV BIT(5) > +#define _X86_FEATURE_SGX_ENCLS_C BIT(6) > + > + unsigned int eax; > + > + clear_cpu_cap(c, X86_FEATURE_SGX1); > + clear_cpu_cap(c, X86_FEATURE_SGX2); > + clear_cpu_cap(c, X86_FEATURE_SGX_ENCLV); > + clear_cpu_cap(c, X86_FEATURE_SGX_ENCLS_C); > + > + if (c->cpuid_level < SGX_CPUID) { > + pr_err_once("x86/sgx: cannot enumerate CPUID leaf (0x%x)\n", > + SGX_CPUID); > + clear_cpu_cap(c, X86_FEATURE_SGX); > + return; > + } > + > + eax = cpuid_eax(SGX_CPUID); > + > + if (eax & _X86_FEATURE_SGX1) > + set_cpu_cap(c, X86_FEATURE_SGX1); > + > + if (eax & _X86_FEATURE_SGX2) > + set_cpu_cap(c, X86_FEATURE_SGX2); > + > + if (eax & _X86_FEATURE_SGX_ENCLV) > + set_cpu_cap(c, X86_FEATURE_SGX_ENCLV); > + > + if (eax & _X86_FEATURE_SGX_ENCLS_C) > + set_cpu_cap(c, X86_FEATURE_SGX_ENCLS_C); Look at arch/x86/kernel/cpu/scattered.c for how to do this properly. -- Regards/Gruss, Boris. Good mailing practices for 400: avoid top-posting and trim the reply.