1. 05 Jul, 2021 3 commits
  2. 17 Jun, 2021 3 commits
    • Matthias Maennich's avatar
      kbuild: mkcompile_h: consider timestamp if KBUILD_BUILD_TIMESTAMP is set · a979522a
      Matthias Maennich authored
      To avoid unnecessary recompilations, mkcompile_h does not regenerate
      compile.h if just the timestamp changed.
      Though, if KBUILD_BUILD_TIMESTAMP is set, an explicit timestamp for the
      build was requested, in which case we should not ignore it.
      
      If a user follows the documentation for reproducible builds [1] and
      defines KBUILD_BUILD_TIMESTAMP as the git commit timestamp, a clean
      build will have the correct timestamp. A subsequent cherry-pick (or
      amend) changes the commit timestamp and if an incremental build is done
      with a different KBUILD_BUILD_TIMESTAMP now, that new value is not taken
      into consideration. But it should for reproducibility.
      
      Hence, whenever KBUILD_BUILD_TIMESTAMP is explicitly set, do not ignore
      UTS_VERSION when making a decision about whether the regenerated version
      of compile.h should be moved into place.
      
      [1] https://www.kernel.org/doc/html/latest/kbuild/reproducible-builds.htmlSigned-off-by: default avatarMatthias Maennich <maennich@google.com>
      Signed-off-by: default avatarMasahiro Yamada <masahiroy@kernel.org>
      a979522a
    • Mark Brown's avatar
      kbuild: modpost: Explicitly warn about unprototyped symbols · 4a679593
      Mark Brown authored
      One common cause of modpost version generation failures is a failure to
      prototype exported assembly functions - the tooling requires this for
      exported functions even if they are not and should not be called from C
      code in order to do the version mangling for symbols. Unfortunately the
      error message is currently rather abstruse, simply saying that "version
      generation failed" and even diving into the code doesn't directly show
      what's going on since there's several steps between the problem and it
      being observed.
      
      Provide an explicit hint as to the likely cause of a version generation
      failure to help anyone who runs into this in future more readily diagnose
      and fix the problem.
      Signed-off-by: default avatarMark Brown <broonie@kernel.org>
      Signed-off-by: default avatarMasahiro Yamada <masahiroy@kernel.org>
      4a679593
    • Masahiro Yamada's avatar
      kbuild: remove trailing slashes from $(KBUILD_EXTMOD) · 74ee585b
      Masahiro Yamada authored
      M= (or KBUILD_EXTMOD) generally expects a directory path without any
      trailing slashes, like M=a/b/c.
      
      If you add a trailing slash, like M=a/b/c/, you will get ugly build
      logs (two slashes in a series), but it still works fine as long as it
      is consistent between 'make modules' and 'make modules_install'.
      
      The following commands correctly build and install the modules.
      
        $ make M=a/b/c/ modules
        $ sudo make M=a/b/c/ modules_install
      
      Since commit ccae4cfa ("kbuild: refactor scripts/Makefile.modinst"),
      a problem happens if you add a trailing slash only for modules_install.
      
        $ make M=a/b/c modules
        $ sudo make M=a/b/c/ modules_install
      
      No module is installed in this case, Johannes Berg reported. [1]
      
      Trim any trailing slashes from $(KBUILD_EXTMOD).
      
      I used the 'dirname' command to remove all the trailing slashes in
      case someone adds more slashes like M=a/b/c/////. The Make's built-in
      function, $(dir ...) cannot take care of such a case.
      
      [1]: https://lore.kernel.org/lkml/10cc8522b27a051e6a9c3e158a4c4b6414fd04a0.camel@sipsolutions.net/
      
      Fixes: ccae4cfa ("kbuild: refactor scripts/Makefile.modinst")
      Reported-by: default avatarJohannes Berg <johannes@sipsolutions.net>
      Signed-off-by: default avatarMasahiro Yamada <masahiroy@kernel.org>
      74ee585b
  3. 05 Jun, 2021 2 commits
  4. 26 May, 2021 14 commits
  5. 24 May, 2021 3 commits
  6. 23 May, 2021 15 commits