diff options
author | Michael Brown | 2007-07-09 02:10:32 +0200 |
---|---|---|
committer | Michael Brown | 2007-07-09 02:10:32 +0200 |
commit | 487dc5be562be223512ed22b008c24db63463655 (patch) | |
tree | 0322faaa45b2146b9bc973c9130281b3e1d8a59f /src/usr | |
parent | Add missing static (diff) | |
download | ipxe-487dc5be562be223512ed22b008c24db63463655.tar.gz ipxe-487dc5be562be223512ed22b008c24db63463655.tar.xz ipxe-487dc5be562be223512ed22b008c24db63463655.zip |
Fix up iscsiboot missing prototype warnings
Diffstat (limited to 'src/usr')
-rw-r--r-- | src/usr/autoboot.c | 1 | ||||
-rw-r--r-- | src/usr/iscsiboot.c | 46 |
2 files changed, 47 insertions, 0 deletions
diff --git a/src/usr/autoboot.c b/src/usr/autoboot.c index 277e8b09..97b9a406 100644 --- a/src/usr/autoboot.c +++ b/src/usr/autoboot.c @@ -26,6 +26,7 @@ #include <usr/route.h> #include <usr/dhcpmgmt.h> #include <usr/imgmgmt.h> +#include <usr/iscsiboot.h> #include <usr/autoboot.h> /** @file diff --git a/src/usr/iscsiboot.c b/src/usr/iscsiboot.c new file mode 100644 index 00000000..f3910f14 --- /dev/null +++ b/src/usr/iscsiboot.c @@ -0,0 +1,46 @@ +#include <stdint.h> +#include <string.h> +#include <stdio.h> +#include <gpxe/iscsi.h> +#include <gpxe/dhcp.h> +#include <int13.h> +#include <usr/iscsiboot.h> + +int iscsiboot ( const char *root_path ) { + struct scsi_device scsi; + struct int13_drive drive; + int rc; + + memset ( &scsi, 0, sizeof ( scsi ) ); + memset ( &drive, 0, sizeof ( drive ) ); + + printf ( "iSCSI booting from %s\n", root_path ); + + if ( ( rc = iscsi_attach ( &scsi, root_path ) ) != 0 ) { + printf ( "Could not attach iSCSI device: %s\n", + strerror ( rc ) ); + goto error_attach; + } + if ( ( rc = init_scsidev ( &scsi ) ) != 0 ) { + printf ( "Could not initialise iSCSI device: %s\n", + strerror ( rc ) ); + goto error_init; + } + + drive.drive = find_global_dhcp_num_option ( DHCP_EB_BIOS_DRIVE ); + drive.blockdev = &scsi.blockdev; + + register_int13_drive ( &drive ); + printf ( "Registered as BIOS drive %#02x\n", drive.drive ); + printf ( "Booting from BIOS drive %#02x\n", drive.drive ); + rc = int13_boot ( drive.drive ); + printf ( "Boot failed\n" ); + + printf ( "Unregistering BIOS drive %#02x\n", drive.drive ); + unregister_int13_drive ( &drive ); + + error_init: + iscsi_detach ( &scsi ); + error_attach: + return rc; +} |