From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id C5E19C83F22 for ; Thu, 17 Jul 2025 08:49:13 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id A71898D000F; Thu, 17 Jul 2025 04:49:00 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 9D4408D0008; Thu, 17 Jul 2025 04:49:00 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 803A78D0010; Thu, 17 Jul 2025 04:49:00 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0016.hostedemail.com [216.40.44.16]) by kanga.kvack.org (Postfix) with ESMTP id 5CEFA8D000D for ; Thu, 17 Jul 2025 04:49:00 -0400 (EDT) Received: from smtpin05.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay05.hostedemail.com (Postfix) with ESMTP id 246E65A493 for ; Thu, 17 Jul 2025 08:49:00 +0000 (UTC) X-FDA: 83673131640.05.24FD50F Received: from galois.linutronix.de (Galois.linutronix.de [193.142.43.55]) by imf01.hostedemail.com (Postfix) with ESMTP id 3ED6C40002 for ; Thu, 17 Jul 2025 08:48:58 +0000 (UTC) Authentication-Results: imf01.hostedemail.com; dkim=pass header.d=linutronix.de header.s=2020 header.b=0r1anL2X; dkim=pass header.d=linutronix.de header.s=2020e header.b=BY10f4Cv; dmarc=pass (policy=none) header.from=linutronix.de; spf=pass (imf01.hostedemail.com: domain of t-8ch@linutronix.de designates 193.142.43.55 as permitted sender) smtp.mailfrom=t-8ch@linutronix.de ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1752742138; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=ZBDQvUHybVGdnxlnUf0GHbOvIvdhQLf7DfYi3dD2ndo=; b=3ZPdzlpeAVGZovMbFLx6ok2WAc2gb1xgE/MkiYUMUn7n0yOKVXDR3gi22l+8JfzSevj5cC zb2XiEuw09oeyIsv05H/8WUMLXdj990f2OTne/tiEOR3S8YL5bHHnrs+sFKnNBDzi+EUxT aM1CfXJ1pwT7Qi0C/OSgkyFrcPADfyw= ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1752742138; a=rsa-sha256; cv=none; b=ppXcewdgHf59MVZtToNFQGpt0cyO8TjwoVRDQj8Mf5kE4QOazQOJkzp9z3wnqEquxt+XK2 jjn9A0v/pFx2EOaKD0DUZUxZA0A0UB1q4MxB27XBHb4faeLn6RAH7aTbeGDO01/pxElJLQ RNdJMQAFBWlIWDnKpIAzy30D4lkExHY= ARC-Authentication-Results: i=1; imf01.hostedemail.com; dkim=pass header.d=linutronix.de header.s=2020 header.b=0r1anL2X; dkim=pass header.d=linutronix.de header.s=2020e header.b=BY10f4Cv; dmarc=pass (policy=none) header.from=linutronix.de; spf=pass (imf01.hostedemail.com: domain of t-8ch@linutronix.de designates 193.142.43.55 as permitted sender) smtp.mailfrom=t-8ch@linutronix.de From: =?utf-8?q?Thomas_Wei=C3=9Fschuh?= DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020; t=1752742135; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=ZBDQvUHybVGdnxlnUf0GHbOvIvdhQLf7DfYi3dD2ndo=; b=0r1anL2XdznoHnt0YQNzoHoVPgouB7uPz0KjE2zGIk0E/YL1f49fBnD8gB/zF7on6U2IFc I7f7ZzsaeLfPBHbQgnvz5qw/FvYYnv+YsTLzm64rR2mzWZxbJQdHm+sg4ivTr3Efyl8jIu UyLHVFLT/RAXXhxsRI5LHn7Cye5b+h05WJY6UpnZ4XahvvJo0ADVob9j3D+81Z9QxvLVYM Lveq1/WEZMSxEqvMvxfaeJ35+eo5rUfzA0rSopge68bAjTIBAsqPwROKlTbsijE1PBb5h2 3mRt3my3r+LdEY9DtR8DE3ThSjB1bqyxOLZHGDUM0cz4z/laJ2WcvRO61wgPzw== DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020e; t=1752742135; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=ZBDQvUHybVGdnxlnUf0GHbOvIvdhQLf7DfYi3dD2ndo=; b=BY10f4Cvo0dik2q5QxTr5XWE8yAT2Bjh0+VuB/YSdoYqzwursG5yWt8pBlvUwfel/bM2PB Olx3ZbtWGa2Ge7Ag== Date: Thu, 17 Jul 2025 10:48:07 +0200 Subject: [PATCH v5 05/15] init: add nolibc build support MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 8bit Message-Id: <20250717-kunit-kselftests-v5-5-442b711cde2e@linutronix.de> References: <20250717-kunit-kselftests-v5-0-442b711cde2e@linutronix.de> In-Reply-To: <20250717-kunit-kselftests-v5-0-442b711cde2e@linutronix.de> To: Masahiro Yamada , Nathan Chancellor , Andrew Morton , Willy Tarreau , =?utf-8?q?Thomas_Wei=C3=9Fschuh?= , Brendan Higgins , David Gow , Rae Moar , Shuah Khan , Jonathan Corbet , Nicolas Schier , Kees Cook , Alexander Viro , Christian Brauner , Jan Kara , Christoph Hellwig , Luis Chamberlain Cc: Christophe Leroy , linux-kbuild@vger.kernel.org, linux-kernel@vger.kernel.org, linux-kselftest@vger.kernel.org, kunit-dev@googlegroups.com, linux-doc@vger.kernel.org, workflows@vger.kernel.org, linux-mm@kvack.org, linux-fsdevel@vger.kernel.org, =?utf-8?q?Thomas_Wei=C3=9Fschuh?= , Nicolas Schier X-Developer-Signature: v=1; a=ed25519-sha256; t=1752742130; l=3172; i=thomas.weissschuh@linutronix.de; s=20240209; h=from:subject:message-id; bh=jzd2GUyiQxguW35ue6s9/EhpHIGuMVbD761YRMKAxLU=; b=dmf4tJQr/51uuhkxdme9I0cExjnXB3IbgezIgvUWGaA7uD3N5c2wOPXgZ2+kxEhd8DOop2TGb 1ZHq7+H/KUDDVgv3r0H8ACgHCzcWbBg4ShFzTvi32/oMIT08FYCpnTG X-Developer-Key: i=thomas.weissschuh@linutronix.de; a=ed25519; pk=pfvxvpFUDJV2h2nY0FidLUml22uGLSjByFbM6aqQQws= X-Rspamd-Queue-Id: 3ED6C40002 X-Stat-Signature: 8wn1ck5k9tc3mjotozussabszfb6ss9o X-Rspam-User: X-Rspamd-Server: rspam11 X-HE-Tag: 1752742138-800342 X-HE-Meta: U2FsdGVkX1+hyUMd22dZ+dmlTe9+t4Apw3TTquqVUC8IkdfbC1ZHuzuVJGPt0E/zEfHe+xbhk4rBw+FMn5tqzLYW1mSrHjFNRvPpiSkuP9MXEQLeed1D9LtYGycmcypdSyWOe6zBBBeFJRmxgmf0k8r6CEsCuEX2jjRisGoS+JEkg40qwmR3SRntfGpJUhOK2OISGHKxnF5/rfsBuQbHi0i1RItYQ5Il4/3dhB6NifaItmvJfRVHufiw4cIYfPtMHV9N5HtqmgDJCoBSFMG02ZQvAi14uwlaQXfZdJqt6nvhOrPm+ku12EwrwY3sNlIAYcNfPqzZcitfFXIGBjxc4Kq6OiBa6eeDkeeBhLYmAW4YFkUePJOSS6j+8ccrgDrgcKd0FDfpcSihkwJuKmS+B9aPSZNf5bcwYpyIZK+lAxau4UWfwSWxAVNjgMJhOR+vTOAIb6+koCeVxfI/tSnTIZVGMO9JKsigr+FngnvK0Ya5PhgKNU/FQIye/5Fp8p81v7Q5f02GFxiRudIguNp1vp87jRGFkRckUhKASlqrYE5PPDMcwzbYidyPgJkIJ8qsbgqGd/0GDyODZ2fRNCIMWFOwuN8Wg0hmM59K6gHKelBPERQevJLySEgbNM0ATc9k3FJj2umgb9Zb1xaOX9BoI1liQ9dxv91QkP+ty0idr5lmQ/7Dp4tECDzcz/Gdb4cyTV8UlEUYybeVrV3gmpFN+uYOWNjPQIbSDnKb19GSHlEaXA0/62Uz1lCKl39BDaWyh/U90unXkaaWZXf+VI5h0T6SVrsvonDhZQZXNC9KTlrVFewIzXjGh7m+C1ljNroOIaLG874w7vtDwIcxgc1v0GqyG6cfv64O7t4igN0xasJc2J4UilFq9UeSDRy+DxSAJpBc4RYOyBkrqKB8A+UfgN4eWA8KyWZxID4m6/ZEP22f/1Y/arvIYC1PG9yZ5VGsHfpPfMHjA54dW3pF/rb 5M5fG5rX eTP4LrxJ55oPGv4+CWJYc+WYGczk7eNQeYVoN3EF1Bcs8rZZUSuOV5/90CktbSRrAMZLN0HoZd1aq95tWAKIGLNb4QxaKvWezD/pGDbgw89hneEf1DYL/Z1QS5DyxUGQFZ1+/D+DJwiK8bqdKCeyvv7pFNHu4gKIycC71IDN4Qfi5tIuXHZsNzfIC/utnM6EVJN71uVCnWaApcp1j7sIjjwQtpnuFGAGfIzGmM6jpjakeFhIs+ln7/YWQbTqmY2ITzWr1f+PXVxlAdl6DEeQkHSJyD94Ar2Q1mdwc1TObNksOZEaHM68eoIp602xMNELXk8SxXWpjkm4BBRPNz4kqMV8qwy+pn61U1WtnparoOwo3EeJYpZH5GKZGLBlDS+CPPHJGZAbMWMG+kIxTcZFJ4pPdjm3Vk5l3pGPIiyX8Epwds0aAnPts4MjIZU1TnTARlHpaIUdsS3lxV/s52R4T+UaguV91JvYAAlZEG0yrUeSvQkErbynUZWQr8qChQP2Z65s4x40uaCb6DTb4+Of1BwGgdF4HKi+zBImaCHR6RurQPeL6wnXAa0d8aTB7TmqqcxiGpvxIbTfCfb+O5LcoH9iDiqe5O8cylF3LldaSD29B9tXWFHqLHoHF07jgPox+w8hNwpROgDUH4bjf/nGzLJUG9lIH6DZQ2neNDv8uzmckx0c= X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: List-Subscribe: List-Unsubscribe: Building userspace applications through the kbuild "userprogs" framework requires a libc. Kernel toolchains often do not contain a libc. In this case it is useful to use the nolibc library from the kernel tree. Nolibc does not support all architectures and requires compiler flags. Add a kconfig option, so users can know where it is available and provide a variable for common options. Reviewed-by: Nicolas Schier Signed-off-by: Thomas Weißschuh --- MAINTAINERS | 2 ++ init/Kconfig | 2 ++ init/Kconfig.nolibc | 15 +++++++++++++++ init/Makefile.nolibc | 13 +++++++++++++ 4 files changed, 32 insertions(+) diff --git a/MAINTAINERS b/MAINTAINERS index a92290fffa163f9fe8fe3f04bf66426f9a894409..e806158cc6798cf97a4aab58c038fb5351d469aa 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -17702,6 +17702,8 @@ M: Willy Tarreau M: Thomas Weißschuh S: Maintained T: git git://git.kernel.org/pub/scm/linux/kernel/git/nolibc/linux-nolibc.git +F: init/Kconfig.nolibc +F: init/Makefile.nolibc F: tools/include/nolibc/ F: tools/testing/selftests/nolibc/ diff --git a/init/Kconfig b/init/Kconfig index 26cafbad4f1560fb56b4bef31ae29baf54175661..0af62f135192e0470e16eb6bb2fbb45ac38f4b81 100644 --- a/init/Kconfig +++ b/init/Kconfig @@ -92,6 +92,8 @@ config CC_CAN_LINK_STATIC default $(success,$(srctree)/scripts/cc-can-link.sh $(CC) $(CLANG_FLAGS) $(USERCFLAGS) $(USERLDFLAGS) $(m64-flag) -static) if 64BIT default $(success,$(srctree)/scripts/cc-can-link.sh $(CC) $(CLANG_FLAGS) $(USERCFLAGS) $(USERLDFLAGS) $(m32-flag) -static) +source "init/Kconfig.nolibc" + # Fixed in GCC 14, 13.3, 12.4 and 11.5 # https://gcc.gnu.org/bugzilla/show_bug.cgi?id=113921 config GCC_ASM_GOTO_OUTPUT_BROKEN diff --git a/init/Kconfig.nolibc b/init/Kconfig.nolibc new file mode 100644 index 0000000000000000000000000000000000000000..29cbc5437e70cbc5e256f00b74d0ab4801b40de7 --- /dev/null +++ b/init/Kconfig.nolibc @@ -0,0 +1,15 @@ +# SPDX-License-Identifier: GPL-2.0 + +config ARCH_HAS_NOLIBC + bool + default y if ARM + default y if ARM64 + default y if LOONGARCH + default y if M68K + default y if MIPS + default y if PPC + default y if RISCV + default y if S390 + default y if SPARC + default y if UML_X86 + default y if X86 diff --git a/init/Makefile.nolibc b/init/Makefile.nolibc new file mode 100644 index 0000000000000000000000000000000000000000..dacc78ab4c81c93f3a24ebeb70e34253842f9a53 --- /dev/null +++ b/init/Makefile.nolibc @@ -0,0 +1,13 @@ +# SPDX-License-Identifier: GPL-2.0 +# Compiler flags, which are necessary to build userspace applications with the +# in-kernel libc "nolibc". + +ifeq ($(and $(CONFIG_ARCH_HAS_NOLIBC),$(CONFIG_HEADERS_INSTALL)),y) + +NOLIBC_USERCFLAGS := -nostdlib -nostdinc -static -ffreestanding \ + -fno-asynchronous-unwind-tables -fno-stack-protector \ + -I$(objtree)/usr/include -I$(srctree)/tools/include/nolibc/ + +NOLIBC_USERLDFLAGS := -nostdlib -nostdinc -static + +endif # CONFIG_ARCH_HAS_NOLIBC && CONFIG_HEADERS_INSTALL -- 2.50.0