mirror of
				https://git.proxmox.com/git/mirror_zfs.git
				synced 2025-10-25 09:25:00 +03:00 
			
		
		
		
	Move final zvol_remove_minors to common code
This logic is not platform dependent and should reside in the common code. Reviewed-by: Igor Kozhukhov <igor@dilos.org> Reviewed-by: Jorgen Lundman <lundman@lundman.net> Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Signed-off-by: Matt Macy <mmacy@FreeBSD.org> Closes #9505
This commit is contained in:
		
							parent
							
								
									1952fe0e25
								
							
						
					
					
						commit
						c392c5aec0
					
				| @ -1092,16 +1092,6 @@ zvol_init(void) | |||||||
| void | void | ||||||
| zvol_fini(void) | zvol_fini(void) | ||||||
| { | { | ||||||
| 	zvol_remove_minors_impl(NULL); |  | ||||||
| 
 |  | ||||||
| 	/*
 |  | ||||||
| 	 * The call to "zvol_remove_minors_impl" may dispatch entries to |  | ||||||
| 	 * the system_taskq, but it doesn't wait for those entires to |  | ||||||
| 	 * complete before it returns. Thus, we must wait for all of the |  | ||||||
| 	 * removals to finish, before we can continue. |  | ||||||
| 	 */ |  | ||||||
| 	taskq_wait_outstanding(system_taskq, 0); |  | ||||||
| 
 |  | ||||||
| 	zvol_fini_impl(); | 	zvol_fini_impl(); | ||||||
| 	blk_unregister_region(MKDEV(zvol_major, 0), 1UL << MINORBITS); | 	blk_unregister_region(MKDEV(zvol_major, 0), 1UL << MINORBITS); | ||||||
| 	unregister_blkdev(zvol_major, ZVOL_DRIVER); | 	unregister_blkdev(zvol_major, ZVOL_DRIVER); | ||||||
|  | |||||||
| @ -1713,6 +1713,16 @@ zvol_init_impl(void) | |||||||
| void | void | ||||||
| zvol_fini_impl(void) | zvol_fini_impl(void) | ||||||
| { | { | ||||||
|  | 	zvol_remove_minors_impl(NULL); | ||||||
|  | 
 | ||||||
|  | 	/*
 | ||||||
|  | 	 * The call to "zvol_remove_minors_impl" may dispatch entries to | ||||||
|  | 	 * the system_taskq, but it doesn't wait for those entires to | ||||||
|  | 	 * complete before it returns. Thus, we must wait for all of the | ||||||
|  | 	 * removals to finish, before we can continue. | ||||||
|  | 	 */ | ||||||
|  | 	taskq_wait_outstanding(system_taskq, 0); | ||||||
|  | 
 | ||||||
| 	kmem_free(zvol_htable, ZVOL_HT_SIZE * sizeof (struct hlist_head)); | 	kmem_free(zvol_htable, ZVOL_HT_SIZE * sizeof (struct hlist_head)); | ||||||
| 	list_destroy(&zvol_state_list); | 	list_destroy(&zvol_state_list); | ||||||
| 	rw_destroy(&zvol_state_lock); | 	rw_destroy(&zvol_state_lock); | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Matthew Macy
						Matthew Macy