diff options
| -rw-r--r-- | mm/backing-dev.c | 28 |
1 files changed, 11 insertions, 17 deletions
diff --git a/mm/backing-dev.c b/mm/backing-dev.c index 4e9ed2a8521f..327e36d1d623 100644 --- a/mm/backing-dev.c +++ b/mm/backing-dev.c | |||
| @@ -331,8 +331,8 @@ static int bdi_forker_thread(void *ptr) | |||
| 331 | set_user_nice(current, 0); | 331 | set_user_nice(current, 0); |
| 332 | 332 | ||
| 333 | for (;;) { | 333 | for (;;) { |
| 334 | struct task_struct *task; | ||
| 334 | struct backing_dev_info *bdi, *tmp; | 335 | struct backing_dev_info *bdi, *tmp; |
| 335 | struct bdi_writeback *wb; | ||
| 336 | 336 | ||
| 337 | /* | 337 | /* |
| 338 | * Temporary measure, we want to make sure we don't see | 338 | * Temporary measure, we want to make sure we don't see |
| @@ -383,29 +383,23 @@ static int bdi_forker_thread(void *ptr) | |||
| 383 | list_del_init(&bdi->bdi_list); | 383 | list_del_init(&bdi->bdi_list); |
| 384 | spin_unlock_bh(&bdi_lock); | 384 | spin_unlock_bh(&bdi_lock); |
| 385 | 385 | ||
| 386 | wb = &bdi->wb; | 386 | task = kthread_run(bdi_writeback_thread, &bdi->wb, "flush-%s", |
| 387 | wb->task = kthread_run(bdi_writeback_thread, wb, "flush-%s", | 387 | dev_name(bdi->dev)); |
| 388 | dev_name(bdi->dev)); | 388 | if (IS_ERR(task)) { |
| 389 | /* | ||
| 390 | * If thread creation fails, then readd the bdi to | ||
| 391 | * the pending list and force writeout of the bdi | ||
| 392 | * from this forker thread. That will free some memory | ||
| 393 | * and we can try again. | ||
| 394 | */ | ||
| 395 | if (IS_ERR(wb->task)) { | ||
| 396 | wb->task = NULL; | ||
| 397 | |||
| 398 | /* | 389 | /* |
| 399 | * Add this 'bdi' to the back, so we get | 390 | * If thread creation fails, then readd the bdi back to |
| 400 | * a chance to flush other bdi's to free | 391 | * the list and force writeout of the bdi from this |
| 401 | * memory. | 392 | * forker thread. That will free some memory and we can |
| 393 | * try again. Add it to the tail so we get a chance to | ||
| 394 | * flush other bdi's to free memory. | ||
| 402 | */ | 395 | */ |
| 403 | spin_lock_bh(&bdi_lock); | 396 | spin_lock_bh(&bdi_lock); |
| 404 | list_add_tail(&bdi->bdi_list, &bdi_pending_list); | 397 | list_add_tail(&bdi->bdi_list, &bdi_pending_list); |
| 405 | spin_unlock_bh(&bdi_lock); | 398 | spin_unlock_bh(&bdi_lock); |
| 406 | 399 | ||
| 407 | bdi_flush_io(bdi); | 400 | bdi_flush_io(bdi); |
| 408 | } | 401 | } else |
| 402 | bdi->wb.task = task; | ||
| 409 | } | 403 | } |
| 410 | 404 | ||
| 411 | return 0; | 405 | return 0; |
