13 years ago[infiniband] Add find_ibdev()
Michael Brown [Sun, 9 Aug 2009 18:29:03 +0000 (19:29 +0100)]
[infiniband] Add find_ibdev()

13 years ago[infiniband] Add a "communication-managed reliable connection" protocol
Michael Brown [Sun, 9 Aug 2009 10:05:21 +0000 (11:05 +0100)]
[infiniband] Add a "communication-managed reliable connection" protocol

SRP over Infiniband uses a protocol whereby data is sent via a
combination of the CM private data fields and the RC queue pair
itself.  This seems sufficiently generic that it's worth having
available as a separate protocol.

13 years ago[hermon] Reduce the RC ACK timeout
Michael Brown [Mon, 10 Aug 2009 01:10:17 +0000 (02:10 +0100)]
[hermon] Reduce the RC ACK timeout

The ACK timeout determines how long we take to notice a failed
Reliable Connection.  Reducing it from the arbitrary value of 19 down
to 14 reduces the individual ACK timeout from around 2.1s to 67ms;
this in turn reduces the time to tear down and re-establish a broken
SRP session from around 30s to around 1s.

13 years ago[hermon] Randomise the high-order bits of queue pair numbers
Michael Brown [Sun, 9 Aug 2009 19:38:35 +0000 (20:38 +0100)]
[hermon] Randomise the high-order bits of queue pair numbers

The Infiniband Communication Manager will refuse to establish a
connection if it believes the connection is already established.
There is no immediately obvious way to ask it to tear down the
existing connection and replace it; to issue a DREP we would need to
know the local and remote communication IDs used for the previous
connection setup.

We can work around this by randomising the high-order bits of the
queue pair number; these have no significance to the hardware, but are
sufficient to convince the IB CM that this is a different connection.

13 years ago[scsi] Make LUN a property of the SCSI backend only
Michael Brown [Sun, 9 Aug 2009 15:09:47 +0000 (16:09 +0100)]
[scsi] Make LUN a property of the SCSI backend only

Nothing within the SCSI core actually refers to the LUN, so we can
simplify matters by treating it as purely a property of the backend.

13 years ago[scsi] Generalise iscsi_parse_lun() to scsi_parse_lun()
Michael Brown [Sun, 9 Aug 2009 14:30:07 +0000 (15:30 +0100)]
[scsi] Generalise iscsi_parse_lun() to scsi_parse_lun()

13 years ago[scsi] Generalise iscsi_detached_command() to scsi_detached_command()
Michael Brown [Sun, 9 Aug 2009 14:20:46 +0000 (15:20 +0100)]
[scsi] Generalise iscsi_detached_command() to scsi_detached_command()

13 years ago[process] Make it safe to call process_add() multiple times
Michael Brown [Mon, 10 Aug 2009 00:09:41 +0000 (01:09 +0100)]
[process] Make it safe to call process_add() multiple times

13 years ago[infiniband] Handle duplicate Communication Management REPs
Michael Brown [Sun, 9 Aug 2009 00:25:38 +0000 (01:25 +0100)]
[infiniband] Handle duplicate Communication Management REPs

We will terminate our transaction as soon as we receive the first CM
REP, since that provides all the state that we need.  However, the
peer may resend the REP if it didn't see our RTU, and if we don't
respond with another RTU we risk being disconnected.  (This protocol
appears not to handle retries gracefully.)

Fix by adding a management agent that will listen for these duplicate
REPs and send back an RTU.

13 years ago[ath5k] Add support for non-802.11n Atheros wireless NICs
Joshua Oreman [Fri, 7 Aug 2009 09:25:35 +0000 (02:25 -0700)]
[ath5k] Add support for non-802.11n Atheros wireless NICs

Signed-off-by: Michael Brown <>
13 years ago[legal] Add MIT licence declaration
Joshua Oreman [Fri, 7 Aug 2009 09:23:30 +0000 (02:23 -0700)]
[legal] Add MIT licence declaration

Signed-off-by: Michael Brown <>
13 years ago[802.11] Fix memory leak on unsuccessful probes
Joshua Oreman [Thu, 6 Aug 2009 23:20:57 +0000 (16:20 -0700)]
[802.11] Fix memory leak on unsuccessful probes

When a probe found no results, the list head of beacons would not be
freed, leaking 16 bytes of memory per probe.

Signed-off-by: Michael Brown <>
13 years ago[802.11] Fix maximum packet length
Joshua Oreman [Sat, 1 Aug 2009 16:56:44 +0000 (09:56 -0700)]
[802.11] Fix maximum packet length

Previously the maximum packet length was computed using an erroneous
understanding of the role of the MIC field in TKIP-encrypted packets.
The field is actually considered to be part of the MSDU (encrypted and
fragmented data), not the MPDU (container for each encrypted
fragment). As such its size does not contribute to cryptographic
overhead outside the data field's size limitations. The net result is
that the previous maximum packet length value was 4 bytes too long;
fix it to the correct value of 2352.

