"Vladimir 'phcoder' Serbinenko" <phco...@gmail.com> writes:

> Reviewed-by: phco...@gmail.com
>

Thanks. Can this be picked up, please?

Rasmus


> Le jeu. 29 août 2024, 14:07, Rasmus Villemoes via Grub-devel <
> grub-devel@gnu.org> a écrit :
>
>> Unlike files accessed via a normal file system, the file->read_hook is
>> not honoured when using blocklist notation.
>>
>> This means that when trying to use a dedicated, 1KiB, raw partition
>> for the environment block and hence does something like
>>
>>   save_env --file=(hd0,gpt9)0+2 X Y Z
>>
>> this fails with "sparse file not allowed", which is rather unexpected,
>> as I've explicitly said exactly which blocks should be used. Adding a
>> little debugging reveals that grub_file_size (file) is 1024 as
>> expected, but total_length is 0, simply because the callback was never
>> invoked, so blocklists is an empty list.
>>
>> Fix that by honouring the ->read_hook set by the caller, also when a
>> "file" is specified with blocklist notation.
>>
>> Signed-off-by: Rasmus Villemoes <rasmus.villem...@prevas.dk>
>> ---
>> I've tried to keep the patch at a minimum, but since the
>> disk->read_hook needs to be cleared on all return paths, it seemed a
>> little easier to drop the 'return -1' and instead set ret and break.
>>
>> For readability, it seemed best to introduce the disk local variable to
>> hold file->device->disk, and then there's no point in not also using
>> that in the grub_disk_read() call.
>>
>>  grub-core/kern/fs.c | 11 +++++++++--
>>  1 file changed, 9 insertions(+), 2 deletions(-)
>>
>> diff --git a/grub-core/kern/fs.c b/grub-core/kern/fs.c
>> index 7ad0aaf4e..79f1a797c 100644
>> --- a/grub-core/kern/fs.c
>> +++ b/grub-core/kern/fs.c
>> @@ -215,12 +215,15 @@ grub_fs_blocklist_read (grub_file_t file, char *buf,
>> grub_size_t len)
>>    grub_disk_addr_t sector;
>>    grub_off_t offset;
>>    grub_ssize_t ret = 0;
>> +  grub_disk_t disk = file->device->disk;
>>
>>    if (len > file->size - file->offset)
>>      len = file->size - file->offset;
>>
>>    sector = (file->offset >> GRUB_DISK_SECTOR_BITS);
>>    offset = (file->offset & (GRUB_DISK_SECTOR_SIZE - 1));
>> +  disk->read_hook = file->read_hook;
>> +  disk->read_hook_data = file->read_hook_data;
>>    for (p = file->data; p->length && len > 0; p++)
>>      {
>>        if (sector < p->length)
>> @@ -232,9 +235,12 @@ grub_fs_blocklist_read (grub_file_t file, char *buf,
>> grub_size_t len)
>>                >> GRUB_DISK_SECTOR_BITS) > p->length - sector)
>>             size = ((p->length - sector) << GRUB_DISK_SECTOR_BITS) -
>> offset;
>>
>> -         if (grub_disk_read (file->device->disk, p->offset + sector,
>> offset,
>> +         if (grub_disk_read (disk, p->offset + sector, offset,
>>                               size, buf) != GRUB_ERR_NONE)
>> -           return -1;
>> +           {
>> +             ret = -1;
>> +             break;
>> +           }
>>
>>           ret += size;
>>           len -= size;
>> @@ -244,6 +250,7 @@ grub_fs_blocklist_read (grub_file_t file, char *buf,
>> grub_size_t len)
>>        else
>>         sector -= p->length;
>>      }
>> +  disk->read_hook = 0;
>>
>>    return ret;
>>  }
>> --
>> 2.46.0
>>
>>
>> _______________________________________________
>> Grub-devel mailing list
>> Grub-devel@gnu.org
>> https://lists.gnu.org/mailman/listinfo/grub-devel
>>

_______________________________________________
Grub-devel mailing list
Grub-devel@gnu.org
https://lists.gnu.org/mailman/listinfo/grub-devel

Reply via email to