Commit ec097b7b by lhchavez Committed by Edward Thomson

Use `p_pwrite`/`p_pread` consistently throughout the codebase

This change stops using the seek+read/write combo to perform I/O with an
offset, since this is faster by one system call (and also more atomic
and therefore safer).
parent bb278ceb
...@@ -656,7 +656,6 @@ static int append_to_pack(git_indexer *idx, const void *data, size_t size) ...@@ -656,7 +656,6 @@ static int append_to_pack(git_indexer *idx, const void *data, size_t size)
size_t page_offset; size_t page_offset;
off64_t page_start; off64_t page_start;
off64_t current_size = idx->pack->mwf.size; off64_t current_size = idx->pack->mwf.size;
int fd = idx->pack->mwf.fd;
int error; int error;
if (!size) if (!size)
...@@ -673,8 +672,7 @@ static int append_to_pack(git_indexer *idx, const void *data, size_t size) ...@@ -673,8 +672,7 @@ static int append_to_pack(git_indexer *idx, const void *data, size_t size)
page_offset = new_size % mmap_alignment; page_offset = new_size % mmap_alignment;
page_start = new_size - page_offset; page_start = new_size - page_offset;
if (p_lseek(fd, page_start + mmap_alignment - 1, SEEK_SET) < 0 || if (p_pwrite(idx->pack->mwf.fd, data, 1, page_start + mmap_alignment - 1) < 0) {
p_write(idx->pack->mwf.fd, data, 1) < 0) {
git_error_set(GIT_ERROR_OS, "cannot extend packfile '%s'", idx->pack->pack_name); git_error_set(GIT_ERROR_OS, "cannot extend packfile '%s'", idx->pack->pack_name);
return -1; return -1;
} }
......
...@@ -1063,8 +1063,7 @@ static int packfile_open(struct git_pack_file *p) ...@@ -1063,8 +1063,7 @@ static int packfile_open(struct git_pack_file *p)
/* Verify the pack matches its index. */ /* Verify the pack matches its index. */
if (p->num_objects != ntohl(hdr.hdr_entries) || if (p->num_objects != ntohl(hdr.hdr_entries) ||
p_lseek(p->mwf.fd, p->mwf.size - GIT_OID_RAWSZ, SEEK_SET) == -1 || p_pread(p->mwf.fd, sha1.id, GIT_OID_RAWSZ, p->mwf.size - GIT_OID_RAWSZ) < 0)
p_read(p->mwf.fd, sha1.id, GIT_OID_RAWSZ) < 0)
goto cleanup; goto cleanup;
idx_sha1 = ((unsigned char *)p->index_map.data) + p->index_map.len - 40; idx_sha1 = ((unsigned char *)p->index_map.data) + p->index_map.len - 40;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment