Re: [PATCH] zbd: fix zonemode=zbd with NDEBUG

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 2020/04/11 4:06, Alexey Dobriyan wrote:
> assert() with NDEBUG doesn't evaluate argument.
> 
> Signed-off-by: Alexey Dobriyan (SK hynix) <adobriyan@xxxxxxxxx>
> ---
> 
>  zbd.c |    4 +++-
>  1 file changed, 3 insertions(+), 1 deletion(-)
> 
> --- a/zbd.c
> +++ b/zbd.c
> @@ -1220,6 +1220,7 @@ static void zbd_put_io(const struct io_u *io_u)
>  	struct zoned_block_device_info *zbd_info = f->zbd_info;
>  	struct fio_zone_info *z;
>  	uint32_t zone_idx;
> +	int ret;
>  
>  	if (!zbd_info)
>  		return;
> @@ -1235,7 +1236,8 @@ static void zbd_put_io(const struct io_u *io_u)
>  	       "%s: terminate I/O (%lld, %llu) for zone %u\n",
>  	       f->file_name, io_u->offset, io_u->buflen, zone_idx);
>  
> -	assert(pthread_mutex_unlock(&z->mutex) == 0);
> +	ret = pthread_mutex_unlock(&z->mutex);
> +	assert(ret == 0);
>  	zbd_check_swd(f);
>  }
>  
> 

Looks good. And that may actually be the reason for the fio hang reported on
github issues. Will ping the issue submitter to try this.

Reviewed-by: Damien Le Moal <damien.lemoal@xxxxxxx>

-- 
Damien Le Moal
Western Digital Research




[Index of Archives]     [Linux Kernel]     [Linux SCSI]     [Linux IDE]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux SCSI]

  Powered by Linux