]> git.ipfire.org Git - thirdparty/ipxe.git/log
thirdparty/ipxe.git
12 years ago[test] Add self-tests for snprintf()
Michael Brown [Mon, 12 Aug 2013 15:34:10 +0000 (16:34 +0100)] 
[test] Add self-tests for snprintf()

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[settings] Expose CPUID instruction via settings mechanism
Michael Brown [Tue, 6 Aug 2013 18:16:30 +0000 (19:16 +0100)] 
[settings] Expose CPUID instruction via settings mechanism

Allow CPUID values to be read using the syntax

  ${cpuid/<register>.<function>}

For example, ${cpuid/2.0x80000001} will give the value of %ecx after
calling CPUID with %eax=0x80000001.  Values for <register> are encoded
as %eax=0, %ebx=1, %ecx=2, %edx=3.

The numeric encoding is more sophisticated than described above,
allowing for settings such as the CPU model (obtained by calling CPUID
with %eax=0x80000002-0x80000004 inclusive and concatenating the values
returned in %eax:%ebx:%ecx:%edx).  See the source code for details.

The "cpuvendor" and "cpumodel" settings provide easy access to these
more complex CPUID settings.

This functionality is intended to complement the "cpuid" command,
which allows for testing individual CPUID feature bits.

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[nfs] Fix an issue with the selection of a local port
Marin Hannache [Thu, 18 Jul 2013 12:35:30 +0000 (14:35 +0200)] 
[nfs] Fix an issue with the selection of a local port

Reported-by: Robin Smidsrød <robin@smidsrod.no>
Signed-off-by: Marin Hannache <git@mareo.fr>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[tcpip] Allow binding to unspecified privileged ports (below 1024)
Michael Brown [Tue, 6 Aug 2013 14:56:54 +0000 (15:56 +0100)] 
[tcpip] Allow binding to unspecified privileged ports (below 1024)

Originally-implemented-by: Marin Hannache <git@mareo.fr>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[ipv6] Rename sin_{family,port} to sin6_{family,port} in struct sockaddr_in6
Michael Brown [Tue, 6 Aug 2013 14:55:23 +0000 (15:55 +0100)] 
[ipv6] Rename sin_{family,port} to sin6_{family,port} in struct sockaddr_in6

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[udp] Move high-frequency debug messages to DBGLVL_EXTRA
Michael Brown [Tue, 6 Aug 2013 14:52:31 +0000 (15:52 +0100)] 
[udp] Move high-frequency debug messages to DBGLVL_EXTRA

This makes it possible to leave UDP debugging enabled in order to see
interesting UDP events, without flooding the console with at least one
message per packet.

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[cmdline] Add "pciscan" command to allow iteration over PCI devices
Michael Brown [Thu, 1 Aug 2013 15:53:17 +0000 (16:53 +0100)] 
[cmdline] Add "pciscan" command to allow iteration over PCI devices

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[pci] Add pci_find_next() to iterate over existent PCI devices
Michael Brown [Thu, 1 Aug 2013 15:52:28 +0000 (16:52 +0100)] 
[pci] Add pci_find_next() to iterate over existent PCI devices

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[cmdline] Add "inc" command
Michael Brown [Thu, 1 Aug 2013 13:42:28 +0000 (14:42 +0100)] 
[cmdline] Add "inc" command

The "inc" command allows the numeric value of a setting to be
incremented, allowing for the construction of simple loops within an
iPXE script.

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[settings] Introduce the generalised concept of a numeric setting
Michael Brown [Thu, 1 Aug 2013 13:39:58 +0000 (14:39 +0100)] 
[settings] Introduce the generalised concept of a numeric setting

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[script] Allow commands following a script label
Michael Brown [Tue, 23 Jul 2013 15:49:12 +0000 (16:49 +0100)] 
[script] Allow commands following a script label

Allow commands to be placed on the same line as a label.  This allows
for improved legibility of loop constructions by incorporating the
loop check condition into the same line as the loop label.  For
example, to iterate over network devices using the forthcoming "inc"
command:

  set idx:int16 0
  :loop isset ${net${idx}/mac} || goto loop_done
    echo net${idx} is a ${net${idx}/chip} with MAC ${net${idx}/mac}
    inc idx && goto loop
  :loop_done

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[script] Allow initial whitespace on lines containing labels
Michael Brown [Tue, 23 Jul 2013 13:46:45 +0000 (14:46 +0100)] 
[script] Allow initial whitespace on lines containing labels

Initial whitespace is already accepted on lines containing commands,
since it gets ignored by the system() call.  Minimise surprise and
allow for neater indentation of scripts by also allowing whitespace on
lines containing labels.

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[settings] Remove now-unused fetchf_named_setting() and storef_named_setting()
Michael Brown [Mon, 22 Jul 2013 13:36:00 +0000 (14:36 +0100)] 
[settings] Remove now-unused fetchf_named_setting() and storef_named_setting()

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[settings] Eliminate calls to {fetch,store}f_named_setting() in NVO commands
Michael Brown [Fri, 19 Jul 2013 13:07:18 +0000 (14:07 +0100)] 
[settings] Eliminate calls to {fetch,store}f_named_setting() in NVO commands

