On 2012-03-10 06:39, Robert P. J. Day wrote:
On Sat, 10 Mar 2012, Gary Thomas wrote:All you really need are these lines: SOURCE_MIRROR_URL ?= "file://${COREBASE}/sources/" INHERIT += "own-mirrors" Adjust the SOURCE_MIRROR_URL to wherever you want the files. I also always add BB_GENERATE_MIRROR_TARBALLS = "1" This will let the fetcher make a git2_XXX tarball, once the repo has been cloned. My understanding is that the git (and other SCM) fetcher works like this: * If there is a git2_XXX tar file in the DL_DIR (or mirror), unpack it into ${BUILD}/downloads/git2 * Check to see if the desired ${SRCREV} is present. If not, do a 'git pull' to update the local clone and then rebuild the git2_XXX tarball. This way, you only have to clone once - just copy any generated tarballs back to your source mirror. Finally, if you set BB_NO_NETWORK = "1" the build will fail if bitbake *ever* has to go to the network,well, that (sort of) worked so let me summarize for the benefit of anyone else interested. i configured for a new build (beagleboard), and added the following to the bottom of local.conf: SOURCE_MIRROR_URL ?= "file:///home/rpjday/dl/" INHERIT += "own-mirrors" BB_GENERATE_MIRROR_TARBALLS = "1" # BB_NO_NETWORK = "1" (since i know i'll need to do some downloading, i won't ban network access, obviously, not for this first run.) did a "bitbake -c fetchall core-image-minimal", then checked my downloads/ directory for any content that actually got downloaded and tarball-ed, and found one obvious and sizable download: ... 87770604 2012-03-10 06:45 gcc-4_6-branch_gcc.gnu.org_.svn.gcc.branches_184847_.tar.gz i copied that over to my own mirror dl/ directory, then configured a whole new build (also beagleboard), added same mirror directives to local.conf except (of course) banning network access this time, and once again did $ bitbake -c fetchall core-image-minimal and got something unexpected: NOTE: package bash-4.2-r1: task do_fetch: Started ERROR: Function failed: Network access disabled through BB_NO_NETWORK but access rquested with command /usr/bin/env wget -t 5 -nv --passive-ftp --no-check-certificate -P /home/rpjday/yocto/builds/beag2/downloads 'ftp://ftp.gnu.org/gnu/bash/bash-4.2-patches/bash42-001' (for url None) ERROR: Logfile of failure stored in: /home/rpjday/yocto/builds/beag2/tmp/work/armv7a-vfp-neon-poky-linux-gnueabi/bash-4.2-r1/temp/log.do_fetch.32479 Log data follows: | DEBUG: Trying PREMIRRORS ... snip ... i can clearly see the problem -- while i have the bash tarball itself in my own mirror, i don't have the patches to go with it, as defined in the recipes file: SRC_URI = "${GNU_MIRROR}/bash/${BPN}-${PV}.tar.gz;name=tarball \ ${GNU_MIRROR}/bash/bash-4.2-patches/bash42-001;apply=yes;striplevel=0;name=patch001 \ ${GNU_MIRROR}/bash/bash-4.2-patches/bash42-002;apply=yes;striplevel=0;name=patch002 \ ${GNU_MIRROR}/bash/bash-4.2-patches/bash42-003;apply=yes;striplevel=0;name=patch003 \ ... etc etc ... when i went looking for actual downloads in step 1, i just searched for sizable tarballs or zip files, it never occurred to me to check for patch files. so i guess i just have to be more observant and check for patch files as well (or anything else a recipe might want to download). so far, so good?
I didn't check but this is often the recipe's fault. It must specify an exact git SRCREV, not a tag, for the NO_NETWORK to be successful. -- ------------------------------------------------------------ Gary Thomas | Consulting for the MLB Associates | Embedded world ------------------------------------------------------------ _______________________________________________ yocto mailing list [email protected] https://lists.yoctoproject.org/listinfo/yocto
