Skip to content

Instantly share code, notes, and snippets.

@jedp
Created September 24, 2012 22:50
Show Gist options
  • Save jedp/3778932 to your computer and use it in GitHub Desktop.
Save jedp/3778932 to your computer and use it in GitHub Desktop.
B2G repo setup and build quickstart

B2G Quickstart for Payments and Identity

This sets you up to make two separate targets:

  • One for a desktop [simulator] 1
  • One for the ZTE [device] 2

These are the moving parts:

  • [mozilla-inbound repo] 3 clone (hg)
  • [gaia repo] 4 fork (git)
  • [B2G project clone] 5 (git)

Basic organization

I've structured my directories like so:

b2g-src/
  gaia/       # git clone of my gaia fork
  mi/         # hg clone of my mozilla-inbound user repo
  build/      # build dir that mi will create

b2g/          # git clone of mozilla-b2g/B2G

Prep steps: Setting up Mercurial Queues

Follow the steps in the [introduction to Mercurial queues] 6.

Read the [Mercurial queue workflow] 7 documentation.

Setting up the mozilla-inbound repo

This is where we will be working on navigator.id and friends.

First, cd b2g-src; mkdir mi; cd mi

In the mi directory:

hg init .
hg qinit -c    # initializes mercurial queues

Create and edit .hg/hgrc, filling in your LDAP username correctly:

[paths]
default = ssh://<LDAP_username>@[email protected]/users/jparsons_mozilla.com/b2g-payments-identity/
mozilla-inbound = https://hg.mozilla.org/integration/mozilla-inbound/

Create and edit .hg/patches/.hg/hgrc

[paths]
default = http://hg.mozilla.org/users/jparsons_mozilla.com/b2g-payments-identity
default-push = ssh://hg.mozilla.org/users/jparsons_mozilla.com/b2g-payments-identity

Now you should be able to pull and build:

hg pull
hg update
make -f client.mk

Whoever is managing the shared user repo (me, in this case), would regularly do:

hg pull mozilla-inbound
hg update
make -f client.mk

You have to regularly blow away the ../build directory. Try that first if make crashes.

While that runs, set up Gaia.

Setting up gaia

cd b2g-src

Update with a git pull.

Build with:

DEBUG=1 make

You need network to build, since packages will be downloaded from nightly.

Building B2G

Now we will use our mozilla-inbound and gaia repos to build B2G.

cd $HOME/b2g

We can build either for the device (and flash the build to the phone), or for the desktop. Desktop builds are useful for testing and more rapid development.

Device builds

Create .userconfig and add these lines (adjusting paths accordingly):

# Configuration for custom device builds;  Desktop builds ignore this.

GAIA_PATH=/path/to/b2g-src/gaia
GECKO_PATH=/path/to/b2g-src/mi

VARIANT=user  # 'user' strangely means 'production'
              # this option omits the test apps from the phone

If this is your first time flashing a phone, be sure to follow the [preliminary instructions] 2.

Now configure, build, and flash:

./config.sh otoro   # assuming otoro is the correct target
./build.sh
./flash.sh

Desktop builds

Create a .mozconfig file containing:

mk_add_options MOZ_OBJDIR=../build
mk_add_options MOZ_MAKE_FLAGS="-j8 -s"   # adjust for your number of cores

ac_add_options --enable-application=b2g
ac_add_options --disable-libjpeg-turbo
 
# This option is required if you want to be able to run Gaia's tests
ac_add_options --enable-tests

# turn on mozTelephony/mozSms interfaces
# Only turn this line on if you actually have a dev phone
# you want to forward to. If you get crashes at startup,
# make sure this line is commented.
#ac_add_options --enable-b2g-ril
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment