|  | @@ -24,11 +24,11 @@ | 
														
													
														
															
																|  |  | 
 |  |  | 
 | 
														
													
														
															
																|  |  | AVFifoBuffer *av_fifo_alloc(unsigned int size) |  |  | AVFifoBuffer *av_fifo_alloc(unsigned int size) | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | AVFifoBuffer *f= av_mallocz(sizeof(AVFifoBuffer)); |  |  |  | 
														
													
														
															
																|  |  |  |  |  | AVFifoBuffer *f = av_mallocz(sizeof(AVFifoBuffer)); | 
														
													
														
															
																|  |  | if (!f) |  |  | if (!f) | 
														
													
														
															
																|  |  | return NULL; |  |  | return NULL; | 
														
													
														
															
																|  |  | f->buffer = av_malloc(size); |  |  | f->buffer = av_malloc(size); | 
														
													
														
															
																|  |  | f->end = f->buffer + size; |  |  |  | 
														
													
														
															
																|  |  |  |  |  | f->end    = f->buffer + size; | 
														
													
														
															
																|  |  | av_fifo_reset(f); |  |  | av_fifo_reset(f); | 
														
													
														
															
																|  |  | if (!f->buffer) |  |  | if (!f->buffer) | 
														
													
														
															
																|  |  | av_freep(&f); |  |  | av_freep(&f); | 
														
													
												
													
														
															
																|  | @@ -64,7 +64,7 @@ int av_fifo_realloc2(AVFifoBuffer *f, unsigned int new_size) | 
														
													
														
															
																|  |  | unsigned int old_size = f->end - f->buffer; |  |  | unsigned int old_size = f->end - f->buffer; | 
														
													
														
															
																|  |  | 
 |  |  | 
 | 
														
													
														
															
																|  |  | if (old_size < new_size) { |  |  | if (old_size < new_size) { | 
														
													
														
															
																|  |  | int len = av_fifo_size(f); |  |  |  | 
														
													
														
															
																|  |  |  |  |  | int len          = av_fifo_size(f); | 
														
													
														
															
																|  |  | AVFifoBuffer *f2 = av_fifo_alloc(new_size); |  |  | AVFifoBuffer *f2 = av_fifo_alloc(new_size); | 
														
													
														
															
																|  |  | 
 |  |  | 
 | 
														
													
														
															
																|  |  | if (!f2) |  |  | if (!f2) | 
														
													
												
													
														
															
																|  | @@ -92,8 +92,10 @@ int av_fifo_grow(AVFifoBuffer *f, unsigned int size) | 
														
													
														
															
																|  |  | return 0; |  |  | return 0; | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  | 
 |  |  | 
 | 
														
													
														
															
																|  |  | // src must NOT be const as it can be a context for func that may need updating (like a pointer or byte counter) |  |  |  | 
														
													
														
															
																|  |  | int av_fifo_generic_write(AVFifoBuffer *f, void *src, int size, int (*func)(void*, void*, int)) |  |  |  | 
														
													
														
															
																|  |  |  |  |  | /* src must NOT be const as it can be a context for func that may need | 
														
													
														
															
																|  |  |  |  |  | * updating (like a pointer or byte counter) */ | 
														
													
														
															
																|  |  |  |  |  | int av_fifo_generic_write(AVFifoBuffer *f, void *src, int size, | 
														
													
														
															
																|  |  |  |  |  | int (*func)(void *, void *, int)) | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | int total = size; |  |  | int total = size; | 
														
													
														
															
																|  |  | uint32_t wndx= f->wndx; |  |  | uint32_t wndx= f->wndx; | 
														
													
												
													
														
															
																|  | @@ -106,30 +108,31 @@ int av_fifo_generic_write(AVFifoBuffer *f, void *src, int size, int (*func)(void | 
														
													
														
															
																|  |  | break; |  |  | break; | 
														
													
														
															
																|  |  | } else { |  |  | } else { | 
														
													
														
															
																|  |  | memcpy(wptr, src, len); |  |  | memcpy(wptr, src, len); | 
														
													
														
															
																|  |  | src = (uint8_t*)src + len; |  |  |  | 
														
													
														
															
																|  |  |  |  |  | src = (uint8_t *)src + len; | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  | // Write memory barrier needed for SMP here in theory |  |  | // Write memory barrier needed for SMP here in theory | 
														
													
														
															
																|  |  | wptr += len; |  |  | wptr += len; | 
														
													
														
															
																|  |  | if (wptr >= f->end) |  |  | if (wptr >= f->end) | 
														
													
														
															
																|  |  | wptr = f->buffer; |  |  | wptr = f->buffer; | 
														
													
														
															
																|  |  | wndx += len; |  |  |  | 
														
													
														
															
																|  |  | size -= len; |  |  |  | 
														
													
														
															
																|  |  |  |  |  | wndx    += len; | 
														
													
														
															
																|  |  |  |  |  | size    -= len; | 
														
													
														
															
																|  |  | } while (size > 0); |  |  | } while (size > 0); | 
														
													
														
															
																|  |  | f->wndx= wndx; |  |  | f->wndx= wndx; | 
														
													
														
															
																|  |  | f->wptr= wptr; |  |  | f->wptr= wptr; | 
														
													
														
															
																|  |  | return total - size; |  |  | return total - size; | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  | 
 |  |  | 
 | 
														
													
														
															
																|  |  |  |  |  |  | 
														
													
														
															
																|  |  | int av_fifo_generic_read(AVFifoBuffer *f, void *dest, int buf_size, void (*func)(void*, void*, int)) |  |  |  | 
														
													
														
															
																|  |  |  |  |  | int av_fifo_generic_read(AVFifoBuffer *f, void *dest, int buf_size, | 
														
													
														
															
																|  |  |  |  |  | void (*func)(void *, void *, int)) | 
														
													
														
															
																|  |  | { |  |  | { | 
														
													
														
															
																|  |  | // Read memory barrier needed for SMP here in theory |  |  | // Read memory barrier needed for SMP here in theory | 
														
													
														
															
																|  |  | do { |  |  | do { | 
														
													
														
															
																|  |  | int len = FFMIN(f->end - f->rptr, buf_size); |  |  | int len = FFMIN(f->end - f->rptr, buf_size); | 
														
													
														
															
																|  |  | if(func) func(dest, f->rptr, len); |  |  |  | 
														
													
														
															
																|  |  | else{ |  |  |  | 
														
													
														
															
																|  |  |  |  |  | if (func) | 
														
													
														
															
																|  |  |  |  |  | func(dest, f->rptr, len); | 
														
													
														
															
																|  |  |  |  |  | else { | 
														
													
														
															
																|  |  | memcpy(dest, f->rptr, len); |  |  | memcpy(dest, f->rptr, len); | 
														
													
														
															
																|  |  | dest = (uint8_t*)dest + len; |  |  |  | 
														
													
														
															
																|  |  |  |  |  | dest = (uint8_t *)dest + len; | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  | // memory barrier needed for SMP here in theory |  |  | // memory barrier needed for SMP here in theory | 
														
													
														
															
																|  |  | av_fifo_drain(f, len); |  |  | av_fifo_drain(f, len); | 
														
													
												
													
														
															
																|  | @@ -160,9 +163,9 @@ int main(void) | 
														
													
														
															
																|  |  | av_fifo_generic_write(fifo, &i, sizeof(int), NULL); |  |  | av_fifo_generic_write(fifo, &i, sizeof(int), NULL); | 
														
													
														
															
																|  |  | 
 |  |  | 
 | 
														
													
														
															
																|  |  | /* peek at FIFO */ |  |  | /* peek at FIFO */ | 
														
													
														
															
																|  |  | n = av_fifo_size(fifo)/sizeof(int); |  |  |  | 
														
													
														
															
																|  |  | for (i = -n+1; i < n; i++) { |  |  |  | 
														
													
														
															
																|  |  | int *v = (int *)av_fifo_peek2(fifo, i*sizeof(int)); |  |  |  | 
														
													
														
															
																|  |  |  |  |  | n = av_fifo_size(fifo) / sizeof(int); | 
														
													
														
															
																|  |  |  |  |  | for (i = -n + 1; i < n; i++) { | 
														
													
														
															
																|  |  |  |  |  | int *v = (int *)av_fifo_peek2(fifo, i * sizeof(int)); | 
														
													
														
															
																|  |  | printf("%d: %d\n", i, *v); |  |  | printf("%d: %d\n", i, *v); | 
														
													
														
															
																|  |  | } |  |  | } | 
														
													
														
															
																|  |  | printf("\n"); |  |  | printf("\n"); | 
														
													
												
													
														
															
																|  | 
 |