Merge branch 'jk/misc-uninitialized-fixes'

Various fixes to codepaths gcc 9 had trouble following dataflow.

* jk/misc-uninitialized-fixes:
  pack-objects: drop packlist index_pos optimization
  test-read-cache: drop namelen variable
  diff-delta: set size out-parameter to 0 for NULL delta
  bulk-checkin: zero-initialize hashfile_checkpoint
  pack-objects: use object_id in packlist_alloc()
  git-am: handle missing "author" when parsing commit
This commit is contained in:
Junio C Hamano 2019-09-30 13:19:30 +09:00
commit d8ce144e11
9 changed files with 38 additions and 40 deletions

View File

@ -1272,7 +1272,9 @@ static void get_commit_info(struct am_state *state, struct commit *commit)
buffer = logmsg_reencode(commit, NULL, get_commit_output_encoding()); buffer = logmsg_reencode(commit, NULL, get_commit_output_encoding());
ident_line = find_commit_header(buffer, "author", &ident_len); ident_line = find_commit_header(buffer, "author", &ident_len);
if (!ident_line)
die(_("missing author line in commit %s"),
oid_to_hex(&commit->object.oid));
if (split_ident_line(&id, ident_line, ident_len) < 0) if (split_ident_line(&id, ident_line, ident_len) < 0)
die(_("invalid ident line: %.*s"), (int)ident_len, ident_line); die(_("invalid ident line: %.*s"), (int)ident_len, ident_line);

View File