Signed-off-by: Michael Brown <>
13 years ago[802.11] Set channels early on to avoid tuning to an undefined channel
Joshua Oreman [Sat, 1 Aug 2009 16:52:59 +0000 (09:52 -0700)]
[802.11] Set channels early on to avoid tuning to an undefined channel

Some cards (such as ath5k) always need to tune to a particular channel
when they are reset; the reset may happen upon open(), which is before
the channels array would be set up (in prepare_probe()). Avoid tuning
the card to an inconsistent state by copying the hardware
supported-channels array to the 802.11 device's allowable-channels
array even before channels are "properly" set up.

Signed-off-by: Michael Brown <>
13 years ago[802.11] Enhance support for driver PHY differences
Joshua Oreman [Fri, 7 Aug 2009 08:38:23 +0000 (01:38 -0700)]
[802.11] Enhance support for driver PHY differences

The prior net80211 model of physical-layer behavior for drivers was
overly simplistic and limited the drivers that could be written.  To
be more flexible, split the driver-provided list of supported rates by
band, and add a means for specifying a list of supported channels.
Allow drivers to specify a hardware channel value that will be tied to
uses of the channel.

Expose net80211_duration() to drivers, and make the rate it uses in
its computations configurable, so that it can be used in calculating
durations that must be set in hardware for ACK and CTS packets. Add
net80211_cts_duration() for the common case of calculating the
duration for a CTS packet.

Signed-off-by: Michael Brown <>
13 years ago[geniso] Emit proper error message for incorrect location of ISOLINUX_BIN
vibi sreenivasan [Fri, 3 Jul 2009 06:21:54 +0000 (11:51 +0530)]
[geniso] Emit proper error message for incorrect location of ISOLINUX_BIN

If isolinux.bin is not installed in the expected location the error
message shown is slightly misleading.

Signed-off-by: Vibi Sreenivasan <>
Signed-off-by: Michael Brown <>
13 years ago[infiniband] Update all other MAD users to use a management interface
Michael Brown [Thu, 6 Aug 2009 00:18:38 +0000 (01:18 +0100)]
[infiniband] Update all other MAD users to use a management interface

13 years ago[infiniband] Update subnet management agent to use a management interface
Michael Brown [Mon, 3 Aug 2009 16:47:55 +0000 (17:47 +0100)]
[infiniband] Update subnet management agent to use a management interface

13 years ago[infiniband] Add the concept of a management interface
Michael Brown [Mon, 3 Aug 2009 14:56:56 +0000 (15:56 +0100)]
[infiniband] Add the concept of a management interface

A management interface is the component through which both local and
remote management agents are accessed.

This new implementation of a management interface allows for the user
to react to timed-out transactions, and also allows for cancellation
of in-progress transactions.

13 years ago[hermon] Allow for multiple calls to ib_modify_qp()
Michael Brown [Sat, 8 Aug 2009 13:17:27 +0000 (14:17 +0100)]
[hermon] Allow for multiple calls to ib_modify_qp()

13 years ago[romprefix] Cope with PnP BIOSes that fail to set %es:%di on entry
Michael Brown [Sat, 8 Aug 2009 13:36:10 +0000 (14:36 +0100)]
[romprefix] Cope with PnP BIOSes that fail to set %es:%di on entry

Some BIOSes support the BIOS Boot Specification (BBS) but fail to set
%es:%di correctly when calling the option ROM initialisation entry
point.  This causes gPXE to identify the BIOS as non-PnP (and so
non-BBS), leaving the user unable to control the boot order.

Fix by scanning for the $PnP signature ourselves, rather than relying
on the BIOS having passed in %es:%di correctly.

Tested-by: Helmut Adrigan <>
13 years ago[hermon] Add support for multiple ports and detecting non-IB ports
Michael Brown [Thu, 6 Aug 2009 00:55:38 +0000 (01:55 +0100)]
[hermon] Add support for multiple ports and detecting non-IB ports

Originally-fixed-by: Itay Gazit <>
13 years ago[infiniband] Change IB_{QPN,QKEY,QPT} names from {SMA,GMA} to {SMI,GSI}
Michael Brown [Sun, 2 Aug 2009 21:57:01 +0000 (22:57 +0100)]
[infiniband] Change IB_{QPN,QKEY,QPT} names from {SMA,GMA} to {SMI,GSI}

The IBA specification refers to management "interfaces" and "agents".
The interface is the component that connects to the queue pair and
sends and receives MADs; the agent is the component that constructs
the reply to the MAD.

Rename the IB_{QPN,QKEY,QPT} constants as a first step towards making
this separation in gPXE.

13 years ago[build] Mark __intel_new_proc_init with __libgcc rather than cdecl
Michael Brown [Mon, 3 Aug 2009 14:53:43 +0000 (15:53 +0100)]
[build] Mark __intel_new_proc_init with __libgcc rather than cdecl

The function __intel_new_proc_init() (called implicitly when building
using icc) is marked with __attribute__((cdecl)).  This breaks
building on x86_64, where cdecl is meaningless.

Fix by replacing with the existing __libgcc macro, which is already
defined to be "__attribute__((cdecl))" for i386 builds and empty for
x86_64 builds.

