coreboot-kgpe-d16/src/lib
Ward Vandewege ec2bd53c37 If you have
option CONFIG_COMPRESSED_PAYLOAD_LZMA=1
  option CONFIG_PRECOMPRESSED_PAYLOAD=1

set in Config.lb but accidentally use an uncompressed payload, coreboot (v2)
bombs out like this:

  elfboot: Attempting to load payload.
  rom_stream: 0xfffc0000 - 0xfffdefff
  Uncompressing to RAM 0x01000000 Decoder scratchpad too small!
  Decoding error = 1
  Unexpected Exception: 6 @ 10:04000408 - Halting
  Code: 0 eflags: 00010057
  eax: 00000101 ebx: 04000400 ecx: 000003d4 edx: fffc0000
  edi: 04000400 esi: 04000401 ebp: 04000400 esp: 0013dfb4

The attached patch modifies v2's lzma code so that it assumes an uncompressed
payload if it fails to find a properly compressed payload.

Compare with the fatal error above:

  elfboot: Attempting to load payload.
  rom_stream: 0xfffc0000 - 0xfffdefff
  Uncompressing to RAM 0x01000000 Decoder scratchpad too small!
   olen = 0x00000000 done.
  Decompression failed. Assuming payload is uncompressed...
  Found ELF candidate at offset 0
  header_offset is 0
  Try to load at offset 0x0

If you don't have CONFIG_COMPRESSED_PAYLOAD_LZMA and
CONFIG_PRECOMPRESSED_PAYLOAD set and use an uncompressed payload, things are as
before:

  elfboot: Attempting to load payload.
  rom_stream: 0xfffc0000 - 0xfffdefff
  Found ELF candidate at offset 0
  header_offset is 0
  Try to load at offset 0x0

One can argue that this is a case of 'builder beware', but my counter argument
is that anything that causes unexpected runtime breakage is really, really,
really bad, and should be avoided where possible.

This patch also fixes one erroneous comment.

Signed-off-by: Ward Vandewege <ward@gnu.org>
Acked-by: Myles Watson <mylesgw@gmail.com>
Acked-by: Carl-Daniel Hailfinger <c-d.hailfinger.devel.2006@gmx.net>



git-svn-id: svn://svn.coreboot.org/coreboot/trunk@3542 2b7e53f0-3cfb-0310-b3e9-8179ed1497e1
2008-08-27 21:53:11 +00:00
..
clog2.c eric patch 2005-07-08 02:49:49 +00:00
compute_ip_checksum.c - Initial checkin of the freebios2 tree 2003-04-22 19:02:15 +00:00
Config.lb clean up Config.lb in lib/ (trivial) 2008-08-01 11:32:12 +00:00
delay.c - Major cleanup of the bootpath 2003-07-19 04:28:22 +00:00
fallback_boot.c eric patch 2005-07-08 02:49:49 +00:00
lzma.c If you have 2008-08-27 21:53:11 +00:00
lzmadecode.c additions and mods for lzma. 2006-09-14 15:12:36 +00:00
lzmadecode.h additions and mods for lzma. 2006-09-14 15:12:36 +00:00
malloc.c Revision: linuxbios@linuxbios.org--devel/freebios--devel--2.0--patch-34 2005-07-06 17:15:30 +00:00
memcmp.c - Initial checkin of the freebios2 tree 2003-04-22 19:02:15 +00:00
memcpy.c - Moved hlt() to it's own header. 2004-03-11 15:01:31 +00:00
memmove.c tidy 2004-03-13 03:40:29 +00:00
memset.c - Initial checkin of the freebios2 tree 2003-04-22 19:02:15 +00:00
nrv2b.c AMD Rev F support 2006-10-04 20:46:15 +00:00
uart8250.c Add serial stream payload support from Ed Swierk <eswierk@arastra.com> 2006-10-07 00:13:24 +00:00
usbdebug_direct.c Rename almost all occurences of LinuxBIOS to coreboot. 2008-01-18 15:08:58 +00:00
version.c Rename almost all occurences of LinuxBIOS to coreboot. 2008-01-18 15:08:58 +00:00
xmodem.c replace table based crc with computational one. by Ed Swierk. 2006-10-09 22:35:45 +00:00