]> git.ipfire.org Git - thirdparty/ipxe.git/commitdiff
Split "iSCSI as a SCSI device" out from "iSCSI as a TCP protocol".
authorMichael Brown <mcb30@etherboot.org>
Sun, 14 May 2006 23:29:16 +0000 (23:29 +0000)
committerMichael Brown <mcb30@etherboot.org>
Sun, 14 May 2006 23:29:16 +0000 (23:29 +0000)
src/drivers/scsi/iscsidev.c [new file with mode: 0644]
src/include/gpxe/iscsi.h
src/net/tcp/iscsi.c

diff --git a/src/drivers/scsi/iscsidev.c b/src/drivers/scsi/iscsidev.c
new file mode 100644 (file)
index 0000000..17ad376
--- /dev/null
@@ -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 );
+}
index fdb4b5445b03a9fe0e7c4c3fc8f4d9444551408f..a853b9aaa441046762708ad8db1d2de63183cfc2 100644 (file)
@@ -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 */
index 1f0c452160148c85a1b81d4c1fc68462b2167639..345cd5fd198d7ca4cb8f19f61929b9fc0b1d5d0b 100644 (file)
@@ -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 );
-}