Received: by 2002:a05:6358:f14:b0:e5:3b68:ec04 with SMTP id b20csp3196017rwj; Mon, 19 Dec 2022 14:38:35 -0800 (PST) X-Google-Smtp-Source: AMrXdXstqHG1CSEuCOdkKB5pEWQky81cySSyaGcQUU7oNa0xmmZzjj6FHib02SYUwnySHa5tinE9 X-Received: by 2002:a05:6a00:3254:b0:579:6402:64ce with SMTP id bn20-20020a056a00325400b00579640264cemr10819729pfb.8.1671489515623; Mon, 19 Dec 2022 14:38:35 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1671489515; cv=none; d=google.com; s=arc-20160816; b=DKUNbTd7eFPEp1+UQZW53pZ5NlgHQmMIfU6NAeN1z6jDgru9HQfpuUHB2Q1mW+Jm2E vWBqNx1dhV3ENFQYqsPk2zhSBKLFa98iccZuzhjS10VR5gvI4C9ysR6EbRiUV6ciFbTE wN/xcs8Iq1ZAtoG6ngUrZhjdgOiGNG0ahRXPk0tn9udWOVvmSuYd3m0AHEnpLt39rRD7 Jo61c/nW7Ow48kSMQhsDAB2/mMWUvHHbs39RHOXd3TTKZfX0l6isV3AenWH0ViNgsmqk 2l8eGsRaIThOxei/RvSM0t/QjrAyDlQhYEfHNrVuHr+XlUpexjtOWOREhKkjDVlzsl6K kXnQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :dkim-signature; bh=iD7BpxEaWGuy9CQnI2WjXYNcUeX7//NhEChm1ql7rCk=; b=V+GPowZUHkFAc7b5ZInCBJbjaWHgqcUPx/NpdNmYSI8SsdcHXNq2I5XbPguUGy6hBb nMgi+UmeSEXajICZbIgPRpSzhmjYQ0kYJfGo5GvrEdZBXx0AV4DRrbxmDPgv5OUhz0jv eaPI1plKmIY/15SHStFoR6DC/6H3+1Gq3yKGAWf9QgTRZPbJghxq/5RYPDzpzQx/ZsGV X0ynnRf5dddyGEVqdH8Jn0+Ni+abqWXr/FeHKql62/97BAV4GsExS7iFAL12wu40v4PJ uL/2Z5fSuaXYLrU7BJBPqhFs+3OY/7w9wgS6ZgNMweBZVuwWwbzEfW7a3KbEhjoHzrDI BxgA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@infradead.org header.s=bombadil.20210309 header.b=uMHXHAU0; 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=kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id h9-20020aa79f49000000b005765b5bf597si11099424pfr.190.2022.12.19.14.38.25; Mon, 19 Dec 2022 14:38:35 -0800 (PST) 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=@infradead.org header.s=bombadil.20210309 header.b=uMHXHAU0; 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=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232931AbiLSWKq (ORCPT + 71 others); Mon, 19 Dec 2022 17:10:46 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35658 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232634AbiLSWKO (ORCPT ); Mon, 19 Dec 2022 17:10:14 -0500 Received: from bombadil.infradead.org (bombadil.infradead.org [IPv6:2607:7c80:54:3::133]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A9CCA15722; Mon, 19 Dec 2022 14:07:48 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=bombadil.20210309; h=Sender:In-Reply-To:Content-Type: MIME-Version:References:Message-ID:Subject:Cc:To:From:Date:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description; bh=iD7BpxEaWGuy9CQnI2WjXYNcUeX7//NhEChm1ql7rCk=; b=uMHXHAU0yvkrsxG9oduHvNGzAH aQCgxcdBI2JTBzkfArGCots01pzjHDMTSqfO+Ma3KCoQPhcyryS5P2u60lD8oQgjMtiZD4I6lr1q3 UohpRvfqhBCzWdvZfVG2jxYhdhr4Y7Ova+vYloyId2DOzYNG2mst28JJuKVcqh9jdv8bRtDEkTIO1 eUKt2gx/TBRhrlrqJVxu9fymdn0NA369WiY5ZW7HurtN0BTrptodwxaN86LH90lw2Omrr4msKFqwH vh12iomSEAdDTMPByR/4wdOrCCQ4l8+cvU0vabwq4m1RMqba741UDCKXw3aV5cqvAIrqmO/TrUrPD hsH5S7TQ==; Received: from mcgrof by bombadil.infradead.org with local (Exim 4.94.2 #2 (Red Hat Linux)) id 1p7OIV-004GEb-Rw; Mon, 19 Dec 2022 22:07:48 +0000 Date: Mon, 19 Dec 2022 14:07:47 -0800 From: Luis Chamberlain To: Allen Webb Cc: "linux-modules@vger.kernel.org" , "linux-usb@vger.kernel.org" , "linux-kernel@vger.kernel.org" , Greg Kroah-Hartman , "Rafael J. Wysocki" Subject: Re: [PATCH v9 10/10] docs: Include modules.builtin.alias Message-ID: References: <20221219191855.2010466-1-allenwebb@google.com> <20221219204619.2205248-1-allenwebb@google.com> <20221219204619.2205248-11-allenwebb@google.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: Sender: Luis Chamberlain X-Spam-Status: No, score=-4.0 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_EF,HEADER_FROM_DIFFERENT_DOMAINS, RCVD_IN_DNSWL_MED,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 Mon, Dec 19, 2022 at 03:40:42PM -0600, Allen Webb wrote: > On Mon, Dec 19, 2022 at 3:23 PM Luis Chamberlain wrote: > > > > On Mon, Dec 19, 2022 at 02:46:18PM -0600, Allen Webb wrote: > > > Update the documentation to include the presense and use case of > > > modules.builtin.alias. > > > > > > Signed-off-by: Allen Webb > > > --- > > > Documentation/kbuild/kbuild.rst | 6 ++++++ > > > 1 file changed, 6 insertions(+) > > > > > > diff --git a/Documentation/kbuild/kbuild.rst b/Documentation/kbuild/kbuild.rst > > > index 08f575e6236c..1c7c02040a54 100644 > > > --- a/Documentation/kbuild/kbuild.rst > > > +++ b/Documentation/kbuild/kbuild.rst > > > @@ -17,6 +17,12 @@ modules.builtin > > > This file lists all modules that are built into the kernel. This is used > > > by modprobe to not fail when trying to load something builtin. > > > > > > +modules.builtin.alias > > > +--------------------- > > > +This file lists all match-id based aliases for modules built into the kernel. > > > +These are intended to enable userspace to make authorization decisions based > > > +on which modules are likely to be bound to a device after it is authorized. > > > > What is an example? This sounds obscure. > > Many of the devices that match the usb_storage driver only specify the > vendor id, product id, and device id (VID:PID:D) and do not match > against device class, interface class, etc. Here are some examples > from modules.alias: A grep for wildcards in these fields yields 6136 > matches: > grep 'dc\*dsc\*dp\*ic\*isc\*ip\*in\*' > /lib/modules/5.19.11-1rodete1-amd64/modules.alias | wc -l > 6136 > > To write USBGuard policy that only authorizes devices that bind to a > particular module the policy needs to be aware of all these VID:PID:D > which can change between kernel versions. > > This is done at runtime rather than excluding modules from the build > because some devices are not needed at or before login or when a > device is locked. By not authorizing new devices that would bind to a > set of modules, these modules become unreachable to an attacker who > seeks to exploit kernel bugs in those modules. > > I could add this detail to the documentation file, but I was trying to > keep the description to about the same length as the others around it. How about the second sentence you wrote say something like: An example usage of the built-in aliases is to enable software such as USBGuard to enable / disable specific devices outside of just the vendor, product and device ID. This allows more flexible security policies in userspace. Luis