From patchwork Mon Apr 12 09:04:34 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Raoul Strackx X-Patchwork-Id: 12197215 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-15.2 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER,INCLUDES_PATCH, MAILING_LIST_MULTI,MSGID_FROM_MTA_HEADER,SPF_HELO_NONE,SPF_PASS, USER_AGENT_SANE_1 autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id EF453C433B4 for ; Mon, 12 Apr 2021 09:06:30 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id C57F0613AE for ; Mon, 12 Apr 2021 09:06:30 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S238696AbhDLJGq (ORCPT ); Mon, 12 Apr 2021 05:06:46 -0400 Received: from mail-dm6nam12on2125.outbound.protection.outlook.com ([40.107.243.125]:21408 "EHLO NAM12-DM6-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S240142AbhDLJFA (ORCPT ); Mon, 12 Apr 2021 05:05:00 -0400 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=DsrG9CgZEgtLMhfspBfiPumfuXSle4uhoZy5pRMaIy+XiuGD8wRlCHjm/VS3lkvRDkFp+piSdMIHz/bb4Z8UO5quEqkcKyvp6Fn0rkzfhnQh18z+s8AiR/OeBYzTZEusgmUVjd3LzhYKNF0mxmNOo5Ak8K7qQAq6nJWVxBPnHWjhEwtfulhQWI/Cbzvlyr5VJ6tiirj+4/MBnOluIF3RZlaKz9P1wdf+8XPz1MkqEd9h9OPEzoTFtkjg9vQbwRdGgIQr3NJBhxMzIJ6ylGKDy/y1sePULsntG4PjcqLCVR3Rw6RHI/NZxgsTKzsalw/1qpdbO58KT1BQzoTjVgrBrA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=fc8Kck0rI90sPNfPmxxpUXA58/NsgLxjYBmzfGOsevI=; b=X5u/Q74AlxjvPxMvmMSoDk4zl63Ejg4M049kb4o0m7oYcjWNQymtMr6b1q4t2DCbyVo0TgwKGfO/nVND8CPd62f0pfcf236BbUnZKOffKcHfPjEYU9qwAhlgs5nlWNQnO7NMyUvCNrRBJQ6rUBPsr/+Gw/h6NgUVK5c+siT38jWrpnDZ8s0fhXyyO3PVplPOYQA7yDQZL/w5jHzduIKYU811L5YBvQ0u/Y7xsawLuwlkNh//6R6WFKKPapVYyGrxEJlLLnSyMRVmtgYXpP3rAKhMJAp8rTlrIUGw59iJwKPTn3lg9/mjPJRwmB+vjfjaM7A4P3GW3pGn97tHd71pMg== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=fortanix.com; dmarc=pass action=none header.from=fortanix.com; dkim=pass header.d=fortanix.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=fortanix.onmicrosoft.com; s=selector2-fortanix-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=fc8Kck0rI90sPNfPmxxpUXA58/NsgLxjYBmzfGOsevI=; b=Izj3WrK3lQkMI+/RoDtEjbTHBxJix/FBj33BsMeM+vBjDfkv3TuGgDbZNehlub0+QXxN9kaNRWzlGolz7Fg7a1Zenic1tWUW1deVXs8rtZKQgr7oporaN5uMYcY6RZRw7hUwNCH1dTeeieV4Gl/SyMqe9ZIJifEvBActT6dgHsI= Authentication-Results: vger.kernel.org; dkim=none (message not signed) header.d=none;vger.kernel.org; dmarc=none action=none header.from=fortanix.com; Received: from CY4PR11MB1783.namprd11.prod.outlook.com (2603:10b6:903:11d::20) by CY4PR11MB1384.namprd11.prod.outlook.com (2603:10b6:903:2c::12) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4020.21; Mon, 12 Apr 2021 09:04:41 +0000 Received: from CY4PR11MB1783.namprd11.prod.outlook.com ([fe80::f052:14fe:c2a9:5fb1]) by CY4PR11MB1783.namprd11.prod.outlook.com ([fe80::f052:14fe:c2a9:5fb1%3]) with mapi id 15.20.4020.022; Mon, 12 Apr 2021 09:04:41 +0000 From: Raoul Strackx Subject: [PATCH v2 1/3] x86/sgx: Adding eextend ioctl To: Jarkko Sakkinen , Dave Hansen , Thomas Gleixner , Ingo Molnar , Borislav Petkov , x86@kernel.org, "H. Peter Anvin" , linux-sgx@vger.kernel.org, linux-kernel@vger.kernel.org References: Autocrypt: addr=raoul.strackx@fortanix.com; keydata= LS0tLS1CRUdJTiBQR1AgUFVCTElDIEtFWSBCTE9DSy0tLS0tCgptUUlOQkYyb2lmOEJFQURN UkFMT1ZjRkYyTlQva1FsWTBtVnN3YlMrYi9WNzR1azZFcDdxenpoNHpHbEtSS1pzClplS0I4 WmpFT2h5Q2pZaExwdnJHTVh2cTV1bm5pWENIbG9BR1hZRm9rN0Q0SGd2Q0djYnlTYVRMQjds NHc4MFIKOStYUkp2SnJpMEdPSmVubjRnNUpIQU5RN2h5YWl5RlRIYTVERU5CMjc2VG9kZUFQ bnVidGl1VmRDT0lnQVJVbAp1dzJHemFsbmY0WmZ1TGdEaHg5YzIza2pjZTFBQkFWbWdxUEtN TkVUSnhyZFdLQUt5QkVIWGJ0Snh6YnR4bFI1CnFUZU8yTExCU2V4TFBDbTRZOTZzRHlGK3JJ a2FpRk5JQWk2b3RrTFBxYkROUlB4OTdLTTkzcmh5dVpIaWVQM1gKNWY5dG8vN0xEcGhqV0ds L0ZBcldmT2U1QTgxTnhoTG5GNm9kakMrN2JwakdkNXdvM2E5TTkya2wyelJ1bEhSUAoreFFY T2Z4NkNoNnBMSVkvbmRtSGZOVDA2ZTBCUkt1MlZxWEw4Y2Y1a2pkMW4waW1vU0FxOElGNmFq UThBdHl0CkR1T3JpTk82WGFQRVlqaHVvTzF5YnBFeDJCWE95N3J4aUN5WFlkSldJVmY3T29a c0xEM0wzTHBYM2Q4K1hZYXUKeWxab2dVaFErMHpoWlhBVnExSEkzc2duNnFIZ2RTT0J6aUJI cnhycGFvUnRhQkREL0I5WFhyM0FOTDhZWG9BegpISzJ4bDhhQTg1eWt0THlBNVc5WU1GS2Jj UXIrR1VuNStCNWRlOFN4SDgzTkR6TkljNnhtYUtKTU9xdGFiK2hHCmhRUEdtcDlmNDdGQmQ2 QkhLYzFBSHJ2OElteDAyNVdYc1lBakpZbkVlMzI1dW5MeXlUTlB5VFo0NFFBUkFRQUIKdENw U1lXOTFiQ0JUZEhKaFkydDRJRHh5WVc5MWJDNXpkSEpoWTJ0NFFHWnZjblJoYm1sNExtTnZi VDZKQWp3RQpFd0VJQUNjRkFsMm9pZjhDR3lNRkNRbG1BWUFGQ3drSUJ3SUdGUWdKQ2dzQ0JC WUNBd0VDSGdFQ0Y0QUFDZ2tRCkFrY1ROU0RvS1ZoU1B3LzQ4T0FoUExHVndWSGtsSnE0QktK ckUrc0xTMjY4RnIyeEg5SlNaN3B5YU83bm5aYXcKcjNHL0dEVmN6L0FWZVZCQXY1OW8xMW9y TmFZdFAvUzdhOWFFbUl2bVZJZitvaW9ZaXh5eXlNZk9obFNmZnloagplWkg4ZC9OZDJTajJ3 SXJ5S1BxNm9rYWY1N2pVR1dlbEFaNUZaUWJQNzFlU2E2dzNtcmQ5L1NOTFdFVTNPNWloCjRs em9HT1Fob2R6Qms2Yzh4UjZsQzJ3OHVyRkYrRnRhcmxwNkhxbWVBeHdXeHVQVDh4ZDhCMERl ODFFbjZIMFYKNjA0ekdsa0dYS1VTdXZJVHltdzEzYTJqYXQzTTRFTjNRb0lsbG5hN3N3ckly K3l4aTB3NzgvczZEU2dtVmFIZgozd0lncllMNDEwRnpCeVY1RzBDTlVuZ3lnL0d5ZWFiUVl0 ZU04NHMwRXdMRFFkWSsrYXBZN1FYVEE1d1J6bFJNClRyc0s0MDBndlF5d2lPandST2x3U1oy L2QwSjBJdXNFdnpzQXIzbUNIQTRXWnNaeWpsT3Z1UXE4LzR0ekNKN1UKVTRvVUxMWll4ZkQ3 Y1BVQXRTanBnNTFiVGhoai9nZXJDN1p4Sk1nSDM1MWR6RlowS2xsVUpHRU5QSmJkRFZ3WgpW c2lHRjdtcXVXVEwwQmpLYXl3ekgwZWdLVlh2ek56NXlrbjhJMDlTM3VvY09jSjU1bnNhR3pT WXlnZ3k3eGRoCitTMjVEVjMzWXNobU0vcGdXWW5IL3BUQzRDQUpmaGVpU0Yyd2EyR1g1bUZF QVBaQmh2Q0I2SzlXdkNKbEZXVzcKZTZ0dUpPRGdNUklQLzJ0SHJIMEFiMmFyVWJFWjhpaEdM L1pXcUIyRHlkeTJDVjU2ZjdjWVZBSndJTGtDRFFSZApxSW4vQVJBQXVEbXlwU3U1K3BFdlRt QzBBY2NUbVZnbm8xKzA0SllzckcvbVVuMG11cmFHM0xnZWtWMWVJWTVQCjVpYW05OEhiL2pI MU9kVXM5R1VCNCtLU1d4SnJERmNXNkZOcjJiZ1V1Y24wZm1XRHdOWU5oWGxJd0ZHMGRaV3MK SzNuRWlNSXJTTnhnSzBmS21jU2lpaTJhZlRMMkFTVm5JM09RcUN0RGhpU0VEWkJ3eW5BeDIx Nk4ydklNRFJVMQpiS05oVzRvNnk2R3BHNUdVQ2VBZnZ6SE5lMUNEbzQyQm5CRXUrVmlZYUE0 cERrZ3hjaC8ydk5YQTBtc25rY1BiClJmcVlhOElpSVVTUG91WWVneHZ5dVJjbEhadFA3TW5n V2ZRSmxwQVlIOHdJWExUSTlScUpmTTM1K0xZRTNQR3kKS0RYZmE3MWFFUjkxcUJWMDQzMkNn KzFQN3pJUERTR0w2TEZJaFRBTE5TV05TRFU2NXpKWlNkY1NVQ21raytWZApqZkdGbk5LeEpW OGl2ckN2TGZMY2VpQWFWK2RHaGc0WkFWWStscVdFSGxYNW03V1JXQ1Jjb3pDNUd1TlVIeW90 CngydVpHQys2TDVPTGVXeTZoUlhGSWdZWURLaWNnYTAzZjQ2WWorcDdKaTlWTGxvYWIyU0xO YlJFOERpK0xUWmQKempBMjQ4cDNTMDJpM1h5K3cxeGs4Q1VzOHVtMjlYNTVEaGtDSXdDdk5i Y3ZZcGtneTNjU3dZL2JmMm4xUnZ4aAo3MldxM2JBYXlVdC9yV0JFRTlTWkZ0cXRITUpCWVFX eDh3S244TVl5MU54YmpWZ0J0cVVaakdycW5OV3lnRStNCmFJZ3RpcUM4Q1VaU1c3dThMVW5a OUlaaGEzL2h1c0pJNXRmTHc5RmhTNXMvRzh6bWl3OEFFUUVBQVlrQ0pRUVkKQVFnQUR3VUNY YWlKL3dJYkRBVUpDV1lCZ0FBS0NSQUNSeE0xSU9ncFdHMlpELzQ1dFpmOFlvUkUxcHRQd3ov OQo5S3BIdFp5TUt5NFZLNmxXWDRCNnpHZ0hpcXpIQi9lekpwOEEzaitNc2FjM0hMZmtHdjVN UWYwRnNYUnBCZWhJClYrU0FBUmw3SktzM3pUck13TDU4QXpnNk5nbG5DZDNaYXQxU2hlWkhQ dVdXTUdCeERPMUg2UFI2NmRGWVJIM2MKODVaZHNHdWFobnJVSFBLemhZbWx4dUhDQ3FCZ3RK am9wS2NWVGsxRnRLVGUyZHJ3Z25Bb1M2dkh4bTdRTWxJVwpaMTluS25GOFAyN0pFanU0ckdX Z1h3NkgxSmFKMTF4YVVkZG9qdk53T1RKRVcvb3Jhd2tuUUF1ZW5EYnpBR1Z1CkdMV0w3T2ov RGZyTFBBemNXV25GblV2VVc2NEFEWFNBOTh0SWNBY3lod05uY2lqYnNIUkFTQlJidkg5RFhJ c2wKaEwxMDArdzZNTWNMeFpNVmJ4UHBTWWVHaGp4SjdNUysyeGp3eDB4MWlMNmszZk5UNHNT Q3dZa0xRZjJlKzhxYwpFYjNTa0Q0VFR3RDQxUW85SFNuUlkwdnRqblNyZkwyQ3JhVmptOXhh MXhmNlJDQ3kvaXpKNU5TQTZZMXduT0U3Ck1IOHorcVFUM1NxMld0a0NzU1M5K1U2VU9OWmFK dFN5MWNvZ1ZhMDV1QWdRY0tHT3FvcHg3QWlmZUhIUFpqZnIKakVNaHJZQ3Q5WXgzR1VET0hs MnRObDJIOStqZC9BVjByMDRKUTNxSHRWM1Z5UTNxN0N1UTlCTTdnQzVpK1JleQpHSU14Zm0v a09GWTRLRUxOeVYrV01PK2lXRHpZS21tTUxnUkVXNitqZk5jMzhrYWhaQjI2RmJOZTh6QmxU cVpPCmhxYmNZR1ZZNW9Ec004YSthbkwyZDhmaStnPT0KPW9ZT0QKLS0tLS1FTkQgUEdQIFBV QkxJQyBLRVkgQkxPQ0stLS0tLQo= Message-ID: <67471818-fe87-32a9-ae9e-26a21ebd37e4@fortanix.com> Date: Mon, 12 Apr 2021 11:04:34 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.10.0 In-Reply-To: Content-Language: en-US X-Originating-IP: [81.164.43.210] X-ClientProxiedBy: AM0PR10CA0057.EURPRD10.PROD.OUTLOOK.COM (2603:10a6:20b:150::37) To CY4PR11MB1783.namprd11.prod.outlook.com (2603:10b6:903:11d::20) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from [192.168.1.101] (81.164.43.210) by AM0PR10CA0057.EURPRD10.PROD.OUTLOOK.COM (2603:10a6:20b:150::37) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4020.16 via Frontend Transport; Mon, 12 Apr 2021 09:04:39 +0000 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: a48bbbfa-6622-416e-e440-08d8fd9201d2 X-MS-TrafficTypeDiagnostic: CY4PR11MB1384: X-Microsoft-Antispam-PRVS: X-MS-Oob-TLC-OOBClassifiers: OLM:248; X-MS-Exchange-SenderADCheck: 1 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: d567Lp/2nVNeNeSiwaodXrzhIHFUU1xjs00nMayB1kkxlqWB5C+w56f3qK+QdqrkDUBVUmNl7Ejv14PxltB58XEF3krY73eSsrWpBwWh4B9e3Xu0l8YryWzstR59oxGwhydBA96TZ8KpSJrYOesavEkB48LDh/ujlQNrm7e8idVkru2UwRlAVFyNrneBq4TOcZmBOPHF0ow7gPsVdiTgYdQkJjLXw4beU2uV4qRZXYmDU75Wd/G6roIc/aNjrAVvZKze6KesDWekUk4IO+9Ybs3nRrlvm9qRckRrwx1M7ihXRURYMVvzTyRtEnca2K6FSCbpt2wtjLhoA3Pe8vETCvQidvP/V9otnldtSjXuiPNHWXQWVG86wh+rNxvJcPwq4WdrIlDQk1jy+3sdYZXhEJLV2+Jmn3sfSop4dO54nc3MCqd8P0OMFFx5x5lB3kro+AK/NrTY3o2+PSDeKagNelxu4CUH3xESLRilhxIZ3egZ2Pb4cOeK0GcSSVVOqlqx990mYzZkzUpBuEBcTFpEf6B8zkHWC3tAFc5tT9U8sCGrNZ9dX5p98QShPvw/OJ3KM7m1CTvW8ghw5sk2WEtSG3UuHremTsDBhJNkCQfpk7QxzilDVcCly33VSIYlQR/SGKbY0BTdPOzvYBGhkMTb3o3n1W0sco2+TePdcD5reEWS+TlLN5qO5O980oxsDkHN2kJzb50FVo/M/rd/VIg0C9mM6Al6cLCJn/hAXyj/XVE= X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:CY4PR11MB1783.namprd11.prod.outlook.com;PTR:;CAT:NONE;SFS:(346002)(39830400003)(376002)(136003)(396003)(366004)(26005)(66476007)(6486002)(186003)(16526019)(66556008)(44832011)(5660300002)(2616005)(38350700002)(316002)(86362001)(6666004)(956004)(66946007)(52116002)(31686004)(8936002)(8676002)(110136005)(36756003)(16576012)(2906002)(83380400001)(478600001)(38100700002)(31696002)(45980500001)(43740500002);DIR:OUT;SFP:1102; X-MS-Exchange-AntiSpam-MessageData: =?utf-8?q?bwi16hUqpijciZ9TnDoX5kSQuRdIdA?= =?utf-8?q?IRZKiFkJOyy2fOZ90qK0GUliDLbVMhPDNjH8oUBYoN9agzA8ETK2dGYPb35TXkCJi?= =?utf-8?q?R6i+MEFnjwSGk3UENWuvfenwlVpb4Pv4RyXSmVt+Owk2C+dN3ORJLG2hJZcb3CvdG?= =?utf-8?q?6of9JPjWhyQYLS8EzO9+ScR8iaAR6htgEGPbNiShzLNf1o903cjNBqW3CyObW5A1c?= =?utf-8?q?ft78M9rDdjxDjL9S5yI9xDqnvKcy8Y6aQf/rJftBPmCEOR8ogCWq2lAPvoo3CBfAP?= =?utf-8?q?ZA1o4ifPUEMwufSA9jXnjcEVrRb1mDLgU14F7VCWw8wTS1cdytXdg2ixIgtkeTt6p?= =?utf-8?q?nwTSgnflSK6S7T1URnM4/dkqfKAz44nnNZ2R+2bKw4cuUdmWQ8Qonje754j39nqQs?= =?utf-8?q?71ngMuk+91zn9OZVf0iAr07fCyunBCVy5jqivTVArJVhEXhfCU4A+LtmtRQsX1nbs?= =?utf-8?q?ZKltti5yca4kwxMlNMYsT5udnrE4NX54CMgcap/soXfYWaOwLB+F6JftEHgs597q7?= =?utf-8?q?GgPlWL9nm2qOXEqd+LRc29djsfa+/SmCMpA0bZo9DzF7byRCYyXBjgUSW12sERLCO?= =?utf-8?q?L47oPNjigtvwfXwqGG5IIjMyeCldWxl+1zwxxh+dQjwri1oksCELrKz41VCiHZudi?= =?utf-8?q?cDuC7Hnx34TyiGDNNWMvi8fFESDOvQ4t1YaGzbT7gkFuRZjdBc6S/+sjyX0m/mmsr?= =?utf-8?q?X2XPP6el0+S7v0isSNGg575Mzqx8+bSPwdLlUxGe0BeFaGTu1TTwjzWzrdSHVelWP?= =?utf-8?q?4b0aVNmDu582ox3IPaHit5Oaljt4dR/yhP9/ve1BxmeonucbX98vOxLORbysA/9tK?= =?utf-8?q?6S1SojXmzI1MmvVM9kMIVL4PtqBvML9yBd0eAcaQkRetGlJakU7pV9ROHKsjYh12q?= =?utf-8?q?EBAZg5DQRG1jjywrHogBAoT4cU5QeAyfsaJLKA0y/hfwanTLZ8YAv6N7vrkIPWD2S?= =?utf-8?q?lojHAAg/K2765sykX/F2KvgulcI0jxI2g7QUkKtI8BK1wwo74/aycvBH99V/i3BJl?= =?utf-8?q?obE4j120hKXdSWsLXwU1maAncEa3D607X6p+n9zRHBFrPMNTGEqGzkv48rwND0E9R?= =?utf-8?q?IP7/0qYhL0V+GSdZK2cu/H6aBF+b2yDGGi0zr4W3UFPfC6TotONskWLyc8dDwBhQf?= =?utf-8?q?l9cMb+Rx2rDS2ND/BgCx21DU5QbM+K/2zCrpor/pzbi+4vzWLNtZHROMKNAXpK3RS?= =?utf-8?q?Vhb9OipkfzEkdzyEhLpUrLJG4YpGsIC/EUdZ+1TBQqUDYjcm7XqAlHkuSzvx/GgT9?= =?utf-8?q?DvBqHrus+UZTob?= X-OriginatorOrg: fortanix.com X-MS-Exchange-CrossTenant-Network-Message-Id: a48bbbfa-6622-416e-e440-08d8fd9201d2 X-MS-Exchange-CrossTenant-AuthSource: CY4PR11MB1783.namprd11.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 12 Apr 2021 09:04:41.2844 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: de7becae-4883-43e8-82c7-7dbdbb988ae6 X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: 0LqDf0WIXnGLkM06rTrMaRDECPCCIbZYKpp20cFBWYqICgxGzlIICGj6g6pUwd1IlucZCqt+As37KOLa2riz54xz6c9s+mUT4045PCi4tic= X-MS-Exchange-Transport-CrossTenantHeadersStamped: CY4PR11MB1384 Precedence: bulk List-ID: X-Mailing-List: linux-sgx@vger.kernel.org SGXv1 enclaves can be created by an ECREATE, followed by any number of EADD and EEXTEND functions. It is finalized by an EINIT. The SGX enclave vendor defines the order of these invocations when the enclave is being developed, and cannot be changed later on. Currently enclave measurements can only be extended per 4K measurements immediately after the page has been added by the EADD instruction. This commit adds a new ioctl to execute the EEXTEND leaf function per 256 bytes of enclave memory. In combination with the SGX_IOC_ENCLAVE_ADD_PAGES ioctl (without the SGX_PAGE_MEASURE flag), this enables the driver to load all SGXv1 compatible enclaves. Signed-off-by: Raoul Strackx --- arch/x86/include/uapi/asm/sgx.h | 11 ++++++ arch/x86/kernel/cpu/sgx/ioctl.c | 81 +++++++++++++++++++++++++++++++++++------ 2 files changed, 81 insertions(+), 11 deletions(-) diff --git a/arch/x86/include/uapi/asm/sgx.h b/arch/x86/include/uapi/asm/sgx.h index 9034f30..121ca5f 100644 --- a/arch/x86/include/uapi/asm/sgx.h +++ b/arch/x86/include/uapi/asm/sgx.h @@ -27,6 +27,8 @@ enum sgx_page_flags { _IOW(SGX_MAGIC, 0x02, struct sgx_enclave_init) #define SGX_IOC_ENCLAVE_PROVISION \ _IOW(SGX_MAGIC, 0x03, struct sgx_enclave_provision) +#define SGX_IOC_ENCLAVE_EXTEND \ + _IOW(SGX_MAGIC, 0x04, struct sgx_enclave_extend) /** * struct sgx_enclave_create - parameter structure for the @@ -57,6 +59,15 @@ struct sgx_enclave_add_pages { }; /** + * struct sgx_enclave_extend - parameter structure for the + * %SGX_IOC_ENCLAVE_MEASURE ioctl + * @offset: offset of the data from the start address for the data + */ +struct sgx_enclave_extend { + __u64 offset; +}; + +/** * struct sgx_enclave_init - parameter structure for the * %SGX_IOC_ENCLAVE_INIT ioctl * @sigstruct: address for the SIGSTRUCT data diff --git a/arch/x86/kernel/cpu/sgx/ioctl.c b/arch/x86/kernel/cpu/sgx/ioctl.c index 90a5caf..69521e9 100644 --- a/arch/x86/kernel/cpu/sgx/ioctl.c +++ b/arch/x86/kernel/cpu/sgx/ioctl.c @@ -261,20 +261,20 @@ static int __sgx_encl_add_page(struct sgx_encl *encl, return ret ? -EIO : 0; } -/* - * If the caller requires measurement of the page as a proof for the content, - * use EEXTEND to add a measurement for 256 bytes of the page. Repeat this - * operation until the entire page is measured." - */ -static int __sgx_encl_extend(struct sgx_encl *encl, - struct sgx_epc_page *epc_page) +static int __sgx_encl_extend_chunk(struct sgx_encl *encl, + void *chunk, unsigned long size) { unsigned long offset; int ret; + void *secs_addr; - for (offset = 0; offset < PAGE_SIZE; offset += SGX_EEXTEND_BLOCK_SIZE) { - ret = __eextend(sgx_get_epc_virt_addr(encl->secs.epc_page), - sgx_get_epc_virt_addr(epc_page) + offset); + if (!size || !IS_ALIGNED(size, SGX_EEXTEND_BLOCK_SIZE)) + return -EINVAL; + + secs_addr = sgx_get_epc_virt_addr(encl->secs.epc_page); + for (offset = 0; offset < size; offset += SGX_EEXTEND_BLOCK_SIZE) { + ret = __eextend(secs_addr, + chunk + offset); if (ret) { if (encls_failed(ret)) ENCLS_WARN(ret, "EEXTEND"); @@ -286,6 +286,19 @@ static int __sgx_encl_extend(struct sgx_encl *encl, return 0; } +/* + * If the caller requires measurement of the page as a proof for the content, + * use EEXTEND to add a measurement for 256 bytes of the page. Repeat this + * operation until the entire page is measured." + */ +static int __sgx_encl_extend_page(struct sgx_encl *encl, + struct sgx_epc_page *epc_page) +{ + void *chunk = sgx_get_epc_virt_addr(epc_page); + + return __sgx_encl_extend_chunk(encl, chunk, PAGE_SIZE); +} + static int sgx_encl_add_page(struct sgx_encl *encl, unsigned long src, unsigned long offset, struct sgx_secinfo *secinfo, unsigned long flags) @@ -346,7 +359,7 @@ static int sgx_encl_add_page(struct sgx_encl *encl, unsigned long src, encl->secs_child_cnt++; if (flags & SGX_PAGE_MEASURE) { - ret = __sgx_encl_extend(encl, epc_page); + ret = __sgx_encl_extend_page(encl, epc_page); if (ret) goto err_out; } @@ -466,6 +479,49 @@ static long sgx_ioc_enclave_add_pages(struct sgx_encl *encl, void __user *arg) return ret; } +static long sgx_ioc_enclave_extend(struct sgx_encl *encl, void __user *user_arg) +{ + struct sgx_enclave_extend arg; + struct sgx_encl_page *encl_page; + void *chunk; + long ret = 0; + + if (!test_bit(SGX_ENCL_CREATED, &encl->flags) || + test_bit(SGX_ENCL_INITIALIZED, &encl->flags)) + return -EINVAL; + + if (copy_from_user(&arg, user_arg, sizeof(arg))) + return -EFAULT; + + if (!arg.offset || !IS_ALIGNED(arg.offset, SGX_EEXTEND_BLOCK_SIZE)) { + pr_info("offset not a multiple of 256: %llu\n", arg.offset); + return -EINVAL; + } + + encl_page = xa_load(&encl->page_array, PFN_DOWN(encl->base + arg.offset)); + + if (!encl_page) { + pr_info("enc page not found\n"); + return -EFAULT; + } + + mmap_read_lock(current->mm); + mutex_lock(&encl->lock); + sgx_unmark_page_reclaimable(encl_page->epc_page); + + chunk = sgx_get_epc_virt_addr(encl_page->epc_page) + (arg.offset & (PAGE_SIZE - 1)); + + if (__sgx_encl_extend_chunk(encl, chunk, SGX_EEXTEND_BLOCK_SIZE)) { + pr_info("extend returned an error\n"); + ret = -EFAULT; + } + + sgx_mark_page_reclaimable(encl_page->epc_page); + mutex_unlock(&encl->lock); + mmap_read_unlock(current->mm); + return ret; +} + static int __sgx_get_key_hash(struct crypto_shash *tfm, const void *modulus, void *hash) { @@ -706,6 +762,9 @@ long sgx_ioctl(struct file *filep, unsigned int cmd, unsigned long arg) case SGX_IOC_ENCLAVE_PROVISION: ret = sgx_ioc_enclave_provision(encl, (void __user *)arg); break; + case SGX_IOC_ENCLAVE_EXTEND: + ret = sgx_ioc_enclave_extend(encl, (void __user *)arg); + break; default: ret = -ENOIOCTLCMD; break;