From: Sasha Levin <sashal@kernel.org>
To: linux-kernel@vger.kernel.org, stable@vger.kernel.org
Cc: Masahiro Yamada <masahiroy@kernel.org>,
Sasha Levin <sashal@kernel.org>,
linux-kbuild@vger.kernel.org
Subject: [PATCH AUTOSEL 5.10 32/88] kbuild: sink stdout from cmd for silent build
Date: Wed, 14 Jul 2021 15:42:07 -0400 [thread overview]
Message-ID: <20210714194303.54028-32-sashal@kernel.org> (raw)
In-Reply-To: <20210714194303.54028-1-sashal@kernel.org>
From: Masahiro Yamada <masahiroy@kernel.org>
[ Upstream commit 174a1dcc96429efce4ef7eb2f5c4506480da2182 ]
When building with 'make -s', no output to stdout should be printed.
As Arnd Bergmann reported [1], mkimage shows the detailed information
of the generated images.
I think this should be suppressed by the 'cmd' macro instead of by
individual scripts.
Insert 'exec >/dev/null;' in order to redirect stdout to /dev/null for
silent builds.
[Note about this implementation]
'exec >/dev/null;' may look somewhat tricky, but this has a reason.
Appending '>/dev/null' at the end of command line is a common way for
redirection, so I first tried this:
cmd = @set -e; $(echo-cmd) $(cmd_$(1)) >/dev/null
... but it would not work if $(cmd_$(1)) itself contains a redirection.
For example, cmd_wrap in scripts/Makefile.asm-generic redirects the
output from the 'echo' command into the target file.
It would be expanded into:
echo "#include <asm-generic/$*.h>" > $@ >/dev/null
Then, the target file gets empty because the string will go to /dev/null
instead of $@.
Next, I tried this:
cmd = @set -e; $(echo-cmd) { $(cmd_$(1)); } >/dev/null
The form above would be expanded into:
{ echo "#include <asm-generic/$*.h>" > $@; } >/dev/null
This works as expected. However, it would be a syntax error if
$(cmd_$(1)) is empty.
When CONFIG_TRIM_UNUSED_KSYMS is disabled, $(call cmd,gen_ksymdeps) in
scripts/Makefile.build would be expanded into:
set -e; { ; } >/dev/null
..., which causes an syntax error.
I also tried this:
cmd = @set -e; $(echo-cmd) ( $(cmd_$(1)) ) >/dev/null
... but this causes a syntax error for the same reason.
So, finally I adopted:
cmd = @set -e; $(echo-cmd) exec >/dev/null; $(cmd_$(1))
[1]: https://lore.kernel.org/lkml/20210514135752.2910387-1-arnd@kernel.org/
Signed-off-by: Masahiro Yamada <masahiroy@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
---
scripts/Kbuild.include | 7 ++++++-
1 file changed, 6 insertions(+), 1 deletion(-)
diff --git a/scripts/Kbuild.include b/scripts/Kbuild.include
index 08e011175b4c..0d6e11820791 100644
--- a/scripts/Kbuild.include
+++ b/scripts/Kbuild.include
@@ -174,8 +174,13 @@ clean := -f $(srctree)/scripts/Makefile.clean obj
echo-cmd = $(if $($(quiet)cmd_$(1)),\
echo ' $(call escsq,$($(quiet)cmd_$(1)))$(echo-why)';)
+# sink stdout for 'make -s'
+ redirect :=
+ quiet_redirect :=
+silent_redirect := exec >/dev/null;
+
# printing commands
-cmd = @set -e; $(echo-cmd) $(cmd_$(1))
+cmd = @set -e; $(echo-cmd) $($(quiet)redirect) $(cmd_$(1))
###
# if_changed - execute command if any prerequisite is newer than
--
2.30.2
next prev parent reply other threads:[~2021-07-14 19:49 UTC|newest]
Thread overview: 88+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-07-14 19:41 [PATCH AUTOSEL 5.10 01/88] ARM: dts: gemini: rename mdio to the right name Sasha Levin
2021-07-14 19:41 ` [PATCH AUTOSEL 5.10 02/88] ARM: dts: gemini: add device_type on pci Sasha Levin
2021-07-14 19:41 ` [PATCH AUTOSEL 5.10 03/88] ARM: dts: rockchip: Fix thermal sensor cells o rk322x Sasha Levin
2021-07-14 19:41 ` [PATCH AUTOSEL 5.10 04/88] ARM: dts: rockchip: fix pinctrl sleep nodename for rk3036-kylin and rk3288 Sasha Levin
2021-07-14 19:41 ` [PATCH AUTOSEL 5.10 05/88] arm64: dts: rockchip: fix pinctrl sleep nodename for rk3399.dtsi Sasha Levin
2021-07-14 19:41 ` [PATCH AUTOSEL 5.10 06/88] ARM: dts: rockchip: Fix the timer clocks order Sasha Levin
2021-07-14 19:41 ` [PATCH AUTOSEL 5.10 07/88] ARM: dts: rockchip: Fix IOMMU nodes properties on rk322x Sasha Levin
2021-07-14 19:41 ` [PATCH AUTOSEL 5.10 08/88] ARM: dts: rockchip: Fix power-controller node names for rk3066a Sasha Levin
2021-07-14 19:41 ` [PATCH AUTOSEL 5.10 09/88] ARM: dts: rockchip: Fix power-controller node names for rk3188 Sasha Levin
2021-07-14 19:41 ` [PATCH AUTOSEL 5.10 10/88] ARM: dts: rockchip: Fix power-controller node names for rk3288 Sasha Levin
2021-07-14 19:41 ` [PATCH AUTOSEL 5.10 11/88] arm64: dts: rockchip: Fix power-controller node names for px30 Sasha Levin
2021-07-14 19:41 ` [PATCH AUTOSEL 5.10 12/88] arm64: dts: rockchip: Fix power-controller node names for rk3328 Sasha Levin
2021-07-14 19:41 ` [PATCH AUTOSEL 5.10 13/88] arm64: dts: rockchip: Fix power-controller node names for rk3399 Sasha Levin
2021-07-14 19:41 ` [PATCH AUTOSEL 5.10 14/88] reset: ti-syscon: fix to_ti_syscon_reset_data macro Sasha Levin
2021-07-14 19:41 ` [PATCH AUTOSEL 5.10 15/88] ARM: brcmstb: dts: fix NAND nodes names Sasha Levin
2021-07-14 19:41 ` [PATCH AUTOSEL 5.10 16/88] ARM: Cygnus: " Sasha Levin
2021-07-14 19:41 ` [PATCH AUTOSEL 5.10 17/88] ARM: NSP: " Sasha Levin
2021-07-14 19:41 ` [PATCH AUTOSEL 5.10 18/88] ARM: dts: BCM63xx: Fix " Sasha Levin
2021-07-14 19:41 ` [PATCH AUTOSEL 5.10 19/88] ARM: dts: Hurricane 2: " Sasha Levin
2021-07-14 19:41 ` [PATCH AUTOSEL 5.10 20/88] ARM: dts: imx25-pinfunc: Fix gpio function name for pads GPIO_[A-F] Sasha Levin
2021-07-14 19:41 ` [PATCH AUTOSEL 5.10 21/88] ARM: dts: exynos: align Broadcom WiFi with dtschema Sasha Levin
2021-07-14 19:41 ` [PATCH AUTOSEL 5.10 22/88] ARM: dts: imx6: phyFLEX: Fix UART hardware flow control Sasha Levin
2021-07-14 19:41 ` [PATCH AUTOSEL 5.10 23/88] ARM: imx: pm-imx5: Fix references to imx5_cpu_suspend_info Sasha Levin
2021-07-14 19:41 ` [PATCH AUTOSEL 5.10 24/88] arm64: dts: rockchip: fix regulator-gpio states array Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 25/88] ARM: dts: ux500: Fix interrupt cells Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 26/88] ARM: dts: ux500: Rename gpio-controller node Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 27/88] ARM: dts: ux500: Fix orientation of accelerometer Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 28/88] ARM: dts: imx6dl-riotboard: configure PHY clock and set proper EEE value Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 29/88] rtc: mxc_v2: add missing MODULE_DEVICE_TABLE Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 30/88] arm64: dts: renesas: beacon: Fix USB extal reference Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 31/88] arm64: dts: renesas: beacon: Fix USB ref clock references Sasha Levin
2021-07-14 19:42 ` Sasha Levin [this message]
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 33/88] ARM: dts: am335x: align GPIO hog names with dt-schema Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 34/88] ARM: dts: am437x: align gpio " Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 35/88] ARM: dts: omap3: " Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 36/88] ARM: dts: omap5-board-common: " Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 37/88] ARM: dts: dra7x-evm: Align GPIO " Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 38/88] ARM: dts: am57xx-cl-som-am57x: fix ti,no-reset-on-init flag for gpios Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 39/88] ARM: dts: am437x-gp-evm: " Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 40/88] ARM: dts: am335x: " Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 41/88] ARM: dts: OMAP2+: Replace underscores in sub-mailbox node names Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 42/88] arm64: dts: ti: k3-am654x/j721e/j7200-common-proc-board: Fix MCU_RGMII1_TXC direction Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 43/88] ARM: tegra: wm8903: Fix polarity of headphones-detection GPIO in device-trees Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 44/88] ARM: tegra: nexus7: Correct 3v3 regulator GPIO of PM269 variant Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 45/88] arm64: dts: qcom: msm8996: Make CPUCC actually probe (and work) Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 46/88] arm64: dts: qcom: sc7180: Move rmtfs memory region Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 47/88] ARM: dts: stm32: Remove extra size-cells on dhcom-pdk2 Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 48/88] ARM: dts: stm32: Fix touchscreen node " Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 49/88] ARM: dts: stm32: fix stm32mp157c-odyssey card detect pin Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 50/88] ARM: dts: stm32: fix gpio-keys node on STM32 MCU boards Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 51/88] ARM: dts: stm32: fix RCC node name on stm32f429 MCU Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 52/88] ARM: dts: stm32: fix timer nodes on STM32 MCU to prevent warnings Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 53/88] memory: tegra: Fix compilation warnings on 64bit platforms Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 54/88] firmware: arm_scmi: Add SMCCC discovery dependency in Kconfig Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 55/88] firmware: arm_scmi: Fix the build when CONFIG_MAILBOX is not selected Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 56/88] ARM: dts: bcm283x: Fix up MMC node names Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 57/88] ARM: dts: bcm283x: Fix up GPIO LED " Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 58/88] arm64: dts: juno: Update SCPI nodes as per the YAML schema Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 59/88] ARM: dts: rockchip: fix supply properties in io-domains nodes Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 60/88] ARM: dts: stm32: fix i2c node name on stm32f746 to prevent warnings Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 61/88] ARM: dts: stm32: move stmmac axi config in ethernet node on stm32mp15 Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 62/88] ARM: dts: stm32: fix the Odyssey SoM eMMC VQMMC supply Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 63/88] ARM: dts: stm32: Drop unused linux,wakeup from touchscreen node on DHCOM SoM Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 64/88] ARM: dts: stm32: Rename spi-flash/mx66l51235l@N to flash@N " Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 65/88] ARM: dts: stm32: fix stpmic node for stm32mp1 boards Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 66/88] ARM: OMAP2+: Block suspend for am3 and am4 if PM is not configured Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 67/88] soc/tegra: fuse: Fix Tegra234-only builds Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 68/88] firmware: tegra: bpmp: " Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 69/88] arm64: dts: ls208xa: remove bus-num from dspi node Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 70/88] arm64: dts: imx8mq: assign PCIe clocks Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 71/88] thermal/core: Correct function name thermal_zone_device_unregister() Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 72/88] thermal/drivers/rcar_gen3_thermal: Do not shadow rcar_gen3_ths_tj_1 Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 73/88] thermal/drivers/imx_sc: Add missing of_node_put for loop iteration Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 74/88] thermal/drivers/sprd: " Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 75/88] kbuild: mkcompile_h: consider timestamp if KBUILD_BUILD_TIMESTAMP is set Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 76/88] arch/arm64/boot/dts/marvell: fix NAND partitioning scheme Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 77/88] rtc: max77686: Do not enforce (incorrect) interrupt trigger type Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 78/88] scsi: aic7xxx: Fix unintentional sign extension issue on left shift of u8 Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 79/88] scsi: libsas: Add LUN number check in .slave_alloc callback Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 80/88] scsi: be2iscsi: Fix some missing space in some messages Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 81/88] scsi: libfc: Fix array index out of bound exception Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 82/88] scsi: qedf: Add check to synchronize abort and flush Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 83/88] sched/fair: Fix CFS bandwidth hrtimer expiry type Sasha Levin
2021-07-14 19:42 ` [PATCH AUTOSEL 5.10 84/88] perf/x86/intel/uncore: Clean up error handling path of iio mapping Sasha Levin
2021-07-14 19:43 ` [PATCH AUTOSEL 5.10 85/88] thermal/core/thermal_of: Stop zone device before unregistering it Sasha Levin
2021-07-14 19:43 ` [PATCH AUTOSEL 5.10 86/88] s390/traps: do not test MONITOR CALL without CONFIG_BUG Sasha Levin
2021-07-14 19:43 ` [PATCH AUTOSEL 5.10 87/88] s390: introduce proper type handling call_on_stack() macro Sasha Levin
2021-07-14 19:43 ` [PATCH AUTOSEL 5.10 88/88] cifs: prevent NULL deref in cifs_compose_mount_options() Sasha Levin
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20210714194303.54028-32-sashal@kernel.org \
--to=sashal@kernel.org \
--cc=linux-kbuild@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=masahiroy@kernel.org \
--cc=stable@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).