13 years ago[sky2] Add support for Marvell Yukon-II gigabit Ethernet cards
Joshua Oreman [Sun, 2 Aug 2009 23:14:01 +0000 (16:14 -0700)]
[sky2] Add support for Marvell Yukon-II gigabit Ethernet cards

Signed-off-by: Michael Brown <>
13 years ago[pci] Add definitions for Advanced Error Reporting registers
Joshua Oreman [Sun, 2 Aug 2009 23:13:40 +0000 (16:13 -0700)]
[pci] Add definitions for Advanced Error Reporting registers

Signed-off-by: Michael Brown <>
13 years ago[legal] Add the MIT and ISC licenses to
H. Peter Anvin [Sun, 2 Aug 2009 21:42:55 +0000 (14:42 -0700)]
[legal] Add the MIT and ISC licenses to

The MIT and ISC licenses are legally equivalent to the bsd2 license,
but with slightly different verbiage.

Signed-off-by: H. Peter Anvin <>
Signed-off-by: Michael Brown <>
13 years ago[pxe] Dual-license pxe_api.h under the MIT license
H. Peter Anvin [Sun, 2 Aug 2009 21:41:38 +0000 (14:41 -0700)]
[pxe] Dual-license pxe_api.h under the MIT license

pxe_api.h is just a description of API functions, it's actively
undesirable to have more implementations than necessary.  Allowing it
under the MIT license lets the Syslinux libraries use it.

Signed-off-by: H. Peter Anvin <>
Signed-off-by: Michael Brown <>
13 years ago[config] Enable PXE commands by default only on pcbios architecture
Joshua Oreman [Sun, 2 Aug 2009 21:52:05 +0000 (14:52 -0700)]
[config] Enable PXE commands by default only on pcbios architecture

The commands bring in UNDI and thus real-mode code, so they cannot be
used on EFI.

Signed-off-by: Michael Brown <>
13 years ago[pxe] Avoid printf format warning on some compilers
Michael Brown [Sun, 2 Aug 2009 21:40:58 +0000 (22:40 +0100)]
[pxe] Avoid printf format warning on some compilers

Tested-by: Joshua Oreman <>
13 years ago[tcp] Avoid printf format warnings on some compilers
Michael Brown [Sun, 2 Aug 2009 21:19:31 +0000 (22:19 +0100)]
[tcp] Avoid printf format warnings on some compilers

In several places, we currently use size_t to represent a difference
between TCP sequence numbers.  This can cause compiler warnings
relating to printf format specifiers, since the result of
(uint32_t+size_t) may be an unsigned long on some compilers.

Fix by using uint32_t for all variables that represent a difference
between TCP sequence numbers.

Tested-by: Joshua Oreman <>
13 years ago[build] Allow safe concurrent builds of .iso, .liso and .sdsk targets
Michael Brown [Sun, 2 Aug 2009 10:17:02 +0000 (11:17 +0100)]
[build] Allow safe concurrent builds of .iso, .liso and .sdsk targets

The geniso, genliso and gensdsk scripts contain hard-coded temporary
directory names, and so could potentially collide with each other when
run as part of a concurrent build (e.g. "make -j 4").

Fix by using mktemp to generate suitable temporary directory names.

13 years ago[build] Make .liso image generation silent unless errors occur
Michael Brown [Sun, 2 Aug 2009 10:08:43 +0000 (11:08 +0100)]
[build] Make .liso image generation silent unless errors occur

13 years ago[build] Add syslinux floppy image type .sdsk
Marty Connor [Sun, 29 Mar 2009 05:25:15 +0000 (01:25 -0400)]
[build] Add syslinux floppy image type .sdsk

We add a syslinux floppy disk type using parts of the genliso script.
This floppy image cat be dd'ed to a physical floppy or used in
instances where a virtual floppy with an mountable DOS filesystem is

We also modify the genliso script to only generate .liso images
rather than creating images depending on how it is called.

Signed-off-by: Michael Brown <>
13 years ago[rtl818x] Add driver for Realtek 8180/8185 wireless cards
Joshua Oreman [Sun, 21 Jun 2009 00:58:10 +0000 (17:58 -0700)]
[rtl818x] Add driver for Realtek 8180/8185 wireless cards

13 years ago[802.11] Add support for 802.11 devices with software MAC layer
Joshua Oreman [Tue, 21 Jul 2009 18:16:38 +0000 (11:16 -0700)]
[802.11] Add support for 802.11 devices with software MAC layer

This is required for all modern 802.11 devices, and allows drivers
to be written for them with minimally more effort than is required
for a wired NIC.

Signed-off-by: Michael Brown <>
Modified-by: Michael Brown <>
13 years ago[hermon] Add support for RC queue pairs
Michael Brown [Fri, 17 Jul 2009 21:34:38 +0000 (22:34 +0100)]
[hermon] Add support for RC queue pairs

13 years ago[hermon] Allow software GMA to receive packets destined for QP1
Michael Brown [Thu, 9 Jul 2009 04:18:33 +0000 (05:18 +0100)]
[hermon] Allow software GMA to receive packets destined for QP1

