Lines Matching refs:f

67 static inline bool is_erasure(fec_handle *f, uint64_t offset,  in is_erasure()  argument
70 if (unlikely(offset >= f->data_size)) { in is_erasure()
80 return !verity_check_block(f, &f->verity.hash[n * SHA256_DIGEST_LENGTH], in is_erasure()
85 static inline bool is_zero(fec_handle *f, uint64_t offset) in is_zero() argument
87 verity_info *v = &f->verity; in is_zero()
89 if (!v->hash || unlikely(offset >= f->data_size)) { in is_zero()
105 static int __ecc_read(fec_handle *f, void *rs, uint8_t *dest, uint64_t offset, in __ecc_read() argument
109 ecc_info *e = &f->ecc; in __ecc_read()
120 check(!use_erasures || f->verity.hash); in __ecc_read()
134 if (likely(interleaved < e->start) && !is_zero(f, interleaved)) { in __ecc_read()
136 if (!raw_pread(f, bbuf, FEC_BLOCKSIZE, interleaved)) { in __ecc_read()
144 is_erasure(f, interleaved, bbuf)) { in __ecc_read()
161 if (!raw_pread(f, &ecc_data[i * FEC_RSM + e->rsn], e->roots, in __ecc_read()
181 } else if (!f->verity.hash) { in __ecc_read()
206 static int ecc_init(fec_handle *f, rs_unique_ptr& rs, in ecc_init() argument
209 check(f); in ecc_init()
211 rs.reset(init_rs_char(FEC_PARAMS(f->ecc.roots))); in ecc_init()
232 static ssize_t ecc_read(fec_handle *f, uint8_t *dest, size_t count, in ecc_read() argument
235 check(f); in ecc_read()
237 check(offset < f->data_size); in ecc_read()
238 check(offset + count <= f->data_size); in ecc_read()
246 if (ecc_init(f, rs, ecc_data) == -1) { in ecc_read()
258 if (__ecc_read(f, rs.get(), data, curr * FEC_BLOCKSIZE, false, in ecc_read()
283 static ssize_t verity_read(fec_handle *f, uint8_t *dest, size_t count, in verity_read() argument
286 check(f); in verity_read()
288 check(offset < f->data_size); in verity_read()
289 check(offset + count <= f->data_size); in verity_read()
290 check(f->verity.hash); in verity_read()
298 if (f->ecc.start && ecc_init(f, rs, ecc_data) == -1) { in verity_read()
307 uint64_t max_hash_block = (f->verity.hash_data_blocks * FEC_BLOCKSIZE - in verity_read()
313 uint8_t *hash = &f->verity.hash[curr * SHA256_DIGEST_LENGTH]; in verity_read()
316 bool expect_zeros = is_zero(f, curr_offset); in verity_read()
320 if (f->mode & O_RDONLY && expect_zeros) { in verity_read()
326 if (!raw_pread(f, data, FEC_BLOCKSIZE, curr_offset)) { in verity_read()
331 if (likely(verity_check_block(f, hash, data))) { in verity_read()
342 if (!f->ecc.start) { in verity_read()
354 if (__ecc_read(f, rs.get(), data, curr_offset, false, ecc_data.get(), in verity_read()
356 verity_check_block(f, hash, data)) { in verity_read()
361 if (__ecc_read(f, rs.get(), data, curr_offset, true, ecc_data.get(), in verity_read()
363 verity_check_block(f, hash, data)) { in verity_read()
377 if (f->mode & O_RDWR && in verity_read()
378 !raw_pwrite(f, data, FEC_BLOCKSIZE, curr_offset)) { in verity_read()
402 int fec_seek(struct fec_handle *f, int64_t offset, int whence) in fec_seek() argument
404 check(f); in fec_seek()
412 f->pos = offset; in fec_seek()
414 if (offset < 0 && f->pos < (uint64_t)-offset) { in fec_seek()
417 } else if (offset > 0 && (uint64_t)offset > UINT64_MAX - f->pos) { in fec_seek()
422 f->pos += offset; in fec_seek()
427 } else if ((uint64_t)-offset > f->size) { in fec_seek()
432 f->pos = f->size + offset; in fec_seek()
443 ssize_t fec_read(struct fec_handle *f, void *buf, size_t count) in fec_read() argument
445 ssize_t rc = fec_pread(f, buf, count, f->pos); in fec_read()
448 check(f->pos < UINT64_MAX - rc); in fec_read()
449 f->pos += rc; in fec_read()
470 bool raw_pread(fec_handle *f, void *buf, size_t count, uint64_t offset) in raw_pread() argument
472 check(f); in raw_pread()
479 ssize_t n = TEMP_FAILURE_RETRY(pread64(f->fd, p, remaining, offset)); in raw_pread()
494 bool raw_pwrite(fec_handle *f, const void *buf, size_t count, uint64_t offset) in raw_pwrite() argument
496 check(f); in raw_pwrite()
503 ssize_t n = TEMP_FAILURE_RETRY(pwrite64(f->fd, p, remaining, offset)); in raw_pwrite()
519 ssize_t fec_pread(struct fec_handle *f, void *buf, size_t count, in fec_pread() argument
522 check(f); in fec_pread()
530 if (f->verity.hash) { in fec_pread()
531 return process(f, (uint8_t *)buf, in fec_pread()
532 get_max_count(offset, count, f->data_size), offset, in fec_pread()
534 } else if (f->ecc.start) { in fec_pread()
535 check(f->ecc.start < f->size); in fec_pread()
537 count = get_max_count(offset, count, f->data_size); in fec_pread()
538 ssize_t rc = process(f, (uint8_t *)buf, count, offset, ecc_read); in fec_pread()
547 count = get_max_count(offset, count, f->size); in fec_pread()
550 if (raw_pread(f, buf, count, offset)) { in fec_pread()