qemu-devel
[Top][All Lists]
Advanced

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

Re: [PATCH-for-6.1 v2] block/export/fuse.c: fix musl build


From: Denis V. Lunev
Subject: Re: [PATCH-for-6.1 v2] block/export/fuse.c: fix musl build
Date: Mon, 9 Aug 2021 14:05:57 +0300
User-agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.11.0

On 8/9/21 1:27 PM, Philippe Mathieu-Daudé wrote:
> On 8/9/21 11:51 AM, Fabrice Fontaine wrote:
>> Fix the following build failure on musl raised since version 6.0.0 and
>> https://gitlab.com/qemu-project/qemu/-/commit/4ca37a96a75aafe7a37ba51ab1912b09b7190a6b
>> because musl does not define FALLOC_FL_ZERO_RANGE:
>>
>> ../block/export/fuse.c: In function 'fuse_fallocate':
>> ../block/export/fuse.c:563:23: error: 'FALLOC_FL_ZERO_RANGE' undeclared 
>> (first use in this function)
>>   563 |     } else if (mode & FALLOC_FL_ZERO_RANGE) {
>>       |                       ^~~~~~~~~~~~~~~~~~~~
>>
>> Fixes:
>>  - 
>> http://autobuild.buildroot.org/results/b96e3d364fd1f8bbfb18904a742e73327d308f64
>>
>> Signed-off-by: Fabrice Fontaine <fontaine.fabrice@gmail.com>
>> ---
>> Changes v1 -> v2 (after review of Philippe Mathieu-Daudé):
>>  - Use CONFIG_FALLOCATE_ZERO_RANGE and make safer #ifdef'ry
>>
>>  block/export/fuse.c | 8 ++++++--
>>  1 file changed, 6 insertions(+), 2 deletions(-)
>>
>> diff --git a/block/export/fuse.c b/block/export/fuse.c
>> index ada9e263eb..fc7b07d2b5 100644
>> --- a/block/export/fuse.c
>> +++ b/block/export/fuse.c
>> @@ -635,7 +635,9 @@ static void fuse_fallocate(fuse_req_t req, fuse_ino_t 
>> inode, int mode,
>>              offset += size;
>>              length -= size;
>>          } while (ret == 0 && length > 0);
>> -    } else if (mode & FALLOC_FL_ZERO_RANGE) {
>> +    }
>> +#ifdef CONFIG_FALLOCATE_ZERO_RANGE
>> +    else if (mode & FALLOC_FL_ZERO_RANGE) {
>>          if (!(mode & FALLOC_FL_KEEP_SIZE) && offset + length > blk_len) {
>>              /* No need for zeroes, we are going to write them ourselves */
>>              ret = fuse_do_truncate(exp, offset + length, false,
>> @@ -654,7 +656,9 @@ static void fuse_fallocate(fuse_req_t req, fuse_ino_t 
>> inode, int mode,
>>              offset += size;
>>              length -= size;
>>          } while (ret == 0 && length > 0);
>> -    } else if (!mode) {
>> +    }
>> +#endif /* CONFIG_FALLOCATE_ZERO_RANGE */
>> +    else if (!mode) {
>>          /* We can only fallocate at the EOF with a truncate */
>>          if (offset < blk_len) {
>>              fuse_reply_err(req, EOPNOTSUPP);
>>
> Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
>
Reviewed-by: Denis V. Lunev <den@openvz.org>



reply via email to

[Prev in Thread] Current Thread [Next in Thread]