A deliberate side effect of this commit is that the "read" command
will now preserve the type of the setting, if the setting name
contains no type information.  For example:

  iPXE> set foo:ipv4 192.168.0.1
  iPXE> read foo
  192.168.0.100
  iPXE> show foo
  foo:ipv4 = 192.168.0.100

rather than the arguably unexpected behaviour of resetting the type to
"string".

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[settings] Eliminate call to storef_named_setting() in choose_exec()
Michael Brown [Thu, 18 Jul 2013 14:49:32 +0000 (15:49 +0100)] 
[settings] Eliminate call to storef_named_setting() in choose_exec()

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[parseopt] Add parse_setting()
Michael Brown [Thu, 18 Jul 2013 15:11:39 +0000 (16:11 +0100)] 
[parseopt] Add parse_setting()

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[parseopt] Move parse_settings() to parseopt.c
Michael Brown [Thu, 18 Jul 2013 14:30:00 +0000 (15:30 +0100)] 
[parseopt] Move parse_settings() to parseopt.c

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[parseopt] Allow parsed option to be modified
Michael Brown [Mon, 22 Jul 2013 15:13:25 +0000 (16:13 +0100)] 
[parseopt] Allow parsed option to be modified

Parsing a setting name requires the ability to modify the text being
parsed.

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[settings] Remove now-unused store_named_setting()
Michael Brown [Thu, 18 Jul 2013 14:19:59 +0000 (15:19 +0100)] 
[settings] Remove now-unused store_named_setting()

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[settings] Eliminate call to store_named_setting() in nslookup.c
Michael Brown [Thu, 18 Jul 2013 13:49:06 +0000 (14:49 +0100)] 
[settings] Eliminate call to store_named_setting() in nslookup.c

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[settings] Eliminate call to fetchf_named_setting() in expand_settings()
Michael Brown [Thu, 18 Jul 2013 13:47:42 +0000 (14:47 +0100)] 
[settings] Eliminate call to fetchf_named_setting() in expand_settings()

Use parse_setting_name() and fetchf_setting_copy() in
expand_settings(), to eliminate the call to fetchf_named_setting().

This change also eliminates the potentially large stack-allocated
buffer in expand_settings().

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[settings] Add fetchf_setting_copy()
Michael Brown [Thu, 18 Jul 2013 13:46:20 +0000 (14:46 +0100)] 
[settings] Add fetchf_setting_copy()

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[settings] Change "not-found" semantics of fetch_setting_copy()
Michael Brown [Fri, 19 Jul 2013 13:53:38 +0000 (14:53 +0100)] 
[settings] Change "not-found" semantics of fetch_setting_copy()

fetch_settings_copy() currently returns success and a NULL data
pointer to indicate a non-existent setting.  This is intended to allow
the caller to differentiate between a non-existent setting and an
error in allocating memory for the copy of the setting.

The underlying settings blocks' fetch() methods provide no way to
perform an existence check separate from an attempt to fetch the
setting.  A "non-existent setting" therefore means simply a setting
for which an error was encountered when attempting to fetch from every
settings block within the subtree.

Since any underlying error within a settings block (e.g. a GuestRPC
failure when attempting to retrieve a VMware GuestInfo setting) will
produce the effect of a "non-existent setting", it seems somewhat
meaningless to give special treatment to memory allocation errors
within fetch_setting_copy().

Remove the special treatment and simplify the semantics of
fetch_setting_copy() by directly passing through any underlying error
(including non-existence) encountered while fetching the setting.

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[settings] Expose parse_setting_name()
Michael Brown [Thu, 18 Jul 2013 13:44:09 +0000 (14:44 +0100)] 
[settings] Expose parse_setting_name()

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[settings] Remove default_type parameter from parse_setting_name()
Michael Brown [Fri, 19 Jul 2013 13:08:13 +0000 (14:08 +0100)] 
[settings] Remove default_type parameter from parse_setting_name()

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[settings] Remove temporary name buffer parameter from parse_setting_name()
Michael Brown [Thu, 18 Jul 2013 14:48:29 +0000 (15:48 +0100)] 
[settings] Remove temporary name buffer parameter from parse_setting_name()

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[settings] Avoid potentially large stack allocations
Michael Brown [Wed, 17 Jul 2013 13:00:38 +0000 (14:00 +0100)] 
[settings] Avoid potentially large stack allocations

Avoid potentially large stack allocations in fetchf_setting() and
storef_setting().

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[settings] Clarify usage of the term "named setting"
Michael Brown [Thu, 18 Jul 2013 12:35:19 +0000 (13:35 +0100)] 
[settings] Clarify usage of the term "named setting"

There are currently two conflicting usages of the term "named setting"
within iPXE: one refers to predefined settings (such as show up in the
"config" UI), the other refers to settings identified by a name (such
as "net0.dhcp/ip").

Split these usages into the term "predefined setting" and "named
setting" to avoid ambiguity.

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[build] Fix %.licence build target
Michael Brown [Mon, 15 Jul 2013 22:08:50 +0000 (00:08 +0200)] 
[build] Fix %.licence build target

Our use of --gc-sections causes the linker to discard the symbols
defined by FILE_LICENCE(), meaning that the resulting licence
determination is incomplete.

We must use the KEEP() directive in the linker script to force the
linker to not discard the licence symbols.  Using KEEP(*(COMMON))
would be undesirable, since there are some symbols in COMMON which we
may wish to discard.

