From e4ff503787c5c3e9a664e59aa331447058c1a19a Mon Sep 17 00:00:00 2001 From: Sebastian Reimers Date: Wed, 11 Dec 2024 11:18:26 +0100 Subject: [PATCH] rtp/sess: fix missing srate_tx locking Found by coverity: CID 443862: Concurrent data access violations (MISSING_LOCK) Accessing "sess->srate_tx" without holding lock "rtcp_sess.lock". Elsewhere, "rtcp_sess.srate_tx" is written to with "rtcp_sess.lock" held 2 out of 2 times (2 of these accesses strongly imply that it is necessary). --- src/rtp/sess.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/rtp/sess.c b/src/rtp/sess.c index 5b8a3b48f..3e0be4c68 100644 --- a/src/rtp/sess.c +++ b/src/rtp/sess.c @@ -426,10 +426,12 @@ static int encode_handler(struct mbuf *mb, void *arg) static int mk_sr(struct rtcp_sess *sess, struct mbuf *mb) { struct txstat txstat; + uint32_t srate_tx; int err; mtx_lock(sess->lock); txstat = sess->txstat; + srate_tx = sess->srate_tx; sess->txstat.ts_synced = false; mtx_unlock(sess->lock); @@ -442,7 +444,7 @@ static int mk_sr(struct rtcp_sess *sess, struct mbuf *mb) dur = jfs_rt - txstat.jfs_rt_ref; rtp_ts = (uint32_t)((uint64_t)txstat.ts_ref + dur * - sess->srate_tx / 1000000u); + srate_tx / 1000000u); err = rtcp_encode(mb, RTCP_SR, sess->senderc, rtp_sess_ssrc(sess->rs), ntp.hi, ntp.lo,