提交 d6dbf42e 编写于 作者: M Mike Miller 提交者: Linus Torvalds

[PATCH] cciss: busy_initializing bug fix

This patch fixes the problem Bjorn reported.  The busy_initializing flag
should have cleared before going into the for loop.
Signed-off-by: NMike Miller <mike.miller@hp.com>
Signed-off-by: NAndrew Morton <akpm@osdl.org>
Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
上级 3c2822cc
...@@ -483,9 +483,6 @@ static int cciss_open(struct inode *inode, struct file *filep) ...@@ -483,9 +483,6 @@ static int cciss_open(struct inode *inode, struct file *filep)
printk(KERN_DEBUG "cciss_open %s\n", inode->i_bdev->bd_disk->disk_name); printk(KERN_DEBUG "cciss_open %s\n", inode->i_bdev->bd_disk->disk_name);
#endif /* CCISS_DEBUG */ #endif /* CCISS_DEBUG */
if (host->busy_initializing)
return -EBUSY;
if (host->busy_initializing || drv->busy_configuring) if (host->busy_initializing || drv->busy_configuring)
return -EBUSY; return -EBUSY;
/* /*
...@@ -2991,6 +2988,7 @@ static int __devinit cciss_init_one(struct pci_dev *pdev, ...@@ -2991,6 +2988,7 @@ static int __devinit cciss_init_one(struct pci_dev *pdev,
hba[i]->access.set_intr_mask(hba[i], CCISS_INTR_ON); hba[i]->access.set_intr_mask(hba[i], CCISS_INTR_ON);
cciss_procinit(i); cciss_procinit(i);
hba[i]->busy_initializing = 0;
for(j=0; j < NWD; j++) { /* mfm */ for(j=0; j < NWD; j++) { /* mfm */
drive_info_struct *drv = &(hba[i]->drv[j]); drive_info_struct *drv = &(hba[i]->drv[j]);
...@@ -3033,7 +3031,6 @@ static int __devinit cciss_init_one(struct pci_dev *pdev, ...@@ -3033,7 +3031,6 @@ static int __devinit cciss_init_one(struct pci_dev *pdev,
add_disk(disk); add_disk(disk);
} }
hba[i]->busy_initializing = 0;
return(1); return(1);
clean4: clean4:
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册