[Buildroot] [PATCH 00/13] New DL_DIR organisation; git cache feature

Peter Seiderer ps.report at gmx.net
Thu Jul 27 22:37:56 UTC 2017


Hello Maxime,

On Tue,  4 Jul 2017 18:21:58 +0200, Maxime Hadjinlian <maxime.hadjinlian at gmail.com> wrote:

> Hi all,
> 
> This series will progressively reorganize the DL_DIR folder, in order to
> hve a subdirectory for each packages.
> This way, we store patches into subdirectory called by the package name
> instead of flattly into DL_DIR.
> We also avoid possible conflicts between packages.
> 
> Finally, this series introduce the 'git cache' feature. What it does is
> that it keeps a copy of the Git clone in the subdirectory of the
> package.
> This way, when you change the version of said package, instead of
> cloning from scratch, we only fetch the missing objects and create the
> tarball from that git clone.
> 

Tested your patch series (hoping to speed up RPi kernel/userland/firmware
update which are huge git downloads) but failed with the raspberrypi3_defconfig
while compiling the linux kernel:

  DTC     arch/arm/boot/dts/bcm2710-rpi-3-b.dtb
In file included from arch/arm/boot/dts/bcm2710.dtsi:1:0,
                 from arch/arm/boot/dts/bcm2710-rpi-3-b.dts:3:
arch/arm/boot/dts/bcm283x.dtsi:1:41: fatal error: dt-bindings/pinctrl/bcm2835.h: No such file or directory
 #include <dt-bindings/pinctrl/bcm2835.h>
                                         ^
compilation terminated.
  DTC     arch/arm/boot/dts/bcm2710-rpi-cm3.dtb
In file included from arch/arm/boot/dts/bcm2710.dtsi:1:0,
                 from arch/arm/boot/dts/bcm2710-rpi-cm3.dts:3:
arch/arm/boot/dts/bcm283x.dtsi:1:41: fatal error: dt-bindings/pinctrl/bcm2835.h: No such file or directory
 #include <dt-bindings/pinctrl/bcm2835.h>
                                         ^
compilation terminated.


This is due to wrong dt-bindings link, the failing version (with your patchset):

	$ ls -ld build/linux-9126e25b0934bd7bd843763310ea4b34c6e139d0/arch/arm/boot/dts/include/dt-bindings

lrwxrwxrwx 1 seiderer users 79 Jul 11 23:15 build/linux-9126e25b0934bd7bd843763310ea4b34c6e139d0/arch/arm/boot/dts/include/dt-bindings -> linux-9126e25b0934bd7bd843763310ea4b34c6e139d0./../../../../include/dt-bindings

And from a working version (without your patchset):

	$ ls -ld build/linux-9126e25b0934bd7bd843763310ea4b34c6e139d0/arch/arm/boot/dts/include/dt-bindings
lrwxrwxrwx 1 seiderer users 34 Jul 11 23:15 build/linux-9126e25b0934bd7bd843763310ea4b34c6e139d0/arch/arm/boot/dts/include/dt-bindings -> ../../../../../include/dt-bindings

Regards,

Peter