The Linux IB Communication Manager will always send MADs to QP1,
rather than back to the originating QP.  On Hermon, QP1 is by default
handled by the embedded firmware.  We can change this, but the cost is
that we have to handle both QP0 and QP1 (i.e. we have to provide SMA
as well as GMA service in software), and we have to use MLX queues
rather than standard UD queues (i.e. we have to construct the UD
datagrams by hand).

There doesn't seem to be any viable way around this situation, ugly
though it is.

13 years ago[hermon] Disable debugging around mapping of firmware tables
Michael Brown [Thu, 9 Jul 2009 01:45:37 +0000 (02:45 +0100)]
[hermon] Disable debugging around mapping of firmware tables

13 years ago[hermon] Remove an unnecessary check for GID-less transmissions
Michael Brown [Wed, 8 Jul 2009 21:00:07 +0000 (22:00 +0100)]
[hermon] Remove an unnecessary check for GID-less transmissions

13 years ago[infiniband] Add Communication Manager (CM)
Michael Brown [Fri, 17 Jul 2009 21:10:42 +0000 (22:10 +0100)]
[infiniband] Add Communication Manager (CM)

The Communication Manager is responsible for handling the setup and
teardown of RC connections.

13 years ago[infiniband] Add infrastructure for RC queue pairs
Michael Brown [Fri, 17 Jul 2009 21:27:34 +0000 (22:27 +0100)]
[infiniband] Add infrastructure for RC queue pairs

Queue pairs are now assumed to be created in the INIT state, with a
call to ib_modify_qp() required to bring the queue pair to the RTS

ib_modify_qp() no longer takes a modification list; callers should
modify the relevant queue pair parameters (e.g. qkey) directly and
then call ib_modify_qp() to synchronise the changes to the hardware.

The packet sequence number is now a property of the queue pair, rather
than of the device.

Each queue pair may have an associated address vector.  For RC queue
pairs, this is the address vector that will be programmed in to the
hardware as the remote address.  For UD queue pairs, it will be used
as the default address vector if none is supplied to ib_post_send().

13 years ago[infiniband] Pass a generic MAD to ib_set_port_info()
Michael Brown [Fri, 17 Jul 2009 21:40:12 +0000 (22:40 +0100)]
[infiniband] Pass a generic MAD to ib_set_port_info()

13 years ago[infiniband] Expose supported and enabled link speeds and widths
Michael Brown [Sat, 11 Jul 2009 00:14:43 +0000 (01:14 +0100)]
[infiniband] Expose supported and enabled link speeds and widths

13 years ago[infiniband] Allow MAD handlers to indicate response via return value
Michael Brown [Fri, 10 Jul 2009 21:31:40 +0000 (22:31 +0100)]
[infiniband] Allow MAD handlers to indicate response via return value

Now that MAD handlers no longer return a status code, we can allow
them to return a pointer to a MAD structure if and only if they want
to send a response.  This provides a more natural and flexible
approach than using a "response method" field within the handler's

13 years ago[infiniband] Remove the return status code from MAD handlers
Michael Brown [Fri, 10 Jul 2009 20:29:25 +0000 (21:29 +0100)]
[infiniband] Remove the return status code from MAD handlers

MAD handlers have to set the status fields within the MAD itself
anyway, in order to provide a meaningful response MAD; the additional
gPXE return status code is just noise.

Note that we probably don't need to ever explicitly set the status to
IB_MGMT_STATUS_OK, since it should already have this value from the
request.  (By not explicitly setting the status in this way, we can
safely have ib_sma_set_xxx() call ib_sma_get_xxx() in order to
generate the GetResponse MAD without worrying that ib_sma_get_xxx()
will clear any error status set by ib_sma_set_xxx().)

13 years ago[infiniband] Allow external QPN to differ from real QPN
Michael Brown [Thu, 9 Jul 2009 14:52:04 +0000 (15:52 +0100)]
[infiniband] Allow external QPN to differ from real QPN

Most IB hardware seems not to allow allocation of the genuine QPNs 0
and 1, so allow for the externally-visible QPN (as constructed and
parsed by ib_packet, where used) to differ from the real
hardware-allocated QPN.

13 years ago[infiniband] Always create an SMA and a GMA
Michael Brown [Thu, 9 Jul 2009 02:49:37 +0000 (03:49 +0100)]
[infiniband] Always create an SMA and a GMA

13 years ago[infiniband] Add notion of a queue pair type
Michael Brown [Thu, 9 Jul 2009 02:09:00 +0000 (03:09 +0100)]
[infiniband] Add notion of a queue pair type

13 years ago[infiniband] Allow completion queue operations to be optional
Michael Brown [Wed, 8 Jul 2009 10:50:47 +0000 (11:50 +0100)]
[infiniband] Allow completion queue operations to be optional

The send completion handler typically will just free the I/O buffer,
so allow this common case to be handled by the Infiniband core.

13 years ago[infiniband] Improve ib_packet debugging messages
Michael Brown [Wed, 8 Jul 2009 03:31:48 +0000 (04:31 +0100)]
[infiniband] Improve ib_packet debugging messages

