aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/mtd/nand
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/mtd/nand')
-rw-r--r--drivers/mtd/nand/nand_base.c7
-rw-r--r--drivers/mtd/nand/ndfc.c6
2 files changed, 9 insertions, 4 deletions
diff --git a/drivers/mtd/nand/nand_base.c b/drivers/mtd/nand/nand_base.c
index 5690de223c11..61b2363f9324 100644
--- a/drivers/mtd/nand/nand_base.c
+++ b/drivers/mtd/nand/nand_base.c
@@ -2125,6 +2125,9 @@ static int nand_allocate_kmem(struct mtd_info *mtd, struct nand_chip *chip)
2125 GFP_KERNEL); 2125 GFP_KERNEL);
2126 if (!chip->controller) 2126 if (!chip->controller)
2127 goto outerr; 2127 goto outerr;
2128
2129 spin_lock_init(&chip->controller->lock);
2130 init_waitqueue_head(&chip->controller->wq);
2128 chip->options |= NAND_CONTROLLER_ALLOC; 2131 chip->options |= NAND_CONTROLLER_ALLOC;
2129 } 2132 }
2130 return 0; 2133 return 0;
@@ -2451,10 +2454,8 @@ int nand_scan(struct mtd_info *mtd, int maxchips)
2451 BUG(); 2454 BUG();
2452 } 2455 }
2453 2456
2454 /* Initialize state, waitqueue and spinlock */ 2457 /* Initialize state */
2455 chip->state = FL_READY; 2458 chip->state = FL_READY;
2456 init_waitqueue_head(&chip->controller->wq);
2457 spin_lock_init(&chip->controller->lock);
2458 2459
2459 /* De-select the device */ 2460 /* De-select the device */
2460 chip->select_chip(mtd, -1); 2461 chip->select_chip(mtd, -1);
diff --git a/drivers/mtd/nand/ndfc.c b/drivers/mtd/nand/ndfc.c
index 481541a683ca..4d70dd16cf5d 100644
--- a/drivers/mtd/nand/ndfc.c
+++ b/drivers/mtd/nand/ndfc.c
@@ -293,8 +293,12 @@ static struct platform_driver ndfc_nand_driver = {
293 293
294static int __init ndfc_nand_init(void) 294static int __init ndfc_nand_init(void)
295{ 295{
296 int ret = platform_driver_register(&ndfc_nand_driver); 296 int ret;
297 297
298 spin_lock_init(&ndfc_ctrl.ndfc_control.lock);
299 init_waitqueue_head(&ndfc_ctrl.ndfc_control.wq);
300
301 ret = platform_driver_register(&ndfc_nand_driver);
298 if (!ret) 302 if (!ret)
299 ret = platform_driver_register(&ndfc_chip_driver); 303 ret = platform_driver_register(&ndfc_chip_driver);
300 return ret; 304 return ret;