From Fedora Project Wiki
(Created page with '{{header|events}} == [ARM] Fedora15 HardFP Bootstrap Virtual FAD - 2011/06/10 == We wish to accelerate the bringup of [https://fedoraproject.org/wiki/Architectures/ARM/Fedora15_...')
 
No edit summary
 
(20 intermediate revisions by 3 users not shown)
Line 8: Line 8:


'''IRC:''' #fedora-arm on irc.freenode.net
'''IRC:''' #fedora-arm on irc.freenode.net
'''Phone:''' Access code: 1236987415
Toll Free Dial-In Number (US & Canada): (800) 451-8679
International Dial-In Number: (212) 729-5016
Australia, Sydney Dial-In #: 0289852326
Austria, Vienna Dial-In #: 012534978196
Belgium, Brussels Dial-In #: 027920405
China Dial-In #: 4006205013
China, Domestic Dial-In #: 8008190132-Landline
Denmark, Copenhagen Dial-In #: 32729215
Finland, Helsinki Dial-In #: 0923194436
France, Paris Dial-In #: 0170377140
Germany, Berlin Dial-In #: 030300190579
nHong Kong Dial-In #: 85230730429
Ireland, Dublin Dial-In #: 014367793
Italy, Milan Dial-In #: 0236269529
Netherlands, Amsterdam Dial-In #: 0207975872
Norway, Oslo Dial-In #: 21033188
Singapore Dial-In #: 64840858
Spain, Barcelona Dial-In #: 935452328
Sweden, Stockholm Dial-In #: 0850513770
Switzerland, Geneva Dial-In #: 0225927881
Switzerland, Zurich Dial-In #: 0445803463
United Kingdom Dial-In #: 02078970515
United Kingdom Dial-In #: 08445790676
United Kingdom, LocalCall Dial-In #: 08445790678
United States Dial-In #: 2127295016
Global Access Numbers Tollfree:
Argentina Dial-In #: 8004441016
Australia Dial-In #: 1800337169
Austria Dial-In #: 0800005898
Bahamas Dial-In #: 18002054776
Bahrain Dial-In #: 80004377
Belgium Dial-In #: 080048325
Brazil Dial-In #: 08008921002
Bulgaria Dial-In #: 008001100236
Chile Dial-In #: 800370228
Colombia Dial-In #: 018009134033
Costa Rica Dial-In #: 08000131048
Cyprus Dial-In #: 80095297
Czech Republic Dial-In #: 800700318
Denmark Dial-In #: 80887114
Dominican Republic Dial-In #: 18887512313
Egypt, SAC 5117 Dial-In #: 23640083
Estonia Dial-In #: 8000100232
Finland Dial-In #: 0800117116
France Dial-In #: 0805632867
Germany Dial-In #: 08006647541
Greece Dial-In #: 00800127562
Hong Kong Dial-In #: 800930349
Hungary Dial-In #: 0680016796
Iceland Dial-In #: 8008967
India Dial-In #: 0008006501533
Indonesia Dial-In #: 0018030179162
Ireland Dial-In #: 1800932401
Israel Dial-In #: 1809462557
Italy Dial-In #: 800985897
Jamaica Dial-In #: 18002050328
Japan Dial-In #: 0120934453
Korea (South) Dial-In #: 007986517393
Latvia Dial-In #: 80003339
Lithuania Dial-In #: 880030479
Luxembourg Dial-In #: 80026595
Malaysia Dial-In #: 1800814451
Mexico Dial-In #: 0018664590915
Netherlands Dial-In #: 08000222329
New Zealand Dial-In #: 0800888167
Norway Dial-In #: 80012994
Panama Dial-In #: 008002269184
Peru Dial-In #: 080052972
Philippines Dial-In #: 180011100991
Poland Dial-In #: 008001210187
Portugal Dial-In #: 800814625
Romania Dial-In #: 0800895537
Russian Federation Dial-In #: 81080028341012
Saint Kitts and Nevis Dial-In #: 18002059252
Saudi Arabia Dial-In #: 8008445917
Singapore Dial-In #: 8006162235
Slovak Republic Dial-In #: 0800001441
South Africa Dial-In #: 0800981148
Spain Dial-In #: 800300524
Sweden Dial-In #: 200896860
Switzerland Dial-In #: 800650077
Taiwan Dial-In #: 00801127141
Thailand Dial-In #: 001800656966
Trinidad and Tobago Dial-In #: 18002024615
United Arab Emirates Dial-In #: 8000650591
United Kingdom Dial-In #: 08006948057
United States Dial-In #: 8004518679
Uruguay Dial-In #: 00040190315
Venezuela Dial-In #: 08001627182