Fix by placing symbols defined by PROVIDE_SYMBOL() (which is used by
FILE_LICENCE()) into a special ".provided" section, which we then mark
with KEEP().  All such symbols are zero-length, so there is no cost in
terms of the final binary size.

Since the symbols are no longer in COMMON, the linker will reject
symbols with the same name coming from multiple objects.  We therefore
append the object name to the licence symbol, to ensure that it is
unique.

Reported-by: Marin Hannache <git@mareo.fr>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[legal] Add missing FILE_LICENCE declarations
Michael Brown [Mon, 15 Jul 2013 22:23:09 +0000 (00:23 +0200)] 
[legal] Add missing FILE_LICENCE declarations

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[script] Avoid trying to read final character of a zero-length string
Michael Brown [Mon, 15 Jul 2013 16:06:41 +0000 (18:06 +0200)] 
[script] Avoid trying to read final character of a zero-length string

Detected using Valgrind.

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[nfs] Add support for NFS protocol
Marin Hannache [Mon, 15 Jul 2013 15:56:29 +0000 (17:56 +0200)] 
[nfs] Add support for NFS protocol

Tested-by: Robin Smidsrød <robin@smidsrod.no>
Signed-off-by: Marin Hannache <git@mareo.fr>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[ifmgmt] Avoid relying on global variable within ifcommon_exec()
Michael Brown [Mon, 15 Jul 2013 15:30:39 +0000 (17:30 +0200)] 
[ifmgmt] Avoid relying on global variable within ifcommon_exec()

The getopt API defines optind as a global variable.  When used by the
"autoboot" command, the payload function passed to ifcommon_exec() may
result in a new iPXE script being executed; the commands therein would
then overwrite the value of optind.  On returning, ifcommon_exec()
would continue processing the list of interfaces from an undefined
point.

Fix by using a local variable to hold the index within the list of
interfaces.

Reported-by: Robin Smidsrød <robin@smidsrod.no>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[build] Include ipxe.pxe in default build
Robin Smidsrød [Mon, 15 Jul 2013 12:21:04 +0000 (14:21 +0200)] 
[build] Include ipxe.pxe in default build

Signed-off-by: Robin Smidsrød <robin@smidsrod.no>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[cmdline] Add "poweroff" command
Marin Hannache [Sat, 13 Jul 2013 12:31:15 +0000 (14:31 +0200)] 
[cmdline] Add "poweroff" command

Modified-by: Michael Brown <mcb30@ipxe.org>
Signed-off-by: Marin Hannache <git@mareo.fr>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[legal] Add missing FILE_LICENCE declarations
Marin Hannache [Mon, 15 Jul 2013 10:30:57 +0000 (12:30 +0200)] 
[legal] Add missing FILE_LICENCE declarations

Signed-off-by: Marin Hannache <git@mareo.fr>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[realtek] Allow extra space in RX buffers
Michael Brown [Mon, 15 Jul 2013 10:15:48 +0000 (12:15 +0200)] 
[realtek] Allow extra space in RX buffers

Some hardware (observed with an onboard RTL8168) will erroneously
report a buffer overflow error if the received packet exactly fills
the receive buffer.

Fix by adding an extra four bytes of padding to each receive buffer.

Debugged-by: Thomas Miletich <thomas.miletich@gmail.com>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[settings] Add support for navigation keys in "config" user interface
Michael Brown [Mon, 15 Jul 2013 09:59:13 +0000 (11:59 +0200)] 
[settings] Add support for navigation keys in "config" user interface

Add support for page up, page down, home and end keys, matching the
navigation logic used in the menu user interface.

Originally-implemented-by: Marin Hannache <git@mareo.fr>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[velocity] Rewrite VIA Velocity driver
Adrian Jamróz [Sat, 13 Jul 2013 16:59:07 +0000 (18:59 +0200)] 
[velocity] Rewrite VIA Velocity driver

Signed-off-by: Adrian Jamróz <adrian.jamroz@gmail.com>
Modified-by: Thomas Miletich <thomas.miletich@gmail.com>
Signed-off-by: Thomas Miletich <thomas.miletich@gmail.com>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[script] Allow for backslash continuation of script lines
Michael Brown [Mon, 15 Jul 2013 09:13:33 +0000 (11:13 +0200)] 
[script] Allow for backslash continuation of script lines

Allow long script lines to be broken up using backslash continuation.
For example:

   choose --default linux --timeout 3000 os \
      && goto boot_${os} || goto cancelled

Requested-by: Robin Smidsrød <robin@smidsrod.no>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[realtek] Report RX error detail in debug messages
Michael Brown [Sun, 14 Jul 2013 22:38:43 +0000 (00:38 +0200)] 
[realtek] Report RX error detail in debug messages

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[base16] Ensure base16_encode() always terminates its result string
Michael Brown [Sun, 14 Jul 2013 22:06:45 +0000 (00:06 +0200)] 
[base16] Ensure base16_encode() always terminates its result string

base16_encode() will fail to generate a terminating NUL if the length
of the raw data is zero, since the loop calling sprintf() will never
execute.

Fix by explicitly terminating the result with a NUL.

