Received: by 2002:a05:6358:7058:b0:131:369:b2a3 with SMTP id 24csp5426580rwp; Mon, 17 Jul 2023 04:08:13 -0700 (PDT) X-Google-Smtp-Source: APBJJlELqjJT9v3oifkshlKwcwelBu8385quBJahbxvM3F8dfTiG9+5aSx7XjuUpVriGmg14E/WN X-Received: by 2002:a17:906:3956:b0:991:d727:6977 with SMTP id g22-20020a170906395600b00991d7276977mr9633991eje.38.1689592093144; Mon, 17 Jul 2023 04:08:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1689592093; cv=none; d=google.com; s=arc-20160816; b=tQwCbQuwrg+e/02nheFJ9WHKFiDSYtTIN9C383RYhLTr6SHV+HQz/pKo0ziYi+/DTm ErufKYtIFrHezYgH6SxUc7uZcyvok5Aa3NG9YOFrzFrCK0v4gng3RSbzB37KlO8OZ9z6 CEEwfyEZV2RjZmYyhNxa++KARsKma6OrXJJ7cLRzPnVtCFurgChfE5ejIrKEgrVEuCCU o6A9zrCtkXd2Jt6D5asGiBwE6gY0ZQAQlxIYgL1edv2PCzQPoU91/ZCIcWgNu+I3/37m VKV74C+OekpgFjG86scOhx6t8OYA2M2Zg0YaVqm2qzQggJq8F4rv4c1r7AXDsExIf3uJ Dyyw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature:dkim-signature; bh=eUec1+EitZahVX/PmsSDqXXCbGH3k6qkThntzyMYwBE=; fh=AVdnBkCzYGOB5oRrOKcaACuRLonL9A4Pn6PwCHl69B0=; b=Ojzg9No3EG5m38w2DYDR7iltTmSvPy40d43BHysx5CjSaPIQdJ7MedywspVRdBmy51 BjE2OjzCVAVogr/QndmOVs+jZf6sVw62WANlLy0cV97VfXrhTpm4TmVQHUdNV18k/kEc gTcSCvm/tcgvGDfyQl2uEee5xZRervqM2mFxreUvJnp0fibejDIMk5KOlFyxEyVpWGDP mIdaOavKDChY/19zen468WqDUTLAJDNoLeGJPxiMHOPDL5VUBonZzd/jTVVDdKslAPjC 3Tr3cfH1jRuw0lL2UsxYOS10+OZTRNvi1VB9ioIJFmQmsBB913lUmLsSVmrEnfEI+BfQ caew== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@suse.de header.s=susede2_rsa header.b=PdA1u9+e; dkim=neutral (no key) header.i=@suse.de header.b=zy2RnRLU; 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=suse.de Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id u11-20020a17090657cb00b00993afed2932si13410035ejr.324.2023.07.17.04.07.48; Mon, 17 Jul 2023 04:08:13 -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=@suse.de header.s=susede2_rsa header.b=PdA1u9+e; dkim=neutral (no key) header.i=@suse.de header.b=zy2RnRLU; 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=suse.de Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230218AbjGQKkO (ORCPT + 99 others); Mon, 17 Jul 2023 06:40:14 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:48420 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229973AbjGQKkG (ORCPT ); Mon, 17 Jul 2023 06:40:06 -0400 Received: from smtp-out1.suse.de (smtp-out1.suse.de [195.135.220.28]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id D196A83; Mon, 17 Jul 2023 03:40:04 -0700 (PDT) Received: from relay2.suse.de (relay2.suse.de [149.44.160.134]) by smtp-out1.suse.de (Postfix) with ESMTP id 83B8821923; Mon, 17 Jul 2023 10:40:03 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=suse.de; s=susede2_rsa; t=1689590403; h=from:from:reply-to:date:date:message-id:message-id:to:to:cc:cc: mime-version:mime-version: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=eUec1+EitZahVX/PmsSDqXXCbGH3k6qkThntzyMYwBE=; b=PdA1u9+ezNuB4QcKhWJap3NtjoAlviQRb5xVemfpfO+bu5sHORVeyTdMu/GR8a3RX75r9E 2gngUyW3LB3wtjMLgHvY1JYkVLEXI4DhhalmyOZnEzhoxsArrFtHhPL9/l356Cib3QCrWl DeRHojVFtTl5zjZxB0ZN/1yJ6/2+pus= DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=suse.de; s=susede2_ed25519; t=1689590403; h=from:from:reply-to:date:date:message-id:message-id:to:to:cc:cc: mime-version:mime-version: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=eUec1+EitZahVX/PmsSDqXXCbGH3k6qkThntzyMYwBE=; b=zy2RnRLU6aR9cgMn1nERiTadxzietXO1gVmV8OQQ1VFNijHMWwy9iUcdY4mPy46I74P68S oxnMcEfRtVm/JhCg== Received: from kitsune.suse.cz (kitsune.suse.cz [10.100.12.127]) by relay2.suse.de (Postfix) with ESMTP id 2512A2C142; Mon, 17 Jul 2023 10:40:03 +0000 (UTC) From: Michal Suchanek To: linux-modules@vger.kernel.org Cc: Michal Suchanek , Takashi Iwai , Lucas De Marchi , =?UTF-8?q?Michal=20Koutn=C3=BD?= , Jiri Slaby , Jan Engelhardt , Masahiro Yamada , Nathan Chancellor , Nick Desaulniers , Nicolas Schier , linux-kbuild@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH kmod v4 0/4] kmod /usr support Date: Mon, 17 Jul 2023 12:39:49 +0200 Message-ID: X-Mailer: git-send-email 2.41.0 In-Reply-To: <20230711153126.28876-1-msuchanek@suse.de> References: <20230711153126.28876-1-msuchanek@suse.de> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_BLOCKED, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE 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 Hello, with these patches it is possible to install kernel modules in an arbitrary directory - eg. moving the /lib/modules to /usr/lib/modules or /opt/linux. While the modprobe.d and depmod.d search which already includes multiple paths is expanded to also include $(prefix) the module directory still supports only one location, only a different one under $(module_directory). Having kmod search multiple module locations while only one is supported now might break some assumption about relative module path corresponding to a specific file, would require more invasive changes to implement, and is not supportive of the goal of moving the modules away from /lib. Both kmod and the kernel need to be patched to make use of this feature. Patched kernel is backwards compatible with older kmod. Patched kmod with $(module_directory) set to /lib/modules is equivalent to unpatched kmod. With this patch the kmod tool can spit out a JSON with the tool build-time configuration, and jq is used for getting a single value out of that. I opted for this because crating .pc files requires putting the logic into the autohell files which is very clumsy. Also pkg-config insists on hiding the actual .pc file data and only allowing clumsy queries through its commandline interface. jq has its downsides, too. So far it is not used by kernel build, only by other tools shipped with the kernel. This adds another dependency for kernel builds. It turns out that the kernel already does use pkg-config. There are two alternate spellings: pkg-config and pkgconfig. Searching for the latter gives a few matches in the kernel giving off the impression that it's a thing but not really used. Thanks Michal Link: https://lore.kernel.org/linux-modules/20210112160211.5614-1-msuchanek@suse.de/ Michal Suchanek (4): man/depmod.d: Fix incorrect /usr/lib search path libkmod, depmod: Load modprobe.d, depmod.d from $prefix/lib. kmod: Add config command to show compile time configuration as JSON libkmod, depmod, modprobe: Make directory for kernel modules configurable Makefile.am | 4 +- configure.ac | 7 ++ libkmod/libkmod.c | 11 +-- man/Makefile.am | 10 ++- man/depmod.d.xml | 9 ++- man/depmod.xml | 4 +- man/kmod.xml | 6 ++ man/modinfo.xml | 2 +- man/modprobe.d.xml | 1 + man/modprobe.xml | 2 +- man/modules.dep.xml | 6 +- testsuite/module-playground/Makefile | 2 +- testsuite/setup-rootfs.sh | 109 +++++++++++++++------------ testsuite/test-depmod.c | 16 ++-- testsuite/test-testsuite.c | 8 +- tools/depmod.c | 7 +- tools/kmod.c | 41 ++++++++++ tools/modinfo.c | 4 +- tools/modprobe.c | 4 +- tools/static-nodes.c | 6 +- 20 files changed, 169 insertions(+), 90 deletions(-) -- 2.41.0