Mercurial > libavutil.hg
annotate fifo.c @ 862:434a611c1e54 libavutil
Add lots of missing includes
author | mru |
---|---|
date | Mon, 08 Mar 2010 18:43:52 +0000 |
parents | 9b61454d2fee |
children |
rev | line source |
---|---|
110 | 1 /* |
633 | 2 * a very simple circular buffer FIFO implementation |
110 | 3 * Copyright (c) 2000, 2001, 2002 Fabrice Bellard |
4 * Copyright (c) 2006 Roman Shaposhnik | |
5 * | |
116
d76a36742464
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
110
diff
changeset
|
6 * This file is part of FFmpeg. |
d76a36742464
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
110
diff
changeset
|
7 * |
d76a36742464
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
110
diff
changeset
|
8 * FFmpeg is free software; you can redistribute it and/or |
110 | 9 * modify it under the terms of the GNU Lesser General Public |
10 * License as published by the Free Software Foundation; either | |
116
d76a36742464
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
110
diff
changeset
|
11 * version 2.1 of the License, or (at your option) any later version. |
110 | 12 * |
116
d76a36742464
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
110
diff
changeset
|
13 * FFmpeg is distributed in the hope that it will be useful, |
110 | 14 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
16 * Lesser General Public License for more details. | |
17 * | |
18 * You should have received a copy of the GNU Lesser General Public | |
116
d76a36742464
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
110
diff
changeset
|
19 * License along with FFmpeg; if not, write to the Free Software |
110 | 20 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
21 */ | |
22 #include "common.h" | |
23 #include "fifo.h" | |
24 | |
679
58a5033060c3
Allocate AVFifoBuffer through the fifo API to reduce future API/ABI issues.
michael
parents:
677
diff
changeset
|
25 AVFifoBuffer *av_fifo_alloc(unsigned int size) |
110 | 26 { |
679
58a5033060c3
Allocate AVFifoBuffer through the fifo API to reduce future API/ABI issues.
michael
parents:
677
diff
changeset
|
27 AVFifoBuffer *f= av_mallocz(sizeof(AVFifoBuffer)); |
58a5033060c3
Allocate AVFifoBuffer through the fifo API to reduce future API/ABI issues.
michael
parents:
677
diff
changeset
|
28 if(!f) |
58a5033060c3
Allocate AVFifoBuffer through the fifo API to reduce future API/ABI issues.
michael
parents:
677
diff
changeset
|
29 return NULL; |
110 | 30 f->buffer = av_malloc(size); |
229
3f5c648b82c4
simpler branch structure in init (16 bytes smaller object file)
michael
parents:
228
diff
changeset
|
31 f->end = f->buffer + size; |
688
91216685a7ae
Add av_fifo_reset function to completely reset fifo state, which makes
reimar
parents:
687
diff
changeset
|
32 av_fifo_reset(f); |
110 | 33 if (!f->buffer) |
679
58a5033060c3
Allocate AVFifoBuffer through the fifo API to reduce future API/ABI issues.
michael
parents:
677
diff
changeset
|
34 av_freep(&f); |
58a5033060c3
Allocate AVFifoBuffer through the fifo API to reduce future API/ABI issues.
michael
parents:
677
diff
changeset
|
35 return f; |
110 | 36 } |
37 | |
38 void av_fifo_free(AVFifoBuffer *f) | |
39 { | |
679
58a5033060c3
Allocate AVFifoBuffer through the fifo API to reduce future API/ABI issues.
michael
parents:
677
diff
changeset
|
40 if(f){ |
687 | 41 av_free(f->buffer); |
42 av_free(f); | |
679
58a5033060c3
Allocate AVFifoBuffer through the fifo API to reduce future API/ABI issues.
michael
parents:
677
diff
changeset
|
43 } |
110 | 44 } |
45 | |
688
91216685a7ae
Add av_fifo_reset function to completely reset fifo state, which makes
reimar
parents:
687
diff
changeset
|
46 void av_fifo_reset(AVFifoBuffer *f) |
91216685a7ae
Add av_fifo_reset function to completely reset fifo state, which makes
reimar
parents:
687
diff
changeset
|
47 { |
91216685a7ae
Add av_fifo_reset function to completely reset fifo state, which makes
reimar
parents:
687
diff
changeset
|
48 f->wptr = f->rptr = f->buffer; |
91216685a7ae
Add av_fifo_reset function to completely reset fifo state, which makes
reimar
parents:
687
diff
changeset
|
49 f->wndx = f->rndx = 0; |
91216685a7ae
Add av_fifo_reset function to completely reset fifo state, which makes
reimar
parents:
687
diff
changeset
|
50 } |
91216685a7ae
Add av_fifo_reset function to completely reset fifo state, which makes
reimar
parents:
687
diff
changeset
|
51 |
110 | 52 int av_fifo_size(AVFifoBuffer *f) |
53 { | |
676 | 54 return (uint32_t)(f->wndx - f->rndx); |
110 | 55 } |
56 | |
722 | 57 int av_fifo_space(AVFifoBuffer *f) |
58 { | |
59 return f->end - f->buffer - av_fifo_size(f); | |
60 } | |
61 | |
564 | 62 int av_fifo_realloc2(AVFifoBuffer *f, unsigned int new_size) { |
110 | 63 unsigned int old_size= f->end - f->buffer; |
64 | |
676 | 65 if(old_size < new_size){ |
225 | 66 int len= av_fifo_size(f); |
679
58a5033060c3
Allocate AVFifoBuffer through the fifo API to reduce future API/ABI issues.
michael
parents:
677
diff
changeset
|
67 AVFifoBuffer *f2= av_fifo_alloc(new_size); |
110 | 68 |
679
58a5033060c3
Allocate AVFifoBuffer through the fifo API to reduce future API/ABI issues.
michael
parents:
677
diff
changeset
|
69 if (!f2) |
564 | 70 return -1; |
691
4e9e0c52ed08
Reorder arguments for av_fifo_generic_read to be more logical and
reimar
parents:
688
diff
changeset
|
71 av_fifo_generic_read(f, f2->buffer, len, NULL); |
679
58a5033060c3
Allocate AVFifoBuffer through the fifo API to reduce future API/ABI issues.
michael
parents:
677
diff
changeset
|
72 f2->wptr += len; |
58a5033060c3
Allocate AVFifoBuffer through the fifo API to reduce future API/ABI issues.
michael
parents:
677
diff
changeset
|
73 f2->wndx += len; |
225 | 74 av_free(f->buffer); |
679
58a5033060c3
Allocate AVFifoBuffer through the fifo API to reduce future API/ABI issues.
michael
parents:
677
diff
changeset
|
75 *f= *f2; |
58a5033060c3
Allocate AVFifoBuffer through the fifo API to reduce future API/ABI issues.
michael
parents:
677
diff
changeset
|
76 av_free(f2); |
110 | 77 } |
564 | 78 return 0; |
110 | 79 } |
80 | |
847
9b61454d2fee
Clarify non constness of src in av_fifo_generic_write()
michael
parents:
722
diff
changeset
|
81 // src must NOT be const as it can be a context for func that may need updating (like a pointer or byte counter) |
493 | 82 int av_fifo_generic_write(AVFifoBuffer *f, void *src, int size, int (*func)(void*, void*, int)) |
492 | 83 { |
84 int total = size; | |
230
4c85ac99ab37
change while loops to do-while as the condition is true the first time and the check just wastes cpu cycles
michael
parents:
229
diff
changeset
|
85 do { |
223 | 86 int len = FFMIN(f->end - f->wptr, size); |
492 | 87 if(func) { |
493 | 88 if(func(src, f->wptr, len) <= 0) |
492 | 89 break; |
90 } else { | |
493 | 91 memcpy(f->wptr, src, len); |
92 src = (uint8_t*)src + len; | |
492 | 93 } |
677
5dd1730abf98
Comments to indicate where memory barriers may be needed.
michael
parents:
676
diff
changeset
|
94 // Write memory barrier needed for SMP here in theory |
110 | 95 f->wptr += len; |
96 if (f->wptr >= f->end) | |
97 f->wptr = f->buffer; | |
676 | 98 f->wndx += len; |
110 | 99 size -= len; |
230
4c85ac99ab37
change while loops to do-while as the condition is true the first time and the check just wastes cpu cycles
michael
parents:
229
diff
changeset
|
100 } while (size > 0); |
492 | 101 return total - size; |
110 | 102 } |
103 | |
104 | |
691
4e9e0c52ed08
Reorder arguments for av_fifo_generic_read to be more logical and
reimar
parents:
688
diff
changeset
|
105 int av_fifo_generic_read(AVFifoBuffer *f, void *dest, int buf_size, void (*func)(void*, void*, int)) |
110 | 106 { |
677
5dd1730abf98
Comments to indicate where memory barriers may be needed.
michael
parents:
676
diff
changeset
|
107 // Read memory barrier needed for SMP here in theory |
230
4c85ac99ab37
change while loops to do-while as the condition is true the first time and the check just wastes cpu cycles
michael
parents:
229
diff
changeset
|
108 do { |
223 | 109 int len = FFMIN(f->end - f->rptr, buf_size); |
224 | 110 if(func) func(dest, f->rptr, len); |
111 else{ | |
112 memcpy(dest, f->rptr, len); | |
113 dest = (uint8_t*)dest + len; | |
114 } | |
677
5dd1730abf98
Comments to indicate where memory barriers may be needed.
michael
parents:
676
diff
changeset
|
115 // memory barrier needed for SMP here in theory |
227 | 116 av_fifo_drain(f, len); |
110 | 117 buf_size -= len; |
230
4c85ac99ab37
change while loops to do-while as the condition is true the first time and the check just wastes cpu cycles
michael
parents:
229
diff
changeset
|
118 } while (buf_size > 0); |
110 | 119 return 0; |
120 } | |
121 | |
633 | 122 /** Discard data from the FIFO. */ |
110 | 123 void av_fifo_drain(AVFifoBuffer *f, int size) |
124 { | |
125 f->rptr += size; | |
126 if (f->rptr >= f->end) | |
127 f->rptr -= f->end - f->buffer; | |
676 | 128 f->rndx += size; |
110 | 129 } |