Received: by 2002:ad5:4acb:0:0:0:0:0 with SMTP id n11csp3668672imw; Mon, 18 Jul 2022 12:18:26 -0700 (PDT) X-Google-Smtp-Source: AGRyM1sl6aye5vVW0ks6+WywJuXqrYZM8JJP7xTiXJEoVCimRlUHMTW1sfD4QNfwtVlwyvY1SfSV X-Received: by 2002:a63:f854:0:b0:419:83a9:4c00 with SMTP id v20-20020a63f854000000b0041983a94c00mr26451186pgj.115.1658171906298; Mon, 18 Jul 2022 12:18:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1658171906; cv=none; d=google.com; s=arc-20160816; b=MbTlRoLCiN2Y0Sa2874JaCiEt4MO6NPuBaOeDr22owx5gAtlYXX4oxoym5G+v+CAed Xe39h6TgRabPVMW4Fs6CjYUDdUH83QIS9iggeXFqQko+bs9GZwVzE1Kh9w6gf+SThaXa 3g6q5wM/9rRQgj6Sg8wtRXtE5rcKwOshuM60yxADpdj+V8OlduxxddVFhUshtKyiPMzt BovGigN7mYhdif7BBQy1TfHF6+AqVD/MaV+oWZpPd81P8y+yR7VX8MOtLTLV2LbRoHnP e+jnojB3Pvj2h66Ohdnklg2bS9SVetFZIka0uVKtloN9hcajIJcetn+rVf93kal0XU3J xdzQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=oGCzSh7FQcHHvqBI91TyOfARkJhYG6tcxLrR4fOUTEI=; b=rnjxQq3LoOO2+P/zmtbozbpAd6aY3IuPowhlAyGDxnevjPmmncTJcFwWm+vzdeuchc Zi14pDyjVyFRDRmNMEodbLIVHzl1hbjnaxxoSk/HYqvUh5srNiOEdJADPVtwUPPITRKn ZUNmFtYlQQcAyzdnqv/yRBfmHllx8vwweAE/et8h+m3ojCn1AjD+on/nWkS04iGwvoh7 oBh0IBfhjDGwWFG54w4XsuiEdzcH5mMa469yuJZ+NnsQsT6Jb3Ktyg4kH5hJAl6WP8A4 BGu8XzHhHEFlvxMnNgxtzbe2eoKxbtZRo+7Rh5HyKTJo2wFmovdwLd1tthOD5sJCACc2 9lJA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=MvvjCy55; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id m7-20020a632607000000b00412ac9d3590si18098384pgm.413.2022.07.18.12.18.11; Mon, 18 Jul 2022 12:18:26 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=MvvjCy55; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235573AbiGRSw6 (ORCPT + 99 others); Mon, 18 Jul 2022 14:52:58 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47988 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235615AbiGRSw4 (ORCPT ); Mon, 18 Jul 2022 14:52:56 -0400 Received: from mga11.intel.com (mga11.intel.com [192.55.52.93]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A62E42613F; Mon, 18 Jul 2022 11:52:55 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1658170375; x=1689706375; h=message-id:date:mime-version:subject:to:cc:references: from:in-reply-to:content-transfer-encoding; bh=c0ZnVimJBtUWZW5UAl0hkii20Vq7jefbvdlIVd+RvNY=; b=MvvjCy55pYXgBFVEPNeE439HTOBgZ4rmtgCcwghhjOibXOrBK2Quw3yD mYCpeDNuJcu6wjGj3PrccthVbtaOMjNCaZm9TznC4uysLu4EOUZiI9uQX sUOSK2vtMyK3xMVpo9dZ+VQh2OT3e9XHFT8HtvlkNagRHvPGOHmfIbGGt OzToYD4SD/ZB6vpMwC5Cz/gA+XgTX1KqnbBaiOJP7EcVtGwtyCu2RdyWb fWj3/V1qPoR1qmBhzKqSnOGPoQW5CPa7ktzDcodRqVWTKvIIT1qFTUlmA /6ZD5RTzOVYr/epvY02xjo8pPs9WczAFrv7GUhRpSkzOwKpSa6hYxsyd9 Q==; X-IronPort-AV: E=McAfee;i="6400,9594,10412"; a="283862693" X-IronPort-AV: E=Sophos;i="5.92,281,1650956400"; d="scan'208";a="283862693" Received: from orsmga006.jf.intel.com ([10.7.209.51]) by fmsmga102.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 18 Jul 2022 11:52:55 -0700 X-IronPort-AV: E=Sophos;i="5.92,281,1650956400"; d="scan'208";a="572529935" Received: from bblaisde-mobl1.amr.corp.intel.com (HELO [10.212.195.115]) ([10.212.195.115]) by orsmga006-auth.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 18 Jul 2022 11:52:55 -0700 Message-ID: Date: Mon, 18 Jul 2022 11:52:54 -0700 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.9.1 Subject: Re: [tip: x86/urgent] x86/sgx: Set active memcg prior to shmem allocation Content-Language: en-US To: Borislav Petkov , Kristen Carlson Accardi Cc: linux-tip-commits@vger.kernel.org, Dave Hansen , Shakeel Butt , Roman Gushchin , x86@kernel.org, linux-kernel@vger.kernel.org References: <20220520174248.4918-1-kristen@linux.intel.com> <165419442842.4207.2566961916839377924.tip-bot2@tip-bot2> From: Dave Hansen In-Reply-To: Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-7.8 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A, RCVD_IN_DNSWL_HI,SPF_HELO_NONE,SPF_NONE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 7/18/22 02:50, Borislav Petkov wrote: >> -int sgx_encl_get_backing(struct sgx_encl *encl, unsigned long page_index, >> - struct sgx_backing *backing); >> +int sgx_encl_lookup_backing(struct sgx_encl *encl, unsigned long page_index, >> + struct sgx_backing *backing); >> +int sgx_encl_alloc_backing(struct sgx_encl *encl, unsigned long page_index, >> + struct sgx_backing *backing); >> void sgx_encl_put_backing(struct sgx_backing *backing); > So this is making the sgx_encl_get_backing() thing static but its > counterpart sgx_encl_put_backing() is not and is still called by other > places. > > Perhaps something wrong with the layering or is this on purpose? All three of the: sgx_encl_get_backing() sgx_encl_lookup_backing() sgx_encl_alloc_backing() functions take a reference on the backing storage that must be dropped with sgx_encl_put_backing(). The "lookup" and "alloc" were added because there really are two different users: 1. I want to *create* backing storage space (alloc) 2. I want to find *existing* backing storage (lookup) and those two logical uses need different cgroup accounting semantics. As a further cleanup, it would probably be nice to explicitly document that "lookup" and "alloc" also require a subsequent "put". It would also be nice to change sgx_encl_get_backing() to __sgx_encl_get_backing() to make it clear that it's an internal thing. So, I think the _code_ is OK as-is, but it could use some more love.