]> err.no Git - linux-2.6/blobdiff - include/scsi/scsi_transport.h
Merge master.kernel.org:/home/rmk/linux-2.6-arm
[linux-2.6] / include / scsi / scsi_transport.h
index a4f1837a33b150b925e471e1c2938d35a6c4eded..cca1d4926d2aa47333749967577087df93b9ec52 100644 (file)
@@ -29,6 +29,11 @@ struct scsi_transport_template {
        struct transport_container target_attrs;
        struct transport_container device_attrs;
 
+       /*
+        * If set, called from sysfs and legacy procfs rescanning code.
+        */
+       int (*user_scan)(struct Scsi_Host *, uint, uint, uint);
+
        /* The size of the specific transport attribute structure (a
         * space of this size will be left at the end of the
         * scsi_* structure */
@@ -43,6 +48,22 @@ struct scsi_transport_template {
         * True if the transport wants to use a host-based work-queue
         */
        unsigned int create_work_queue : 1;
+
+       /*
+        * Allows a transport to override the default error handler.
+        */
+       void (* eh_strategy_handler)(struct Scsi_Host *);
+
+       /*
+        * This is an optional routine that allows the transport to become
+        * involved when a scsi io timer fires. The return value tells the
+        * timer routine how to finish the io timeout handling:
+        * EH_HANDLED:          I fixed the error, please complete the command
+        * EH_RESET_TIMER:      I need more time, reset the timer and
+        *                      begin counting again
+        * EH_NOT_HANDLED       Begin normal error recovery
+        */
+       enum scsi_eh_timer_return (* eh_timed_out)(struct scsi_cmnd *);
 };
 
 #define transport_class_to_shost(tc) \