xref: /openbmc/qemu/pc-bios/README (revision fc8c745d50150a63f6c5ba2cd0b83b430963b7e8)
1c0ced0f3SStefan Weil- SeaBIOS (bios.bin) is the successor of pc bios.
2c0ced0f3SStefan Weil  See http://www.seabios.org/ for more information.
3f5dc4c7cSaliguori
47f5d44e0Sbellard- The VGA BIOS and the Cirrus VGA BIOS come from the LGPL VGA bios
5c34ebfdcSAnthony Liguori  project (http://www.nongnu.org/vgabios/).
6fa36761dSbellard
70986ac3bSbellard- OpenBIOS (http://www.openbios.org/) is a free (GPL v2) portable
80986ac3bSbellard  firmware implementation. The goal is to implement a 100% IEEE
90986ac3bSbellard  1275-1994 (referred to as Open Firmware) compliant firmware.
100bce98dfSBlue Swirl  The included images for PowerPC (for 32 and 64 bit PPC CPUs),
119eb08a43SMark Cave-Ayland  Sparc32 (including QEMU,tcx.bin and QEMU,cgthree.bin) and Sparc64 are built
125264917bSMark Cave-Ayland  from OpenBIOS SVN revision 1280.
13eec85c2aSths
14a9f8ad8fSDavid Gibson- SLOF (Slimline Open Firmware) is a free IEEE 1275 Open Firmware
15a9f8ad8fSDavid Gibson  implementation for certain IBM POWER hardware.  The sources are at
164807ab4fSAlexey Kardashevskiy  https://github.com/aik/SLOF, and the image currently in qemu is
17b88e0a57SAlexey Kardashevskiy  built from git tag qemu-slof-20210217.
18a9f8ad8fSDavid Gibson
19*fc8c745dSAlexey Kardashevskiy- VOF (Virtual Open Firmware) is a minimalistic firmware to work with
20*fc8c745dSAlexey Kardashevskiy  -machine pseries,x-vof=on. When enabled, the firmware acts as a slim shim and
21*fc8c745dSAlexey Kardashevskiy  QEMU implements parts of the IEEE 1275 Open Firmware interface.
22*fc8c745dSAlexey Kardashevskiy
236329866fSPaolo Bonzini- sgabios (the Serial Graphics Adapter option ROM) provides a means for
246329866fSPaolo Bonzini  legacy x86 software to communicate with an attached serial console as
256329866fSPaolo Bonzini  if a video card were attached.  The master sources reside in a subversion
266329866fSPaolo Bonzini  repository at http://sgabios.googlecode.com/svn/trunk.  A git mirror is
27c5ea4ec1SStefan Hajnoczi  available at https://gitlab.com/qemu-project/sgabios.git.
286329866fSPaolo Bonzini
2936d8d02dSAlex Williamson- The PXE roms come from the iPXE project. Built with BANNER_TIME 0.
3036d8d02dSAlex Williamson  Sources available at http://ipxe.org.  Vendor:Device ID -> ROM mapping:
3174b12befSAnthony Liguori
3236d8d02dSAlex Williamson	8086:100e -> pxe-e1000.rom
3336d8d02dSAlex Williamson	8086:1209 -> pxe-eepro100.rom
3436d8d02dSAlex Williamson	1050:0940 -> pxe-ne2k_pci.rom
3536d8d02dSAlex Williamson	1022:2000 -> pxe-pcnet.rom
3636d8d02dSAlex Williamson	10ec:8139 -> pxe-rtl8139.rom
3736d8d02dSAlex Williamson	1af4:1000 -> pxe-virtio.rom
38fe270d04SAlexander Graf
39753d11f2SRichard Henderson- The sources for the Alpha palcode image is available from:
4006bef596SStefan Hajnoczi  https://github.com/rth7680/qemu-palcode.git
414e73c781SAlexander Graf
424e73c781SAlexander Graf- The u-boot binary for e500 comes from the upstream denx u-boot project where
434e73c781SAlexander Graf  it was compiled using the qemu-ppce500 target.
44c5ea4ec1SStefan Hajnoczi  A git mirror is available at: https://gitlab.com/qemu-project/u-boot.git
454e73c781SAlexander Graf  The hash used to compile the current version is: 2072e72
46bcad45deSCédric Le Goater
47bcad45deSCédric Le Goater- Skiboot (https://github.com/open-power/skiboot/) is an OPAL
48bcad45deSCédric Le Goater  (OpenPower Abstraction Layer) firmware for OpenPOWER systems. It can
49bcad45deSCédric Le Goater  run an hypervisor OS or simply a host OS on the "baremetal"
50bcad45deSCédric Le Goater  platform, also known as the PowerNV (Non-Virtualized) platform.
510806b30cSMark Cave-Ayland
520806b30cSMark Cave-Ayland- QemuMacDrivers (https://github.com/ozbenh/QemuMacDrivers) is a project to
530806b30cSMark Cave-Ayland  provide virtualised drivers for PPC MacOS guests.
5413814db0SLaszlo Ersek
5513814db0SLaszlo Ersek- The "edk2-*.fd.bz2" images are platform firmware binaries and matching UEFI
5613814db0SLaszlo Ersek  variable store templates built from the TianoCore community's EFI Development
5713814db0SLaszlo Ersek  Kit II project
5813814db0SLaszlo Ersek  <https://github.com/tianocore/tianocore.github.io/wiki/EDK-II>. The images
5941923660SLaszlo Ersek  were built at git tag "edk2-stable202008". The firmware binaries bundle parts
6041923660SLaszlo Ersek  of the OpenSSL project, at git tag "OpenSSL_1_1_1g" (the OpenSSL tag is a
61541617caSLaszlo Ersek  function of the edk2 tag). Parts of the Berkeley SoftFloat library are
62541617caSLaszlo Ersek  bundled as well, at Release 3e plus a subsequent typo fix (commit
63541617caSLaszlo Ersek  b64af41c3276f97f0e181920400ee056b9c88037), as an OpenSSL dependency on 32-bit
64541617caSLaszlo Ersek  ARM. Licensing information is given in "edk2-licenses.txt". The image files
65541617caSLaszlo Ersek  are described by the JSON documents in the "pc-bios/descriptors" directory,
66541617caSLaszlo Ersek  which conform to the "docs/interop/firmware.json" schema.
6791f3a2f0SAlistair Francis
6891f3a2f0SAlistair Francis- OpenSBI (https://github.com/riscv/opensbi) aims to provide an open-source
6991f3a2f0SAlistair Francis  reference implementation of the RISC-V Supervisor Binary Interface (SBI)
7091f3a2f0SAlistair Francis  specifications for platform-specific firmwares executing in M-mode. For all
7191f3a2f0SAlistair Francis  supported platforms, OpenSBI provides several runtime firmware examples.
7291f3a2f0SAlistair Francis  These example firmwares can be used to replace the legacy riscv-pk bootloader
7391f3a2f0SAlistair Francis  and enable the use of well-known bootloaders such as U-Boot.
7491f3a2f0SAlistair Francis  OpenSBI is distributed under the terms of the BSD 2-clause license
7591f3a2f0SAlistair Francis  ("Simplified BSD License" or "FreeBSD License", SPDX: BSD-2-Clause). OpenSBI
7691f3a2f0SAlistair Francis  source code also contains code reused from other projects desribed here:
7791f3a2f0SAlistair Francis  https://github.com/riscv/opensbi/blob/master/ThirdPartyNotices.md.
78d1cb5edaSHavard Skinnemoen
79d1cb5edaSHavard Skinnemoen- npcm7xx_bootrom.bin is a simplified, free (Apache 2.0) boot ROM for Nuvoton
80d1cb5edaSHavard Skinnemoen  NPCM7xx BMC devices. It currently implements the bare minimum to load, parse,
81d1cb5edaSHavard Skinnemoen  initialize and run boot images stored in SPI flash, but may grow more
82d1cb5edaSHavard Skinnemoen  features over time as needed. The source code is available at:
83d1cb5edaSHavard Skinnemoen  https://github.com/google/vbootrom
84