13 years ago[ipoib] Attempt the broadcast group join only if the link is up
Michael Brown [Tue, 7 Jul 2009 18:14:52 +0000 (19:14 +0100)]
[ipoib] Attempt the broadcast group join only if the link is up

Attempting the broadcast group join while the link is down is
harmless, but can generate annoying volumes of debug messages.

13 years ago[infiniband] Implement SMA as an instance of a GMA
Michael Brown [Tue, 7 Jul 2009 17:30:15 +0000 (18:30 +0100)]
[infiniband] Implement SMA as an instance of a GMA

The GMA code was based upon the SMA code.  We can save space by making
the SMA simply an instance of the GMA.

13 years ago[infiniband] Pass GMA as a parameter to GMA MAD handlers
Michael Brown [Tue, 7 Jul 2009 17:09:21 +0000 (18:09 +0100)]
[infiniband] Pass GMA as a parameter to GMA MAD handlers

13 years ago[ipoib] Remove the queue set abstraction
Michael Brown [Tue, 7 Jul 2009 15:26:57 +0000 (16:26 +0100)]
[ipoib] Remove the queue set abstraction

Now that IPoIB has to deal with only one set of queues, the queue set
abstraction becomes merely an inconvenient wrapper.

13 years ago[ipoib] Kill off the now-unused IPoIB metadata queue set
Michael Brown [Tue, 7 Jul 2009 15:18:47 +0000 (16:18 +0100)]
[ipoib] Kill off the now-unused IPoIB metadata queue set

All packets handled by the metadata queue set now go via the GMA.

13 years ago[infiniband] Provide a general mechanism for multicast group joins
Michael Brown [Tue, 7 Jul 2009 15:07:31 +0000 (16:07 +0100)]
[infiniband] Provide a general mechanism for multicast group joins

Generalise out the multicast group membership record code from IPoIB.

13 years ago[infiniband] Allow for sending MADs via GMA without retransmission
Michael Brown [Tue, 7 Jul 2009 15:01:51 +0000 (16:01 +0100)]
[infiniband] Allow for sending MADs via GMA without retransmission

13 years ago[infiniband] Make qkey and rate optional parameters to ib_post_send()
Michael Brown [Tue, 7 Jul 2009 13:03:11 +0000 (14:03 +0100)]
[infiniband] Make qkey and rate optional parameters to ib_post_send()

The queue key is stored as a property of the queue pair, and so can
optionally be added by the Infiniband core at the time of calling
ib_post_send(), rather than always having to be specified by the

This allows IPoIB to avoid explicitly keeping track of the data queue

13 years ago[ipoib] Clarify new role of IPoIB peer cache as for MAC addresses only
Michael Brown [Tue, 7 Jul 2009 12:54:39 +0000 (13:54 +0100)]
[ipoib] Clarify new role of IPoIB peer cache as for MAC addresses only

Now that path record lookups are handled entirely via
ib_resolve_path(), the only role of the IPoIB peer cache is as a
lookup table for MAC addresses.  Update the code structure and
comments to reflect this.

13 years ago[ipoib] Expose the real broadcast MAC
Michael Brown [Tue, 7 Jul 2009 12:30:47 +0000 (13:30 +0100)]
[ipoib] Expose the real broadcast MAC

The IPoIB broadcast MAC address varies according to the partition key.
Now that the broadcast MAC address is a property of the network device
rather than of the link layer, we can expose this real MAC address

The broadcast LID is now identified via a path record lookup; this is
marginally inefficient (since it was present in the MCMemberRecord
GetResponse), but avoids the need to special-case broadcasts when
constructing the address vector in ipoib_transmit().

13 years ago[ipoib] Use Infiniband broadcast QPN in IPoIB broadcast MAC address
Michael Brown [Tue, 7 Jul 2009 10:31:35 +0000 (11:31 +0100)]
[ipoib] Use Infiniband broadcast QPN in IPoIB broadcast MAC address

Remove the special handling of the IPoIB broadcast QPN.

13 years ago[infiniband] Provide a general mechanism for path record lookups
Michael Brown [Tue, 7 Jul 2009 01:01:21 +0000 (02:01 +0100)]
[infiniband] Provide a general mechanism for path record lookups

Generalise out the path record lookup code from IPoIB.

13 years ago[infiniband] Create a general management agent
Michael Brown [Mon, 6 Jul 2009 22:09:26 +0000 (23:09 +0100)]
[infiniband] Create a general management agent

Generalise the subnet management agent into a general management agent
capable of sending and responding to MADs, including support for
retransmissions as necessary.

13 years ago[infiniband] Centralise SMA and GMA queue constants
Michael Brown [Mon, 6 Jul 2009 19:31:44 +0000 (20:31 +0100)]
[infiniband] Centralise SMA and GMA queue constants

13 years ago[infiniband] Poll completion queues automatically
Michael Brown [Mon, 6 Jul 2009 18:12:12 +0000 (19:12 +0100)]
[infiniband] Poll completion queues automatically

Currently, all Infiniband users must create a process for polling
their completion queues (or rely on a regular hook such as
netdev_poll() in ipoib.c).

