summaryrefslogtreecommitdiffstats
path: root/src/tests
diff options
context:
space:
mode:
authorMichael Brown2007-07-08 23:01:49 +0200
committerMichael Brown2007-07-08 23:01:49 +0200
commitb94420a52bd2f19336b02bd431e80e59ff30d60b (patch)
tree55cab3f25ec7e2f2726682715146af67280b2298 /src/tests
parentCode in place to use a hypothetical SCSI interface. (diff)
downloadipxe-b94420a52bd2f19336b02bd431e80e59ff30d60b.tar.gz
ipxe-b94420a52bd2f19336b02bd431e80e59ff30d60b.tar.xz
ipxe-b94420a52bd2f19336b02bd431e80e59ff30d60b.zip
Ready to start testing
Diffstat (limited to 'src/tests')
-rw-r--r--src/tests/iscsiboot.c59
1 files changed, 24 insertions, 35 deletions
diff --git a/src/tests/iscsiboot.c b/src/tests/iscsiboot.c
index 22dccb1d..9331357d 100644
--- a/src/tests/iscsiboot.c
+++ b/src/tests/iscsiboot.c
@@ -1,48 +1,36 @@
#include <stdint.h>
#include <string.h>
#include <stdio.h>
-#include <byteswap.h>
-#include <gpxe/netdevice.h>
#include <gpxe/iscsi.h>
-#include <gpxe/ibft.h>
-#include <gpxe/tcpip.h>
+#include <gpxe/dhcp.h>
#include <int13.h>
-static struct iscsi_device test_iscsidev;
-
-int test_iscsiboot ( const char *initiator_iqn,
- struct sockaddr_tcpip *target,
- const char *target_iqn,
- unsigned int lun,
- const char *username,
- const char *password,
- struct net_device *netdev,
- unsigned int drivenum ) {
+int iscsiboot ( const char *root_path ) {
+ struct scsi_device scsi;
struct int13_drive drive;
int rc;
- memset ( &test_iscsidev, 0, sizeof ( test_iscsidev ) );
- memcpy ( &test_iscsidev.iscsi.target, target,
- sizeof ( test_iscsidev.iscsi.target ) );
- test_iscsidev.iscsi.initiator_iqn = initiator_iqn;
- test_iscsidev.iscsi.target_iqn = target_iqn;
- test_iscsidev.iscsi.lun = lun;
- test_iscsidev.iscsi.username = username;
- test_iscsidev.iscsi.password = password;
-
- printf ( "Initialising %s\n", target_iqn );
- if ( ( rc = init_iscsidev ( &test_iscsidev ) ) != 0 ) {
- printf ( "Could not reach %s: %s\n", target_iqn,
+ 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 ) );
- return rc;
+ goto error_attach;
}
- ibft_fill_data ( netdev, &test_iscsidev.iscsi );
- memset ( &drive, 0, sizeof ( drive ) );
- drive.drive = drivenum;
- drive.blockdev = &test_iscsidev.scsi.blockdev;
+ 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 %s as BIOS drive %#02x\n",
- target_iqn, 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" );
@@ -50,7 +38,8 @@ int test_iscsiboot ( const char *initiator_iqn,
printf ( "Unregistering BIOS drive %#02x\n", drive.drive );
unregister_int13_drive ( &drive );
- fini_iscsidev ( &test_iscsidev );
-
+ error_init:
+ iscsi_detach ( &scsi );
+ error_attach:
return rc;
}