Skip to content

Commit

Permalink
aumix: use mutex_alloc()
Browse files Browse the repository at this point in the history
  • Loading branch information
alfredh committed Jun 12, 2024
1 parent 47a5d9a commit 82a5f90
Showing 1 changed file with 26 additions and 26 deletions.
52 changes: 26 additions & 26 deletions rem/aumix/aumix.c
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@

/** Defines an Audio mixer */
struct aumix {
mtx_t mutex;
mtx_t *mutex;
cnd_t cond;
struct list srcl;
thrd_t thread;
Expand Down Expand Up @@ -62,21 +62,22 @@ static void destructor(void *arg)
{
struct aumix *mix = arg;

mtx_lock(&mix->mutex);
mtx_lock(mix->mutex);
bool run = mix->run;
mtx_unlock(&mix->mutex);
mtx_unlock(mix->mutex);

if (run) {

mtx_lock(&mix->mutex);
mtx_lock(mix->mutex);
mix->run = false;
cnd_signal(&mix->cond);
mtx_unlock(&mix->mutex);
mtx_unlock(mix->mutex);

thrd_join(mix->thread, NULL);
}

mem_deref(mix->af);
mem_deref(mix->mutex);
}


Expand All @@ -85,9 +86,9 @@ static void source_destructor(void *arg)
struct aumix_source *src = arg;

if (src->le.list) {
mtx_lock(&src->mix->mutex);
mtx_lock(src->mix->mutex);
list_unlink(&src->le);
mtx_unlock(&src->mix->mutex);
mtx_unlock(src->mix->mutex);
}

mem_deref(src->aubuf);
Expand All @@ -110,7 +111,7 @@ static int aumix_thread(void *arg)
if (!silence || !frame || !mix_frame)
goto out;

mtx_lock(&mix->mutex);
mtx_lock(mix->mutex);

while (mix->run) {

Expand All @@ -119,13 +120,13 @@ static int aumix_thread(void *arg)

if (!mix->srcl.head) {
mix->af = mem_deref(mix->af);
cnd_wait(&mix->cond, &mix->mutex);
cnd_wait(&mix->cond, mix->mutex);
ts = 0;
}
else {
mtx_unlock(&mix->mutex);
mtx_unlock(mix->mutex);
sys_usleep(4000);
mtx_lock(&mix->mutex);
mtx_lock(mix->mutex);
}

now = tmr_jiffies();
Expand Down Expand Up @@ -243,7 +244,7 @@ static int aumix_thread(void *arg)
ts += mix->ptime;
}

mtx_unlock(&mix->mutex);
mtx_unlock(mix->mutex);

out:
mem_deref(mix_frame);
Expand Down Expand Up @@ -287,9 +288,8 @@ int aumix_alloc(struct aumix **mixp, uint32_t srate,
mix->rec_sum.srate = srate;
mix->rec_sum.sampc = mix->frame_size;

err = mtx_init(&mix->mutex, mtx_plain) != thrd_success;
err = mutex_alloc(&mix->mutex);
if (err) {
err = ENOMEM;
goto out;
}

Expand Down Expand Up @@ -328,9 +328,9 @@ void aumix_recordh(struct aumix *mix, aumix_record_h *recordh)
if (!mix)
return;

mtx_lock(&mix->mutex);
mtx_lock(mix->mutex);
mix->recordh = recordh;
mtx_unlock(&mix->mutex);
mtx_unlock(mix->mutex);
}


Expand All @@ -345,9 +345,9 @@ void aumix_record_sumh(struct aumix *mix, aumix_record_h *recordh)
if (!mix)
return;

mtx_lock(&mix->mutex);
mtx_lock(mix->mutex);
mix->record_sumh = recordh;
mtx_unlock(&mix->mutex);
mtx_unlock(mix->mutex);
}


Expand Down Expand Up @@ -378,10 +378,10 @@ int aumix_playfile(struct aumix *mix, const char *filepath)
return EINVAL;
}

mtx_lock(&mix->mutex);
mtx_lock(mix->mutex);
mem_deref(mix->af);
mix->af = af;
mtx_unlock(&mix->mutex);
mtx_unlock(mix->mutex);

return 0;
}
Expand Down Expand Up @@ -468,9 +468,9 @@ void aumix_source_readh(struct aumix_source *src, aumix_read_h *readh)
if (!src || !src->mix)
return;

mtx_lock(&src->mix->mutex);
mtx_lock(src->mix->mutex);
src->readh = readh;
mtx_unlock(&src->mix->mutex);
mtx_unlock(src->mix->mutex);
}


Expand Down Expand Up @@ -510,7 +510,7 @@ void aumix_source_enable(struct aumix_source *src, bool enable)

mix = src->mix;

mtx_lock(&mix->mutex);
mtx_lock(mix->mutex);

if (enable) {
list_append(&mix->srcl, &src->le, src);
Expand All @@ -520,7 +520,7 @@ void aumix_source_enable(struct aumix_source *src, bool enable)
list_unlink(&src->le);
}

mtx_unlock(&mix->mutex);
mtx_unlock(mix->mutex);
}


Expand Down Expand Up @@ -574,7 +574,7 @@ int aumix_debug(struct re_printf *pf, struct aumix *mix)
return EINVAL;

re_hprintf(pf, "aumix debug:\n");
mtx_lock(&mix->mutex);
mtx_lock(mix->mutex);
LIST_FOREACH(&mix->srcl, le)
{
struct aumix_source *src = le->data;
Expand All @@ -586,6 +586,6 @@ int aumix_debug(struct re_printf *pf, struct aumix *mix)
}

out:
mtx_unlock(&mix->mutex);
mtx_unlock(mix->mutex);
return err;
}

0 comments on commit 82a5f90

Please sign in to comment.