diff options
Diffstat (limited to 'block')
-rw-r--r-- | block/blktrace.c | 9 | ||||
-rw-r--r-- | block/genhd.c | 1 | ||||
-rw-r--r-- | block/ll_rw_blk.c | 23 |
3 files changed, 8 insertions, 25 deletions
diff --git a/block/blktrace.c b/block/blktrace.c index d00ac3993c18..498a0a54a6aa 100644 --- a/block/blktrace.c +++ b/block/blktrace.c | |||
@@ -202,6 +202,7 @@ static void blk_remove_tree(struct dentry *dir) | |||
202 | static struct dentry *blk_create_tree(const char *blk_name) | 202 | static struct dentry *blk_create_tree(const char *blk_name) |
203 | { | 203 | { |
204 | struct dentry *dir = NULL; | 204 | struct dentry *dir = NULL; |
205 | int created = 0; | ||
205 | 206 | ||
206 | mutex_lock(&blk_tree_mutex); | 207 | mutex_lock(&blk_tree_mutex); |
207 | 208 | ||
@@ -209,13 +210,17 @@ static struct dentry *blk_create_tree(const char *blk_name) | |||
209 | blk_tree_root = debugfs_create_dir("block", NULL); | 210 | blk_tree_root = debugfs_create_dir("block", NULL); |
210 | if (!blk_tree_root) | 211 | if (!blk_tree_root) |
211 | goto err; | 212 | goto err; |
213 | created = 1; | ||
212 | } | 214 | } |
213 | 215 | ||
214 | dir = debugfs_create_dir(blk_name, blk_tree_root); | 216 | dir = debugfs_create_dir(blk_name, blk_tree_root); |
215 | if (dir) | 217 | if (dir) |
216 | root_users++; | 218 | root_users++; |
217 | else | 219 | else { |
218 | blk_remove_root(); | 220 | /* Delete root only if we created it */ |
221 | if (created) | ||
222 | blk_remove_root(); | ||
223 | } | ||
219 | 224 | ||
220 | err: | 225 | err: |
221 | mutex_unlock(&blk_tree_mutex); | 226 | mutex_unlock(&blk_tree_mutex); |
diff --git a/block/genhd.c b/block/genhd.c index e609996f2e76..f2ac914160d1 100644 --- a/block/genhd.c +++ b/block/genhd.c | |||
@@ -715,6 +715,7 @@ struct gendisk *alloc_disk_node(int minors, int node_id) | |||
715 | disk->part = kmalloc_node(size, | 715 | disk->part = kmalloc_node(size, |
716 | GFP_KERNEL | __GFP_ZERO, node_id); | 716 | GFP_KERNEL | __GFP_ZERO, node_id); |
717 | if (!disk->part) { | 717 | if (!disk->part) { |
718 | free_disk_stats(disk); | ||
718 | kfree(disk); | 719 | kfree(disk); |
719 | return NULL; | 720 | return NULL; |
720 | } | 721 | } |
diff --git a/block/ll_rw_blk.c b/block/ll_rw_blk.c index 3b927be03850..8b919940b2ab 100644 --- a/block/ll_rw_blk.c +++ b/block/ll_rw_blk.c | |||
@@ -4080,23 +4080,7 @@ static ssize_t queue_max_hw_sectors_show(struct request_queue *q, char *page) | |||
4080 | return queue_var_show(max_hw_sectors_kb, (page)); | 4080 | return queue_var_show(max_hw_sectors_kb, (page)); |
4081 | } | 4081 | } |
4082 | 4082 | ||
4083 | static ssize_t queue_max_segments_show(struct request_queue *q, char *page) | ||
4084 | { | ||
4085 | return queue_var_show(q->max_phys_segments, page); | ||
4086 | } | ||
4087 | |||
4088 | static ssize_t queue_max_segments_store(struct request_queue *q, | ||
4089 | const char *page, size_t count) | ||
4090 | { | ||
4091 | unsigned long segments; | ||
4092 | ssize_t ret = queue_var_store(&segments, page, count); | ||
4093 | 4083 | ||
4094 | spin_lock_irq(q->queue_lock); | ||
4095 | q->max_phys_segments = segments; | ||
4096 | spin_unlock_irq(q->queue_lock); | ||
4097 | |||
4098 | return ret; | ||
4099 | } | ||
4100 | static struct queue_sysfs_entry queue_requests_entry = { | 4084 | static struct queue_sysfs_entry queue_requests_entry = { |
4101 | .attr = {.name = "nr_requests", .mode = S_IRUGO | S_IWUSR }, | 4085 | .attr = {.name = "nr_requests", .mode = S_IRUGO | S_IWUSR }, |
4102 | .show = queue_requests_show, | 4086 | .show = queue_requests_show, |
@@ -4120,12 +4104,6 @@ static struct queue_sysfs_entry queue_max_hw_sectors_entry = { | |||
4120 | .show = queue_max_hw_sectors_show, | 4104 | .show = queue_max_hw_sectors_show, |
4121 | }; | 4105 | }; |
4122 | 4106 | ||
4123 | static struct queue_sysfs_entry queue_max_segments_entry = { | ||
4124 | .attr = {.name = "max_segments", .mode = S_IRUGO | S_IWUSR }, | ||
4125 | .show = queue_max_segments_show, | ||
4126 | .store = queue_max_segments_store, | ||
4127 | }; | ||
4128 | |||
4129 | static struct queue_sysfs_entry queue_iosched_entry = { | 4107 | static struct queue_sysfs_entry queue_iosched_entry = { |
4130 | .attr = {.name = "scheduler", .mode = S_IRUGO | S_IWUSR }, | 4108 | .attr = {.name = "scheduler", .mode = S_IRUGO | S_IWUSR }, |
4131 | .show = elv_iosched_show, | 4109 | .show = elv_iosched_show, |
@@ -4137,7 +4115,6 @@ static struct attribute *default_attrs[] = { | |||
4137 | &queue_ra_entry.attr, | 4115 | &queue_ra_entry.attr, |
4138 | &queue_max_hw_sectors_entry.attr, | 4116 | &queue_max_hw_sectors_entry.attr, |
4139 | &queue_max_sectors_entry.attr, | 4117 | &queue_max_sectors_entry.attr, |
4140 | &queue_max_segments_entry.attr, | ||
4141 | &queue_iosched_entry.attr, | 4118 | &queue_iosched_entry.attr, |
4142 | NULL, | 4119 | NULL, |
4143 | }; | 4120 | }; |