diff options
| author | Jeff King <peff@peff.net> | 2025-01-19 08:23:44 -0500 |
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2025-01-21 08:42:55 -0800 |
| commit | 4f02f4d68d8eefe728008974640839ef6e1b2182 (patch) | |
| tree | 5b6b89d7336b98bc7e9466258dab38b3da71c03d /packfile.c | |
| parent | 798e0f451661f81f4568dce4033cf1c9076f224f (diff) | |
| download | git-4f02f4d68d8eefe728008974640839ef6e1b2182.tar.xz | |
parse_pack_header_option(): avoid unaligned memory writes
In order to recreate a pack header in our in-memory buffer, we cast the
buffer to a "struct pack_header" and assign the individual fields. This
is reported to cause SIGBUS on sparc64 due to alignment issues.
We can work around this by using put_be32() which will write individual
bytes into the buffer.
Reported-by: Koakuma <koachan@protonmail.com>
Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'packfile.c')
| -rw-r--r-- | packfile.c | 15 |
1 files changed, 9 insertions, 6 deletions
diff --git a/packfile.c b/packfile.c index e2bdadc7cb..93f771ad95 100644 --- a/packfile.c +++ b/packfile.c @@ -2297,17 +2297,20 @@ int is_promisor_object(const struct object_id *oid) int parse_pack_header_option(const char *in, unsigned char *out, unsigned int *len) { - struct pack_header *hdr; + unsigned char *hdr; char *c; - hdr = (struct pack_header *)out; - hdr->hdr_signature = htonl(PACK_SIGNATURE); - hdr->hdr_version = htonl(strtoul(in, &c, 10)); + hdr = out; + put_be32(hdr, PACK_SIGNATURE); + hdr += 4; + put_be32(hdr, strtoul(in, &c, 10)); + hdr += 4; if (*c != ',') return -1; - hdr->hdr_entries = htonl(strtoul(c + 1, &c, 10)); + put_be32(hdr, strtoul(c + 1, &c, 10)); + hdr += 4; if (*c) return -1; - *len = sizeof(*hdr); + *len = hdr - out; return 0; } |
