dtlsconnection: Fix overflow in timeout calculation on systems with 32 bit time_t

If a timeout of more than 4295s was scheduled, the calculation would
overflow and a too short timeout would be used instead.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6920>
This commit is contained in:
Sebastian Dröge 2024-05-17 11:13:19 +03:00 committed by GStreamer Marge Bot
parent 4116127217
commit b77de8f6f2

View file

@ -449,7 +449,7 @@ gst_dtls_connection_check_timeout_locked (GstDtlsConnection * self)
priv = self->priv; priv = self->priv;
if (DTLSv1_get_timeout (priv->ssl, &timeout)) { if (DTLSv1_get_timeout (priv->ssl, &timeout)) {
wait_time = timeout.tv_sec * G_USEC_PER_SEC + timeout.tv_usec; wait_time = ((gint64) timeout.tv_sec) * G_USEC_PER_SEC + timeout.tv_usec;
GST_DEBUG_OBJECT (self, "waiting for %" G_GINT64_FORMAT " usec", wait_time); GST_DEBUG_OBJECT (self, "waiting for %" G_GINT64_FORMAT " usec", wait_time);
if (wait_time) { if (wait_time) {