Reported-by: Marin Hannache <git@mareo.fr>
Debugged-by: Marin Hannache <git@mareo.fr>
Tested-by: Marin Hannache <git@mareo.fr>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[legal] Add FILE_LICENCE for ath9k driver headers
Marin Hannache [Sun, 14 Jul 2013 21:19:55 +0000 (23:19 +0200)] 
[legal] Add FILE_LICENCE for ath9k driver headers

Signed-off-by: Marin Hannache <git@mareo.fr>
Modified-by: Michael Brown <mcb30@ipxe.org>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[legal] Add FILE_LICENCE for core/errno.c
Marin Hannache [Sun, 14 Jul 2013 21:19:37 +0000 (23:19 +0200)] 
[legal] Add FILE_LICENCE for core/errno.c

Signed-off-by: Marin Hannache <git@mareo.fr>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[legal] Add FILE_LICENCE for valgrind headers
Marin Hannache [Sun, 14 Jul 2013 21:19:15 +0000 (23:19 +0200)] 
[legal] Add FILE_LICENCE for valgrind headers

Signed-off-by: Marin Hannache <git@mareo.fr>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[linux] Add missing #include <stddef.h>
Marin Hannache [Fri, 12 Jul 2013 22:01:47 +0000 (00:01 +0200)] 
[linux] Add missing #include <stddef.h>

Signed-off-by: Marin Hannache <git@mareo.fr>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[intel] Incorporate ring producer and consumer counters in diagnostics
Michael Brown [Sun, 14 Jul 2013 17:07:38 +0000 (19:07 +0200)] 
[intel] Incorporate ring producer and consumer counters in diagnostics

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[rhine] Rewrite VIA Rhine driver
Adrian Jamróz [Sat, 13 Jul 2013 14:11:50 +0000 (16:11 +0200)] 
[rhine] Rewrite VIA Rhine driver

Replace the old via-rhine driver with a new version using the iPXE
API.

Includes fixes by Thomas Miletich for:

  - MMIO access
  - Link detection
  - RX completion in RX overflow case
  - Reset and EEPROM reloading
  - CRC stripping
  - Missing cpu_to_le32() calls
  - Missing memory barriers

Signed-off-by: Adrian Jamróz <adrian.jamroz@gmail.com>
Modified-by: Thomas Miletich <thomas.miletich@gmail.com>
Tested-by: Thomas Miletich <thomas.miletich@gmail.com>
Tested-by: Robin Smidsrød <robin@smidsrod.no>
Modified-by: Michael Brown <mcb30@ipxe.org>
Tested-by: Michael Brown <mcb30@ipxe.org>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[lotest] Include sequence number within loopback test packets
Michael Brown [Sun, 14 Jul 2013 09:37:17 +0000 (11:37 +0200)] 
[lotest] Include sequence number within loopback test packets

Include a sequence number as the first four bytes of the loopback test
packet payload.  When a content mismatch occurs, this gives some
information about the source of the mismatched packet.

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[settings] Add "version" builtin setting
Robin Smidsrød [Sat, 13 Jul 2013 18:57:39 +0000 (20:57 +0200)] 
[settings] Add "version" builtin setting

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[cmdline] Accept "netX" in iPXE commands
Michael Brown [Sat, 13 Jul 2013 13:22:34 +0000 (15:22 +0200)] 
[cmdline] Accept "netX" in iPXE commands

Allow any iPXE command expecting a network device name to accept
"netX" as a synonym for "most recently opened network device".

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[settings] Make "netX" settings block function as a symbolic link
Michael Brown [Sat, 13 Jul 2013 13:06:20 +0000 (15:06 +0200)] 
[settings] Make "netX" settings block function as a symbolic link

Add a facility for settings blocks to act as symbolic links to other
settings blocks, and reimplement the "netX" virtual settings block
using this facility.

The primary advantage of this approach is that unscoped settings such
as ${mac} and ${filename} will now reflect the settings obtained from
the most recently opened network device: in most cases, this will mean
the settings obtained from the most recent DHCP attempt.  This should
improve conformance to the principle of least astonishment.

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[settings] Expose PCI configuration space via settings mechanism
Michael Brown [Tue, 9 Jul 2013 15:03:35 +0000 (16:03 +0100)] 
[settings] Expose PCI configuration space via settings mechanism

Allow values to be read from PCI configuration space using the syntax

  ${pci/<busdevfn>.<offset>.<length>}

where <busdevfn> is the bus:dev.fn address of the PCI device
(expressed as a single integer, as returned by ${net0/busloc}),
<offset> is the offset within PCI configuration space, and <length> is
the length within PCI configuration space.

Values are returned in reverse byte order, since PCI configuration
space is little-endian by definition.

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[settings] Add config/settings.h
Michael Brown [Tue, 9 Jul 2013 15:01:52 +0000 (16:01 +0100)] 
[settings] Add config/settings.h

Move VMWARE_SETTINGS build configuration option from config/sideband.h
to a new config/settings.h.

Existing instances of config/local/sideband.h will not be affected,
since config.c still #includes config/sideband.h.

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[linux] Add support for accessing PCI configuration space via /proc/bus/pci
Michael Brown [Sat, 13 Jul 2013 10:42:40 +0000 (12:42 +0200)] 
[linux] Add support for accessing PCI configuration space via /proc/bus/pci

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[settings] Add "busdevfn" setting type
Michael Brown [Fri, 12 Jul 2013 20:28:00 +0000 (22:28 +0200)] 
[settings] Add "busdevfn" setting type

