coreboot/payloads/libpayload
Julius Werner d5a460c8c7 libpayload: cbfs: Fix ram_media map() error return value
The correct return value for errors on a cbfs_media->map() call is
CBFS_MEDIA_INVALID_MAP_ADDRESS, not NULL. Not sure if that's the best
choice (since 0xffffffff is probably a more likely valid address than 0
there), but that's what the upper layers expect right now.

BRANCH=veyron
BUG=None
TEST=Press CTRL+L with an RW_LEGACY section filled with 0xff. Observe
how cbfs_get_header() returns failure without doing a bunch of NULL
pointer accesses first (not that those have any visible effect on
Veyron, but that's another problem...)

Change-Id: I0793434116a8c568e19fe0dee24f13942fc50f25
Signed-off-by: Julius Werner <jwerner@chromium.org>
Reviewed-on: https://chromium-review.googlesource.com/238991
Reviewed-by: Hung-Te Lin <hungte@chromium.org>
Reviewed-on: https://chromium-review.googlesource.com/242150
2015-01-21 01:17:03 +00:00
..
arch libpayload: arm64: don't modify cbtable entries 2014-11-18 21:11:52 +00:00
bin libpayload: Add support for arm64 in libpayload 2014-06-07 01:28:57 +00:00
configs Brain: Initial import. 2015-01-21 01:16:33 +00:00
crypto libpayload: Change CONFIG_* to CONFIG_LP_* in the kconfig. 2013-08-14 17:05:33 -07:00
curses libpayload: Change CONFIG_* to CONFIG_LP_* in the kconfig. 2013-08-14 17:05:33 -07:00
drivers libpayload: EHCI: Fix transaction error for interrupt transfer 2014-12-09 06:03:40 +00:00
gdb libpayload: Let GDB stub read/write memory with aligned MMIO words 2014-07-22 01:24:00 +00:00
include CBFS: Automate ROM image layout and remove hardcoded offsets 2014-12-03 06:09:54 +00:00
libc libpayload: UTF-16LE to ASCII conversion 2014-11-25 03:47:18 +00:00
libcbfs libpayload: cbfs: Fix ram_media map() error return value 2015-01-21 01:17:03 +00:00
liblzma libpayload: Make lzma truncation non-fatal. 2013-08-19 19:04:35 -07:00
libpci libpayload: minor cleanups 2012-04-04 00:40:31 +02:00
sample fix compilation of hello.elf example payload. 2010-08-28 23:23:47 +00:00
tests libpayload: Change CONFIG_X86_SERIAL_CONSOLE to CONFIG_8250_SERIAL_CONSOLE 2013-09-27 14:05:53 +00:00
util libpayload: Add support for arm64 in libpayload 2014-06-07 01:28:57 +00:00
Config.in Revert "ryu: libpayload: Add CONFIG_LP_TEGRA_VIDEO_CONSOLE_INIT" 2014-12-04 20:44:56 +00:00
Doxyfile
LICENSE_GPL libpayload: Introduce new Kconfig to explicitly allow GPL code 2014-06-13 20:37:29 +00:00
LICENSES libpayload: Introduce new Kconfig to explicitly allow GPL code 2014-06-13 20:37:29 +00:00
Makefile libpayload: Add support for arm64 in libpayload 2014-06-07 01:28:57 +00:00
Makefile.inc Change GDB_DEBUG to SOURCE_DEBUG 2014-10-08 05:07:21 +00:00
README libpayload, superiotool: README: Prepend coreboot/ to path of change directory line 2013-04-04 17:22:15 +02:00

-------------------------------------------------------------------------------
libpayload README
-------------------------------------------------------------------------------

libpayload is a minimal library to support standalone payloads
that can be booted with firmware like coreboot. It handles the setup
code, and provides common C library symbols such as malloc() and printf().

Note: This is _not_ a standard library for use with an operating system,
rather it's only useful for coreboot payload development!
See http://coreboot.org for details on coreboot.


Installation
------------

 $ git clone http://review.coreboot.org/p/coreboot.git

 $ cd coreboot/payloads/libpayload

 $ make menuconfig

 $ make

 $ sudo make install (optional, will install into /opt per default)

As libpayload is for 32bit x86 systems only, you might have to install the
32bit libgcc version, otherwise your payloads will fail to compile.
On Debian systems you'd do 'apt-get install gcc-multilib' for example.


Usage
-----

Here's an example of a very simple payload (hello.c) and how to build it:

 #include <libpayload.h>

 int main(void)
 {
     printf("Hello, world!\n");
     return 0;
 }

Building the payload using the 'lpgcc' compiler wrapper:

 $ lpgcc -o hello.elf hello.c

Please see the sample/ directory for details.


Website and Mailing List
------------------------

The main website is http://www.coreboot.org/Libpayload.

For additional information, patches, and discussions, please join the
coreboot mailing list at http://coreboot.org/Mailinglist, where most
libpayload developers are subscribed.


Copyright and License
---------------------

See LICENSES.