@ -610,12 +610,12 @@ static int mark_tagged(const char *path, const struct object_id *oid, int flag,
void *cb_data) void *cb_data)
{ {
struct object_id peeled; struct object_id peeled;
struct object_entry *entry = packlist_find(&to_pack, oid, NULL); struct object_entry *entry = packlist_find(&to_pack, oid);
if (entry) if (entry)
entry->tagged = 1; entry->tagged = 1;
if (!peel_ref(path, &peeled)) { if (!peel_ref(path, &peeled)) {
entry = packlist_find(&to_pack, &peeled, NULL); entry = packlist_find(&to_pack, &peeled);
if (entry) if (entry)
entry->tagged = 1; entry->tagged = 1;
} }
@ -996,12 +996,11 @@ static int no_try_delta(const char *path)
* few lines later when we want to add the new entry. * few lines later when we want to add the new entry.
*/ */
static int have_duplicate_entry(const struct object_id *oid, static int have_duplicate_entry(const struct object_id *oid,
int exclude, int exclude)
uint32_t *index_pos)
{ {
struct object_entry *entry; struct object_entry *entry;
entry = packlist_find(&to_pack, oid, index_pos); entry = packlist_find(&to_pack, oid);
if (!entry) if (!entry)
return 0; return 0;
@ -1141,13 +1140,12 @@ static void create_object_entry(const struct object_id *oid,
uint32_t hash, uint32_t hash,
int exclude, int exclude,
int no_try_delta, int no_try_delta,
uint32_t index_pos,
struct packed_git *found_pack, struct packed_git *found_pack,
off_t found_offset) off_t found_offset)
{ {
struct object_entry *entry; struct object_entry *entry;
entry = packlist_alloc(&to_pack, oid->hash, index_pos); entry = packlist_alloc(&to_pack, oid);
entry->hash = hash; entry->hash = hash;
oe_set_type(entry, type); oe_set_type(entry, type);
if (exclude) if (exclude)
@ -1171,11 +1169,10 @@ static int add_object_entry(const struct object_id *oid, enum object_type type,
{ {
struct packed_git *found_pack = NULL; struct packed_git *found_pack = NULL;
off_t found_offset = 0; off_t found_offset = 0;
uint32_t index_pos;
display_progress(progress_state, ++nr_seen); display_progress(progress_state, ++nr_seen);
if (have_duplicate_entry(oid, exclude, &index_pos)) if (have_duplicate_entry(oid, exclude))
return 0; return 0;
if (!want_object_in_pack(oid, exclude, &found_pack, &found_offset)) { if (!want_object_in_pack(oid, exclude, &found_pack, &found_offset)) {
@ -1190,7 +1187,7 @@ static int add_object_entry(const struct object_id *oid, enum object_type type,
create_object_entry(oid, type, pack_name_hash(name), create_object_entry(oid, type, pack_name_hash(name),
exclude, name && no_try_delta(name), exclude, name && no_try_delta(name),
index_pos, found_pack, found_offset); found_pack, found_offset);
return 1; return 1;
} }
@ -1199,17 +1196,15 @@ static int add_object_entry_from_bitmap(const struct object_id *oid,
int flags, uint32_t name_hash, int flags, uint32_t name_hash,
struct packed_git *pack, off_t offset) struct packed_git *pack, off_t offset)
{ {
uint32_t index_pos;
display_progress(progress_state, ++nr_seen); display_progress(progress_state, ++nr_seen);
if (have_duplicate_entry(oid, 0, &index_pos)) if (have_duplicate_entry(oid, 0))
return 0; return 0;
if (!want_object_in_pack(oid, 0, &pack, &offset)) if (!want_object_in_pack(oid, 0, &pack, &offset))
return 0; return 0;
create_object_entry(oid, type, name_hash, 0, 0, index_pos, pack, offset); create_object_entry(oid, type, name_hash, 0, 0, pack, offset);
return 1; return 1;
} }
@ -1507,7 +1502,7 @@ static int can_reuse_delta(const unsigned char *base_sha1,
* First see if we're already sending the base (or it's explicitly in * First see if we're already sending the base (or it's explicitly in
* our "excluded" list). * our "excluded" list).
*/ */
base = packlist_find(&to_pack, &base_oid, NULL); base = packlist_find(&to_pack, &base_oid);
if (base) { if (base) {
if (!in_same_island(&delta->idx.oid, &base->idx.oid)) if (!in_same_island(&delta->idx.oid, &base->idx.oid))
return 0; return 0;
@ -2568,7 +2563,7 @@ static void add_tag_chain(const struct object_id *oid)
* it was included via bitmaps, we would not have parsed it * it was included via bitmaps, we would not have parsed it
* previously). * previously).
*/ */
if (packlist_find(&to_pack, oid, NULL)) if (packlist_find(&to_pack, oid))
return; return;
tag = lookup_tag(the_repository, oid); tag = lookup_tag(the_repository, oid);
@ -2592,7 +2587,7 @@ static int add_ref_tag(const char *path, const struct object_id *oid, int flag,
if (starts_with(path, "refs/tags/") && /* is a tag? */ if (starts_with(path, "refs/tags/") && /* is a tag? */
!peel_ref(path, &peeled) && /* peelable? */ !peel_ref(path, &peeled) && /* peelable? */
packlist_find(&to_pack, &peeled, NULL)) /* object packed? */ packlist_find(&to_pack, &peeled)) /* object packed? */
add_tag_chain(oid); add_tag_chain(oid);
return 0; return 0;
} }
@ -2788,7 +2783,7 @@ static void show_object(struct object *obj, const char *name, void *data)
for (p = strchr(name, '/'); p; p = strchr(p + 1, '/')) for (p = strchr(name, '/'); p; p = strchr(p + 1, '/'))
depth++; depth++;
ent = packlist_find(&to_pack, &obj->oid, NULL); ent = packlist_find(&to_pack, &obj->oid);
if (ent && depth > oe_tree_depth(&to_pack, ent)) if (ent && depth > oe_tree_depth(&to_pack, ent))
oe_set_tree_depth(&to_pack, ent, depth); oe_set_tree_depth(&to_pack, ent, depth);
} }
@ -3019,7 +3014,7 @@ static void loosen_unused_packed_objects(void)
for (i = 0; i < p->num_objects; i++) { for (i = 0; i < p->num_objects; i++) {
nth_packed_object_oid(&oid, p, i); nth_packed_object_oid(&oid, p, i);
if (!packlist_find(&to_pack, &oid, NULL) && if (!packlist_find(&to_pack, &oid) &&
!has_sha1_pack_kept_or_nonlocal(&oid) && !has_sha1_pack_kept_or_nonlocal(&oid) &&
!loosened_object_can_be_discarded(&oid, p->mtime)) !loosened_object_can_be_discarded(&oid, p->mtime))
if (force_object_loose(&oid, p->mtime)) if (force_object_loose(&oid, p->mtime))

View File

@ -197,7 +197,7 @@ static int deflate_to_pack(struct bulk_checkin_state *state,
git_hash_ctx ctx; git_hash_ctx ctx;
unsigned char obuf[16384]; unsigned char obuf[16384];
unsigned header_len; unsigned header_len;
struct hashfile_checkpoint checkpoint; struct hashfile_checkpoint checkpoint = {0};
struct pack_idx_entry *idx = NULL; struct pack_idx_entry *idx = NULL;
seekback = lseek(fd, 0, SEEK_CUR); seekback = lseek(fd, 0, SEEK_CUR);

View File

@ -326,6 +326,8 @@ create_delta(const struct delta_index *index,
const unsigned char *ref_data, *ref_top, *data, *top; const unsigned char *ref_data, *ref_top, *data, *top;
unsigned char *out; unsigned char *out;
*delta_size = 0;
if (!trg_buf || !trg_size) if (!trg_buf || !trg_size)
return NULL; return NULL;

View File

@ -144,7 +144,7 @@ static inline void reset_all_seen(void)
static uint32_t find_object_pos(const struct object_id *oid) static uint32_t find_object_pos(const struct object_id *oid)
{ {
struct object_entry *entry = packlist_find(writer.to_pack, oid, NULL); struct object_entry *entry = packlist_find(writer.to_pack, oid);
if (!entry) { if (!entry) {
die("Failed to write bitmap index. Packfile doesn't have full closure " die("Failed to write bitmap index. Packfile doesn't have full closure "

View File

@ -1061,7 +1061,7 @@ int rebuild_existing_bitmaps(struct bitmap_index *bitmap_git,
entry = &bitmap_git->pack->revindex[i]; entry = &bitmap_git->pack->revindex[i];
nth_packed_object_oid(&oid, bitmap_git->pack, entry->nr); nth_packed_object_oid(&oid, bitmap_git->pack, entry->nr);
oe = packlist_find(mapping, &oid, NULL); oe = packlist_find(mapping, &oid);
if (oe) if (oe)
reposition[i] = oe_in_pack_pos(mapping, oe) + 1; reposition[i] = oe_in_pack_pos(mapping, oe) + 1;

View File

@ -68,8 +68,7 @@ static void rehash_objects(struct packing_data *pdata)
} }
struct object_entry *packlist_find(struct packing_data *pdata, struct object_entry *packlist_find(struct packing_data *pdata,
const struct object_id *oid, const struct object_id *oid)
uint32_t *index_pos)
{ {
uint32_t i; uint32_t i;
int found; int found;
@ -79,9 +78,6 @@ struct object_entry *packlist_find(struct packing_data *pdata,
i = locate_object_entry_hash(pdata, oid, &found); i = locate_object_entry_hash(pdata, oid, &found);
if (index_pos)
*index_pos = i;
if (!found) if (!found)
return NULL; return NULL;
@ -153,8 +149,7 @@ void prepare_packing_data(struct repository *r, struct packing_data *pdata)
} }
struct object_entry *packlist_alloc(struct packing_data *pdata, struct object_entry *packlist_alloc(struct packing_data *pdata,
const unsigned char *sha1, const struct object_id *oid)
uint32_t index_pos)
{ {
struct object_entry *new_entry; struct object_entry *new_entry;
@ -177,12 +172,19 @@ struct object_entry *packlist_alloc(struct packing_data *pdata,
new_entry = pdata->objects + pdata->nr_objects++; new_entry = pdata->objects + pdata->nr_objects++;
memset(new_entry, 0, sizeof(*new_entry)); memset(new_entry, 0, sizeof(*new_entry));
hashcpy(new_entry->idx.oid.hash, sha1); oidcpy(&new_entry->idx.oid, oid);
if (pdata->index_size * 3 <= pdata->nr_objects * 4) if (pdata->index_size * 3 <= pdata->nr_objects * 4)
rehash_objects(pdata); rehash_objects(pdata);
else else {
pdata->index[index_pos] = pdata->nr_objects; int found;
uint32_t pos = locate_object_entry_hash(pdata,
&new_entry->idx.oid,
&found);
if (found)
BUG("duplicate object inserted into hash");
pdata->index[pos] = pdata->nr_objects;
}
if (pdata->in_pack) if (pdata->in_pack)
pdata->in_pack[pdata->nr_objects - 1] = NULL; pdata->in_pack[pdata->nr_objects - 1] = NULL;

View File

@ -183,12 +183,10 @@ static inline void packing_data_unlock(struct packing_data *pdata)
} }
struct object_entry *packlist_alloc(struct packing_data *pdata, struct object_entry *packlist_alloc(struct packing_data *pdata,
const unsigned char *sha1, const struct object_id *oid);
uint32_t index_pos);
struct object_entry *packlist_find(struct packing_data *pdata, struct object_entry *packlist_find(struct packing_data *pdata,
const struct object_id *oid, const struct object_id *oid);
uint32_t *index_pos);
static inline uint32_t pack_name_hash(const char *name) static inline uint32_t pack_name_hash(const char *name)
{ {

View File

@ -4,11 +4,10 @@
int cmd__read_cache(int argc, const char **argv) int cmd__read_cache(int argc, const char **argv)
{ {
int i, cnt = 1, namelen; int i, cnt = 1;
const char *name = NULL; const char *name = NULL;
if (argc > 1 && skip_prefix(argv[1], "--print-and-refresh=", &name)) { if (argc > 1 && skip_prefix(argv[1], "--print-and-refresh=", &name)) {
namelen = strlen(name);
argc--; argc--;
argv++; argv++;
} }
@ -24,7 +23,7 @@ int cmd__read_cache(int argc, const char **argv)
refresh_index(&the_index, REFRESH_QUIET, refresh_index(&the_index, REFRESH_QUIET,
NULL, NULL, NULL); NULL, NULL, NULL);
pos = index_name_pos(&the_index, name, namelen); pos = index_name_pos(&the_index, name, strlen(name));
if (pos < 0) if (pos < 0)
die("%s not in index", name); die("%s not in index", name);
printf("%s is%s up to date\n", name, printf("%s is%s up to date\n", name,