Allow network device's "busloc" setting to be formatted as a PCI
bus:dev.fn address using e.g. ${net0/busloc:busdevfn}.

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[netdevice] Add "bustype" and "busloc" settings
Michael Brown [Fri, 12 Jul 2013 20:25:35 +0000 (22:25 +0200)] 
[netdevice] Add "bustype" and "busloc" settings

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[settings] Add "hexraw" setting type
Michael Brown [Fri, 12 Jul 2013 12:58:19 +0000 (14:58 +0200)] 
[settings] Add "hexraw" setting type

Originally-implemented-by: Jeppe Toustrup <ipxe@tenzer.dk>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[settings] Use hex_decode() to parse hex settings
Michael Brown [Fri, 12 Jul 2013 12:45:55 +0000 (14:45 +0200)] 
[settings] Use hex_decode() to parse hex settings

Use hex_decode() to parse "hex" and "hexhyp" settings.  Note that this
parser is stricter than the old parser; it now requires exactly two
hex digits for each byte.  (The old parser was based upon strtoul()
and so would allow leading whitespace and a leading plus or minus
sign.)

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[base16] Generalise base16_decode() to hex_decode()
Michael Brown [Fri, 12 Jul 2013 12:44:20 +0000 (14:44 +0200)] 
[base16] Generalise base16_decode() to hex_decode()

Provide a generic hex_decode() routine which can be shared between the
Base16 code and the "hex" and "hexhyp" settings parsers.

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[test] Add self-tests for base16
Michael Brown [Fri, 12 Jul 2013 13:14:03 +0000 (15:14 +0200)] 
[test] Add self-tests for base16

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[tcp] Fix comment to match code behaviour
Michael Brown [Fri, 12 Jul 2013 09:15:42 +0000 (11:15 +0200)] 
[tcp] Fix comment to match code behaviour

Reported-by: Thomas Miletich <thomas.miletich@gmail.com>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[tcp] Do not send RST for unrecognised connections
Michael Brown [Fri, 12 Jul 2013 01:10:03 +0000 (03:10 +0200)] 
[tcp] Do not send RST for unrecognised connections

On large networks with substantial numbers of monitoring agents,
unwanted TCP connection attempts may end up flooding iPXE's ARP cache.

Fix by silently dropping packets received for unrecognised TCP
connections.  This should not cause problems, since many firewalls
will also silently drop any such packets.

Reported-by: Jarrod Johnson <jarrod.b.johnson@gmail.com>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[autoboot] Use next-server from filename's settings block
Michael Brown [Mon, 24 Jun 2013 15:14:36 +0000 (16:14 +0100)] 
[autoboot] Use next-server from filename's settings block

