diff options
Diffstat (limited to 'drivers/scsi/scsi_debug.c')
-rw-r--r-- | drivers/scsi/scsi_debug.c | 13 |
1 files changed, 6 insertions, 7 deletions
diff --git a/drivers/scsi/scsi_debug.c b/drivers/scsi/scsi_debug.c index 65c88dde72b4..4e93b69207c4 100644 --- a/drivers/scsi/scsi_debug.c +++ b/drivers/scsi/scsi_debug.c | |||
@@ -148,7 +148,6 @@ static int scsi_debug_cmnd_count = 0; | |||
148 | #define DEV_READONLY(TGT) (0) | 148 | #define DEV_READONLY(TGT) (0) |
149 | #define DEV_REMOVEABLE(TGT) (0) | 149 | #define DEV_REMOVEABLE(TGT) (0) |
150 | 150 | ||
151 | static unsigned int sdebug_store_size; /* in bytes */ | ||
152 | static unsigned int sdebug_store_sectors; | 151 | static unsigned int sdebug_store_sectors; |
153 | static sector_t sdebug_capacity; /* in sectors */ | 152 | static sector_t sdebug_capacity; /* in sectors */ |
154 | 153 | ||
@@ -1969,7 +1968,8 @@ static void __init init_all_queued(void) | |||
1969 | spin_unlock_irqrestore(&queued_arr_lock, iflags); | 1968 | spin_unlock_irqrestore(&queued_arr_lock, iflags); |
1970 | } | 1969 | } |
1971 | 1970 | ||
1972 | static void __init sdebug_build_parts(unsigned char * ramp) | 1971 | static void __init sdebug_build_parts(unsigned char *ramp, |
1972 | unsigned int store_size) | ||
1973 | { | 1973 | { |
1974 | struct partition * pp; | 1974 | struct partition * pp; |
1975 | int starts[SDEBUG_MAX_PARTS + 2]; | 1975 | int starts[SDEBUG_MAX_PARTS + 2]; |
@@ -1977,7 +1977,7 @@ static void __init sdebug_build_parts(unsigned char * ramp) | |||
1977 | int heads_by_sects, start_sec, end_sec; | 1977 | int heads_by_sects, start_sec, end_sec; |
1978 | 1978 | ||
1979 | /* assume partition table already zeroed */ | 1979 | /* assume partition table already zeroed */ |
1980 | if ((scsi_debug_num_parts < 1) || (sdebug_store_size < 1048576)) | 1980 | if ((scsi_debug_num_parts < 1) || (store_size < 1048576)) |
1981 | return; | 1981 | return; |
1982 | if (scsi_debug_num_parts > SDEBUG_MAX_PARTS) { | 1982 | if (scsi_debug_num_parts > SDEBUG_MAX_PARTS) { |
1983 | scsi_debug_num_parts = SDEBUG_MAX_PARTS; | 1983 | scsi_debug_num_parts = SDEBUG_MAX_PARTS; |
@@ -2505,8 +2505,8 @@ static int __init scsi_debug_init(void) | |||
2505 | 2505 | ||
2506 | if (scsi_debug_dev_size_mb < 1) | 2506 | if (scsi_debug_dev_size_mb < 1) |
2507 | scsi_debug_dev_size_mb = 1; /* force minimum 1 MB ramdisk */ | 2507 | scsi_debug_dev_size_mb = 1; /* force minimum 1 MB ramdisk */ |
2508 | sdebug_store_size = (unsigned int)scsi_debug_dev_size_mb * 1048576; | 2508 | sz = (unsigned int)scsi_debug_dev_size_mb * 1048576; |
2509 | sdebug_store_sectors = sdebug_store_size / SECT_SIZE; | 2509 | sdebug_store_sectors = sz / SECT_SIZE; |
2510 | if (scsi_debug_virtual_gb > 0) { | 2510 | if (scsi_debug_virtual_gb > 0) { |
2511 | sdebug_capacity = 2048 * 1024; | 2511 | sdebug_capacity = 2048 * 1024; |
2512 | sdebug_capacity *= scsi_debug_virtual_gb; | 2512 | sdebug_capacity *= scsi_debug_virtual_gb; |
@@ -2530,7 +2530,6 @@ static int __init scsi_debug_init(void) | |||
2530 | (sdebug_sectors_per * sdebug_heads); | 2530 | (sdebug_sectors_per * sdebug_heads); |
2531 | } | 2531 | } |
2532 | 2532 | ||
2533 | sz = sdebug_store_size; | ||
2534 | fake_storep = vmalloc(sz); | 2533 | fake_storep = vmalloc(sz); |
2535 | if (NULL == fake_storep) { | 2534 | if (NULL == fake_storep) { |
2536 | printk(KERN_ERR "scsi_debug_init: out of memory, 1\n"); | 2535 | printk(KERN_ERR "scsi_debug_init: out of memory, 1\n"); |
@@ -2538,7 +2537,7 @@ static int __init scsi_debug_init(void) | |||
2538 | } | 2537 | } |
2539 | memset(fake_storep, 0, sz); | 2538 | memset(fake_storep, 0, sz); |
2540 | if (scsi_debug_num_parts > 0) | 2539 | if (scsi_debug_num_parts > 0) |
2541 | sdebug_build_parts(fake_storep); | 2540 | sdebug_build_parts(fake_storep, sz); |
2542 | 2541 | ||
2543 | ret = device_register(&pseudo_primary); | 2542 | ret = device_register(&pseudo_primary); |
2544 | if (ret < 0) { | 2543 | if (ret < 0) { |