diff options
author | Michael Brown | 2012-08-15 14:18:46 +0200 |
---|---|---|
committer | Michael Brown | 2012-08-15 14:19:16 +0200 |
commit | 69fa49428088ccefd438a0e87b1111a727a8b702 (patch) | |
tree | 510219cf7f55c8d38ae5283a12e59e2e6dac8d05 /src/util/Option | |
parent | [util] Allow for CALL NEAR in the option ROM initialisation entry point (diff) | |
download | ipxe-69fa49428088ccefd438a0e87b1111a727a8b702.tar.gz ipxe-69fa49428088ccefd438a0e87b1111a727a8b702.tar.xz ipxe-69fa49428088ccefd438a0e87b1111a727a8b702.zip |
[util] Display UNDI ROM header in disrom.pl
Requested-by: Daniel Wyatt <daniel.wyatt@gmail.com>
Signed-off-by: Michael Brown <mcb30@ipxe.org>
Diffstat (limited to 'src/util/Option')
-rw-r--r-- | src/util/Option/ROM.pm | 80 |
1 files changed, 80 insertions, 0 deletions
diff --git a/src/util/Option/ROM.pm b/src/util/Option/ROM.pm index bf704cad..fb37ce4b 100644 --- a/src/util/Option/ROM.pm +++ b/src/util/Option/ROM.pm @@ -396,6 +396,25 @@ sub pnp_header { =pod +=item C<< undi_header () >> + +Return a C<Option::ROM::UNDI> object representing the ROM's UNDI header, +if present. + +=cut + +sub undi_header { + my $hash = shift; + my $self = tied(%$hash); + + my $offset = $hash->{undi_header}; + return undef unless $offset != 0; + + return Option::ROM::UNDI->new ( $self->{data}, $offset ); +} + +=pod + =item C<< ipxe_header () >> Return a C<Option::ROM::iPXE> object representing the ROM's iPXE @@ -593,6 +612,67 @@ sub product { ############################################################################## # +# Option::ROM::UNDI +# +############################################################################## + +package Option::ROM::UNDI; + +use strict; +use warnings; +use Carp; +use bytes; + +sub new { + my $class = shift; + my $data = shift; + my $offset = shift; + + my $hash = {}; + tie %$hash, "Option::ROM::Fields", { + data => $data, + offset => $offset, + length => 0x16, + fields => { + signature => { offset => 0x00, length => 0x04, pack => "a4" }, + struct_length => { offset => 0x04, length => 0x01, pack => "C" }, + checksum => { offset => 0x05, length => 0x01, pack => "C" }, + struct_revision =>{ offset => 0x06, length => 0x01, pack => "C" }, + version_revision =>{ offset => 0x07, length => 0x01, pack => "C" }, + version_minor => { offset => 0x08, length => 0x01, pack => "C" }, + version_major => { offset => 0x09, length => 0x01, pack => "C" }, + loader_entry => { offset => 0x0a, length => 0x02, pack => "S" }, + stack_size => { offset => 0x0c, length => 0x02, pack => "S" }, + data_size => { offset => 0x0e, length => 0x02, pack => "S" }, + code_size => { offset => 0x10, length => 0x02, pack => "S" }, + bus_type => { offset => 0x12, length => 0x04, pack => "a4" }, + }, + }; + bless $hash, $class; + + # Retrieve true length of structure + my $self = tied ( %$hash ); + $self->{length} = $hash->{struct_length}; + + return $hash; +} + +sub checksum { + my $hash = shift; + my $self = tied(%$hash); + + return $self->checksum(); +} + +sub fix_checksum { + my $hash = shift; + my $self = tied(%$hash); + + $hash->{checksum} = ( ( $hash->{checksum} - $hash->checksum() ) & 0xff ); +} + +############################################################################## +# # Option::ROM::iPXE # ############################################################################## |