diff options
author | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2022-02-25 19:36:10 +0100 |
---|---|---|
committer | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2022-02-25 19:36:29 +0100 |
commit | d0a59e67fedf760a02109f5c18281241c6caa654 (patch) | |
tree | 3a5f8466eeb3529da9cabdff42aa26adcaeebd02 /fatfs | |
parent | ffdd90522aacaf19914c673f15e50f52137ada75 (diff) | |
download | hurd-d0a59e67fedf760a02109f5c18281241c6caa654.tar.gz hurd-d0a59e67fedf760a02109f5c18281241c6caa654.tar.bz2 hurd-d0a59e67fedf760a02109f5c18281241c6caa654.zip |
Fix store_read calls
store_read takes a look at the size to determine whether to fill the
provided buffer or not. Even if providing a null buffer we should set
the size to 0.
* defpager/defpager.c (pager_read_page): Initialize nread to 0.
* storeio/dev.c (buffered_rw): Initialize amount to 0.
* fatfs/fat.c (fat_read_sblock): Initialize read to the size of the boot
sector. Reuse it as such.
Diffstat (limited to 'fatfs')
-rw-r--r-- | fatfs/fat.c | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/fatfs/fat.c b/fatfs/fat.c index e191cfc4..f31ce115 100644 --- a/fatfs/fat.c +++ b/fatfs/fat.c @@ -69,11 +69,10 @@ void fat_read_sblock (void) { error_t err; - size_t read; + size_t read = sizeof(struct boot_sector); - sblock = malloc (sizeof (struct boot_sector)); - err = store_read (store, 0, sizeof (struct boot_sector), - (void **) &sblock, &read); + sblock = malloc (read); + err = store_read (store, 0, read, (void **) &sblock, &read); if (err) error (1, err, "Could not read superblock"); |