summaryrefslogtreecommitdiffstats
path: root/src/drivers/scsi/iscsidev.c
diff options
context:
space:
mode:
authorMichael Brown2007-01-16 09:10:54 +0100
committerMichael Brown2007-01-16 09:10:54 +0100
commitff8528ea9a69ca2ef6cfbed0b7a1283e165aabe6 (patch)
treebae0e953c128a5d49bedd2f502325b938078635f /src/drivers/scsi/iscsidev.c
parentWhen a network device is specified to tcpip_tx() or it's children, treat (diff)
downloadipxe-ff8528ea9a69ca2ef6cfbed0b7a1283e165aabe6.tar.gz
ipxe-ff8528ea9a69ca2ef6cfbed0b7a1283e165aabe6.tar.xz
ipxe-ff8528ea9a69ca2ef6cfbed0b7a1283e165aabe6.zip
Create and use async_block() macro; it cuts down on the visual overhead
of blocking on asynchronous operations, when that isn't an important aspect of the code.
Diffstat (limited to 'src/drivers/scsi/iscsidev.c')
-rw-r--r--src/drivers/scsi/iscsidev.c20
1 files changed, 10 insertions, 10 deletions
diff --git a/src/drivers/scsi/iscsidev.c b/src/drivers/scsi/iscsidev.c
index 75b857e71..aab99032d 100644
--- a/src/drivers/scsi/iscsidev.c
+++ b/src/drivers/scsi/iscsidev.c
@@ -17,6 +17,7 @@
*/
#include <stddef.h>
+#include <gpxe/async.h>
#include <gpxe/iscsi.h>
/** @file
@@ -37,13 +38,9 @@ static int iscsi_command ( struct scsi_device *scsi,
struct iscsi_device *iscsidev
= container_of ( scsi, struct iscsi_device, scsi );
struct async async;
- int rc;
- async_init_orphan ( &async );
- if ( ( rc = iscsi_issue ( &iscsidev->iscsi, command, &async ) ) != 0 )
- return rc;
- async_wait ( &async, &rc, 1 );
- return rc;
+ return async_block ( &async, iscsi_issue ( &iscsidev->iscsi, command,
+ &async ) );
}
/**
@@ -56,10 +53,13 @@ int init_iscsidev ( struct iscsi_device *iscsidev ) {
iscsidev->scsi.command = iscsi_command;
iscsidev->scsi.lun = iscsidev->iscsi.lun;
- rc = init_scsidev ( &iscsidev->scsi );
- if ( rc != 0 ) {
- fini_iscsidev ( iscsidev );
- }
+ if ( ( rc = init_scsidev ( &iscsidev->scsi ) ) != 0 )
+ goto err;
+
+ return 0;
+
+ err:
+ fini_iscsidev ( iscsidev );
return rc;
}