From a9c5e5e239a9b6ceacd99dc548e0665957127c5e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tim-Philipp=20M=C3=BCller?= Date: Tue, 13 Jun 2023 01:29:14 +0100 Subject: [PATCH] asfmux: fix potentially unaligned write on 32-bit ARM Fixes #2665 Part-of: --- .../gst-plugins-bad/gst/asfmux/gstasfobjects.c | 12 ++++-------- 1 file changed, 4 insertions(+), 8 deletions(-) diff --git a/subprojects/gst-plugins-bad/gst/asfmux/gstasfobjects.c b/subprojects/gst-plugins-bad/gst/asfmux/gstasfobjects.c index d973982638..fa0f2849d1 100644 --- a/subprojects/gst-plugins-bad/gst/asfmux/gstasfobjects.c +++ b/subprojects/gst-plugins-bad/gst/asfmux/gstasfobjects.c @@ -311,14 +311,10 @@ gst_asf_put_time (guint8 * buf, guint64 time) void gst_asf_put_guid (guint8 * buf, Guid guid) { - guint32 *aux32 = (guint32 *) buf; - guint16 *aux16 = (guint16 *) & (buf[4]); - guint64 *aux64 = (guint64 *) & (buf[8]); - *aux32 = GUINT32_TO_LE (guid.v1); - *aux16 = GUINT16_TO_LE (guid.v2); - aux16 = (guint16 *) & (buf[6]); - *aux16 = GUINT16_TO_LE (guid.v3); - *aux64 = GUINT64_TO_BE (guid.v4); + GST_WRITE_UINT32_LE (buf + 0, guid.v1); + GST_WRITE_UINT16_LE (buf + 4, guid.v2); + GST_WRITE_UINT16_LE (buf + 6, guid.v3); + GST_WRITE_UINT64_BE (buf + 8, guid.v4); } /**