Skip to content

Commit

Permalink
macos: fix missing pthread mutex init after calloc
Browse files Browse the repository at this point in the history
calls constructor for a mutex in a struct value init-ed with gu_calloc.

in path `gcs_core_create() -> gcs_group_init()`, the first one allocates
`gcs_core_t* core` with gu_calloc() whereas `gcs_code_t` has
`gcs_group_t group` with `gu::Mutex memb_mtx_`. After memory allocation
gu::Mutex constructor was not called that lead to an error on Darwin in
a call to pthread mutex lock.

Signed-off-by: Ivan Prisyazhnyy <[email protected]>
  • Loading branch information
sitano committed Jul 31, 2024
1 parent 300fd48 commit 629a03c
Showing 1 changed file with 1 addition and 0 deletions.
1 change: 1 addition & 0 deletions gcs/src/gcs_group.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,7 @@ gcs_group_init (gcs_group_t* group, gu::Config* const cnf, gcache_t* const cache
int const appl_proto_ver)
{
// here we also create default node instance.
new (&group->memb_mtx_) gu::Mutex(NULL);
group->cache = cache;
group->act_id_ = GCS_SEQNO_ILL;
group->conf_id = GCS_SEQNO_ILL;
Expand Down

0 comments on commit 629a03c

Please sign in to comment.