annotate tomi/intreadwrite.h @ 1028:5dbb12a37c3d libavutil tip

Move av_set_options_string() from libavfilter to libavutil.
author stefano
date Mon, 27 Sep 2010 22:09:53 +0000
parents e0f7001ef072
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
841
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
1 /*
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
2 * Copyright (c) 2010 Mans Rullgard <mans@mansr.com>
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
3 *
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
4 * This file is part of FFmpeg.
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
5 *
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
6 * FFmpeg is free software; you can redistribute it and/or
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
7 * modify it under the terms of the GNU Lesser General Public
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
8 * License as published by the Free Software Foundation; either
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
9 * version 2.1 of the License, or (at your option) any later version.
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
10 *
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
11 * FFmpeg is distributed in the hope that it will be useful,
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
14 * Lesser General Public License for more details.
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
15 *
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
16 * You should have received a copy of the GNU Lesser General Public
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
17 * License along with FFmpeg; if not, write to the Free Software
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
19 */
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
20
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
21 #ifndef AVUTIL_TOMI_INTREADWRITE_H
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
22 #define AVUTIL_TOMI_INTREADWRITE_H
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
23
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
24 #include <stdint.h>
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
25 #include "config.h"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
26
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
27 #define AV_RB16 AV_RB16
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
28 static av_always_inline uint16_t AV_RB16(const void *p)
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
29 {
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
30 uint16_t v;
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
31 __asm__ ("loadacc, (%1+) \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
32 "rol8 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
33 "storeacc, %0 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
34 "loadacc, (%1+) \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
35 "add, %0 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
36 : "=r"(v), "+a"(p));
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
37 return v;
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
38 }
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
39
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
40 #define AV_WB16 AV_WB16
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
41 static av_always_inline void AV_WB16(void *p, uint16_t v)
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
42 {
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
43 __asm__ volatile ("loadacc, %1 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
44 "lsr8 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
45 "storeacc, (%0+) \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
46 "loadacc, %1 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
47 "storeacc, (%0+) \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
48 : "+&a"(p) : "r"(v));
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
49 }
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
50
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
51 #define AV_RL16 AV_RL16
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
52 static av_always_inline uint16_t AV_RL16(const void *p)
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
53 {
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
54 uint16_t v;
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
55 __asm__ ("loadacc, (%1+) \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
56 "storeacc, %0 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
57 "loadacc, (%1+) \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
58 "rol8 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
59 "add, %0 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
60 : "=r"(v), "+a"(p));
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
61 return v;
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
62 }
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
63
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
64 #define AV_WL16 AV_WL16
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
65 static av_always_inline void AV_WL16(void *p, uint16_t v)
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
66 {
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
67 __asm__ volatile ("loadacc, %1 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
68 "storeacc, (%0+) \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
69 "lsr8 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
70 "storeacc, (%0+) \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
71 : "+&a"(p) : "r"(v));
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
72 }
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
73
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
74 #define AV_RB32 AV_RB32
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
75 static av_always_inline uint32_t AV_RB32(const void *p)
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
76 {
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
77 uint32_t v;
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
78 __asm__ ("loadacc, (%1+) \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
79 "rol8 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
80 "rol8 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
81 "rol8 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
82 "storeacc, %0 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
83 "loadacc, (%1+) \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
84 "rol8 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
85 "rol8 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
86 "add, %0 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
87 "loadacc, (%1+) \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
88 "rol8 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
89 "add, %0 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
90 "loadacc, (%1+) \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
91 "add, %0 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
92 : "=r"(v), "+a"(p));
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
93 return v;
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
94 }
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
95
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
96 #define AV_WB32 AV_WB32
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
97 static av_always_inline void AV_WB32(void *p, uint32_t v)
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
98 {
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
99 __asm__ volatile ("loadacc, #4 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
100 "add, %0 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
101 "loadacc, %1 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
102 "storeacc, (-%0) \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
103 "lsr8 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
104 "storeacc, (-%0) \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
105 "lsr8 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
106 "storeacc, (-%0) \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
107 "lsr8 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
108 "storeacc, (-%0) \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
109 : "+&a"(p) : "r"(v));
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
110 }
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
111
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
112 #define AV_RL32 AV_RL32
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
113 static av_always_inline uint32_t AV_RL32(const void *p)
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
114 {
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
115 uint32_t v;
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
116 __asm__ ("loadacc, (%1+) \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
117 "storeacc, %0 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
118 "loadacc, (%1+) \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
119 "rol8 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
120 "add, %0 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
121 "loadacc, (%1+) \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
122 "rol8 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
123 "rol8 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
124 "add, %0 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
125 "loadacc, (%1+) \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
126 "rol8 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
127 "rol8 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
128 "rol8 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
129 "add, %0 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
130 : "=r"(v), "+a"(p));
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
131 return v;
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
132 }
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
133
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
134 #define AV_WL32 AV_WL32
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
135 static av_always_inline void AV_WL32(void *p, uint32_t v)
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
136 {
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
137 __asm__ volatile ("loadacc, %1 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
138 "storeacc, (%0+) \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
139 "lsr8 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
140 "storeacc, (%0+) \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
141 "lsr8 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
142 "storeacc, (%0+) \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
143 "lsr8 \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
144 "storeacc, (%0+) \n\t"
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
145 : "+&a"(p) : "r"(v));
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
146 }
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
147
e0f7001ef072 TOMI: 16- and 32-bit intreadwrite functions
mru
parents:
diff changeset
148 #endif /* AVUTIL_TOMI_INTREADWRITE_H */