Commit 25bacd0a authored by Martin Storsjö's avatar Martin Storsjö

Don't use expressions with side effects in macro parameters

AV_WB32 can be implemented as a macro that expands its parameters
multiple times (in case AV_HAVE_FAST_UNALIGNED isn't set and the
compiler doesn't support GCC attributes); make sure not to read
multiple times from the source in this case.
Signed-off-by: 's avatarMartin Storsjö <martin@martin.st>
parent 7ebdffc3
...@@ -121,8 +121,10 @@ static int dxv_decompress_dxt1(AVCodecContext *avctx) ...@@ -121,8 +121,10 @@ static int dxv_decompress_dxt1(AVCodecContext *avctx)
int pos = 2; int pos = 2;
/* Copy the first two elements */ /* Copy the first two elements */
AV_WL32(ctx->tex_data, bytestream2_get_le32(gbc)); value = bytestream2_get_le32(gbc);
AV_WL32(ctx->tex_data + 4, bytestream2_get_le32(gbc)); AV_WL32(ctx->tex_data, value);
value = bytestream2_get_le32(gbc);
AV_WL32(ctx->tex_data + 4, value);
/* Process input until the whole texture has been filled */ /* Process input until the whole texture has been filled */
while (pos + 2 <= ctx->tex_size / 4) { while (pos + 2 <= ctx->tex_size / 4) {
...@@ -172,10 +174,14 @@ static int dxv_decompress_dxt5(AVCodecContext *avctx) ...@@ -172,10 +174,14 @@ static int dxv_decompress_dxt5(AVCodecContext *avctx)
int probe, check; int probe, check;
/* Copy the first four elements */ /* Copy the first four elements */
AV_WL32(ctx->tex_data + 0, bytestream2_get_le32(gbc)); value = bytestream2_get_le32(gbc);
AV_WL32(ctx->tex_data + 4, bytestream2_get_le32(gbc)); AV_WL32(ctx->tex_data + 0, value);
AV_WL32(ctx->tex_data + 8, bytestream2_get_le32(gbc)); value = bytestream2_get_le32(gbc);
AV_WL32(ctx->tex_data + 12, bytestream2_get_le32(gbc)); AV_WL32(ctx->tex_data + 4, value);
value = bytestream2_get_le32(gbc);
AV_WL32(ctx->tex_data + 8, value);
value = bytestream2_get_le32(gbc);
AV_WL32(ctx->tex_data + 12, value);
/* Process input until the whole texture has been filled */ /* Process input until the whole texture has been filled */
while (pos + 2 <= ctx->tex_size / 4) { while (pos + 2 <= ctx->tex_size / 4) {
......
...@@ -512,8 +512,10 @@ static int xmv_fetch_video_packet(AVFormatContext *s, ...@@ -512,8 +512,10 @@ static int xmv_fetch_video_packet(AVFormatContext *s,
* WMV2 is little-endian. * WMV2 is little-endian.
* TODO: This manual swap is of course suboptimal. * TODO: This manual swap is of course suboptimal.
*/ */
for (i = 0; i < frame_size; i += 4) for (i = 0; i < frame_size; i += 4) {
AV_WB32(pkt->data + i, avio_rl32(pb)); uint32_t val = avio_rl32(pb);
AV_WB32(pkt->data + i, val);
}
pkt->stream_index = video->stream_index; pkt->stream_index = video->stream_index;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment