[SCSI] tgt: move tsk_mgmt_response callback to transport class
authorFUJITA Tomonori <tomof@acm.org>
Wed, 11 Jul 2007 06:08:22 +0000 (15:08 +0900)
committerJames Bottomley <jejb@mulgrave.localdomain>
Fri, 12 Oct 2007 18:38:01 +0000 (14:38 -0400)
This moves tsk_mgmt_response callback in struct scsi_host_template to
struct scsi_transport_template since struct scsi_transport_template is
more suitable for the task management stuff.

Signed-off-by: FUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp>
Signed-off-by: Mike Christie <michaelc@cs.wisc.edu>
Signed-off-by: James Bottomley <James.Bottomley@SteelEye.com>
drivers/scsi/scsi_tgt_lib.c
drivers/scsi/scsi_transport_srp.c
include/scsi/scsi_host.h
include/scsi/scsi_transport.h
include/scsi/scsi_transport_srp.h

index fa79e54722dbb1ab468daf23196f36513c53c870..5851c8e53e40d3c0edd39688b9af3e92ec4b3258 100644 (file)
@@ -577,7 +577,7 @@ int scsi_tgt_kspace_tsk_mgmt(int host_no, u64 itn_id, u64 mid, int result)
                goto done;
        }
 
-       err = shost->hostt->tsk_mgmt_response(shost, itn_id, mid, result);
+       err = shost->transportt->tsk_mgmt_response(shost, itn_id, mid, result);
 done:
        scsi_host_put(shost);
        return err;
index 8e5b41ca181d435752d8e22b754672f20880d663..cdd001a6639cc70990f62ac5ac0407868d9dabfb 100644 (file)
@@ -280,10 +280,17 @@ void srp_remove_host(struct Scsi_Host *shost)
 }
 EXPORT_SYMBOL_GPL(srp_remove_host);
 
-static int srp_it_nexus_response(struct Scsi_Host *shost, u64 id, int result)
+static int srp_tsk_mgmt_response(struct Scsi_Host *shost, u64 nexus, u64 tm_id,
+                                int result)
 {
        struct srp_internal *i = to_srp_internal(shost->transportt);
-       return i->f->it_nexus_response(shost, id, result);
+       return i->f->tsk_mgmt_response(shost, nexus, tm_id, result);
+}
+
+static int srp_it_nexus_response(struct Scsi_Host *shost, u64 nexus, int result)
+{
+       struct srp_internal *i = to_srp_internal(shost->transportt);
+       return i->f->it_nexus_response(shost, nexus, result);
 }
 
 /**
@@ -300,6 +307,7 @@ srp_attach_transport(struct srp_function_template *ft)
        if (!i)
                return NULL;
 
+       i->t.tsk_mgmt_response = srp_tsk_mgmt_response;
        i->t.it_nexus_response = srp_it_nexus_response;
 
        i->t.host_size = sizeof(struct srp_host_attrs);
index 89c40c4bd5c481030ffc72a9705f125a484b38b9..88f6871badd8ade1e8c82c0f0120a2f0858431de 100644 (file)
@@ -145,9 +145,6 @@ struct scsi_host_template {
        int (* transfer_response)(struct scsi_cmnd *,
                                  void (*done)(struct scsi_cmnd *));
 
-       /* Used as callback for the completion of task management request. */
-       int (* tsk_mgmt_response)(struct Scsi_Host *, u64, u64 mid, int result);
-
        /*
         * This is an error handling strategy routine.  You don't need to
         * define one of these if you don't want to - there is a default
index af5b3e15e64eb1e4fd47dc8718ea24963119da92..0dfef752f0e27c7c9009a2dbe378522322d453a4 100644 (file)
@@ -71,6 +71,12 @@ struct scsi_transport_template {
         * for target drivers.
         */
        int (* it_nexus_response)(struct Scsi_Host *, u64, int);
+
+       /*
+        * Used as callback for the completion of task management
+        * request for target drivers.
+        */
+       int (* tsk_mgmt_response)(struct Scsi_Host *, u64, u64, int);
 };
 
 #define transport_class_to_shost(tc) \
index a705dbc016b342f06abaf270dc830f273e536f16..9c60ca1c08c5a12ac77ba84f3d046cbd21fc60df 100644 (file)
@@ -22,6 +22,7 @@ struct srp_rport {
 
 struct srp_function_template {
        /* for target drivers */
+       int (* tsk_mgmt_response)(struct Scsi_Host *, u64, u64, int);
        int (* it_nexus_response)(struct Scsi_Host *, u64, int);
 };