mirror of
				https://git.proxmox.com/git/mirror_zfs.git
				synced 2025-10-25 01:14:59 +03:00 
			
		
		
		
	zio_dva_throttle_done() should allow zinjected ZIO
If fault injection is enabled, the ZIO_FLAG_IO_RETRY could be set by zio_handle_device_injection() to generate the FMA events and update stats. Hence, ignore the flag and process such zios. A better fix would be to add another flag in the zio_t to indicate that the zio is failed because of a zinject rule. However, considering the fact that we do this in debug bits, we could do with the crude check using the global flag zio_injection_enabled which is set to 1 when zinject records are added. Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Signed-off-by: Sanjeev Bagewadi <sanjeev.bagewadi@gmail.com> Closes #6383 Closes #6384
This commit is contained in:
		
							parent
							
								
									b58237e769
								
							
						
					
					
						commit
						21df134f4c
					
				| @ -3661,7 +3661,8 @@ zio_dva_throttle_done(zio_t *zio) | |||||||
| 	ASSERT3U(zio->io_child_type, ==, ZIO_CHILD_VDEV); | 	ASSERT3U(zio->io_child_type, ==, ZIO_CHILD_VDEV); | ||||||
| 	ASSERT(vd != NULL); | 	ASSERT(vd != NULL); | ||||||
| 	ASSERT3P(vd, ==, vd->vdev_top); | 	ASSERT3P(vd, ==, vd->vdev_top); | ||||||
| 	ASSERT(!(zio->io_flags & (ZIO_FLAG_IO_REPAIR | ZIO_FLAG_IO_RETRY))); | 	ASSERT(zio_injection_enabled || !(zio->io_flags & ZIO_FLAG_IO_RETRY)); | ||||||
|  | 	ASSERT(!(zio->io_flags & ZIO_FLAG_IO_REPAIR)); | ||||||
| 	ASSERT(zio->io_flags & ZIO_FLAG_IO_ALLOCATING); | 	ASSERT(zio->io_flags & ZIO_FLAG_IO_ALLOCATING); | ||||||
| 	ASSERT(!(lio->io_flags & ZIO_FLAG_IO_REWRITE)); | 	ASSERT(!(lio->io_flags & ZIO_FLAG_IO_REWRITE)); | ||||||
| 	ASSERT(!(lio->io_orig_flags & ZIO_FLAG_NODATA)); | 	ASSERT(!(lio->io_orig_flags & ZIO_FLAG_NODATA)); | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 sanjeevbagewadi
						sanjeevbagewadi