On 5/18/20 5:53 PM, Guoqing Jiang wrote: > Got below error when run "make everything". > > restripe.c: In function ‘test_stripes’: > restripe.c:870:4: error: ignoring return value of ‘read’, declared with attribute warn_unused_result [-Werror=unused-result] > read(source[i], stripes[i], chunk_size); > ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ > > Fix it by check the return value of ‘read’, and free memory > in the failure case. > > And check the return value of lseek as well per Jes's comment. > > Signed-off-by: Guoqing Jiang <guoqing.jiang@xxxxxxxxxxxxxxx> > --- > restripe.c | 12 ++++++++++-- > 1 file changed, 10 insertions(+), 2 deletions(-) > > diff --git a/restripe.c b/restripe.c > index 31b07e8..86e1d00 100644 > --- a/restripe.c > +++ b/restripe.c > @@ -866,8 +866,16 @@ int test_stripes(int *source, unsigned long long *offsets, > int disk; > > for (i = 0 ; i < raid_disks ; i++) { > - lseek64(source[i], offsets[i]+start, 0); > - read(source[i], stripes[i], chunk_size); > + if ((lseek64(source[i], offsets[i]+start, 0) < 0) || > + (read(source[i], stripes[i], chunk_size) != > + chunk_size)) { > + free(q); > + free(p); > + free(blocks); > + free(stripes); > + free(stripe_buf); > + return -1; > + } > } > for (i = 0 ; i < data_disks ; i++) { > int disk = geo_map(i, start/chunk_size, raid_disks, > This is not the prettiest solution, would have been nicer to introduce a cleanup handler at the end and just jumping to it. That said, I have applied it since restripe.c is pretty ugly across the board. Thanks, Jes