Merge branch 'ph/pack-objects-mutex-fix'
"git pack-objects" incorrectly used uninitialized mutex, which has been corrected. * ph/pack-objects-mutex-fix: pack-objects: merge read_lock and lock in packing_data struct pack-objects: move read mutex to packing_data struct
This commit is contained in:
@@ -148,7 +148,11 @@ struct packing_data {
|
||||
struct packed_git **in_pack_by_idx;
|
||||
struct packed_git **in_pack;
|
||||
|
||||
pthread_mutex_t lock;
|
||||
/*
|
||||
* During packing with multiple threads, protect the in-core
|
||||
* object database from concurrent accesses.
|
||||
*/
|
||||
pthread_mutex_t odb_lock;
|
||||
|
||||
/*
|
||||
* This list contains entries for bases which we know the other side
|
||||
@@ -168,13 +172,14 @@ struct packing_data {
|
||||
|
||||
void prepare_packing_data(struct repository *r, struct packing_data *pdata);
|
||||
|
||||
/* Protect access to object database */
|
||||
static inline void packing_data_lock(struct packing_data *pdata)
|
||||
{
|
||||
pthread_mutex_lock(&pdata->lock);
|
||||
pthread_mutex_lock(&pdata->odb_lock);
|
||||
}
|
||||
static inline void packing_data_unlock(struct packing_data *pdata)
|
||||
{
|
||||
pthread_mutex_unlock(&pdata->lock);
|
||||
pthread_mutex_unlock(&pdata->odb_lock);
|
||||
}
|
||||
|
||||
struct object_entry *packlist_alloc(struct packing_data *pdata,
|
||||
|
||||
Reference in New Issue
Block a user