Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp6832170imm; Tue, 28 Aug 2018 01:37:32 -0700 (PDT) X-Google-Smtp-Source: ANB0VdbXTTP/PNIomGtgS5IZ5rXOTrKHtpDQ3GqQSdeHOHdBanJ/MgkOhYBVbco1GC+OuL2kcKHK X-Received: by 2002:a63:9841:: with SMTP id l1-v6mr539573pgo.228.1535445452342; Tue, 28 Aug 2018 01:37:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1535445452; cv=none; d=google.com; s=arc-20160816; b=y5lrJL89+Btq/qvHe3WclLUsWg/JZssgiyydgtvKAi1r6o7W+KDlvo5QZqkigulx0F bLdQkOe0cgb/mt7H+owwGiPySx7jVdXO+kC5iE8YEnClfocG+aOgE/Lxb9L04i5rk5O0 4/VMWQipJvE1OIgccr81y0vA6DGKJgr4CAOktoKO4CZMrdQ5I3X6GIP2CIuI2dG/DEKb N0qV/fhXwfR+CIjj7g3KtH/u3DzzTmxEgbYc7rsh4hprpDxGALKboVrcZYSjDsDkwyk/ s5cUimbagcJLePECpRtLkxwkIeWB31kLwNvJ2jv7SdusBI4Z8AV7n7EyV3zUNXFuOcOu d5AA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:organization:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:arc-authentication-results; bh=Vx+gDGHRTbgOPdqWJLUisjkyWAc0U+4DReil3hEGoK8=; b=nXORxUg9raUJhdUgsayBRd9Rp9EM5e0EK10UdhiVcYaifMDAAeoWgWt/XIjSmG/YAy /0fXK7clAceyeyQlFY6rEIHfYXosmhyn5EwVlNt4XUvCvbvRTzLokgP7ZgFW8m78++aO Eq9h7KlXRUFo8YZzfAYmFh4WFofzA50cI0WrJzG4Xz2b4MJTOW0MmgzPF/VqVRoXB9xJ 9iWGOaDVWePIGAUniyYYS7Fw+RSwrS+lrcQTOXnTJHC+LBVgEzGcwSiVK0RWN4iwVPOV GYRi0xNTwEV91IyeGvWL+XGVPr/E4ISoMPNzOnMaiM2hISoiOcPjv5OzoiXO8nKy7V2X n1pQ== 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=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 23-v6si427287pgo.351.2018.08.28.01.37.16; Tue, 28 Aug 2018 01:37:32 -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=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727370AbeH1M0R (ORCPT + 99 others); Tue, 28 Aug 2018 08:26:17 -0400 Received: from mga01.intel.com ([192.55.52.88]:48039 "EHLO mga01.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726997AbeH1M0R (ORCPT ); Tue, 28 Aug 2018 08:26:17 -0400 X-Amp-Result: UNKNOWN X-Amp-Original-Verdict: FILE UNKNOWN X-Amp-File-Uploaded: False Received: from fmsmga008.fm.intel.com ([10.253.24.58]) by fmsmga101.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 28 Aug 2018 01:35:43 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.53,298,1531810800"; d="scan'208";a="66541762" Received: from jsakkine-mobl1.fi.intel.com (HELO localhost) ([10.237.66.39]) by fmsmga008.fm.intel.com with ESMTP; 28 Aug 2018 01:35:40 -0700 Date: Tue, 28 Aug 2018 11:35:40 +0300 From: Jarkko Sakkinen To: Dave Hansen Cc: x86@kernel.org, platform-driver-x86@vger.kernel.org, sean.j.christopherson@intel.com, nhorman@redhat.com, npmccallum@redhat.com, linux-sgx@vger.kernel.org, Thomas Gleixner , Ingo Molnar , "H. Peter Anvin" , Suresh Siddha , Serge Ayoun , "open list:X86 ARCHITECTURE (32-BIT AND 64-BIT)" Subject: Re: [PATCH v13 09/13] x86/sgx: Enclave Page Cache (EPC) memory manager Message-ID: <20180828083540.GH15508@linux.intel.com> References: <20180827185507.17087-1-jarkko.sakkinen@linux.intel.com> <20180827185507.17087-10-jarkko.sakkinen@linux.intel.com> <7c5df14e-3028-46b3-fe93-aa6ba8352317@intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <7c5df14e-3028-46b3-fe93-aa6ba8352317@intel.com> Organization: Intel Finland Oy - BIC 0357606-4 - Westendinkatu 7, 02160 Espoo 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, Aug 27, 2018 at 02:15:34PM -0700, Dave Hansen wrote: > On 08/27/2018 11:53 AM, Jarkko Sakkinen wrote: > > +struct sgx_epc_page_ops { > > + bool (*get)(struct sgx_epc_page *epc_page); > > + void (*put)(struct sgx_epc_page *epc_page); > > + bool (*reclaim)(struct sgx_epc_page *epc_page); > > + void (*block)(struct sgx_epc_page *epc_page); > > + void (*write)(struct sgx_epc_page *epc_page); > > +}; > > Why do we need a fancy, slow (retpoline'd) set of function pointers when > we only have one user of these (the SGX driver)? KVM has its own implementation for these operations. /Jarkko