aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2009-12-15 12:11:28 -0500
committerLinus Torvalds <torvalds@linux-foundation.org>2009-12-15 12:11:28 -0500
commit51b736b85155a56543fda8aeca5f8592795d7983 (patch)
tree937c8be978bf66084128cd62fca3e94fa50c3f36 /drivers
parenta8aa1ebdf880ebe7b5738ccebf67e18d62cbdc0b (diff)
parent66ae291978177d5c012015f12b8fbc76dc7d0965 (diff)
Merge branch 'for-2.6.33' of git://git.kernel.dk/linux-2.6-block
* 'for-2.6.33' of git://git.kernel.dk/linux-2.6-block: cfq: set workload as expired if it doesn't have any slice left Fix a CFQ crash in "for-2.6.33" branch of block tree cfq: Remove wait_request flag when idle time is being deleted cfq-iosched: commenting non-obvious initialization cfq-iosched: Take care of corner cases of group losing share due to deletion cfq-iosched: Get rid of cfqq wait_busy_done flag cfq: Optimization for close cooperating queue searching block,xd: Delay allocation of DMA buffers until device is known drbd: Following the hmac change to SHASH (see linux commit 8bd1209cfff) cfq-iosched: reduce write depth only if sync was delayed
Diffstat (limited to 'drivers')
-rw-r--r--drivers/block/drbd/drbd_nl.c3
-rw-r--r--drivers/block/xd.c30
2 files changed, 20 insertions, 13 deletions
diff --git a/drivers/block/drbd/drbd_nl.c b/drivers/block/drbd/drbd_nl.c
index 436a090b532b..4e0726aa53b0 100644
--- a/drivers/block/drbd/drbd_nl.c
+++ b/drivers/block/drbd/drbd_nl.c
@@ -1271,8 +1271,7 @@ static int drbd_nl_net_conf(struct drbd_conf *mdev, struct drbd_nl_cfg_req *nlp,
1271 goto fail; 1271 goto fail;
1272 } 1272 }
1273 1273
1274 if (crypto_tfm_alg_type(crypto_hash_tfm(tfm)) 1274 if (crypto_tfm_alg_type(crypto_hash_tfm(tfm)) != CRYPTO_ALG_TYPE_SHASH) {
1275 != CRYPTO_ALG_TYPE_HASH) {
1276 retcode = ERR_AUTH_ALG_ND; 1275 retcode = ERR_AUTH_ALG_ND;
1277 goto fail; 1276 goto fail;
1278 } 1277 }
diff --git a/drivers/block/xd.c b/drivers/block/xd.c
index 0877d3628fda..d1fd032e7514 100644
--- a/drivers/block/xd.c
+++ b/drivers/block/xd.c
@@ -169,13 +169,6 @@ static int __init xd_init(void)
169 169
170 init_timer (&xd_watchdog_int); xd_watchdog_int.function = xd_watchdog; 170 init_timer (&xd_watchdog_int); xd_watchdog_int.function = xd_watchdog;
171 171
172 if (!xd_dma_buffer)
173 xd_dma_buffer = (char *)xd_dma_mem_alloc(xd_maxsectors * 0x200);
174 if (!xd_dma_buffer) {
175 printk(KERN_ERR "xd: Out of memory.\n");
176 return -ENOMEM;
177 }
178
179 err = -EBUSY; 172 err = -EBUSY;
180 if (register_blkdev(XT_DISK_MAJOR, "xd")) 173 if (register_blkdev(XT_DISK_MAJOR, "xd"))
181 goto out1; 174 goto out1;
@@ -202,6 +195,19 @@ static int __init xd_init(void)
202 xd_drives,xd_drives == 1 ? "" : "s",xd_irq,xd_dma); 195 xd_drives,xd_drives == 1 ? "" : "s",xd_irq,xd_dma);
203 } 196 }
204 197
198 /*
199 * With the drive detected, xd_maxsectors should now be known.
200 * If xd_maxsectors is 0, nothing was detected and we fall through
201 * to return -ENODEV
202 */
203 if (!xd_dma_buffer && xd_maxsectors) {
204 xd_dma_buffer = (char *)xd_dma_mem_alloc(xd_maxsectors * 0x200);
205 if (!xd_dma_buffer) {
206 printk(KERN_ERR "xd: Out of memory.\n");
207 goto out3;
208 }
209 }
210
205 err = -ENODEV; 211 err = -ENODEV;
206 if (!xd_drives) 212 if (!xd_drives)
207 goto out3; 213 goto out3;
@@ -249,15 +255,17 @@ out4:
249 for (i = 0; i < xd_drives; i++) 255 for (i = 0; i < xd_drives; i++)
250 put_disk(xd_gendisk[i]); 256 put_disk(xd_gendisk[i]);
251out3: 257out3:
252 release_region(xd_iobase,4); 258 if (xd_maxsectors)
259 release_region(xd_iobase,4);
260
261 if (xd_dma_buffer)
262 xd_dma_mem_free((unsigned long)xd_dma_buffer,
263 xd_maxsectors * 0x200);
253out2: 264out2:
254 blk_cleanup_queue(xd_queue); 265 blk_cleanup_queue(xd_queue);
255out1a: 266out1a:
256 unregister_blkdev(XT_DISK_MAJOR, "xd"); 267 unregister_blkdev(XT_DISK_MAJOR, "xd");
257out1: 268out1:
258 if (xd_dma_buffer)
259 xd_dma_mem_free((unsigned long)xd_dma_buffer,
260 xd_maxsectors * 0x200);
261 return err; 269 return err;
262Enomem: 270Enomem:
263 err = -ENOMEM; 271 err = -ENOMEM;