Commit 0d0f76ea authored by Michael Niedermayer's avatar Michael Niedermayer

Merge commit '6327c107'

* commit '6327c107':
  atomic: fix CAS with armcc.
  png: use av_mallocz_array() for the zlib zalloc function
  libmp3lame: use the correct remaining buffer size when flushing
Merged-by: 's avatarMichael Niedermayer <michaelni@gmx.at>
parents d64b8540 6327c107
...@@ -218,7 +218,7 @@ static int mp3lame_encode_frame(AVCodecContext *avctx, AVPacket *avpkt, ...@@ -218,7 +218,7 @@ static int mp3lame_encode_frame(AVCodecContext *avctx, AVPacket *avpkt,
} }
} else { } else {
lame_result = lame_encode_flush(s->gfp, s->buffer + s->buffer_index, lame_result = lame_encode_flush(s->gfp, s->buffer + s->buffer_index,
BUFFER_SIZE - s->buffer_index); s->buffer_size - s->buffer_index);
} }
if (lame_result < 0) { if (lame_result < 0) {
if (lame_result == -1) { if (lame_result == -1) {
......
...@@ -38,9 +38,7 @@ static const uint8_t ff_png_pass_xshift[NB_PASSES] = { ...@@ -38,9 +38,7 @@ static const uint8_t ff_png_pass_xshift[NB_PASSES] = {
void *ff_png_zalloc(void *opaque, unsigned int items, unsigned int size) void *ff_png_zalloc(void *opaque, unsigned int items, unsigned int size)
{ {
if(items >= UINT_MAX / size) return av_mallocz_array(items, size);
return NULL;
return av_malloc(items * size);
} }
void ff_png_zfree(void *opaque, void *ptr) void ff_png_zfree(void *opaque, void *ptr)
......
...@@ -21,6 +21,8 @@ ...@@ -21,6 +21,8 @@
#ifndef AVUTIL_ATOMIC_GCC_H #ifndef AVUTIL_ATOMIC_GCC_H
#define AVUTIL_ATOMIC_GCC_H #define AVUTIL_ATOMIC_GCC_H
#include <stdint.h>
#include "atomic.h" #include "atomic.h"
#define avpriv_atomic_int_get atomic_int_get_gcc #define avpriv_atomic_int_get atomic_int_get_gcc
...@@ -47,7 +49,13 @@ static inline int atomic_int_add_and_fetch_gcc(volatile int *ptr, int inc) ...@@ -47,7 +49,13 @@ static inline int atomic_int_add_and_fetch_gcc(volatile int *ptr, int inc)
static inline void *atomic_ptr_cas_gcc(void * volatile *ptr, static inline void *atomic_ptr_cas_gcc(void * volatile *ptr,
void *oldval, void *newval) void *oldval, void *newval)
{ {
#ifdef __ARMCC_VERSION
// armcc will throw an error if ptr is not an integer type
volatile uintptr_t *tmp = (volatile uintptr_t*)ptr;
return (void*)__sync_val_compare_and_swap(tmp, oldval, newval);
#else
return __sync_val_compare_and_swap(ptr, oldval, newval); return __sync_val_compare_and_swap(ptr, oldval, newval);
#endif
} }
#endif /* AVUTIL_ATOMIC_GCC_H */ #endif /* AVUTIL_ATOMIC_GCC_H */
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