> It should speed up the build, especially for some use cases; drawback is
> that the disk usage for the DL_DIR will increase significantly. But disk
> space are pretty cheap, especially on build servers.
> 
> Maxime Hadjinlian (12):
>   pkg-{download,generic}: remove source-check
>   download: put most of the infra in dl-wrapper
>   pkg-generic: make PKG_DL_DIR equal to DL_DIR
>   packages: use new $($PKG)_DL_DIR) variable
>   pkg-{download,generic}: use new $($(PKG)_DL_DIR)
>   support/download: make sure the download folder is created
>   pkg-generic: add a subdirectory to the DL_DIR
>   pkg-download: support new subdir for mirrors
>   pkg-generic: introduce _SAME_SOURCE_AS
>   help/manual: update help about the new $(LIBFOO_DL_DIR)
>   download: add flock call before dl-wrapper
>   download: git: introduce cache feature
> 
> Yann E. MORIN (1):
>   core/pkg-download: change all helpers to use common options
> 
>  Config.in                                          |   3 +
>  docs/manual/adding-packages-generic.txt            |   6 +-
>  package/amd-catalyst/amd-catalyst.mk               |   2 +-
>  package/android-tools/android-tools.mk             |   2 +-
>  package/angularjs/angularjs.mk                     |   2 +-
>  package/bootstrap/bootstrap.mk                     |   2 +-
>  package/cache-calibrator/cache-calibrator.mk       |   2 +-
>  package/cracklib/cracklib.mk                       |   2 +-
>  package/cryptopp/cryptopp.mk                       |   2 +-
>  package/devmem2/devmem2.mk                         |   2 +-
>  package/dhrystone/dhrystone.mk                     |   2 +-
>  package/doom-wad/doom-wad.mk                       |   2 +-
>  package/espeak/espeak.mk                           |   2 +-
>  package/fan-ctrl/fan-ctrl.mk                       |   2 +-
>  package/gcc/gcc.mk                                 |   2 +-
>  package/irrlicht/irrlicht.mk                       |   2 +-
>  package/jquery-mobile/jquery-mobile.mk             |   2 +-
>  package/jquery-sparkline/jquery-sparkline.mk       |   2 +-
>  package/jquery-ui-themes/jquery-ui-themes.mk       |   2 +-
>  package/jquery-ui/jquery-ui.mk                     |   2 +-
>  package/jquery-validation/jquery-validation.mk     |   2 +-
>  package/jquery/jquery.mk                           |   2 +-
>  package/kodi/kodi.mk                               |   6 +-
>  package/libfreeimage/libfreeimage.mk               |   2 +-
>  package/libjson/libjson.mk                         |   2 +-
>  package/libsoil/libsoil.mk                         |   2 +-
>  package/lsof/lsof.mk                               |   2 +-
>  package/musl-compat-headers/musl-compat-headers.mk |   2 +-
>  package/nmon/nmon.mk                               |   2 +-
>  package/nvidia-driver/nvidia-driver.mk             |   2 +-
>  package/openobex/openobex.mk                       |   2 +-
>  package/opentyrian-data/opentyrian-data.mk         |   2 +-
>  package/perl/perl.mk                               |   2 +-
>  package/pkg-download.mk                            | 216 ++++-----------------
>  package/pkg-generic.mk                             |  10 +-
>  package/python-keyring/python-keyring.mk           |   2 +-
>  .../python-simplegeneric/python-simplegeneric.mk   |   2 +-
>  package/rapidxml/rapidxml.mk                       |   2 +-
>  package/rpi-wifi-firmware/rpi-wifi-firmware.mk     |   2 +-
>  package/sam-ba/sam-ba.mk                           |   2 +-
>  package/spidev_test/spidev_test.mk                 |   2 +-
>  package/tar/tar.mk                                 |   2 +-
>  package/tesseract-ocr/tesseract-ocr.mk             |   2 +-
>  package/ti-cgt-pru/ti-cgt-pru.mk                   |   4 +-
>  package/ti-gfx/ti-gfx.mk                           |   4 +-
>  package/ts4900-fpga/ts4900-fpga.mk                 |   2 +-
>  package/unscd/unscd.mk                             |   2 +-
>  package/urg/urg.mk                                 |   2 +-
>  package/waf/waf.mk                                 |   2 +-
>  package/whetstone/whetstone.mk                     |   2 +-
>  package/wilc1000-firmware/wilc1000-firmware.mk     |   2 +-
>  package/zynq-boot-bin/zynq-boot-bin.mk             |   2 +-
>  support/download/bzr                               |  25 +--
>  support/download/check-hash                        |   2 +-
>  support/download/cp                                |  17 +-
>  support/download/cvs                               |  34 ++--
>  support/download/dl-wrapper                        |  62 +++---
>  support/download/git                               |  96 +++++----
>  support/download/hg                                |  25 +--
>  support/download/scp                               |  19 +-
>  support/download/svn                               |  25 +--
>  support/download/wget                              |  24 ++-
>  62 files changed, 286 insertions(+), 382 deletions(-)
> 
> --
> 2.13.2
> 
> _______________________________________________
> buildroot mailing list
> buildroot at busybox.net
> http://lists.busybox.net/mailman/listinfo/buildroot



More information about the buildroot mailing list