summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorMichael Brown2006-05-15 01:29:16 +0200
committerMichael Brown2006-05-15 01:29:16 +0200
commitf25731d08fcb22567ff7eb537e50273ff28d7afe (patch)
tree352c7797883e313ff76fd6a2b2060a1575871331 /src
parentFix a couple of minor typos. (diff)
downloadipxe-f25731d08fcb22567ff7eb537e50273ff28d7afe.tar.gz
ipxe-f25731d08fcb22567ff7eb537e50273ff28d7afe.tar.xz
ipxe-f25731d08fcb22567ff7eb537e50273ff28d7afe.zip
Split "iSCSI as a SCSI device" out from "iSCSI as a TCP protocol".
Diffstat (limited to 'src')
-rw-r--r--src/drivers/scsi/iscsidev.c52
-rw-r--r--src/include/gpxe/iscsi.h3
-rw-r--r--src/net/tcp/iscsi.c48
3 files changed, 75 insertions, 28 deletions
diff --git a/src/drivers/scsi/iscsidev.c b/src/drivers/scsi/iscsidev.c
new file mode 100644
index 00000000..17ad3761
--- /dev/null
+++ b/src/drivers/scsi/iscsidev.c
@@ -0,0 +1,52 @@
+/*
+ * Copyright (C) 2006 Michael Brown <mbrown@fensystems.co.uk>.
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; either version 2 of the
+ * License, or any later version.
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ */
+
+#include <stddef.h>
+#include <gpxe/iscsi.h>
+
+/** @file
+ *
+ * iSCSI SCSI device
+ *
+ */
+
+/**
+ * Issue SCSI command via iSCSI device
+ *
+ * @v scsi SCSI device
+ * @v command SCSI command
+ * @ret rc Return status code
+ */
+static int iscsi_command ( struct scsi_device *scsi,
+ struct scsi_command *command ) {
+ struct iscsi_device *iscsidev
+ = container_of ( scsi, struct iscsi_device, scsi );
+
+ return iscsi_issue ( &iscsidev->iscsi, command );
+}
+
+/**
+ * Initialise iSCSI device
+ *
+ * @v iscsidev iSCSI device
+ */
+int init_iscsidev ( struct iscsi_device *iscsidev ) {
+ iscsidev->scsi.command = iscsi_command;
+ iscsidev->scsi.lun = iscsidev->iscsi.lun;
+ return init_scsidev ( &iscsidev->scsi );
+}
diff --git a/src/include/gpxe/iscsi.h b/src/include/gpxe/iscsi.h
index fdb4b544..a853b9aa 100644
--- a/src/include/gpxe/iscsi.h
+++ b/src/include/gpxe/iscsi.h
@@ -513,6 +513,9 @@ struct iscsi_session {
/** Maximum number of retries at connecting */
#define ISCSI_MAX_RETRIES 2
+extern int iscsi_issue ( struct iscsi_session *iscsi,
+ struct scsi_command *command );
+
/** An iSCSI device */
struct iscsi_device {
/** SCSI device interface */
diff --git a/src/net/tcp/iscsi.c b/src/net/tcp/iscsi.c
index 1f0c4521..345cd5fd 100644
--- a/src/net/tcp/iscsi.c
+++ b/src/net/tcp/iscsi.c
@@ -1,3 +1,21 @@
+/*
+ * Copyright (C) 2006 Michael Brown <mbrown@fensystems.co.uk>.
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; either version 2 of the
+ * License, or any later version.
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ */
+
#include <stddef.h>
#include <string.h>
#include <vsprintf.h>
@@ -543,8 +561,8 @@ static struct tcp_operations iscsi_tcp_operations = {
* @v command SCSI command
* @ret rc Return status code
*/
-static int iscsi_command ( struct iscsi_session *iscsi,
- struct scsi_command *command ) {
+int iscsi_issue ( struct iscsi_session *iscsi,
+ struct scsi_command *command ) {
iscsi->command = command;
iscsi->status &= ~( ISCSI_STATUS_DONE | ISCSI_STATUS_ERR );
@@ -563,29 +581,3 @@ static int iscsi_command ( struct iscsi_session *iscsi,
return ( ( iscsi->status & ISCSI_STATUS_ERR ) ? -EIO : 0 );
}
-
-/**
- * Issue SCSI command via iSCSI device
- *
- * @v scsi SCSI device
- * @v command SCSI command
- * @ret rc Return status code
- */
-static int iscsi_scsi_command ( struct scsi_device *scsi,
- struct scsi_command *command ) {
- struct iscsi_device *iscsidev
- = container_of ( scsi, struct iscsi_device, scsi );
-
- return iscsi_command ( &iscsidev->iscsi, command );
-}
-
-/**
- * Initialise iSCSI device
- *
- * @v iscsidev iSCSI device
- */
-int init_iscsidev ( struct iscsi_device *iscsidev ) {
- iscsidev->scsi.command = iscsi_scsi_command;
- iscsidev->scsi.lun = iscsidev->iscsi.lun;
- return init_scsidev ( &iscsidev->scsi );
-}