commit | ed98d7e7a8de6aabd158ccd893239bc611c912a6 | [log] [tgz] |
---|---|---|
author | Joel Stanley <joel@jms.id.au> | Fri May 10 15:00:18 2019 +0930 |
committer | Joel Stanley <joel@jms.id.au> | Mon May 13 13:11:20 2019 +0930 |
tree | 80807d9d59dbce35cff57ba7d886c47b9fcc1182 | |
parent | 622e8d000eaa4d456e6a2b4aa3c4da465b47ffee [diff] |
skiboot: Fix building device tree with host-dtc We need to do the build with the PATH set to the host tools. Without this change the build fails when the host lacks a dtc, as it is not in the PATH. I suspect CI missed this as only opal_defconfig tries to build with the SKIBOOT_DEVICETREE option and the CI that builds this config also happened to have dtc installed: $ git grep SKIBOOT_DEVICETREE openpower/configs/ openpower/configs/opal_defconfig:BR2_SKIBOOT_DEVICETREE=y Note that this will still fail without a skiboot that has "devicetree: Don't set path to dtc in makefile"[1] applied. This patch won't make any currently working system fail, so it is safe to merge while we wait for the skiboot patch to be merged. [1] https://patchwork.ozlabs.org/patch/1097826/ Signed-off-by: Joel Stanley <joel@jms.id.au>
The OpenPOWER firmware build process uses Buildroot to create a toolchain and build the various components of the PNOR firmware, including Hostboot, Skiboot, OCC, Petitboot etc.
https://open-power.github.io/op-build/
See the doc/ directory for documentation source. Contributions are VERY welcome!
Issues, Milestones, pull requests and code hosting is on GitHub: https://github.com/open-power/op-build
See CONTRIBUTING.md for howto contribute code.
To build an image for a Palmetto system:
git clone --recursive git@github.com:open-power/op-build.git cd op-build ./op-build palmetto_defconfig && ./op-build
There are also default configurations for other platforms in openpower/configs/
. Current POWER8 platforms include Habanero, Firestone, and Garrison. Current POWER9 platforms include Witherspoon, Boston (p9dsu), Romulus, and Zaius.
Buildroot/op-build supports both native and cross-compilation - it will automatically download and build an appropriate toolchain as part of the build process, so you don't need to worry about setting up a cross-compiler. Cross-compiling from a x86-64 host is officially supported.
The machine your building on will need Python 2.7, GCC 6.2 (or later), and a handful of other packages (see below).
Install Ubuntu (>= 18.04) or Debian (>= 9) 64-bit.
Enable Universe (Ubuntu only):
sudo apt-get install software-properties-common sudo add-apt-repository universe
Install the packages necessary for the build:
sudo apt-get install cscope ctags libz-dev libexpat-dev \ python language-pack-en texinfo \ build-essential g++ git bison flex unzip \ libssl-dev libxml-simple-perl libxml-sax-perl libxml-parser-perl libxml2-dev libxml2-utils xsltproc \ wget bc rsync
Install Fedora (>= 25) 64-bit.
Install the packages necessary for the build:
sudo dnf install gcc-c++ flex bison git ctags cscope expat-devel patch \ zlib-devel zlib-static texinfo perl-bignum "perl(XML::Simple)" \ "perl(YAML)" "perl(XML::SAX)" "perl(Fatal)" "perl(Thread::Queue)" \ "perl(Env)" "perl(XML::LibXML)" "perl(Digest::SHA1)" libxml2-devel \ which wget unzip tar cpio python bzip2 bc findutils ncurses-devel