From: Michael Brown Date: Thu, 16 Apr 2009 04:59:44 +0000 (+0100) Subject: [build] Reinstate the .pdsk padded-floppy image format X-Git-Tag: v0.9.8~164 X-Git-Url: http://git.etherboot.org/people/cooldavid/gpxe.git/commitdiff_plain/7aee624881ec3cf05d23cdeb9bccf2411a2081c1 [build] Reinstate the .pdsk padded-floppy image format Some utilities that expect a floppy disk image (e.g. iLO?) may test for a file of the correct size. Reinstate the .pdsk image format in order to provide this if needed. --- diff --git a/src/arch/i386/Makefile.pcbios b/src/arch/i386/Makefile.pcbios index 7aa0afd8..b1854181 100644 --- a/src/arch/i386/Makefile.pcbios +++ b/src/arch/i386/Makefile.pcbios @@ -59,3 +59,9 @@ NON_AUTO_MEDIA += usb %usb: $(BIN)/usbdisk.bin %hd $(QM)$(ECHO) " [FINISH] $@" $(Q)cat $^ > $@ + +# Padded floppy image (e.g. for iLO) +NON_AUTO_MEDIA += pdsk +%pdsk : %dsk + $(Q)cp $< $@ + $(Q)$(PADIMG) --blksize=1474560 $@ diff --git a/src/util/padimg.pl b/src/util/padimg.pl index f3dcbbc3..71d0eee8 100755 --- a/src/util/padimg.pl +++ b/src/util/padimg.pl @@ -23,8 +23,8 @@ GetOptions ( { map { /^(\w+)/; $1 => $opts->{$_} } keys %$opts }, keys %$opts ) while ( my $filename = shift ) { die "$filename is not a file\n" unless -f $filename; my $oldsize = -s $filename; - my $newsize = ( ( $oldsize + $blksize - 1 ) & ~( $blksize - 1 ) ); - my $padsize = ( $newsize - $oldsize ); + my $padsize = ( ( -$oldsize ) % $blksize ); + my $newsize = ( $oldsize + $padsize ); next unless $padsize; if ( $verbosity >= 1 ) { printf "Padding %s from %d to %d bytes with %d x 0x%02x\n", @@ -40,5 +40,6 @@ while ( my $filename = shift ) { truncate $filename, $newsize or die "Could not resize $filename: $!\n"; } - die "Failed to pad $filename\n" unless -s $filename == $newsize; + die "Failed to pad $filename\n" + unless ( ( ( -s $filename ) % $blksize ) == 0 ); }