From f25731d08fcb22567ff7eb537e50273ff28d7afe Mon Sep 17 00:00:00 2001 From: Michael Brown Date: Sun, 14 May 2006 23:29:16 +0000 Subject: [PATCH] Split "iSCSI as a SCSI device" out from "iSCSI as a TCP protocol". --- src/drivers/scsi/iscsidev.c | 52 +++++++++++++++++++++++++++++++++++++ src/include/gpxe/iscsi.h | 3 +++ src/net/tcp/iscsi.c | 48 ++++++++++++++-------------------- 3 files changed, 75 insertions(+), 28 deletions(-) create mode 100644 src/drivers/scsi/iscsidev.c 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 . + * + * 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 +#include + +/** @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 . + * + * 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 #include #include @@ -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 ); -}