]> Gitweb @ Texas Instruments - Open Source Git Repositories - git.TI.com/gitweb - android/platform-hardware-interfaces.git/blob - tests/baz/1.0/default/Baz.cpp
Adds test cases to stress marshaling of primitive array types and
[android/platform-hardware-interfaces.git] / tests / baz / 1.0 / default / Baz.cpp
1 /*
2  * Copyright (C) 2017 The Android Open Source Project
3  *
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  */
17 #include "Baz.h"
18 #include <android-base/logging.h>
20 namespace android {
21 namespace hardware {
22 namespace tests {
23 namespace baz {
24 namespace V1_0 {
25 namespace implementation {
27 struct BazCallback : public IBazCallback {
28     Return<void> heyItsMe(const sp<IBazCallback> &cb) override;
29     Return<void> hey() override;
30 };
32 Return<void> BazCallback::heyItsMe(
33         const sp<IBazCallback> &cb) {
34     LOG(INFO) << "SERVER: heyItsMe cb = " << cb.get();
36     return Void();
37 }
39 Return<void> BazCallback::hey() {
40     LOG(INFO) << "SERVER: hey";
42     return Void();
43 }
45 // Methods from ::android::hardware::tests::baz::V1_0::IBase follow.
46 Return<void> Baz::someBaseMethod() {
47     LOG(INFO) << "Baz::someBaseMethod";
49     return Void();
50 }
52 Return<bool> Baz::someBoolMethod(bool x) {
53     LOG(INFO) << "Baz::someBoolMethod(" << std::to_string(x) << ")";
55     return !x;
56 }
58 Return<void> Baz::someBoolArrayMethod(const hidl_array<bool, 3>& x,
59                                       someBoolArrayMethod_cb _hidl_cb) {
60     LOG(INFO) << "Baz::someBoolArrayMethod(" << toString(x) << ")";
62     hidl_array<bool, 4> out;
63     out[0] = !x[0];
64     out[1] = !x[1];
65     out[2] = !x[2];
66     out[3] = true;
68     _hidl_cb(out);
70     return Void();
71 }
73 Return<void> Baz::someBoolVectorMethod(const hidl_vec<bool>& x, someBoolVectorMethod_cb _hidl_cb) {
74     LOG(INFO) << "Baz::someBoolVectorMethod(" << toString(x) << ")";
76     hidl_vec<bool> out;
77     out.resize(x.size());
78     for (size_t i = 0; i < x.size(); ++i) {
79         out[i] = !x[i];
80     }
82     _hidl_cb(out);
84     return Void();
85 }
87 Return<void> Baz::someOtherBaseMethod(const IBase::Foo& foo, someOtherBaseMethod_cb _hidl_cb) {
88     LOG(INFO) << "Baz::someOtherBaseMethod "
89               << toString(foo);
91     _hidl_cb(foo);
93     return Void();
94 }
96 Return<void> Baz::someMethodWithFooArrays(const hidl_array<IBase::Foo, 2>& fooInput,
97                                           someMethodWithFooArrays_cb _hidl_cb) {
98     LOG(INFO) << "Baz::someMethodWithFooArrays "
99               << toString(fooInput);
101     hidl_array<IBaz::Foo, 2> fooOutput;
102     fooOutput[0] = fooInput[1];
103     fooOutput[1] = fooInput[0];
105     _hidl_cb(fooOutput);
107     return Void();
110 Return<void> Baz::someMethodWithFooVectors(const hidl_vec<IBase::Foo>& fooInput,
111                                            someMethodWithFooVectors_cb _hidl_cb) {
112     LOG(INFO) << "Baz::someMethodWithFooVectors "
113               << toString(fooInput);
115     hidl_vec<IBaz::Foo> fooOutput;
116     fooOutput.resize(2);
117     fooOutput[0] = fooInput[1];
118     fooOutput[1] = fooInput[0];
120     _hidl_cb(fooOutput);
122     return Void();
125 Return<void> Baz::someMethodWithVectorOfArray(const IBase::VectorOfArray& in,
126                                               someMethodWithVectorOfArray_cb _hidl_cb) {
127     LOG(INFO) << "Baz::someMethodWithVectorOfArray "
128               << toString(in);
130     IBase::VectorOfArray out;
132     const size_t n = in.addresses.size();
133     out.addresses.resize(n);
135     for (size_t i = 0; i < n; ++i) {
136         out.addresses[i] = in.addresses[n - 1 - i];
137     }
139     _hidl_cb(out);
141     return Void();
144 Return<void> Baz::someMethodTakingAVectorOfArray(const hidl_vec<hidl_array<uint8_t, 6>>& in,
145                                                  someMethodTakingAVectorOfArray_cb _hidl_cb) {
146     LOG(INFO) << "Baz::someMethodTakingAVectorOfArray "
147               << toString(in);
149     const size_t n = in.size();
151     hidl_vec<hidl_array<uint8_t, 6> > out;
152     out.resize(n);
154     for (size_t i = 0; i < n; ++i) {
155         out[i] = in[n - 1 - i];
156     }
158     _hidl_cb(out);
160     return Void();
163 Return<void> Baz::transpose(const IBase::StringMatrix5x3& in, transpose_cb _hidl_cb) {
164     LOG(INFO) << "Baz::transpose " << toString(in);
166     IBase::StringMatrix3x5 out;
167     for (size_t i = 0; i < 3; ++i) {
168         for (size_t j = 0; j < 5; ++j) {
169             out.s[i][j] = in.s[j][i];
170         }
171     }
173     _hidl_cb(out);
175     return Void();
178 Return<void> Baz::transpose2(const hidl_array<hidl_string, 5, 3>& in, transpose2_cb _hidl_cb) {
179     LOG(INFO) << "Baz::transpose2 " << toString(in);
181     hidl_array<hidl_string, 3, 5> out;
182     for (size_t i = 0; i < 3; ++i) {
183         for (size_t j = 0; j < 5; ++j) {
184             out[i][j] = in[j][i];
185         }
186     }
188     _hidl_cb(out);
190     return Void();
193 Return<void> Baz::takeAMask(IBase::BitField bf,
194                             uint8_t first,
195                             const IBase::MyMask& second,
196                             uint8_t third,
197                             takeAMask_cb _hidl_cb) {
198     _hidl_cb(bf, bf | first, second.value & bf, (bf | bf) & third);
199     return Void();
202 Return<void> Baz::testArrays(
203         const IBase::LotsOfPrimitiveArrays &in,
204         testArrays_cb _hidl_cb) {
205     _hidl_cb(in);
206     return Void();
209 Return<void> Baz::testByteVecs(
210         const hidl_vec<IBase::ByteOneDim> &in,
211         testByteVecs_cb _hidl_cb) {
212     _hidl_cb(in);
213     return Void();
216 Return<void> Baz::testBooleanVecs(
217         const hidl_vec<IBase::BooleanOneDim> &in,
218         testBooleanVecs_cb _hidl_cb) {
219     _hidl_cb(in);
220     return Void();
223 Return<void> Baz::testDoubleVecs(
224         const hidl_vec<IBase::DoubleOneDim> &in,
225         testDoubleVecs_cb _hidl_cb) {
226     _hidl_cb(in);
227     return Void();
230 // Methods from ::android::hardware::tests::baz::V1_0::IBaz follow.
232 Return<void> Baz::doThis(float param) {
233     LOG(INFO) << "Baz::doThis(" << param << ")";
235     return Void();
238 Return<int32_t> Baz::doThatAndReturnSomething(int64_t param) {
239     LOG(INFO) << "Baz::doThatAndReturnSomething(" << param << ")";
241     return 666;
244 Return<double> Baz::doQuiteABit(int32_t a, int64_t b, float c, double d) {
245     LOG(INFO) << "Baz::doQuiteABit("
246               << a
247               << ", "
248               << b
249               << ", "
250               << c
251               << ", "
252               << d
253               << ")";
255     return 666.5;
258 Return<void> Baz::doSomethingElse(const hidl_array<int32_t, 15>& param,
259                                   doSomethingElse_cb _hidl_cb) {
260     LOG(INFO) << "Baz::doSomethingElse(...)";
262     hidl_array<int32_t, 32> result;
263     for (size_t i = 0; i < 15; ++i) {
264         result[i] = 2 * param[i];
265         result[15 + i] = param[i];
266     }
267     result[30] = 1;
268     result[31] = 2;
270     _hidl_cb(result);
272     return Void();
275 Return<void> Baz::doStuffAndReturnAString(doStuffAndReturnAString_cb _hidl_cb) {
276     LOG(INFO) << "doStuffAndReturnAString";
278     hidl_string s;
279     s = "Hello, world!";
281     _hidl_cb(s);
283     return Void();
286 Return<void> Baz::mapThisVector(const hidl_vec<int32_t>& param, mapThisVector_cb _hidl_cb) {
287     LOG(INFO) << "mapThisVector";
289     hidl_vec<int32_t> out;
290     out.resize(param.size());
291     for (size_t i = 0; i < param.size(); ++i) {
292         out[i] = param[i] * 2;
293     }
295     _hidl_cb(out);
297     return Void();
300 Return<void> Baz::callMe(const sp<IBazCallback>& cb) {
301     LOG(INFO) << "callMe " << cb.get();
303     if (cb != NULL) {
304         sp<IBazCallback> my_cb = new BazCallback;
305         cb->heyItsMe(my_cb);
306     }
308     return Void();
311 Return<void> Baz::callMeLater(const sp<IBazCallback>& cb) {
312     LOG(INFO) << "callMeLater " << cb.get();
314     mStoredCallback = cb;
316     return Void();
319 Return<void> Baz::iAmFreeNow() {
320     if (mStoredCallback != nullptr) {
321         mStoredCallback->hey();
322     }
323     return Void();
326 Return<void> Baz::dieNow() {
327     exit(1);
328     return Void();
331 Return<IBaz::SomeEnum> Baz::useAnEnum(IBaz::SomeEnum zzz) {
332     LOG(INFO) << "useAnEnum " << (int)zzz;
334     return SomeEnum::goober;
337 Return<void> Baz::haveSomeStrings(const hidl_array<hidl_string, 3>& array,
338                                   haveSomeStrings_cb _hidl_cb) {
339     LOG(INFO) << "haveSomeStrings("
340               << toString(array)
341               << ")";
343     hidl_array<hidl_string, 2> result;
344     result[0] = "Hello";
345     result[1] = "World";
347     _hidl_cb(result);
349     return Void();
352 Return<void> Baz::haveAStringVec(const hidl_vec<hidl_string>& vector,
353                                  haveAStringVec_cb _hidl_cb) {
354     LOG(INFO) << "haveAStringVec(" << toString(vector) << ")";
356     hidl_vec<hidl_string> result;
357     result.resize(2);
359     result[0] = "Hello";
360     result[1] = "World";
362     _hidl_cb(result);
364     return Void();
367 Return<void> Baz::returnABunchOfStrings(returnABunchOfStrings_cb _hidl_cb) {
368     hidl_string eins; eins = "Eins";
369     hidl_string zwei; zwei = "Zwei";
370     hidl_string drei; drei = "Drei";
371     _hidl_cb(eins, zwei, drei);
373     return Void();
376 Return<uint8_t> Baz::returnABitField() {
377     return 0;
380 Return<uint32_t> Baz::size(uint32_t size) {
381     return size;
384 Return<void> Baz::getNestedStructs(getNestedStructs_cb _hidl_cb) {
385     int size = 5;
386     hidl_vec<IBaz::NestedStruct> result;
387     result.resize(size);
388     for (int i = 0; i < size; i++) {
389         result[i].a = i;
390         if (i == 1) {
391             result[i].matrices.resize(6);
392         }
393     }
394     _hidl_cb(result);
395     return Void();
397 // Methods from ::android::hidl::base::V1_0::IBase follow.
399 IBaz* HIDL_FETCH_IBaz(const char* /* name */) {
400     return new Baz();
403 }  // namespace implementation
404 }  // namespace V1_0
405 }  // namespace baz
406 }  // namespace tests
407 }  // namespace hardware
408 }  // namespace android