Re: [PATCH v2] kbuild: factor out the common installation code into scripts/install.sh

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



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



[Index of Archives]     [Linux&nblp;USB Development]     [Linux Media]     [Video for Linux]     [Linux Audio Users]     [Yosemite Secrets]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux