Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp1518181pxb; Wed, 12 Jan 2022 17:09:53 -0800 (PST) X-Google-Smtp-Source: ABdhPJxe+x6W75X9ii1DcwbOg7V8uNgh0k5v+RwX2n3xe8ajJeYUwGKMAwA24yV35Pa6M2nBEqYk X-Received: by 2002:aa7:dc53:: with SMTP id g19mr2071818edu.294.1642036193296; Wed, 12 Jan 2022 17:09:53 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1642036193; cv=none; d=google.com; s=arc-20160816; b=VKUf4vIvAADx2LSBdl0Gq4mVlC6DN5HOS0XVGE2mquNczk5QtPHG6SH3rO+CtMzuyN IcaZ+DjEWTiT3hTg/V2eX+Dn/Hx0C7NcTix4MnY+8v0TxGOWA3bemPu7tTBBx44pf7lP wSoUu2Vd/WPoOEbd66dHV+AaitNTpCbI3lGHdwgxl6G3T4KVN0DwIbMWpJyeQPY13q1H vhgWWB40AC1XplZFbN+U2UXMB1yIPY3z81JIFCYEtq7L6L1FgmDbprEVlaniZ5qf+gCB w0MFNCs12JENj9EmROwf505pdZ2N5In1qZrKqnFBo1r7VPG9cMHRHd5lvxOjn/u28OlC NN+Q== 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:subject :from:references:cc:to:content-language:user-agent:mime-version:date :message-id; bh=izJhbA/PdUJyUmH9lZ7p5jFRTEUhiw4A5svyCPv5dbM=; b=oumblSMQO38fh28HsD4zs/qJF3Jc7LVqWsvZmKyVnoyIcksFIQveX4Si9+NZ4T9j+i OsqWO/tGT8BeNbJjAdyZ4I9PHcobtpTMDg02yQL5/o/9vcsTREBZ6VlJN8jcHcK4V5lI Xknnkm6YVa4Xg44ceZXxNVbp2/eIG1XDVhtFDv97IwwIu4GeGFuQTcnllQKcSy+D6JgP oLvDHXL9lcMIBejwrMknz0R6QHv0Uyn9XjiWRt6oAqTpM/pIDjCnqVkByYSoo6okNpDm kN8o82DDCv2nrXCmnK2ecmYBYaSiqXySOL799AssAYc5O4R2o8gb0wd75Qu5+0Ounk5P yZjQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-crypto-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-crypto-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id i17si748922ejw.199.2022.01.12.17.09.03; Wed, 12 Jan 2022 17:09:53 -0800 (PST) Received-SPF: pass (google.com: domain of linux-crypto-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-crypto-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-crypto-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1357139AbiALUPy (ORCPT + 99 others); Wed, 12 Jan 2022 15:15:54 -0500 Received: from vps-vb.mhejs.net ([37.28.154.113]:55462 "EHLO vps-vb.mhejs.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1350686AbiALUPy (ORCPT ); Wed, 12 Jan 2022 15:15:54 -0500 Received: from MUA by vps-vb.mhejs.net with esmtps (TLS1.2) tls TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256 (Exim 4.94.2) (envelope-from ) id 1n7k24-0005Dj-Rb; Wed, 12 Jan 2022 21:15:44 +0100 Message-ID: Date: Wed, 12 Jan 2022 21:15:38 +0100 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.4.0 Content-Language: en-US To: Roberto Sassu Cc: "keyrings@vger.kernel.org" , "linux-crypto@vger.kernel.org" , "linux-integrity@vger.kernel.org" , "linux-fscrypt@vger.kernel.org" , "linux-kernel@vger.kernel.org" , "zohar@linux.ibm.com" , "ebiggers@kernel.org" , "dhowells@redhat.com" , "dwmw2@infradead.org" , "herbert@gondor.apana.org.au" , "davem@davemloft.net" References: <20220111180318.591029-1-roberto.sassu@huawei.com> From: "Maciej S. Szmigiero" Subject: Re: [PATCH 00/14] KEYS: Add support for PGP keys and signatures In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-crypto@vger.kernel.org On 12.01.2022 10:16, Roberto Sassu wrote: >> From: Maciej S. Szmigiero [mailto:mail@maciej.szmigiero.name] >> Sent: Tuesday, January 11, 2022 9:33 PM >> On 11.01.2022 19:03, Roberto Sassu wrote: >>> Support for PGP keys and signatures was proposed by David long time ago, >>> before the decision of using PKCS#7 for kernel modules signatures >>> verification was made. After that, there has been not enough interest to >>> support PGP too. >>> >>> Lately, when discussing a proposal of introducing fsverity signatures in >>> Fedora [1], developers expressed their preference on not having a separate >>> key for signing, which would complicate the management of the distribution. >>> They would be more in favor of using the same PGP key, currently used for >>> signing RPM headers, also for file-based signatures (not only fsverity, but >>> also IMA ones). >> >> Aren't PGP keys simply RSA / ECC / EdDSA keys with additional metadata? >> Can't they be unwrapped from their (complex) PGP format in userspace and >> loaded raw into the kernel, in a similar way as they are sometimes used >> for SSH authentication? > > Probably, this would be possible by introducing a new asymmetric > key subtype parsing PGP keys and signatures in a more simple format, > after conversion by user space. But still, a parser would be required. > To be honest, I would prefer to implement (actually David did) a > parser following an RFC, than developing a new one. A parser in userspace is preferred to one in kernel since if there is a bug somewhere its consequences are much less severe. And experience shows that parsers are especially prone to bugs. A userspace implementation can also be tightly sandboxed for extra security. There are many existing OpenPGP parsing libraries to choose from. >> This will save us from having to add complex parsers (a well-known source >> of bugs) into the kernel - I guess there aren't any plans to add an >> in-kernel PGP Web of Trust implementation. > > I extensively tested the implementation with an ad-hoc fault injector, > to see if the code can correctly handle errors. I also developed a > fuzzer to corrupt the data before it is read by the kernel. Finally, > I checked that there are not memory leaks. But I agree, there could > still be bugs. > > If you mean that a key can be added to the kernel if is vouched for > by another key in the built-in keyring, I actually implemented this > (was missing in the original implementation). Some keyrings, e.g. .ima, > have this restriction. > > The way this works is that, whenever you add a PGP key to the > kernel, the parser takes not only the public key and the user ID, > but also its signature by the same or another PGP key. > > The signature is verified when the key is added to the keyring > with that restriction, and only if the verification is successful > the key can be added. I understand but it would be great to make use as much as possible of the existing in-kernel signature verification mechanisms. > Roberto Thanks, Maciej