Skip to content

Commit

Permalink
Browse files Browse the repository at this point in the history
Merge branch 'jk/pack-bitmap'
* jk/pack-bitmap:
  pack-bitmap: do not use gcc packed attribute
  • Loading branch information
Junio C Hamano committed Dec 12, 2014
2 parents 23c0956 + b500721 commit 3889e7a
Show file tree
Hide file tree
Showing 4 changed files with 29 additions and 18 deletions.
11 changes: 11 additions & 0 deletions csum-file.h
Expand Up @@ -39,4 +39,15 @@ extern void sha1flush(struct sha1file *f);
extern void crc32_begin(struct sha1file *);
extern uint32_t crc32_end(struct sha1file *);

static inline void sha1write_u8(struct sha1file *f, uint8_t data)
{
sha1write(f, &data, sizeof(data));
}

static inline void sha1write_be32(struct sha1file *f, uint32_t data)
{
data = htonl(data);
sha1write(f, &data, sizeof(data));
}

#endif
8 changes: 3 additions & 5 deletions pack-bitmap-write.c
Expand Up @@ -472,19 +472,17 @@ static void write_selected_commits_v1(struct sha1file *f,

for (i = 0; i < writer.selected_nr; ++i) {
struct bitmapped_commit *stored = &writer.selected[i];
struct bitmap_disk_entry on_disk;

int commit_pos =
sha1_pos(stored->commit->object.sha1, index, index_nr, sha1_access);

if (commit_pos < 0)
die("BUG: trying to write commit not in index");

on_disk.object_pos = htonl(commit_pos);
on_disk.xor_offset = stored->xor_offset;
on_disk.flags = stored->flags;
sha1write_be32(f, commit_pos);
sha1write_u8(f, stored->xor_offset);
sha1write_u8(f, stored->flags);

sha1write(f, &on_disk, sizeof(on_disk));
dump_bitmap(f, stored->write_as);
}
}
Expand Down
22 changes: 15 additions & 7 deletions pack-bitmap.c
Expand Up @@ -197,13 +197,24 @@ static struct stored_bitmap *store_bitmap(struct bitmap_index *index,
return stored;
}

static inline uint32_t read_be32(const unsigned char *buffer, size_t *pos)
{
uint32_t result = get_be32(buffer + *pos);
(*pos) += sizeof(result);
return result;
}

static inline uint8_t read_u8(const unsigned char *buffer, size_t *pos)
{
return buffer[(*pos)++];
}

static int load_bitmap_entries_v1(struct bitmap_index *index)
{
static const size_t MAX_XOR_OFFSET = 160;

uint32_t i;
struct stored_bitmap **recent_bitmaps;
struct bitmap_disk_entry *entry;

recent_bitmaps = xcalloc(MAX_XOR_OFFSET, sizeof(struct stored_bitmap));

Expand All @@ -214,15 +225,12 @@ static int load_bitmap_entries_v1(struct bitmap_index *index)
uint32_t commit_idx_pos;
const unsigned char *sha1;

entry = (struct bitmap_disk_entry *)(index->map + index->map_pos);
index->map_pos += sizeof(struct bitmap_disk_entry);
commit_idx_pos = read_be32(index->map, &index->map_pos);
xor_offset = read_u8(index->map, &index->map_pos);
flags = read_u8(index->map, &index->map_pos);

commit_idx_pos = ntohl(entry->object_pos);
sha1 = nth_packed_object_sha1(index->pack, commit_idx_pos);

xor_offset = (int)entry->xor_offset;
flags = (int)entry->flags;

bitmap = read_bitmap_1(index);
if (!bitmap)
return -1;
Expand Down
6 changes: 0 additions & 6 deletions pack-bitmap.h
Expand Up @@ -5,12 +5,6 @@
#include "khash.h"
#include "pack-objects.h"

struct bitmap_disk_entry {
uint32_t object_pos;
uint8_t xor_offset;
uint8_t flags;
} __attribute__((packed));

struct bitmap_disk_header {
char magic[4];
uint16_t version;
Expand Down

0 comments on commit 3889e7a

Please sign in to comment.