diff options
Diffstat (limited to 'drivers/md/dm-crypt.c')
| -rw-r--r-- | drivers/md/dm-crypt.c | 26 | 
1 files changed, 11 insertions, 15 deletions
| diff --git a/drivers/md/dm-crypt.c b/drivers/md/dm-crypt.c index 874295757caa..a2768835d394 100644 --- a/drivers/md/dm-crypt.c +++ b/drivers/md/dm-crypt.c @@ -113,8 +113,7 @@ struct iv_tcw_private {   * and encrypts / decrypts at the same time.   */  enum flags { DM_CRYPT_SUSPENDED, DM_CRYPT_KEY_VALID, -	     DM_CRYPT_SAME_CPU, DM_CRYPT_NO_OFFLOAD, -	     DM_CRYPT_EXIT_THREAD}; +	     DM_CRYPT_SAME_CPU, DM_CRYPT_NO_OFFLOAD };  /*   * The fields in here must be read only after initialization. @@ -1136,7 +1135,7 @@ static void clone_init(struct dm_crypt_io *io, struct bio *clone)  	clone->bi_private = io;  	clone->bi_end_io  = crypt_endio;  	clone->bi_bdev    = cc->dev->bdev; -	bio_set_op_attrs(clone, bio_op(io->base_bio), io->base_bio->bi_opf); +	bio_set_op_attrs(clone, bio_op(io->base_bio), bio_flags(io->base_bio));  }  static int kcryptd_io_read(struct dm_crypt_io *io, gfp_t gfp) @@ -1207,18 +1206,20 @@ continue_locked:  		if (!RB_EMPTY_ROOT(&cc->write_tree))  			goto pop_from_list; -		if (unlikely(test_bit(DM_CRYPT_EXIT_THREAD, &cc->flags))) { -			spin_unlock_irq(&cc->write_thread_wait.lock); -			break; -		} - -		__set_current_state(TASK_INTERRUPTIBLE); +		set_current_state(TASK_INTERRUPTIBLE);  		__add_wait_queue(&cc->write_thread_wait, &wait);  		spin_unlock_irq(&cc->write_thread_wait.lock); +		if (unlikely(kthread_should_stop())) { +			set_task_state(current, TASK_RUNNING); +			remove_wait_queue(&cc->write_thread_wait, &wait); +			break; +		} +  		schedule(); +		set_task_state(current, TASK_RUNNING);  		spin_lock_irq(&cc->write_thread_wait.lock);  		__remove_wait_queue(&cc->write_thread_wait, &wait);  		goto continue_locked; @@ -1533,13 +1534,8 @@ static void crypt_dtr(struct dm_target *ti)  	if (!cc)  		return; -	if (cc->write_thread) { -		spin_lock_irq(&cc->write_thread_wait.lock); -		set_bit(DM_CRYPT_EXIT_THREAD, &cc->flags); -		wake_up_locked(&cc->write_thread_wait); -		spin_unlock_irq(&cc->write_thread_wait.lock); +	if (cc->write_thread)  		kthread_stop(cc->write_thread); -	}  	if (cc->io_queue)  		destroy_workqueue(cc->io_queue); |