blob: 0a7e88277d2299343bbf7613cc026c6458256e50 [file] [log] [blame]
Jason Sams25430d02010-02-02 15:26:40 -08001/*
Jason Sams5b08a2d2013-02-08 11:22:17 -08002 * Copyright (C) 2013 The Android Open Source Project
Jason Sams25430d02010-02-02 15:26:40 -08003 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17package android.renderscript;
18
19
Stephen Hines9c9ad3f8c22012-05-07 15:34:29 -070020/**
Robert Ly11518ac2011-02-09 13:57:06 -080021 * Utility class for packing arguments and structures from Android system objects to
22 * Renderscript objects.
Jason Sams42d6c9e2010-02-02 15:45:58 -080023 *
24 **/
Jason Sams25430d02010-02-02 15:26:40 -080025public class FieldPacker {
26 public FieldPacker(int len) {
27 mPos = 0;
Stephen Hinese27832a2011-06-02 19:36:41 -070028 mLen = len;
Jason Sams25430d02010-02-02 15:26:40 -080029 mData = new byte[len];
30 }
31
Jason Sams5b08a2d2013-02-08 11:22:17 -080032 public FieldPacker(byte[] data) {
33 mPos = 0;
34 mLen = data.length;
35 mData = data;
36 }
37
Jason Sams25430d02010-02-02 15:26:40 -080038 public void align(int v) {
Stephen Hinese27832a2011-06-02 19:36:41 -070039 if ((v <= 0) || ((v & (v - 1)) != 0)) {
40 throw new RSIllegalArgumentException("argument must be a non-negative non-zero power of 2: " + v);
41 }
42
Jason Sams25430d02010-02-02 15:26:40 -080043 while ((mPos & (v - 1)) != 0) {
44 mData[mPos++] = 0;
45 }
46 }
47
Jason Samsa70f4162010-03-26 15:33:42 -070048 public void reset() {
Jason Sams25430d02010-02-02 15:26:40 -080049 mPos = 0;
50 }
Jason Samsa70f4162010-03-26 15:33:42 -070051 public void reset(int i) {
Stephen Hinese27832a2011-06-02 19:36:41 -070052 if ((i < 0) || (i >= mLen)) {
53 throw new RSIllegalArgumentException("out of range argument: " + i);
54 }
Jason Samsa70f4162010-03-26 15:33:42 -070055 mPos = i;
56 }
Jason Sams25430d02010-02-02 15:26:40 -080057
Jason Sams020bb7b2010-06-17 15:55:00 -070058 public void skip(int i) {
Stephen Hinese27832a2011-06-02 19:36:41 -070059 int res = mPos + i;
Shih-wei Liao6e667252011-06-05 00:51:54 -070060 if ((res < 0) || (res > mLen)) {
Stephen Hinese27832a2011-06-02 19:36:41 -070061 throw new RSIllegalArgumentException("out of range argument: " + i);
62 }
63 mPos = res;
Jason Sams020bb7b2010-06-17 15:55:00 -070064 }
65
Jason Samsa70f4162010-03-26 15:33:42 -070066 public void addI8(byte v) {
Jason Sams25430d02010-02-02 15:26:40 -080067 mData[mPos++] = v;
68 }
69
Jason Samsa70f4162010-03-26 15:33:42 -070070 public void addI16(short v) {
Jason Sams25430d02010-02-02 15:26:40 -080071 align(2);
72 mData[mPos++] = (byte)(v & 0xff);
73 mData[mPos++] = (byte)(v >> 8);
74 }
75
Jason Samsa70f4162010-03-26 15:33:42 -070076 public void addI32(int v) {
Jason Sams25430d02010-02-02 15:26:40 -080077 align(4);
78 mData[mPos++] = (byte)(v & 0xff);
79 mData[mPos++] = (byte)((v >> 8) & 0xff);
80 mData[mPos++] = (byte)((v >> 16) & 0xff);
81 mData[mPos++] = (byte)((v >> 24) & 0xff);
82 }
83
Jason Samsa70f4162010-03-26 15:33:42 -070084 public void addI64(long v) {
Jason Sams25430d02010-02-02 15:26:40 -080085 align(8);
86 mData[mPos++] = (byte)(v & 0xff);
87 mData[mPos++] = (byte)((v >> 8) & 0xff);
88 mData[mPos++] = (byte)((v >> 16) & 0xff);
89 mData[mPos++] = (byte)((v >> 24) & 0xff);
90 mData[mPos++] = (byte)((v >> 32) & 0xff);
91 mData[mPos++] = (byte)((v >> 40) & 0xff);
92 mData[mPos++] = (byte)((v >> 48) & 0xff);
93 mData[mPos++] = (byte)((v >> 56) & 0xff);
94 }
95
Jason Samsa70f4162010-03-26 15:33:42 -070096 public void addU8(short v) {
Jason Sams25430d02010-02-02 15:26:40 -080097 if ((v < 0) || (v > 0xff)) {
Jason Samsee734982010-08-12 12:44:02 -070098 android.util.Log.e("rs", "FieldPacker.addU8( " + v + " )");
Jason Sams25430d02010-02-02 15:26:40 -080099 throw new IllegalArgumentException("Saving value out of range for type");
100 }
101 mData[mPos++] = (byte)v;
102 }
103
Jason Samsa70f4162010-03-26 15:33:42 -0700104 public void addU16(int v) {
Jason Sams25430d02010-02-02 15:26:40 -0800105 if ((v < 0) || (v > 0xffff)) {
Jason Samsee734982010-08-12 12:44:02 -0700106 android.util.Log.e("rs", "FieldPacker.addU16( " + v + " )");
Jason Sams25430d02010-02-02 15:26:40 -0800107 throw new IllegalArgumentException("Saving value out of range for type");
108 }
109 align(2);
110 mData[mPos++] = (byte)(v & 0xff);
111 mData[mPos++] = (byte)(v >> 8);
112 }
113
Jason Samsa70f4162010-03-26 15:33:42 -0700114 public void addU32(long v) {
Jason Samsee734982010-08-12 12:44:02 -0700115 if ((v < 0) || (v > 0xffffffffL)) {
116 android.util.Log.e("rs", "FieldPacker.addU32( " + v + " )");
Jason Sams25430d02010-02-02 15:26:40 -0800117 throw new IllegalArgumentException("Saving value out of range for type");
118 }
119 align(4);
120 mData[mPos++] = (byte)(v & 0xff);
121 mData[mPos++] = (byte)((v >> 8) & 0xff);
122 mData[mPos++] = (byte)((v >> 16) & 0xff);
123 mData[mPos++] = (byte)((v >> 24) & 0xff);
124 }
125
Jason Samsa70f4162010-03-26 15:33:42 -0700126 public void addU64(long v) {
Jason Sams25430d02010-02-02 15:26:40 -0800127 if (v < 0) {
Jason Samsee734982010-08-12 12:44:02 -0700128 android.util.Log.e("rs", "FieldPacker.addU64( " + v + " )");
Jason Sams25430d02010-02-02 15:26:40 -0800129 throw new IllegalArgumentException("Saving value out of range for type");
130 }
131 align(8);
132 mData[mPos++] = (byte)(v & 0xff);
133 mData[mPos++] = (byte)((v >> 8) & 0xff);
134 mData[mPos++] = (byte)((v >> 16) & 0xff);
135 mData[mPos++] = (byte)((v >> 24) & 0xff);
136 mData[mPos++] = (byte)((v >> 32) & 0xff);
137 mData[mPos++] = (byte)((v >> 40) & 0xff);
138 mData[mPos++] = (byte)((v >> 48) & 0xff);
139 mData[mPos++] = (byte)((v >> 56) & 0xff);
140 }
141
Jason Samsa70f4162010-03-26 15:33:42 -0700142 public void addF32(float v) {
Jason Sams25430d02010-02-02 15:26:40 -0800143 addI32(Float.floatToRawIntBits(v));
144 }
145
Stephen Hines02f417052010-09-30 15:19:22 -0700146 public void addF64(double v) {
Jason Sams25430d02010-02-02 15:26:40 -0800147 addI64(Double.doubleToRawLongBits(v));
148 }
149
Jason Samsa70f4162010-03-26 15:33:42 -0700150 public void addObj(BaseObj obj) {
151 if (obj != null) {
Jason Samse07694b2012-04-03 15:36:36 -0700152 addI32(obj.getID(null));
Jason Samsa70f4162010-03-26 15:33:42 -0700153 } else {
154 addI32(0);
155 }
156 }
157
158 public void addF32(Float2 v) {
159 addF32(v.x);
160 addF32(v.y);
161 }
162 public void addF32(Float3 v) {
163 addF32(v.x);
164 addF32(v.y);
165 addF32(v.z);
166 }
167 public void addF32(Float4 v) {
168 addF32(v.x);
169 addF32(v.y);
170 addF32(v.z);
171 addF32(v.w);
172 }
173
Stephen Hines79ad3f22011-06-20 17:27:09 -0700174 public void addF64(Double2 v) {
175 addF64(v.x);
176 addF64(v.y);
177 }
178 public void addF64(Double3 v) {
179 addF64(v.x);
180 addF64(v.y);
181 addF64(v.z);
182 }
183 public void addF64(Double4 v) {
184 addF64(v.x);
185 addF64(v.y);
186 addF64(v.z);
187 addF64(v.w);
188 }
189
Jason Samsa70f4162010-03-26 15:33:42 -0700190 public void addI8(Byte2 v) {
191 addI8(v.x);
192 addI8(v.y);
193 }
194 public void addI8(Byte3 v) {
195 addI8(v.x);
196 addI8(v.y);
197 addI8(v.z);
198 }
199 public void addI8(Byte4 v) {
200 addI8(v.x);
201 addI8(v.y);
202 addI8(v.z);
203 addI8(v.w);
204 }
205
206 public void addU8(Short2 v) {
207 addU8(v.x);
208 addU8(v.y);
209 }
210 public void addU8(Short3 v) {
211 addU8(v.x);
212 addU8(v.y);
213 addU8(v.z);
214 }
215 public void addU8(Short4 v) {
216 addU8(v.x);
217 addU8(v.y);
218 addU8(v.z);
219 addU8(v.w);
220 }
221
222 public void addI16(Short2 v) {
223 addI16(v.x);
224 addI16(v.y);
225 }
226 public void addI16(Short3 v) {
227 addI16(v.x);
228 addI16(v.y);
229 addI16(v.z);
230 }
231 public void addI16(Short4 v) {
232 addI16(v.x);
233 addI16(v.y);
234 addI16(v.z);
235 addI16(v.w);
236 }
237
238 public void addU16(Int2 v) {
239 addU16(v.x);
240 addU16(v.y);
241 }
242 public void addU16(Int3 v) {
243 addU16(v.x);
244 addU16(v.y);
245 addU16(v.z);
246 }
247 public void addU16(Int4 v) {
248 addU16(v.x);
249 addU16(v.y);
250 addU16(v.z);
251 addU16(v.w);
252 }
253
254 public void addI32(Int2 v) {
255 addI32(v.x);
256 addI32(v.y);
257 }
258 public void addI32(Int3 v) {
259 addI32(v.x);
260 addI32(v.y);
261 addI32(v.z);
262 }
263 public void addI32(Int4 v) {
264 addI32(v.x);
265 addI32(v.y);
266 addI32(v.z);
267 addI32(v.w);
268 }
269
Stephen Hinese9f5c182011-01-20 18:17:25 -0800270 public void addU32(Long2 v) {
Jason Samsa70f4162010-03-26 15:33:42 -0700271 addU32(v.x);
272 addU32(v.y);
273 }
Stephen Hinese9f5c182011-01-20 18:17:25 -0800274 public void addU32(Long3 v) {
Jason Samsa70f4162010-03-26 15:33:42 -0700275 addU32(v.x);
276 addU32(v.y);
277 addU32(v.z);
278 }
Stephen Hinese9f5c182011-01-20 18:17:25 -0800279 public void addU32(Long4 v) {
Jason Samsa70f4162010-03-26 15:33:42 -0700280 addU32(v.x);
281 addU32(v.y);
282 addU32(v.z);
283 addU32(v.w);
284 }
285
Stephen Hines79ad3f22011-06-20 17:27:09 -0700286 public void addI64(Long2 v) {
287 addI64(v.x);
288 addI64(v.y);
289 }
290 public void addI64(Long3 v) {
291 addI64(v.x);
292 addI64(v.y);
293 addI64(v.z);
294 }
295 public void addI64(Long4 v) {
296 addI64(v.x);
297 addI64(v.y);
298 addI64(v.z);
299 addI64(v.w);
300 }
301
302 public void addU64(Long2 v) {
303 addU64(v.x);
304 addU64(v.y);
305 }
306 public void addU64(Long3 v) {
307 addU64(v.x);
308 addU64(v.y);
309 addU64(v.z);
310 }
311 public void addU64(Long4 v) {
312 addU64(v.x);
313 addU64(v.y);
314 addU64(v.z);
315 addU64(v.w);
316 }
317
Alex Sakhartchouke27cdee2010-12-17 11:41:08 -0800318 public void addMatrix(Matrix4f v) {
319 for (int i=0; i < v.mMat.length; i++) {
320 addF32(v.mMat[i]);
321 }
322 }
323
324 public void addMatrix(Matrix3f v) {
325 for (int i=0; i < v.mMat.length; i++) {
326 addF32(v.mMat[i]);
327 }
328 }
329
330 public void addMatrix(Matrix2f v) {
331 for (int i=0; i < v.mMat.length; i++) {
332 addF32(v.mMat[i]);
333 }
334 }
335
Jason Samsfae3f6b2010-06-24 13:54:11 -0700336 public void addBoolean(boolean v) {
Jason Sams9e2b0c52010-06-21 18:30:02 -0700337 addI8((byte)(v ? 1 : 0));
Jason Samsf110d4b2010-06-21 17:42:41 -0700338 }
339
Jason Samsa70f4162010-03-26 15:33:42 -0700340 public final byte[] getData() {
Jason Sams25430d02010-02-02 15:26:40 -0800341 return mData;
342 }
343
344 private final byte mData[];
345 private int mPos;
Stephen Hinese27832a2011-06-02 19:36:41 -0700346 private int mLen;
Jason Sams25430d02010-02-02 15:26:40 -0800347
348}
349
350