mirror of
https://github.com/followmsi/android_kernel_google_msm.git
synced 2024-11-06 23:17:41 +00:00
[SCSI] switch EH thread startup to the kthread API
Signed-off-by: James Bottomley <James.Bottomley@SteelEye.com>
This commit is contained in:
parent
32993523dc
commit
c5478def7a
3 changed files with 10 additions and 44 deletions
|
@ -24,6 +24,7 @@
|
||||||
#include <linux/module.h>
|
#include <linux/module.h>
|
||||||
#include <linux/blkdev.h>
|
#include <linux/blkdev.h>
|
||||||
#include <linux/kernel.h>
|
#include <linux/kernel.h>
|
||||||
|
#include <linux/kthread.h>
|
||||||
#include <linux/string.h>
|
#include <linux/string.h>
|
||||||
#include <linux/mm.h>
|
#include <linux/mm.h>
|
||||||
#include <linux/init.h>
|
#include <linux/init.h>
|
||||||
|
@ -225,15 +226,8 @@ static void scsi_host_dev_release(struct device *dev)
|
||||||
struct Scsi_Host *shost = dev_to_shost(dev);
|
struct Scsi_Host *shost = dev_to_shost(dev);
|
||||||
struct device *parent = dev->parent;
|
struct device *parent = dev->parent;
|
||||||
|
|
||||||
if (shost->ehandler) {
|
if (shost->ehandler)
|
||||||
DECLARE_COMPLETION(sem);
|
kthread_stop(shost->ehandler);
|
||||||
shost->eh_notify = &sem;
|
|
||||||
shost->eh_kill = 1;
|
|
||||||
up(shost->eh_wait);
|
|
||||||
wait_for_completion(&sem);
|
|
||||||
shost->eh_notify = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (shost->work_q)
|
if (shost->work_q)
|
||||||
destroy_workqueue(shost->work_q);
|
destroy_workqueue(shost->work_q);
|
||||||
|
|
||||||
|
@ -263,7 +257,6 @@ struct Scsi_Host *scsi_host_alloc(struct scsi_host_template *sht, int privsize)
|
||||||
{
|
{
|
||||||
struct Scsi_Host *shost;
|
struct Scsi_Host *shost;
|
||||||
int gfp_mask = GFP_KERNEL, rval;
|
int gfp_mask = GFP_KERNEL, rval;
|
||||||
DECLARE_COMPLETION(complete);
|
|
||||||
|
|
||||||
if (sht->unchecked_isa_dma && privsize)
|
if (sht->unchecked_isa_dma && privsize)
|
||||||
gfp_mask |= __GFP_DMA;
|
gfp_mask |= __GFP_DMA;
|
||||||
|
@ -369,12 +362,12 @@ struct Scsi_Host *scsi_host_alloc(struct scsi_host_template *sht, int privsize)
|
||||||
snprintf(shost->shost_classdev.class_id, BUS_ID_SIZE, "host%d",
|
snprintf(shost->shost_classdev.class_id, BUS_ID_SIZE, "host%d",
|
||||||
shost->host_no);
|
shost->host_no);
|
||||||
|
|
||||||
shost->eh_notify = &complete;
|
shost->ehandler = kthread_run(scsi_error_handler, shost,
|
||||||
rval = kernel_thread(scsi_error_handler, shost, 0);
|
"scsi_eh_%d", shost->host_no);
|
||||||
if (rval < 0)
|
if (IS_ERR(shost->ehandler)) {
|
||||||
|
rval = PTR_ERR(shost->ehandler);
|
||||||
goto fail_destroy_freelist;
|
goto fail_destroy_freelist;
|
||||||
wait_for_completion(&complete);
|
}
|
||||||
shost->eh_notify = NULL;
|
|
||||||
|
|
||||||
scsi_proc_hostdir_add(shost->hostt);
|
scsi_proc_hostdir_add(shost->hostt);
|
||||||
return shost;
|
return shost;
|
||||||
|
|
|
@ -20,6 +20,7 @@
|
||||||
#include <linux/string.h>
|
#include <linux/string.h>
|
||||||
#include <linux/slab.h>
|
#include <linux/slab.h>
|
||||||
#include <linux/kernel.h>
|
#include <linux/kernel.h>
|
||||||
|
#include <linux/kthread.h>
|
||||||
#include <linux/interrupt.h>
|
#include <linux/interrupt.h>
|
||||||
#include <linux/blkdev.h>
|
#include <linux/blkdev.h>
|
||||||
#include <linux/delay.h>
|
#include <linux/delay.h>
|
||||||
|
@ -1585,16 +1586,8 @@ int scsi_error_handler(void *data)
|
||||||
int rtn;
|
int rtn;
|
||||||
DECLARE_MUTEX_LOCKED(sem);
|
DECLARE_MUTEX_LOCKED(sem);
|
||||||
|
|
||||||
/*
|
|
||||||
* Flush resources
|
|
||||||
*/
|
|
||||||
|
|
||||||
daemonize("scsi_eh_%d", shost->host_no);
|
|
||||||
|
|
||||||
current->flags |= PF_NOFREEZE;
|
current->flags |= PF_NOFREEZE;
|
||||||
|
|
||||||
shost->eh_wait = &sem;
|
shost->eh_wait = &sem;
|
||||||
shost->ehandler = current;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Wake up the thread that created us.
|
* Wake up the thread that created us.
|
||||||
|
@ -1602,8 +1595,6 @@ int scsi_error_handler(void *data)
|
||||||
SCSI_LOG_ERROR_RECOVERY(3, printk("Wake up parent of"
|
SCSI_LOG_ERROR_RECOVERY(3, printk("Wake up parent of"
|
||||||
" scsi_eh_%d\n",shost->host_no));
|
" scsi_eh_%d\n",shost->host_no));
|
||||||
|
|
||||||
complete(shost->eh_notify);
|
|
||||||
|
|
||||||
while (1) {
|
while (1) {
|
||||||
/*
|
/*
|
||||||
* If we get a signal, it means we are supposed to go
|
* If we get a signal, it means we are supposed to go
|
||||||
|
@ -1624,7 +1615,7 @@ int scsi_error_handler(void *data)
|
||||||
* semaphores isn't unreasonable.
|
* semaphores isn't unreasonable.
|
||||||
*/
|
*/
|
||||||
down_interruptible(&sem);
|
down_interruptible(&sem);
|
||||||
if (shost->eh_kill)
|
if (kthread_should_stop())
|
||||||
break;
|
break;
|
||||||
|
|
||||||
SCSI_LOG_ERROR_RECOVERY(1, printk("Error handler"
|
SCSI_LOG_ERROR_RECOVERY(1, printk("Error handler"
|
||||||
|
@ -1663,22 +1654,6 @@ int scsi_error_handler(void *data)
|
||||||
* Make sure that nobody tries to wake us up again.
|
* Make sure that nobody tries to wake us up again.
|
||||||
*/
|
*/
|
||||||
shost->eh_wait = NULL;
|
shost->eh_wait = NULL;
|
||||||
|
|
||||||
/*
|
|
||||||
* Knock this down too. From this point on, the host is flying
|
|
||||||
* without a pilot. If this is because the module is being unloaded,
|
|
||||||
* that's fine. If the user sent a signal to this thing, we are
|
|
||||||
* potentially in real danger.
|
|
||||||
*/
|
|
||||||
shost->eh_active = 0;
|
|
||||||
shost->ehandler = NULL;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* If anyone is waiting for us to exit (i.e. someone trying to unload
|
|
||||||
* a driver), then wake up that process to let them know we are on
|
|
||||||
* the way out the door.
|
|
||||||
*/
|
|
||||||
complete_and_exit(shost->eh_notify, 0);
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -467,12 +467,10 @@ struct Scsi_Host {
|
||||||
struct task_struct * ehandler; /* Error recovery thread. */
|
struct task_struct * ehandler; /* Error recovery thread. */
|
||||||
struct semaphore * eh_wait; /* The error recovery thread waits
|
struct semaphore * eh_wait; /* The error recovery thread waits
|
||||||
on this. */
|
on this. */
|
||||||
struct completion * eh_notify; /* wait for eh to begin or end */
|
|
||||||
struct semaphore * eh_action; /* Wait for specific actions on the
|
struct semaphore * eh_action; /* Wait for specific actions on the
|
||||||
host. */
|
host. */
|
||||||
unsigned int eh_active:1; /* Indicates the eh thread is awake and active if
|
unsigned int eh_active:1; /* Indicates the eh thread is awake and active if
|
||||||
this is true. */
|
this is true. */
|
||||||
unsigned int eh_kill:1; /* set when killing the eh thread */
|
|
||||||
wait_queue_head_t host_wait;
|
wait_queue_head_t host_wait;
|
||||||
struct scsi_host_template *hostt;
|
struct scsi_host_template *hostt;
|
||||||
struct scsi_transport_template *transportt;
|
struct scsi_transport_template *transportt;
|
||||||
|
|
Loading…
Reference in a new issue