From: Matthew Wilcox <matthew@wil.cx>
To: linux-scsi@vger.kernel.org
Subject: [PATCH] scsi_scan: Cope with kthread_run failing
Date: Mon, 20 Aug 2007 09:20:35 -0600 [thread overview]
Message-ID: <20070820152035.GH30019@parisc-linux.org> (raw)
In-Reply-To: <118762312894-git-send-email-matthew@wil.cx>
Oops. I fail to drive git-send-email properly again.
James, when you're committing this, please use the
Subject: [PATCH] scsi_scan: Cope with kthread_run failing
On Mon, Aug 20, 2007 at 09:18:48AM -0600, Matthew Wilcox wrote:
> If kthread_run failed, we would fail to scan the host, and leak the
> allocated async_scan_data. Since using a separate thread is just an
> optimisation, do the scan synchronously if we fail to spawn a thread.
>
> Signed-off-by: Matthew Wilcox <matthew@wil.cx>
>
> diff --git a/drivers/scsi/scsi_scan.c b/drivers/scsi/scsi_scan.c
> index 309b224..a001ca1 100644
> --- a/drivers/scsi/scsi_scan.c
> +++ b/drivers/scsi/scsi_scan.c
> @@ -1799,6 +1799,7 @@ static int do_scan_async(void *_data)
> **/
> void scsi_scan_host(struct Scsi_Host *shost)
> {
> + struct task_struct *p;
> struct async_scan_data *data;
>
> if (strncmp(scsi_scan_type, "none", 4) == 0)
> @@ -1810,7 +1811,9 @@ void scsi_scan_host(struct Scsi_Host *shost)
> return;
> }
>
> - kthread_run(do_scan_async, data, "scsi_scan_%d", shost->host_no);
> + p = kthread_run(do_scan_async, data, "scsi_scan_%d", shost->host_no);
> + if (IS_ERR(p))
> + do_scan_async(data);
> }
> EXPORT_SYMBOL(scsi_scan_host);
>
> -
> To unsubscribe from this list: send the line "unsubscribe linux-scsi" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
--
"Bill, look, we understand that you're interested in selling us this
operating system, but compare it to ours. We can't possibly take such
a retrograde step."
next prev parent reply other threads:[~2007-08-20 15:20 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2007-08-20 15:18 (unknown), Matthew Wilcox
2007-08-20 15:20 ` Matthew Wilcox [this message]
2007-09-23 14:17 ` [PATCH] scsi_scan: Cope with kthread_run failing James Bottomley
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20070820152035.GH30019@parisc-linux.org \
--to=matthew@wil.cx \
--cc=linux-scsi@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.