Difference between revisions of "Buildrom"

From coreboot
Jump to: navigation, search
m
Line 1: Line 1:
'''Buildrom''' is a tool that can construct a LinuxBIOS image (comprising the LinuxBIOS loader and payload) from scratch.  Starting from a configuration file, it will download and build all the code necessary to construct the final binary.
+
'''Buildrom''' is a tool that can construct a coreboot image (comprising the coreboot loader and payload) from scratch.  Starting from a configuration file, it will download and build all the code necessary to construct the final binary.
  
A tool with similar functionality is [[Etherboot]]'s [http://rom-o-matic.net/ ROM-o-matic] which builds etherboot as a LinuxBIOS ELF payload.
+
A tool with similar functionality is [[Etherboot]]'s [http://rom-o-matic.net/ ROM-o-matic] which builds etherboot as a coreboot ELF payload.
  
 
== Supported Platforms ==
 
== Supported Platforms ==
Line 30: Line 30:
 
== Download ==
 
== Download ==
  
  $ svn co svn://linuxbios.org/buildrom
+
  $ svn co svn://coreboot.org/buildrom
  
 
== Prerequisites ==
 
== Prerequisites ==
Line 58: Line 58:
 
== Developing within Buildrom ==
 
== Developing within Buildrom ==
  
This section is for the developers who wish to change and rebuild the code. BuildROM builds the code for LinuxBIOS and the payloads in the work/ directory.  Here is a typical view of the buildROM work/ directory:
+
This section is for the developers who wish to change and rebuild the code. BuildROM builds the code for coreboot and the payloads in the work/ directory.  Here is a typical view of the buildROM work/ directory:
 
  $ ls work/
 
  $ ls work/
 
   linuxbios  filo
 
   linuxbios  filo
  
 
In each directory, you will find three directories.  Logs from the build will be found in logs/ and timestamps that the build system uses are in stamps/.  You normally won't have to touch these directories.  The source code is located in the third directory.    BuildROM provides several commands to make it easy to rebuild individual packages and ROMs.    To clean a directory (but not remove the source code) use 'make <package>-clean'.  You can build an individual packages with 'make <package>'.  f you wish to completely erase the source code and start again with a pristine version, use 'make <package>-distclean'. Typing 'make' at any time will rebuild the ROM using the most current versions of the individual packages.
 
In each directory, you will find three directories.  Logs from the build will be found in logs/ and timestamps that the build system uses are in stamps/.  You normally won't have to touch these directories.  The source code is located in the third directory.    BuildROM provides several commands to make it easy to rebuild individual packages and ROMs.    To clean a directory (but not remove the source code) use 'make <package>-clean'.  You can build an individual packages with 'make <package>'.  f you wish to completely erase the source code and start again with a pristine version, use 'make <package>-distclean'. Typing 'make' at any time will rebuild the ROM using the most current versions of the individual packages.
Here is a typical work flow for modifying LinuxBIOS code:
+
Here is a typical work flow for modifying coreboot code:
  
 
#Build the initial ROM from scratch with 'make'
 
#Build the initial ROM from scratch with 'make'
#Edit the LinuxBIOS source code in work/linuxbios/svn/
+
#Edit the coreboot source code in work/linuxbios/svn/
#Clean the linuxbios package with 'make linuxbios-clean'
+
#Clean the coreboot package with 'make linuxbios-clean'
 
#Rebuild the ROM with 'make'
 
#Rebuild the ROM with 'make'

Revision as of 16:06, 14 January 2008

Buildrom is a tool that can construct a coreboot image (comprising the coreboot loader and payload) from scratch. Starting from a configuration file, it will download and build all the code necessary to construct the final binary.

A tool with similar functionality is Etherboot's ROM-o-matic which builds etherboot as a coreboot ELF payload.

Supported Platforms

Buildrom supports the following platforms:

  • AMD Geode LX 'Norwich'
  • Artec Group DBE61
  • PC Engines ALIX1.C
  • Digital Logic MSM800SEV
  • AMD DB800
  • Gigabyte GA-M57SLI-S4
  • Gigabyte 2761GXDK
  • Tyan S2882
  • Tyan S2891
  • AMD 'Serengeti Cheetah'

Supported Payloads

Buildrom supports the following payloads:

  • Linux kernel
  • Etherboot
  • FILO
  • "Linux-as-bootloader" (LAB)
  • Memtest86+ (except on the GA-M57SLI-S4 and the Tyan S2891)

Download

$ svn co svn://coreboot.org/buildrom

Prerequisites

You will need the following packages on your system to use buildrom. Please consult your distribution documentation on how to install new packages:

  • subversion
  • make
  • quilt
  • GNU compiler tools (as, ld, gcc)
  • iasl (for AMD K8 platforms)

Configuration

In the buildrom-devel directory, type:

$  make menuconfig

You can now navigate the configuration system (this is the same configuration engine that the Linux kernel uses, so it should be familiar to some readers).

Building the ROM

Make sure you have access to the internet (to download new packages), and type the following to create your ROM:

$ make

Buildrom will download and build all the components of the ROM selected in the configuration stage. if the build is successful, then the final ROM will be located in buildrom-devel/deploy. If it is not successful, then you will see an error message. You can see the build output for each package in by reading build.log in the work/<package>logs/ directory (i.e work/filo/logs/build.log).

Developing within Buildrom

This section is for the developers who wish to change and rebuild the code. BuildROM builds the code for coreboot and the payloads in the work/ directory. Here is a typical view of the buildROM work/ directory:

$ ls work/
  linuxbios  filo

In each directory, you will find three directories. Logs from the build will be found in logs/ and timestamps that the build system uses are in stamps/. You normally won't have to touch these directories. The source code is located in the third directory. BuildROM provides several commands to make it easy to rebuild individual packages and ROMs. To clean a directory (but not remove the source code) use 'make <package>-clean'. You can build an individual packages with 'make <package>'. f you wish to completely erase the source code and start again with a pristine version, use 'make <package>-distclean'. Typing 'make' at any time will rebuild the ROM using the most current versions of the individual packages. Here is a typical work flow for modifying coreboot code:

  1. Build the initial ROM from scratch with 'make'
  2. Edit the coreboot source code in work/linuxbios/svn/
  3. Clean the coreboot package with 'make linuxbios-clean'
  4. Rebuild the ROM with 'make'