This page aims to document and solidify the remaining steps in getting F15 built for both ARMv5 and ARMv7 in koji (and therefore available to users).
Fedora 15 ARM
ARMv7 has recently been the focus of build efforts with many thousands of packages now successfully built into stage3 and stage4. The plan is to move ARMv7 efforts into the same koji build farm as ARMv5. This introduces some challenges which are overcome in this strategy.
ARM v5/v7 Koji Build
- Current Koji Build Status: http://arm.koji.fedoraproject.org/~jchiappetta/stats.html
- Temp Koji External Repos: http://australia.proximity.on.ca/fedora-arm/15/ (arm & armhfp)
- Problems Noted: http://lists.fedoraproject.org/pipermail/arm/2011-December/002307.html
- Meeting Notes + Problem Packages: https://lists.fedoraproject.org/pipermail/arm/2011-December/002326.html
- Up-streaming any source RPMs that contain modifications (.armN packages)
When stage4 is ready and matching exactly for both architectures, the koji build can then start. Koji will be instructed to rebuild the exact stage4 package set, with the output builds going straight into koji.
It is essential that stage4 is pure: that it only consists of packages from mainline Fedora 15 scm. GA packages are preferred, but packages from later points in the 'f15' git branches can be built when they are needed to fix ARM-specific bugs and build blockers.
At the time of writing, stage4 includes a number of hacked packages (i.e. spec file modifications that were made to get ARM builds working that have not gone 'upstream' into f15). These must all be moved into stage3 and removed from stage4. Then they should be fixed properly, then rebuilt for stage4 from official scm sources. The fedora-arm community has a number of provenpackagers on hand who can commit the easy fixes, and the more complicated stuff should be resolved with assistance/oversight from package maintainers. In our F14 experience, package maintainers are generally very responsive to our efforts.
Such fixes must be made in the f15 branch of Fedora scm before fixed packages are built for stage4. It is not sufficient for them to be fixed only in F16 and/or rawhide. Similarly, when fixing f15 branches, please also make sure that f16 and rawhide branches are fixed. This will save us time when we move onto F16.
DJ Delorie is tracking the divergence from Fedora here: http://djdelorie.fedorapeople.org/armv7-srpms.html
ARMv7hl Infrastructure Preparation
As a new architecture, some core Fedora components must be updated to correctly support armv7hl.
- koji: Dennis Gilmore is finishing and testing his patches
- rpm: A simple patch is needed, which could be applied only on armv7hl builds. Looks like Dennis is planning to take care of this.
- yum: Yum must be extended to learn how to detect which ARM ABI is in use. This work is pending.
Koji Que Script
- A list of stage4 source rpms were downloaded into a f15srpms/ folder
#!/bin/bash koji list-tagged dist-f15 > /tmp/k export l=`find ./f15srpms -type f | grep -i '\.src\.rpm' | wc -l` export x=1 find ./f15srpms -type f | sort -R | grep -i '\.src\.rpm' > /tmp/p while true do ak list-tagged dist-f15 > /tmp/t while true do ak list-tasks --mine --quiet | grep '^[0-9]' | grep -Ei ' (open|free) .* build' > /tmp/n #echo "got tasks..." ; cat /tmp/n | wc -l ; echo if [ `cat /tmp/n | wc -l` -ge 10 ] then break fi p=`cat /tmp/p | head -n "$x" | tail -n 1` q=`basename "$p" | sed -e 's/[^0-9A-Za-z]/./g' -e 's/\.src\.rpm//g'` #echo "checking pkg [$p] [$q]..." ; echo c=`cat /tmp/n /tmp/t | grep -i "$q"` let x="($x % $l) + 1" if [ "$c" != "" ] then continue fi c=`cat /tmp/k | grep -i "$q"` if [ "$c" == "" ] then continue fi echo "queing [$p] skipped [$x]" ak build dist-f15 "$p" --nowait --background let n="$n + 1" done sleep 60 done
The above approach of rebuilding the whole distro outside of koji on two architectures before getting koji to rebuild everything for the two architectures again is purely a one-off since we are adding an architecture (armv7) in the F15 cycle. The migration and building needed for F16 and onwards will be able to happen in much less complicated fashion, entirely inside koji.