On Tue, May 10, 2022 at 7:04 PM Nicolas Schier <n.schier@xxxxxx> wrote: > > On Tue, 3 May 2022 11:47 +0900 Masahiro Yamada wrote: > > Many architectures have similar install.sh scripts. > > > > The first half is really generic; verifies that the kernel image and > > System.map exist, then executes ~/bin/${INSTALLKERNEL} or > > /sbin/${INSTALLKERNEL} if available. > > > > The second half is kind of arch-specific. It just copies the kernel image > > and System.map to the destination, but the code is slightly different. > > > > This patch factors out the generic part into scripts/install.sh. > > > > Signed-off-by: Masahiro Yamada <masahiroy@xxxxxxxxxx> > > --- > > > > Changes in v2: > > - Move the installkernel parameters to scripts/install.sh > > > > Makefile | 3 ++- > > arch/arm/Makefile | 4 ++-- > > arch/arm/boot/install.sh | 21 ------------------ > > arch/arm64/Makefile | 6 ++---- > > arch/arm64/boot/install.sh | 21 ------------------ > > arch/ia64/Makefile | 3 ++- > > arch/ia64/install.sh | 10 --------- > > arch/m68k/Makefile | 3 ++- > > arch/m68k/install.sh | 22 ------------------- > > arch/nios2/Makefile | 3 +-- > > arch/nios2/boot/install.sh | 22 ------------------- > > arch/parisc/Makefile | 11 +++++----- > > arch/parisc/install.sh | 28 ------------------------ > > arch/powerpc/Makefile | 3 +-- > > arch/powerpc/boot/install.sh | 23 -------------------- > > arch/riscv/Makefile | 7 +++--- > > arch/riscv/boot/install.sh | 21 ------------------ > > arch/s390/Makefile | 3 +-- > > arch/s390/boot/install.sh | 6 ------ > > arch/sparc/Makefile | 3 +-- > > arch/sparc/boot/install.sh | 22 ------------------- > > arch/x86/Makefile | 3 +-- > > arch/x86/boot/install.sh | 22 ------------------- > > scripts/install.sh | 41 ++++++++++++++++++++++++++++++++++++ > > 24 files changed, 64 insertions(+), 247 deletions(-) > > mode change 100644 => 100755 arch/arm/boot/install.sh > > mode change 100644 => 100755 arch/arm64/boot/install.sh > > mode change 100644 => 100755 arch/ia64/install.sh > > mode change 100644 => 100755 arch/m68k/install.sh > > mode change 100644 => 100755 arch/nios2/boot/install.sh > > mode change 100644 => 100755 arch/parisc/install.sh > > mode change 100644 => 100755 arch/powerpc/boot/install.sh > > mode change 100644 => 100755 arch/riscv/boot/install.sh > > mode change 100644 => 100755 arch/s390/boot/install.sh > > mode change 100644 => 100755 arch/sparc/boot/install.sh > > mode change 100644 => 100755 arch/x86/boot/install.sh > > create mode 100755 scripts/install.sh > > > > diff --git a/Makefile b/Makefile > > index 9a60f732bb3c..154c32af8805 100644 > > --- a/Makefile > > +++ b/Makefile > > @@ -1298,7 +1298,8 @@ scripts_unifdef: scripts_basic > > # to this Makefile to build and install external modules. > > # Cancel sub_make_done so that options such as M=, V=, etc. are parsed. > > > > -install: sub_make_done := > > +quiet_cmd_install = INSTALL $(INSTALL_PATH) > > + cmd_install = unset sub_make_done; $(srctree)/scripts/install.sh > > This is the third 'cmd_install' in the tree; might it be better to take > a more unique name (e.g. cmd_installkernel) to prevent confusion? If this is confusing, we can rename the ones in scripts/Makefile.{modinst,headersinst}. This command name matches the build target ("make install"), so I believe this name is good. > > For me, it would have been more clear, if we'd also move the default > KBUILD_IMAGE definition here (similar to the corresponding part in > arch/parisc/Makefile): > > zinstall: KBUILD_IMAGE := $(boot)/Image.gz > > ($(KBUILD_IMAGE) seems not to be used anywhere else in arch/arm64/ > tree; but I haven't checked in depth.) KBUILD_IMAGE is _indirectly_ used to specify the kernel image for package builds. [1] This target returns the value IMAGE_BUILD. [2] $(KBUILD_IMAGE) is definitely used for arm64. [1]: https://github.com/torvalds/linux/blob/v5.17/scripts/package/builddeb#L150 [2]: https://github.com/torvalds/linux/blob/v5.17/Makefile#L1943 > > diff --git a/arch/parisc/Makefile b/arch/parisc/Makefile > > index 7583fc39ab2d..aca1710fd658 100644 > > --- a/arch/parisc/Makefile > > +++ b/arch/parisc/Makefile > > @@ -184,12 +184,11 @@ vdso_install: > > $(Q)$(MAKE) $(build)=arch/parisc/kernel/vdso $@ > > $(if $(CONFIG_COMPAT_VDSO), \ > > $(Q)$(MAKE) $(build)=arch/parisc/kernel/vdso32 $@) > > -install: > > - $(CONFIG_SHELL) $(srctree)/arch/parisc/install.sh \ > > - $(KERNELRELEASE) vmlinux System.map "$(INSTALL_PATH)" > > -zinstall: > > - $(CONFIG_SHELL) $(srctree)/arch/parisc/install.sh \ > > - $(KERNELRELEASE) vmlinuz System.map "$(INSTALL_PATH)" > > + > > +install: KBUILD_IMAGE := vmlinux > > +zinstall: KBUILD_IMAGE := vmlinuz > > Does this make the KBUILD_IMAGE definition in line 19 obsolete and > unused? As I said above for arm64, KBUILD_IMAGE is used for package builds. If you delete line 19, it will change the behavior. (fall back to the global default [3]) [3]: https://github.com/torvalds/linux/blob/v5.17/Makefile#L1059 > > diff --git a/arch/powerpc/Makefile b/arch/powerpc/Makefile > > index eb541e730d3c..45a9caa37b4e 100644 > > --- a/arch/powerpc/Makefile > > +++ b/arch/powerpc/Makefile > > @@ -408,8 +408,7 @@ endef > > > > PHONY += install > > install: > > I can't find a KBUILD_IMAGE definition in arch/powerpc/Makefile. > Should it be set here as a target-specific varibable, too? Right, powerpc does not define KBUILD_IMAGE explicitly. It falls back to [3]. -- Best Regards Masahiro Yamada