diff options
author | Michael Brown <mcb30@etherboot.org> | 2007-01-11 15:27:06 +0000 |
---|---|---|
committer | Michael Brown <mcb30@etherboot.org> | 2007-01-11 15:27:06 +0000 |
commit | 91ac92bc863d0e0b17c321e19944fbffd52807c1 (patch) | |
tree | eae0bde3641c36ed0c5104fbb7e77afa16c718f4 /src/tests | |
parent | 3460860befbef4f091f06a2f71de36e9cfb3d13a (diff) | |
download | ipxe-91ac92bc863d0e0b17c321e19944fbffd52807c1.tar.gz |
Try image as ELF file first. (Don't yet actually try to execute it).
Diffstat (limited to 'src/tests')
-rw-r--r-- | src/tests/tftptest.c | 15 |
1 files changed, 14 insertions, 1 deletions
diff --git a/src/tests/tftptest.c b/src/tests/tftptest.c index 2e558a358..57f515026 100644 --- a/src/tests/tftptest.c +++ b/src/tests/tftptest.c @@ -6,17 +6,22 @@ #include <gpxe/async.h> #include <gpxe/uaccess.h> #include <gpxe/buffer.h> +#include <gpxe/elf.h> +#include <bios.h> #include "pxe.h" int test_tftp ( struct net_device *netdev, struct sockaddr_tcpip *target, const char *filename ) { struct tftp_session tftp; struct buffer buffer; + struct elf elf; + uint16_t fbms; int rc; memset ( &buffer, 0, sizeof ( buffer ) ); buffer.addr = real_to_user ( 0, 0x7c00 ); - buffer.len = ( 512 * 1024 - 0x7c00 ); + get_real ( fbms, BDA_SEG, BDA_FBMS ); + buffer.len = ( fbms * 1024 - 0x7c00 ); memset ( &tftp, 0, sizeof ( tftp ) ); udp_connect ( &tftp.udp, target ); @@ -27,6 +32,14 @@ int test_tftp ( struct net_device *netdev, struct sockaddr_tcpip *target, if ( ( rc = async_wait ( tftp_get ( &tftp ) ) ) != 0 ) return rc; + elf.image = buffer.addr; + elf.len = buffer.len; + if ( ( rc = elf_load ( &elf ) ) == 0 ) { + printf ( "Got valid ELF image: execaddr at %lx\n", + elf.entry ); + return 0; + } + printf ( "Attempting PXE boot\n" ); pxe_netdev = netdev; rc = pxe_boot(); |