diff options
Diffstat (limited to 'drivers/scsi/scsi_debug.c')
-rw-r--r-- | drivers/scsi/scsi_debug.c | 56 |
1 files changed, 29 insertions, 27 deletions
diff --git a/drivers/scsi/scsi_debug.c b/drivers/scsi/scsi_debug.c index 26979e0185be..be3437c4058c 100644 --- a/drivers/scsi/scsi_debug.c +++ b/drivers/scsi/scsi_debug.c | |||
@@ -50,7 +50,6 @@ | |||
50 | #include <linux/stat.h> | 50 | #include <linux/stat.h> |
51 | 51 | ||
52 | #include "scsi_logging.h" | 52 | #include "scsi_logging.h" |
53 | #include "scsi_debug.h" | ||
54 | 53 | ||
55 | #define SCSI_DEBUG_VERSION "1.81" | 54 | #define SCSI_DEBUG_VERSION "1.81" |
56 | static const char * scsi_debug_version_date = "20070104"; | 55 | static const char * scsi_debug_version_date = "20070104"; |
@@ -167,6 +166,9 @@ static int sdebug_sectors_per; /* sectors per cylinder */ | |||
167 | 166 | ||
168 | #define SDEBUG_SENSE_LEN 32 | 167 | #define SDEBUG_SENSE_LEN 32 |
169 | 168 | ||
169 | #define SCSI_DEBUG_CANQUEUE 255 | ||
170 | #define SCSI_DEBUG_MAX_CMD_LEN 16 | ||
171 | |||
170 | struct sdebug_dev_info { | 172 | struct sdebug_dev_info { |
171 | struct list_head dev_list; | 173 | struct list_head dev_list; |
172 | unsigned char sense_buff[SDEBUG_SENSE_LEN]; /* weak nexus */ | 174 | unsigned char sense_buff[SDEBUG_SENSE_LEN]; /* weak nexus */ |
@@ -204,29 +206,6 @@ struct sdebug_queued_cmd { | |||
204 | }; | 206 | }; |
205 | static struct sdebug_queued_cmd queued_arr[SCSI_DEBUG_CANQUEUE]; | 207 | static struct sdebug_queued_cmd queued_arr[SCSI_DEBUG_CANQUEUE]; |
206 | 208 | ||
207 | static struct scsi_host_template sdebug_driver_template = { | ||
208 | .proc_info = scsi_debug_proc_info, | ||
209 | .name = "SCSI DEBUG", | ||
210 | .info = scsi_debug_info, | ||
211 | .slave_alloc = scsi_debug_slave_alloc, | ||
212 | .slave_configure = scsi_debug_slave_configure, | ||
213 | .slave_destroy = scsi_debug_slave_destroy, | ||
214 | .ioctl = scsi_debug_ioctl, | ||
215 | .queuecommand = scsi_debug_queuecommand, | ||
216 | .eh_abort_handler = scsi_debug_abort, | ||
217 | .eh_bus_reset_handler = scsi_debug_bus_reset, | ||
218 | .eh_device_reset_handler = scsi_debug_device_reset, | ||
219 | .eh_host_reset_handler = scsi_debug_host_reset, | ||
220 | .bios_param = scsi_debug_biosparam, | ||
221 | .can_queue = SCSI_DEBUG_CANQUEUE, | ||
222 | .this_id = 7, | ||
223 | .sg_tablesize = 256, | ||
224 | .cmd_per_lun = 16, | ||
225 | .max_sectors = 0xffff, | ||
226 | .use_clustering = DISABLE_CLUSTERING, | ||
227 | .module = THIS_MODULE, | ||
228 | }; | ||
229 | |||
230 | static unsigned char * fake_storep; /* ramdisk storage */ | 209 | static unsigned char * fake_storep; /* ramdisk storage */ |
231 | 210 | ||
232 | static int num_aborts = 0; | 211 | static int num_aborts = 0; |
@@ -375,7 +354,8 @@ int scsi_debug_queuecommand(struct scsi_cmnd * SCpnt, done_funct_t done) | |||
375 | printk("%02x ", (int)cmd[k]); | 354 | printk("%02x ", (int)cmd[k]); |
376 | printk("\n"); | 355 | printk("\n"); |
377 | } | 356 | } |
378 | if(target == sdebug_driver_template.this_id) { | 357 | |
358 | if (target == SCpnt->device->host->hostt->this_id) { | ||
379 | printk(KERN_INFO "scsi_debug: initiator's id used as " | 359 | printk(KERN_INFO "scsi_debug: initiator's id used as " |
380 | "target!\n"); | 360 | "target!\n"); |
381 | return schedule_resp(SCpnt, NULL, done, | 361 | return schedule_resp(SCpnt, NULL, done, |
@@ -2923,8 +2903,6 @@ static int __init scsi_debug_init(void) | |||
2923 | 2903 | ||
2924 | init_all_queued(); | 2904 | init_all_queued(); |
2925 | 2905 | ||
2926 | sdebug_driver_template.proc_name = sdebug_proc_name; | ||
2927 | |||
2928 | host_to_add = scsi_debug_add_host; | 2906 | host_to_add = scsi_debug_add_host; |
2929 | scsi_debug_add_host = 0; | 2907 | scsi_debug_add_host = 0; |
2930 | 2908 | ||
@@ -3084,6 +3062,30 @@ static void sdebug_remove_adapter(void) | |||
3084 | --scsi_debug_add_host; | 3062 | --scsi_debug_add_host; |
3085 | } | 3063 | } |
3086 | 3064 | ||
3065 | static struct scsi_host_template sdebug_driver_template = { | ||
3066 | .proc_info = scsi_debug_proc_info, | ||
3067 | .proc_name = sdebug_proc_name, | ||
3068 | .name = "SCSI DEBUG", | ||
3069 | .info = scsi_debug_info, | ||
3070 | .slave_alloc = scsi_debug_slave_alloc, | ||
3071 | .slave_configure = scsi_debug_slave_configure, | ||
3072 | .slave_destroy = scsi_debug_slave_destroy, | ||
3073 | .ioctl = scsi_debug_ioctl, | ||
3074 | .queuecommand = scsi_debug_queuecommand, | ||
3075 | .eh_abort_handler = scsi_debug_abort, | ||
3076 | .eh_bus_reset_handler = scsi_debug_bus_reset, | ||
3077 | .eh_device_reset_handler = scsi_debug_device_reset, | ||
3078 | .eh_host_reset_handler = scsi_debug_host_reset, | ||
3079 | .bios_param = scsi_debug_biosparam, | ||
3080 | .can_queue = SCSI_DEBUG_CANQUEUE, | ||
3081 | .this_id = 7, | ||
3082 | .sg_tablesize = 256, | ||
3083 | .cmd_per_lun = 16, | ||
3084 | .max_sectors = 0xffff, | ||
3085 | .use_clustering = DISABLE_CLUSTERING, | ||
3086 | .module = THIS_MODULE, | ||
3087 | }; | ||
3088 | |||
3087 | static int sdebug_driver_probe(struct device * dev) | 3089 | static int sdebug_driver_probe(struct device * dev) |
3088 | { | 3090 | { |
3089 | int error = 0; | 3091 | int error = 0; |