Locate the settings block containing the filename, and search only
that settings block for the next-server address.  This avoids problems
caused by misconfigured DHCP servers which provide a next-server
address (often defaulting to the DHCP server's own IP address) even
when not providing a filename.

Originally-implemented-by: Alex Williamson <alex.williamson@redhat.com>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[build] Work around bug in gcc >= 4.8
Michael Brown [Fri, 7 Jun 2013 12:46:27 +0000 (13:46 +0100)] 
[build] Work around bug in gcc >= 4.8

gcc 4.8 and 4.9 fail to compile pxe_call.c with the error "bp cannot
be used in asm here".  Other points in the codebase which use "ebp" in
the asm clobber list do not seem to be affected.

Unfortunately gcc provides no way to specify %ebp as an output
register, so we cannot use this as a workaround.  The only viable
solution is to explicitly push/pop %ebp within the asm itself.  This
is ugly for two reasons: firstly, it may be unnecessary; secondly, it
may cause gcc to generate invalid %esp-relative addresses if the asm
happens to use memory operands.  This specific block of asm uses no
memory operands and so will not generate invalid code.

Reported-by: Daniel P. Berrange <berrange@redhat.com>
Reported-by: Christian Hesse <list@eworm.de>
Originally-fixed-by: Christian Hesse <list@eworm.de>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[bzimage] Fix spurious uninitialised-variable warning on some gcc versions
Michael Brown [Wed, 5 Jun 2013 14:54:42 +0000 (15:54 +0100)] 
[bzimage] Fix spurious uninitialised-variable warning on some gcc versions

Reported-by: Matthew Helton <mwhelton@gmail.com>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[bzimage] Align initrd images to page boundary
Michael Brown [Wed, 5 Jun 2013 13:01:40 +0000 (14:01 +0100)] 
[bzimage] Align initrd images to page boundary

Some versions of Linux apparently complain if initrds are not aligned
to a page boundary.  Fix by changing INITRD_ALIGN from 4 bytes to 4096
bytes.

The amount of padding at the end of each initrd will now often be
sufficient to allow the cpio header to be prepended without crossing
an alignment boundary.  The final location of the initrd may therefore
end up being slightly higher than the post-shuffle location.
bzimage_load_initrd() must therefore now copy the initrd body prior to
copying the cpio header, otherwise the start of the initrd body may be
overwritten by the cpio header.  (Note that the guarantee that an
initrd will never need to overwrite an initrd at a higher location
still holds, since the overall length of each initrd cannot decrease
as a result of adding a cpio header.)

Reported-by: Dave Hansen <dave@sr71.net>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[crypto] Accept OCSP responses containing multiple certificates
Michael Brown [Wed, 29 May 2013 15:41:58 +0000 (16:41 +0100)] 
[crypto] Accept OCSP responses containing multiple certificates

RFC2560 mandates that a valid OCSP response will contain exactly one
relevant certificate.  However, some OCSP responders include
extraneous certificates.  iPXE currently assumes that the first
certificate in the OCSP response is the relevant certificate; OCSP
checks will therefore fail if the responder includes the extraneous
certificates before the relevant certificate.

Fix by using the responder ID to identify the relevant certificate.

Reported-by: Christian Stroehmeier <stroemi@mail.uni-paderborn.de>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[realtek] Fix reopening of legacy-mode 8139 NIC
Michael Brown [Sun, 26 May 2013 17:26:48 +0000 (18:26 +0100)] 
[realtek] Fix reopening of legacy-mode 8139 NIC

realtek_destroy_ring() currently does nothing if the card is operating
in legacy (pre-RTL8139C+) mode.  In particular, the producer and
consumer counters are incorrectly left holding their current values.
Virtual hardware (e.g. the emulated RTL8139 in qemu and similar VMs)
is tolerant of this behaviour, but real hardware will fail to transmit
if the descriptors are not used in the correct order.

Fix by resetting the producer and consumer counters in
realtek_destroy_ring() even if the card is operating in legacy mode.

Reported-by: Gelip <mrgelip@gmail.com>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[netdevice] Reset MAC address when asked to clear the "mac" setting
Michael Brown [Thu, 16 May 2013 14:40:44 +0000 (15:40 +0100)] 
[netdevice] Reset MAC address when asked to clear the "mac" setting

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[netdevice] Add "chip" setting
Michael Brown [Thu, 16 May 2013 14:32:17 +0000 (15:32 +0100)] 
[netdevice] Add "chip" setting

Suggested-by: Robin Smidsrød <robin@smidsrod.no>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[build] Add efidrv.cab target for UEFI Secure Boot signing
Michael Brown [Tue, 14 May 2013 19:08:26 +0000 (20:08 +0100)] 
[build] Add efidrv.cab target for UEFI Secure Boot signing

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[build] Provide "allXXXs" targets for all media on all platforms
Michael Brown [Tue, 14 May 2013 15:18:44 +0000 (16:18 +0100)] 
[build] Provide "allXXXs" targets for all media on all platforms

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[romprefix] Fix incorrect pointer offset in undiloader.S
Frediano Ziglio [Tue, 14 May 2013 13:06:25 +0000 (14:06 +0100)] 
[romprefix] Fix incorrect pointer offset in undiloader.S

Commit 2422647 ("[prefix] Allow prefix to specify an arbitrary maximum
address for relocation") introduced a regression into the UNDI ROM
loader by preserving an extra register on the stack without modifying
the %sp-relative addresses used in the routine.

Fix by correcting the %sp-relative addresses to allow for the extra
preserved variable.

Signed-off-by: Frediano Ziglio <frediano.ziglio@citrix.com>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[build] Use $(eval) if available
Michael Brown [Tue, 14 May 2013 13:28:30 +0000 (14:28 +0100)] 
[build] Use $(eval) if available

When the $(eval) function is available (in GNU make >= 3.80), we can
evaluate many of the dynamically-generated Makefile rules directly.
This avoids generating a few hundred Makefile fragments in the
filesystem, and so speeds up the build process.

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[crypto] Report meaningful error when certificate chain validation fails
Michael Brown [Fri, 10 May 2013 09:03:56 +0000 (10:03 +0100)] 
[crypto] Report meaningful error when certificate chain validation fails

If a certificate chain contains no certificate which can be validated
as a standalone certificate (i.e. contains no trusted root
certificates or previously-validated certificates) then iPXE will
currently return a fixed error EACCES_UNTRUSTED.  This masks the
actual errors obtained when attempting to validate each certificate as
a standalone certificate, and so makes troubleshooting difficult for
the end user.

Fix by instead returning the error obtained when attempting to
validate the final certificate in the chain as a standalone
certificate.  This error is most likely (though not guaranteed) to
represent the "real" problem.

Reported-by: Sven Dreyer <sven@dreyer-net.de>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[smbios] Allow access to multiple instances of SMBIOS structures
Michael Brown [Wed, 1 May 2013 19:42:57 +0000 (20:42 +0100)] 
[smbios] Allow access to multiple instances of SMBIOS structures

Extend the syntax for numerical SMBIOS settings from

  smbios/<type>.<offset>.<length>

to

  smbios/[<instance>.]<type>.<offset>.<length>

Where SMBIOS provides multiple structures with the same <type>, this
extended syntax allows for access to structures other than the first.
If <instance> is omitted then it will default to zero, giving access
to the first instance (and so matching existing behaviour).

The 16-bit SMBIOS handle (which is an alternative way to disambiguate
multiple instances of the same type of structure) can be accessed, if
required, using

  smbios/<instance>.<type>.2.2:uint16

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[smbios] Allow access to unreferenced SMBIOS strings
Michael Brown [Wed, 1 May 2013 21:00:51 +0000 (22:00 +0100)] 
[smbios] Allow access to unreferenced SMBIOS strings

iPXE allows access to general SMBIOS settings using the syntax:

  smbios/<type>.<offset>.<length>

This provides access to any fixed-offset field within an SMBIOS
structure.  This syntax is currently overloaded to interpret a zero
<length> as meaning that the byte at <offset> contains a string index;
this provides access to SMBIOS strings (which are not located at fixed
offsets).

The "OEM Strings" SMBIOS structure contains strings which are not
referenced by any fixed string index field within the structure.  iPXE
currently provides no way to access these strings.

Fix by overloading the syntax for numerical SMBIOS settings to
interpret an <offset> of zero as implying that <length> contains a
literal string index.  The OEM Strings can then be accessed using:

  smbios/11.0.1
  smbios/11.0.2
  smbios/11.0.3
  ...

The actual byte at offset zero will always contain the structure type,
which is already known since it must be specified in order to access
the structure.  There is thus no plausible existing use case for an
offset of zero; overloading the syntax in this way should therefore
not break compatibility with any existing scripts.

The corner case where both <offset> and <length> are zero is undefined
(and, for now, will simply return a "not found" error).

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[settings] Eliminate settings "tag magic"
Michael Brown [Wed, 1 May 2013 16:20:39 +0000 (17:20 +0100)] 
[settings] Eliminate settings "tag magic"

Create an explicit concept of "settings scope" and eliminate the magic
values used for numerical setting tags.

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[realtek] Defer packets when no transmit descriptors are available
Michael Brown [Wed, 1 May 2013 13:07:51 +0000 (14:07 +0100)] 
[realtek] Defer packets when no transmit descriptors are available

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[netdevice] Add netdev_tx_defer() to allow drivers to defer transmissions
Michael Brown [Wed, 1 May 2013 13:05:42 +0000 (14:05 +0100)] 
[netdevice] Add netdev_tx_defer() to allow drivers to defer transmissions

Devices with small transmit descriptor rings may temporarily run out
of space.  Provide netdev_tx_defer() to allow drivers to defer packets
for retransmission as soon as a descriptor becomes available.

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[dhcp] Remove obsolete bootp.h header
Michael Brown [Wed, 1 May 2013 09:17:15 +0000 (10:17 +0100)] 
[dhcp] Remove obsolete bootp.h header

Reported-by: Christian Helmuth <christian.helmuth@genode-labs.com>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[realtek] Ensure EEPROM writes reach chip before starting udelay()
Michael Brown [Wed, 1 May 2013 08:15:51 +0000 (09:15 +0100)] 
[realtek] Ensure EEPROM writes reach chip before starting udelay()

On some systems, it appears to be possible for writes to the EEPROM
registers to be delayed for long enough that the EEPROM's setup and
hold times are violated, resulting in invalid data being read from the
EEPROM.

Fix by inserting a PCI read cycle immediately after writes to
RTL_9346CR, to ensure that the write has completed before starting the
udelay() used to time the SPI bus transitions.

Reported-by: Gelip <mrgelip@gmail.com>
Tested-by: Gelip <mrgelip@gmail.com>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[romprefix] Report failure cause when unable to open payload
Michael Brown [Tue, 30 Apr 2013 13:31:39 +0000 (14:31 +0100)] 
[romprefix] Report failure cause when unable to open payload

Report the cause of the failure when we are unable to open the .mrom
payload.  There are two possible failure cases:

 - Unable to find a suitable memory BAR to borrow (e.g. if the NIC
   doesn't have a memory BAR that is at least as large as the
   expansion ROM BAR, or if the memory BAR has been assigned a 64-bit
   address which won't fit into the 32-bit expansion ROM BAR).  This
   will be reported as "BABABABA".

 - Unable to find correct ROM image within the BAR.  This will be
   reported as the address (within the borrowed BAR) at which we first
   fail to find a valid 55AA signature.

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[realtek] Allow reaction time between writing RTL_CAPR and reading RTL_CR
Michael Brown [Tue, 30 Apr 2013 12:36:04 +0000 (13:36 +0100)] 
[realtek] Allow reaction time between writing RTL_CAPR and reading RTL_CR

Some older RTL8139 chips seem to not immediately update the
RTL_CR.BUFE bit in response to a write to RTL_CAPR.  This results in
iPXE seeing a spurious zero-length received packet, and thereafter
being out of sync with the hardware's RX ring offset.

Fix by inserting an extra PCI read cycle after writing to RTL_CAPR, to
give the chip time to react before we next read RTL_CR.

Reported-by: Gelip <mrgelip@gmail.com>
Tested-by: Gelip <mrgelip@gmail.com>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[pxe] Convert external PXE API errors into iPXE platform-generated errors
Michael Brown [Mon, 29 Apr 2013 18:58:25 +0000 (19:58 +0100)] 
[pxe] Convert external PXE API errors into iPXE platform-generated errors

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[errdb] Strip platform error code for non-platform-generated errors
Michael Brown [Mon, 29 Apr 2013 14:36:32 +0000 (15:36 +0100)] 
[errdb] Strip platform error code for non-platform-generated errors

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[realtek] Use ID word to detect EEPROM presence
Michael Brown [Sun, 28 Apr 2013 17:50:10 +0000 (18:50 +0100)] 
[realtek] Use ID word to detect EEPROM presence

Some onboard RTL8169 NICs seem to leave the EEPROM pins disconnected.
The existing is_valid_ether_addr() test will not necessarily catch
this, since it expects a missing EEPROM to show up as a MAC address of
00:00:00:00:00:00 or ff:ff:ff:ff:ff:ff.  When the EEPROM pins are
floating the MAC address may read as e.g. 00:00:00:00:0f:00, which
will not be detected as invalid.

Check the ID word in the first two bytes of the EEPROM (which should
have the value 0x8129 for all RTL8139 and RTL8169 chips), and use this
to determine whether or not an EEPROM is present.

Reported-by: Carl Karsten <carl@nextdayvideo.com>
Tested-by: Carl Karsten <carl@nextdayvideo.com>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[build] Default to short wchar_t in stddef.h
Michael Brown [Sun, 28 Apr 2013 16:43:37 +0000 (17:43 +0100)] 
[build] Default to short wchar_t in stddef.h

sparse does not understand -fshort-wchar.  Default to using uint16_t
as a wchar_t if not explicitly specified by the compiler, to avoid
large numbers of spurious warnings from sparse.

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[build] Fix dubious uses of bitwise operators
Michael Brown [Sun, 28 Apr 2013 16:30:01 +0000 (17:30 +0100)] 
[build] Fix dubious uses of bitwise operators

Detected by sparse.

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[build] Fix uses of literal 0 as a NULL pointer
Michael Brown [Sun, 28 Apr 2013 15:51:05 +0000 (16:51 +0100)] 
[build] Fix uses of literal 0 as a NULL pointer

Detected using sparse.

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[build] Use -Wno-decl when running sparse
Michael Brown [Sun, 28 Apr 2013 15:43:32 +0000 (16:43 +0100)] 
[build] Use -Wno-decl when running sparse

Linker table entries must be non-static in order to avoid being
completely optimised away by some versions of gcc.  Use -Wno-decl to
prevent sparse from warning about these, since the alternative would
be to litter the code with otherwise unnecessary "extern"
declarations.

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[realtek] Print bad MAC address in debug message when inferring no EEPROM
Michael Brown [Sat, 27 Apr 2013 20:24:10 +0000 (21:24 +0100)] 
[realtek] Print bad MAC address in debug message when inferring no EEPROM

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[process] Mark process descriptor as static in PERMANENT_PROCESS
Michael Brown [Thu, 25 Apr 2013 14:15:43 +0000 (15:15 +0100)] 
[process] Mark process descriptor as static in PERMANENT_PROCESS

There is no need for the process descriptor to be a global variable.

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[build] Avoid sparse undeclared symbol warning for PROVIDE_SYMBOL()
Michael Brown [Thu, 25 Apr 2013 14:14:59 +0000 (15:14 +0100)] 
[build] Avoid sparse undeclared symbol warning for PROVIDE_SYMBOL()

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[build] Allow sparse to be invoked via "make C=1"
Michael Brown [Thu, 25 Apr 2013 13:56:48 +0000 (14:56 +0100)] 
[build] Allow sparse to be invoked via "make C=1"

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[build] Define __WINT_TYPE__ if necessary
Michael Brown [Thu, 25 Apr 2013 13:51:33 +0000 (14:51 +0100)] 
[build] Define __WINT_TYPE__ if necessary

sparse does not define __WCHAR_TYPE__ or __WINT_TYPE__.  We already
define __WCHAR_TYPE__ if the compiler does not do so; do the same for
__WINT_TYPE__.

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[build] Allow sparse to find compiler.h
Michael Brown [Thu, 25 Apr 2013 12:45:41 +0000 (13:45 +0100)] 
[build] Allow sparse to find compiler.h

sparse seems to have problems finding compiler.h when specified as
"-include compiler.h"; one possible explanation is that it ignores the
include path.  Fix by using "-include include/compiler.h".

Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[netdevice] Use link-layer address as part of RNG seed
Michael Brown [Fri, 19 Apr 2013 13:26:12 +0000 (14:26 +0100)] 
[netdevice] Use link-layer address as part of RNG seed

iPXE currently seeds the random number generator using the system
timer tick count.  When large numbers of machines are booted
simultaneously, multiple machines may end up choosing the same DHCP
transaction ID (XID) value; this can cause problems.

Fix by using the least significant (and hence most variable) bits of
each network device's link-layer address to perturb the random number
generator.  This introduces some per-machine unique data into the
random number generator's seed, and so reduces the chances of DHCP XID
collisions.

This does not affect the ANS X9.82-compatible random bit generator
used by TLS and other cryptography code, which uses an entirely
separate source of entropy.

Originally-implemented-by: Bernhard Kohl <bernhard.kohl@nsn.com>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
12 years ago[efi] Add sample platform-generated error disambiguations
Michael Brown [Fri, 19 Apr 2013 12:29:22 +0000 (13:29 +0100)] 
[efi] Add sample platform-generated error disambiguations

Add disambiguated errors for LoadImage() and StartImage(), primarily
to demonstrate how to use __einfo_uniqify() and __einfo_platformify()
in the context of EFI platform errors.

Signed-off-by: Michael Brown <mcb30@ipxe.org>