diff options
author | Michael Brown | 2009-07-17 23:11:42 +0200 |
---|---|---|
committer | Michael Brown | 2009-08-10 23:27:33 +0200 |
commit | 0c30dc6bc5f26e7011ddfcda34d7adac653464cf (patch) | |
tree | 77510bd3e059a3840f8704eae8f2ac05482f6fc4 /src/arch | |
parent | [infiniband] Add last_opened_ibdev(), analogous to last_opened_netdev() (diff) | |
download | ipxe-0c30dc6bc5f26e7011ddfcda34d7adac653464cf.tar.gz ipxe-0c30dc6bc5f26e7011ddfcda34d7adac653464cf.tar.xz ipxe-0c30dc6bc5f26e7011ddfcda34d7adac653464cf.zip |
[infiniband] Add support for SRP over Infiniband
SRP is the SCSI RDMA Protocol. It allows for a method of SAN booting
whereby the target is responsible for reading and writing data using
Remote DMA directly to the initiator's memory. The software initiator
merely sends and receives SCSI commands; it never has to touch the
actual data.
Diffstat (limited to 'src/arch')
-rw-r--r-- | src/arch/i386/interface/pcbios/ib_srpboot.c | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/src/arch/i386/interface/pcbios/ib_srpboot.c b/src/arch/i386/interface/pcbios/ib_srpboot.c new file mode 100644 index 00000000..ab90c44f --- /dev/null +++ b/src/arch/i386/interface/pcbios/ib_srpboot.c @@ -0,0 +1,63 @@ +#include <stdint.h> +#include <string.h> +#include <stdlib.h> +#include <stdio.h> +#include <errno.h> +#include <gpxe/sanboot.h> +#include <int13.h> +#include <gpxe/srp.h> + +FILE_LICENCE ( GPL2_OR_LATER ); + +static int ib_srpboot ( const char *root_path ) { + struct scsi_device *scsi; + struct int13_drive *drive; + int rc; + + scsi = zalloc ( sizeof ( *scsi ) ); + if ( ! scsi ) { + rc = -ENOMEM; + goto err_alloc_scsi; + } + drive = zalloc ( sizeof ( *drive ) ); + if ( ! drive ) { + rc = -ENOMEM; + goto err_alloc_drive; + } + + if ( ( rc = srp_attach ( scsi, root_path ) ) != 0 ) { + printf ( "Could not attach IB_SRP device: %s\n", + strerror ( rc ) ); + goto err_attach; + } + if ( ( rc = init_scsidev ( scsi ) ) != 0 ) { + printf ( "Could not initialise IB_SRP device: %s\n", + strerror ( rc ) ); + goto err_init; + } + + 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 ); + + err_init: + srp_detach ( scsi ); + err_attach: + free ( drive ); + err_alloc_drive: + free ( scsi ); + err_alloc_scsi: + return rc; +} + +struct sanboot_protocol ib_srp_sanboot_protocol __sanboot_protocol = { + .prefix = "ib_srp:", + .boot = ib_srpboot, +}; |