'''Etherpad:''' [http://www.tinyurl.com/fedora-arm http://www.tinyurl.com/fedora-arm]
'''Phone:''' We used a temporary bridge
 
'''Etherpad:''' [http://www.tinyurl.com/fedora-arm http://www.tinyurl.com/fedora-arm] (including full list of international dialin numbers)
 
== Event owners ==
* [[User:Jcm|Jon Masters]]
* [[User:Ctyler|Chris Tyler]]
 
== Attendees ==
* [[User:Jcm|Jon Masters]]
* [[User:ctyler|Chris Tyler]]
* [[User:DJDelorie|DJ]]
* Anthony Boccia
* Salman Zafar
* Jon Chiappetta
* [[User:pwhalen|Paul Whalen]]
* Dennis Gilmore
* Brendan Conoboy
* Russ Herrold
* Peter Robinson
 
== Summary ==
 
<b>NOTE</b>: Procedure for joining in with this post-activity day is documented on [[Architectures/ARM/Fedora15 HardFP Bootstrap|
Architectures/ARM/Fedora15 HardFP Bootstrap]]
 
* We kicked off with a discussion around build flags and confirmed the current plans
** Building with a Cortex-A8 optimized, hardfp target (aapcs, vfpv3-d16), no NEON, no Thumb2
** We may rebuild with different core optimizations in the future, may enable Thumb2
** Probably will not worry about NEON initially
* We reviewed various build dependencies we had available
** Determined that tools for graphing and obtaining this stuff need improving
** DJ provided an updated depsolving tool later in the day that was helpful
** An initial attempt at a list of dependencies for RPM is in Etherpad
** Determined we want to bring up rpm (rpm-build) at this stage
* We determined a workflow based around a rootfs image in git
** [http://git.fedorahosted.org/git/arm.git http://git.fedorahosted.org/git/arm.git] (ssh://git.fedorahosted.org/git/arm.git) - see the "armv7hl" branch on that repo
** Based on DJ's git://fedorapeople.org/~djdelorie/bootstrap.git (output from a run of stage1/stage used as seed)
** Individual people/groups to create branches named armv7hl-NAME and request merge on list ([[User:Jcm|Jon Masters]] maintaining)
** Each person/group picks a package at a time to bootstrap (edit the [http://tinyurl.com/fedora-arm Etherpad] to add your package status before/during/after - including changing the list of remaining packages/done packages)
** Collaboratively edit stage2/stage2 (copy of version in bootstrap, to be synced back later)
** Explode out new package rpmbuild bits into stage2/rpmbuild before/after adding rule to stage2/stage2
** Packages build in stage2/builds and are installed to the git repo rootfs under a chroot
** Mount this rootfs git repo and chroot on target, run /stage2/stage2 TARGET (where TARGET is e.g. "db4", "readline", etc.)
** Ensure general rules are present in stage2 script in the "go" sections to call targets in order
** Later will verify the bootstrap scripts still run, but use this rootfs git approach to speed up bootstrap
** Contribution will continue to this repo - post pull requests/push to armv7hl-NAME branch
* We added more than a dozen bootstrap packages but more importantly worked out a workflow/model going forward
* Continue this effort and repeat the activity day.
* PROPOSAL: Next activity day on Wednesday June 22.
 
== Program ==
* Summarize requirements/sync up on build flags
** Build for Cortex A-8, with AAPCS, and hard float (vfpv3-d16, not -d32)
** Do not enable NEON (can add later)
** Do not enable Thumb2 (confirmed can non-disruptively enable per-package later)
* Current status of works in progress (DJ/Dennis/Seneca(?)?)
** Plan will be to use DJ's bootstrap.git as a starting point
** Extend stage2 script to on-target build up dependencies for rpm-build
** Stash archives of populated build directories/bits on scotland.proximity.on.ca/fedora-arm/f15hardfp/bootstrap/
* Minimal dependency discussion for F15
** Plan to build dependencies required from the dependency graph
** [http://scotland.proximity.on.ca/fedora-arm/f15hardfp/bootstrap/f15-x86_64-rpm-build_deps.pdf F15 x86_64 rpm-build dependency graph generated from Koji build dependencies]
* Plan for building/co-ordinating builds
** Follow instructions for setting up DJ's bootstrap script and minimal rootfs (target chroot)
** Grab a few package dependencies and work on them (add support to stage2 script)
** Tar up the resulting build tree and make them available to others
** Others install build tree ("make install") on their rootfs
** Once sufficient deps are done for rpm, rebuild things as RPMs
** host bits on scotland.proximity.on.ca/fedora-arm/f15hardfp/bootstrap/
** Stage a Koji F15 instance with the working RPMs
* Status before end of day
* Plan for followup
 
== Requirements ==
* Internet connection to log into IRC, and phone if possible (phone not essential)
* A supported ARMv7 target board
* Lots of coffee
 
== Setup ==
* A pre-requisite is a working ARMv7-compatible supported target board, such as a BeagleBoard or a PandaBoard.
** You can find out more from the main Fedora ARM pages about obtaining a pre-built rootfs (no installer yet)
** We now have some [https://fedoraproject.org/wiki/Architectures/Fedora_ARM_Kernels Fedora ARM kernel packages] for OMAP-based boards
 
* Bootstrap will involve using a partially completed rootfs image that will be used inside a chroot
** Since the new "arch" (armv7hl) is supported by ARMv7 kernels we can use a chroot trick
** A complete from-scratch new arch port would need an also bootable rootfs (but it's not quite that)
** Your normal target rootfs will be the stock F-13 rootfs in this case (so boot target as normal, then use chroot)
* Fetch [[User:DJDelorie|DJ]]'s [http://djdelorie.fedorapeople.org/ bootstrap.git] repository
** You will be making changes to the stage2 script (a copy of it in your rootfs)
** Post patches and pull requests during the day for new packages
* Fetch the [http://scotland.proximity.on.ca/fedora-arm/f15hardfp/bootstrap/rootfs_20110610/ partially bootstrapped rootfs] (progress to date, built using bootstrap scripts)
* Extract the root filesystem into a new directory and copy over to your board
** Or mount over NFS from a server system (e.g. export /data/work/arm/bootstrap/f15/20110610/rootfs from a server to your board)
** Optionally bind mount a directory within the rootfs (e.g. on an NFS server mount -o bind /data/work /data/work/arm/bootstrap/f15/20110610/rootfs/data/work) to allow you to get at data outside the chroot if you want to stash builds somewhere
* Chroot into the new target rootfs
** chroot /data/work/arm/bootstrap/f15/20110610/rootfs (or wherever you extracted it)
* Take a look at the /stage2/stage2 script
** Run it with a "module" name to build a particular package
** /stage2/stage2 nspr
* Modify the stage2 script to support building additional packages in the target rootfs
* Post patches and git pull requests to the Fedora ARM mailing list ([mailto:arm@lists.fedoraproject.org arm@lists.fedoraproject.org]) (the stage2 script is kept in the bootstrap.git and a copy is in the rootfs)
* Once sufficient packages are bootstrapped to support rpm, rebuild packages using RPM
* Further dialog on package build deps and next steps
 
[[Category:Events]]

Latest revision as of 14:22, 22 June 2011

[ARM] Fedora15 HardFP Bootstrap Virtual FAD - 2011/06/10

We wish to accelerate the bringup of Fedora 15 on ARMv7 systems running with hardware floating point (hardfp). To that end, it is proposed to have semi-regular bootstrap days, during which we will meet in a virtual capacity (on IRC, and over the phone) to build up through cross-compilation (and other means) the core packages required for Fedora 15 to become self-hosting on ARMv7 with hardware floating point.

When and Where

14:00 UTC, Friday June 10th 2011

IRC: #fedora-arm on irc.freenode.net

Phone: We used a temporary bridge

Etherpad: http://www.tinyurl.com/fedora-arm (including full list of international dialin numbers)

Event owners

Attendees

Summary

NOTE: Procedure for joining in with this post-activity day is documented on Architectures/ARM/Fedora15 HardFP Bootstrap

  • We kicked off with a discussion around build flags and confirmed the current plans
    • Building with a Cortex-A8 optimized, hardfp target (aapcs, vfpv3-d16), no NEON, no Thumb2
    • We may rebuild with different core optimizations in the future, may enable Thumb2
    • Probably will not worry about NEON initially
  • We reviewed various build dependencies we had available
    • Determined that tools for graphing and obtaining this stuff need improving
    • DJ provided an updated depsolving tool later in the day that was helpful
    • An initial attempt at a list of dependencies for RPM is in Etherpad
    • Determined we want to bring up rpm (rpm-build) at this stage
  • We determined a workflow based around a rootfs image in git
    • http://git.fedorahosted.org/git/arm.git (ssh://git.fedorahosted.org/git/arm.git) - see the "armv7hl" branch on that repo
    • Based on DJ's git://fedorapeople.org/~djdelorie/bootstrap.git (output from a run of stage1/stage used as seed)
    • Individual people/groups to create branches named armv7hl-NAME and request merge on list (Jon Masters maintaining)
    • Each person/group picks a package at a time to bootstrap (edit the Etherpad to add your package status before/during/after - including changing the list of remaining packages/done packages)
    • Collaboratively edit stage2/stage2 (copy of version in bootstrap, to be synced back later)
    • Explode out new package rpmbuild bits into stage2/rpmbuild before/after adding rule to stage2/stage2
    • Packages build in stage2/builds and are installed to the git repo rootfs under a chroot
    • Mount this rootfs git repo and chroot on target, run /stage2/stage2 TARGET (where TARGET is e.g. "db4", "readline", etc.)
    • Ensure general rules are present in stage2 script in the "go" sections to call targets in order
    • Later will verify the bootstrap scripts still run, but use this rootfs git approach to speed up bootstrap
    • Contribution will continue to this repo - post pull requests/push to armv7hl-NAME branch
  • We added more than a dozen bootstrap packages but more importantly worked out a workflow/model going forward
  • Continue this effort and repeat the activity day.
  • PROPOSAL: Next activity day on Wednesday June 22.

Program

  • Summarize requirements/sync up on build flags
    • Build for Cortex A-8, with AAPCS, and hard float (vfpv3-d16, not -d32)
    • Do not enable NEON (can add later)
    • Do not enable Thumb2 (confirmed can non-disruptively enable per-package later)
  • Current status of works in progress (DJ/Dennis/Seneca(?)?)
    • Plan will be to use DJ's bootstrap.git as a starting point
    • Extend stage2 script to on-target build up dependencies for rpm-build
    • Stash archives of populated build directories/bits on scotland.proximity.on.ca/fedora-arm/f15hardfp/bootstrap/
  • Minimal dependency discussion for F15
  • Plan for building/co-ordinating builds
    • Follow instructions for setting up DJ's bootstrap script and minimal rootfs (target chroot)
    • Grab a few package dependencies and work on them (add support to stage2 script)
    • Tar up the resulting build tree and make them available to others
    • Others install build tree ("make install") on their rootfs
    • Once sufficient deps are done for rpm, rebuild things as RPMs
    • host bits on scotland.proximity.on.ca/fedora-arm/f15hardfp/bootstrap/
    • Stage a Koji F15 instance with the working RPMs
  • Status before end of day
  • Plan for followup

Requirements

  • Internet connection to log into IRC, and phone if possible (phone not essential)
  • A supported ARMv7 target board
  • Lots of coffee

Setup

  • A pre-requisite is a working ARMv7-compatible supported target board, such as a BeagleBoard or a PandaBoard.
    • You can find out more from the main Fedora ARM pages about obtaining a pre-built rootfs (no installer yet)
    • We now have some Fedora ARM kernel packages for OMAP-based boards
  • Bootstrap will involve using a partially completed rootfs image that will be used inside a chroot
    • Since the new "arch" (armv7hl) is supported by ARMv7 kernels we can use a chroot trick
    • A complete from-scratch new arch port would need an also bootable rootfs (but it's not quite that)
    • Your normal target rootfs will be the stock F-13 rootfs in this case (so boot target as normal, then use chroot)
  • Fetch DJ's bootstrap.git repository
    • You will be making changes to the stage2 script (a copy of it in your rootfs)
    • Post patches and pull requests during the day for new packages
  • Fetch the partially bootstrapped rootfs (progress to date, built using bootstrap scripts)
  • Extract the root filesystem into a new directory and copy over to your board
    • Or mount over NFS from a server system (e.g. export /data/work/arm/bootstrap/f15/20110610/rootfs from a server to your board)
    • Optionally bind mount a directory within the rootfs (e.g. on an NFS server mount -o bind /data/work /data/work/arm/bootstrap/f15/20110610/rootfs/data/work) to allow you to get at data outside the chroot if you want to stash builds somewhere
  • Chroot into the new target rootfs
    • chroot /data/work/arm/bootstrap/f15/20110610/rootfs (or wherever you extracted it)
  • Take a look at the /stage2/stage2 script
    • Run it with a "module" name to build a particular package
    • /stage2/stage2 nspr
  • Modify the stage2 script to support building additional packages in the target rootfs
  • Post patches and git pull requests to the Fedora ARM mailing list (arm@lists.fedoraproject.org) (the stage2 script is kept in the bootstrap.git and a copy is in the rootfs)
  • Once sufficient packages are bootstrapped to support rpm, rebuild packages using RPM
  • Further dialog on package build deps and next steps