Move instead to a model whereby the Infiniband core maintains a single
process calling ib_poll_eq(), and polling the event queue triggers
polls of the applicable completion queues.  (At present, the
Infiniband core simply polls all of the device's completion queues.)
Polling a completion queue will now implicitly refill all attached
receive work queues; this is analogous to the way that netdev_poll()
implicitly refills the RX ring.

Infiniband users no longer need to create a process just to poll their
completion queues and refill their receive rings.

13 years ago[infiniband] Centralise assumption of 2048-byte payloads
Michael Brown [Fri, 17 Jul 2009 21:50:33 +0000 (22:50 +0100)]
[infiniband] Centralise assumption of 2048-byte payloads

IPoIB and the SMA have separate constants for the packet size to be
used to I/O buffer allocations.  Merge these into the single

(Various other points in the Infiniband stack have hard-coded
assumptions of a 2048-byte payload; we don't currently support
variable MTUs.)

13 years ago[infiniband] Provide ib_get_hca_info() as a commonly-available function
Michael Brown [Thu, 2 Jul 2009 11:54:36 +0000 (12:54 +0100)]
[infiniband] Provide ib_get_hca_info() as a commonly-available function

13 years ago[infiniband] Split queue set functionality out of ipoib.c to ib_qset.c
Michael Brown [Thu, 2 Jul 2009 08:56:14 +0000 (09:56 +0100)]
[infiniband] Split queue set functionality out of ipoib.c to ib_qset.c

13 years ago[infiniband] Move non-driver-specific code to net/infiniband
Michael Brown [Thu, 2 Jul 2009 07:39:34 +0000 (08:39 +0100)]
[infiniband] Move non-driver-specific code to net/infiniband

13 years ago[netdevice] Make ll_broadcast per-netdevice rather than per-ll_protocol
Michael Brown [Fri, 17 Jul 2009 21:48:31 +0000 (22:48 +0100)]
[netdevice] Make ll_broadcast per-netdevice rather than per-ll_protocol

IPoIB has a link-layer broadcast address that varies according to the
partition key.  We currently go through several contortions to pretend
that the link-layer address is a fixed constant; by making the
broadcast address a property of the network device rather than the
link-layer protocol it will be possible to simplify IPoIB's broadcast

13 years ago[ata] Make ATA command issuing partially asynchronous
Michael Brown [Tue, 7 Jul 2009 22:01:28 +0000 (23:01 +0100)]
[ata] Make ATA command issuing partially asynchronous

Move the icky call to step() from aoe.c to ata.c; this takes it at
least one step further away from where it really doesn't belong.

Unfortunately, AoE has the ugly aoe_discover() mechanism which means
that we still have a step() loop in aoe.c for now; this needs to be
replaced at some future point.

13 years ago[scsi] Improve SCSI debugging
Michael Brown [Mon, 13 Jul 2009 04:01:54 +0000 (05:01 +0100)]
[scsi] Improve SCSI debugging

13 years ago[scsi] Make SCSI command issuing partially asynchronous
Michael Brown [Tue, 7 Jul 2009 22:00:11 +0000 (23:00 +0100)]
[scsi] Make SCSI command issuing partially asynchronous

Move the icky call to step() from iscsi.c to scsi.c; this takes it at
least one step further away from where it really doesn't belong.

13 years ago[debug] Use a delimiter to break up DBG_HD() output
Michael Brown [Sun, 12 Jul 2009 20:30:08 +0000 (21:30 +0100)]
[debug] Use a delimiter to break up DBG_HD() output

Reading sixteen columns of hex digits can be difficult; include a "-"
character to split the output into two groups of eight columns.

13 years ago[xfer] Always nullify interface while sending close() message
Michael Brown [Mon, 6 Jul 2009 15:16:59 +0000 (16:16 +0100)]
[xfer] Always nullify interface while sending close() message

Objects typically call xfer_close() as part of their response to a
close() message.  If the initiating object has already nullified the
xfer interface then this isn't a problem, but it can lead to
unexpected behaviour when the initiating object is aiming to reuse the
connection and so does not nullify the interface.

Fix by always temporarily nullifying the interface during xfer_close()
(as was already being done by xfer_vreopen() in order to work around
this specific problem).

Reported-by: infernix <>
Tested-by: infernix <>
13 years ago[pxe] Add startpxe and stoppxe commands
Michael Brown [Sun, 28 Jun 2009 19:50:23 +0000 (20:50 +0100)]
[pxe] Add startpxe and stoppxe commands

These commands can be used to activate or deactivate the PXE API (on a
specifiable network interface).

This is currently of limited use, since most image formats will call
shutdown() before booting the image, meaning that the underlying net
device gets shut down during remove_devices() anyway.

13 years ago[ifmgmt] Move ifmgmt_cmd.h to include/hci
Michael Brown [Sun, 28 Jun 2009 19:28:38 +0000 (20:28 +0100)]
[ifmgmt] Move ifmgmt_cmd.h to include/hci

13 years ago[ifmgmt] Optimise prototype for ifcommon_exec()
Michael Brown [Sun, 28 Jun 2009 19:24:54 +0000 (20:24 +0100)]
[ifmgmt] Optimise prototype for ifcommon_exec()

ifcommon_exec() was long-ago marked as __attribute__((regparm(2))) in
order to minimise the size of functions that call into it.  Since
then, gPXE has added -mregparm=3 as a general compilation option, and
this "optimisation" is now counter-productive.

Change (and simplify) the prototype to minimise code size given the
current compilation conditions.

13 years ago[pxe] Check for unhookable interrupts in PXENV_STOP_UNDI
Michael Brown [Sun, 28 Jun 2009 19:12:16 +0000 (20:12 +0100)]
[pxe] Check for unhookable interrupts in PXENV_STOP_UNDI

cannot be safely unloaded (e.g. due to interrupt vectors that could
not be unhooked).

13 years ago[pxe] Create pxe_[de]activate() wrapper functions
Michael Brown [Sun, 28 Jun 2009 19:08:58 +0000 (20:08 +0100)]
[pxe] Create pxe_[de]activate() wrapper functions

Merge the pxe_set_netdev()+pxe_[un]hook_int1a() pattern into a single
pxe_[de]activate() call.

13 years ago[pxe] Make pxe_init_structures() an initialisation function
Michael Brown [Sun, 28 Jun 2009 18:40:16 +0000 (19:40 +0100)]
[pxe] Make pxe_init_structures() an initialisation function

pxe_init_structures() fills in the fields of the !PXE and PXENV+
structures that aren't known until gPXE starts up.  Once gPXE is
started, these values will never change.

Make pxe_init_structures() an initialisation function so that PXE
users don't have to worry about calling it.

13 years ago[pxe] Update UNDI transmit count before transmitting packet
Michael Brown [Sat, 27 Jun 2009 15:36:21 +0000 (16:36 +0100)]
[pxe] Update UNDI transmit count before transmitting packet

It is possible that the UNDI ISR may be triggered before netdev_tx()
returns control to pxenv_undi_transmit().  This means that
pxenv_undi_isr() may see a zero undi_tx_count, and so not check for TX
completions.  This is not a significant problem, since it will check
for TX completions on the next call to pxenv_undi_isr() anyway; it
just means that the NBP will see a spurious IRQ that was apparently
caused by nothing.

Fix by updating the undi_tx_count before calling netdev_tx(), so that
pxenv_undi_isr() can decrement it and report the TX completion.

13 years ago[pxe] Implement PXENV_UNDI_{GET,SET}_MCAST_ADDRESS
Michael Brown [Sat, 27 Jun 2009 14:45:27 +0000 (15:45 +0100)]

Symantec Ghost requires working multicast support.  gPXE configures
all (sufficiently supported) network adapters into "receive all
multicasts" mode, which means that PXENV_UNDI_SET_MCAST_ADDRESS is
actually a no-op, but the current implementation returns

Fix by making PXENV_UNDI_SET_MCAST_ADDRESS return success.  For good
measure, also implement PXENV_UNDI_GET_MCAST_ADDRESS, since the
relevant functionality is now exposed by the net device core.

Note that this will silently fail if the gPXE driver for the NIC being
used fails to configure the NIC in "receive all multicasts" mode.

13 years ago[pxe] Improve pxe_undi debug messages
Michael Brown [Sat, 27 Jun 2009 13:43:10 +0000 (14:43 +0100)]
[pxe] Improve pxe_undi debug messages

The PXE debugging messages have remained pretty much unaltered since
Etherboot 5.4, and are now difficult to read in comparison to most of
the rest of gPXE.

Bring the pxe_undi debug messages up to normal gPXE standards.

13 years ago[hci] Expose ifcommon_exec() in a local header so wireless commands can use it
Joshua Oreman [Fri, 19 Jun 2009 09:21:08 +0000 (02:21 -0700)]
[hci] Expose ifcommon_exec() in a local header so wireless commands can use it

This keeps code size down, since the wireless interface management
commands have the same command-line interface and overall structure as
the wired commands.

Signed-off-by: Michael Brown <>
13 years ago[dhcp] Await link-up before starting DHCP
Joshua Oreman [Sat, 20 Jun 2009 08:52:41 +0000 (01:52 -0700)]
[dhcp] Await link-up before starting DHCP

Modified-by: Michael Brown <>
Signed-off-by: Michael Brown <>
13 years ago[ifmgmt] Move link-up status messages from autoboot() to iflinkwait()
Joshua Oreman [Fri, 19 Jun 2009 09:08:21 +0000 (02:08 -0700)]
[ifmgmt] Move link-up status messages from autoboot() to iflinkwait()

With the addition of link status codes, we can now display a detailed
error indication if iflinkwait() fails.

Putting the error output in iflinkwait avoids code duplication, and
gains symmetry with the other interface management routines; ifopen()
already prints an error directly if it cannot open its interface.

Modified-by: Michael Brown <>
Signed-off-by: Michael Brown <>
13 years ago[netdevice] Add mechanism for reporting detailed link status codes
Michael Brown [Wed, 24 Jun 2009 11:52:38 +0000 (12:52 +0100)]
[netdevice] Add mechanism for reporting detailed link status codes

Expand the NETDEV_LINK_UP bit into a link_rc status code field,
allowing specific reasons for link failure to be reported via

Originally-authored-by: Joshua Oreman <>
13 years ago[comboot] Implement INT 22h AX=000Bh (Get Serial Console Configuration)
Daniel Verkamp [Tue, 23 Jun 2009 20:57:05 +0000 (16:57 -0400)]
[comboot] Implement INT 22h AX=000Bh (Get Serial Console Configuration)

Signed-off-by: Michael Brown <>
13 years ago[pxe] Fix interoperability with the Symantec (undipd) DOS UNDI driver
Michael Brown [Tue, 23 Jun 2009 21:53:29 +0000 (22:53 +0100)]
[pxe] Fix interoperability with the Symantec (undipd) DOS UNDI driver

The Symantec UNDI DOS driver fails when run on top of gPXE because we
return our interface type as "gPXE" rather than one of the predefined
NDIS interface type strings.

Fix by returning the standard "DIX+802.3" string; this isn't
necessarily always accurate, but it's highly unlikely that anything
trying to use the UNDI API would understand our IPoIB link-layer
pseudo-header anyway.

13 years ago[pxe] Fix interoperability with the Intel DOS UNDI driver
Michael Brown [Tue, 23 Jun 2009 21:42:55 +0000 (22:42 +0100)]
[pxe] Fix interoperability with the Intel DOS UNDI driver

The Intel DOS UNDI driver fails when run on top of gPXE because we do
not fill in the ServiceFlags field in PXENV_UNDI_GET_IFACE_INFO.

Fix by filling in the ServiceFlags field with reasonable values
indicating our approximate feature capabilities.

13 years ago[pxe] Fix interoperability with the 3Com DOS UNDI driver
Michael Brown [Tue, 23 Jun 2009 20:54:50 +0000 (21:54 +0100)]
[pxe] Fix interoperability with the 3Com DOS UNDI driver

The 3Com DOS UNDI driver fails when run on top of gPXE for two
reasons: firstly because PXENV_UNDI_SET_PACKET_FILTER is unsupported,
and secondly because gPXE enters the NBP without enabling interrupts
on the NIC, and the 3Com driver never calls PXENV_UNDI_OPEN.

Fix by always returning success from PXENV_UNDI_SET_PACKET_FILTER
(which is no worse than the current situation, since we already ignore
the receive packet filter in PXENV_UNDI_OPEN), and by forcibly
enabling interrupts on the NIC within PXENV_UNDI_TRANSMIT.  The latter
is something of a hack, but avoids the need to implement a complete
base-code ISR that we would otherwise need if we were to enter the NBP
with interrupts enabled.

13 years ago[rtl8139] Split debug messages into DBGLVL_LOG and DBGLVL_EXTRA
Michael Brown [Tue, 23 Jun 2009 19:41:44 +0000 (20:41 +0100)]
[rtl8139] Split debug messages into DBGLVL_LOG and DBGLVL_EXTRA

13 years ago[undi] Include PXENV_GET_IFACE_INFO's ServiceFlags in debug output
Michael Brown [Tue, 23 Jun 2009 18:26:07 +0000 (19:26 +0100)]
[undi] Include PXENV_GET_IFACE_INFO's ServiceFlags in debug output

13 years ago[e1000] Ensure descriptor is fully written before sending packet
Michael Brown [Tue, 23 Jun 2009 17:36:01 +0000 (18:36 +0100)]
[e1000] Ensure descriptor is fully written before sending packet

Reported-by: Mark McLoughlin <>
13 years ago[tcp] Avoid rewinding sequence numbers on receiving old duplicate ACKs
Michael Brown [Tue, 23 Jun 2009 15:10:34 +0000 (16:10 +0100)]
[tcp] Avoid rewinding sequence numbers on receiving old duplicate ACKs

Commit 558c1a4 ("[tcp] Improve robustness in the presence of duplicated
received packets") introduced a regression in that an old duplicate
ACK received while in the ESTABLISHED state would pass through normal
ACK processing, including updating tcp->snd_seq.

Fix by ensuring that ACK processing ignores all duplicate ACKs.

13 years ago[tcp] Attempt to catch all possible error cases with debug messages
Michael Brown [Tue, 23 Jun 2009 13:28:00 +0000 (14:28 +0100)]
[tcp] Attempt to catch all possible error cases with debug messages

All TCP errors or unusual events should now generate a debugging
message at DBGLVL_LOG, with enough information (SEQ and ACK numbers)
to be able to identify the corresponding packet (or missing packet) in
a network trace from the remote end.

13 years ago[tcp] Include current sequence numbers in "timer expired" messages
Michael Brown [Tue, 23 Jun 2009 13:03:09 +0000 (14:03 +0100)]
[tcp] Include current sequence numbers in "timer expired" messages

13 years ago[tcp] Move high-frequency debug messages to DBGLVL_EXTRA
Michael Brown [Tue, 23 Jun 2009 12:34:48 +0000 (13:34 +0100)]
[tcp] Move high-frequency debug messages to DBGLVL_EXTRA

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