1 /*
2  * Copyright 2019 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  */
16 
17 #define LOG_TAG "libgralloctypes"
18 
19 #include <cstring>
20 #include <cinttypes>
21 #include <limits>
22 
23 #include <hidl/HidlSupport.h>
24 #include <log/log.h>
25 
26 #include "gralloctypes/Gralloc4.h"
27 
28 using android::hardware::hidl_vec;
29 
30 using aidl::android::hardware::graphics::common::BlendMode;
31 using aidl::android::hardware::graphics::common::ChromaSiting;
32 using aidl::android::hardware::graphics::common::Compression;
33 using aidl::android::hardware::graphics::common::Cta861_3;
34 using aidl::android::hardware::graphics::common::Dataspace;
35 using aidl::android::hardware::graphics::common::ExtendableType;
36 using aidl::android::hardware::graphics::common::Interlaced;
37 using aidl::android::hardware::graphics::common::PlaneLayout;
38 using aidl::android::hardware::graphics::common::PlaneLayoutComponent;
39 using aidl::android::hardware::graphics::common::PlaneLayoutComponentType;
40 using aidl::android::hardware::graphics::common::Rect;
41 using aidl::android::hardware::graphics::common::Smpte2086;
42 using aidl::android::hardware::graphics::common::StandardMetadataType;
43 using aidl::android::hardware::graphics::common::XyColor;
44 
45 using BufferDescriptorInfo = android::hardware::graphics::mapper::V4_0::IMapper::BufferDescriptorInfo;
46 using MetadataType = android::hardware::graphics::mapper::V4_0::IMapper::MetadataType;
47 
48 namespace android {
49 
50 namespace gralloc4 {
51 
hasAdditionOverflow(size_t a,size_t b)52 static inline bool hasAdditionOverflow(size_t a, size_t b) {
53     return a > SIZE_MAX - b;
54 }
55 
56 /**
57  * OutputHidlVec represents the hidl_vec that is outputed when a type is encoded into a byte stream.
58  * This class is used to track the current state of a hidl_vec as it is filled with the encoded
59  * byte stream.
60  *
61  * This type is needed because hidl_vec's resize() allocates a new backing array every time.
62  * This type does not need an copies and only needs one resize operation.
63  */
64 class OutputHidlVec {
65 public:
OutputHidlVec(hidl_vec<uint8_t> * vec)66     OutputHidlVec(hidl_vec<uint8_t>* vec)
67         : mVec(vec) {}
68 
resize()69     status_t resize() {
70         if (!mVec) {
71             return BAD_VALUE;
72         }
73         mVec->resize(mNeededResize);
74         mResized = true;
75         return NO_ERROR;
76     }
77 
encode(const uint8_t * data,size_t size)78     status_t encode(const uint8_t* data, size_t size) {
79         if (!mVec) {
80             return BAD_VALUE;
81         }
82         if (!mResized) {
83             if (hasAdditionOverflow(mNeededResize, size)) {
84                 clear();
85                 return BAD_VALUE;
86             }
87             /**
88              * Update mNeededResize and return NO_ERROR here because if (!mResized), the
89              * caller hasn't called resize(). No data will be written into the mVec until
90              * the caller resizes. We can't resize here for the caller because hidl_vec::resize()
91              * allocates a new backing array every time.
92              */
93             mNeededResize += size;
94             return NO_ERROR;
95         }
96 
97         if (hasAdditionOverflow(mOffset, size) || (mVec->size() < size + mOffset)) {
98             clear();
99             return BAD_VALUE;
100         }
101 
102         std::copy(data, data + size, mVec->data() + mOffset);
103 
104         mOffset += size;
105         return NO_ERROR;
106     }
107 
clear()108     void clear() {
109         if (mVec) {
110             mVec->resize(0);
111         }
112         mNeededResize = 0;
113         mResized = false;
114         mOffset = 0;
115     }
116 
117 private:
118     hidl_vec<uint8_t>* mVec;
119     size_t mNeededResize = 0;
120     size_t mResized = false;
121     size_t mOffset = 0;
122 };
123 
124 /**
125  * InputHidlVec represents the hidl_vec byte stream that is inputed when a type is decoded.
126  * This class is used to track the current index of the byte stream of the hidl_vec as it is
127  * decoded.
128  */
129 class InputHidlVec {
130 public:
InputHidlVec(const hidl_vec<uint8_t> * vec)131     InputHidlVec(const hidl_vec<uint8_t>* vec)
132         : mVec(vec) {}
133 
decode(uint8_t * data,size_t size)134     status_t decode(uint8_t* data, size_t size) {
135         if (!mVec || hasAdditionOverflow(mOffset, size) || mOffset + size > mVec->size()) {
136             return BAD_VALUE;
137         }
138 
139         std::copy(mVec->data() + mOffset, mVec->data() + mOffset + size, data);
140 
141         mOffset += size;
142         return NO_ERROR;
143     }
144 
decode(std::string * string,size_t size)145     status_t decode(std::string* string, size_t size) {
146         if (!mVec || hasAdditionOverflow(mOffset, size) || mOffset + size > mVec->size()) {
147             return BAD_VALUE;
148         }
149 
150         string->assign(mVec->data() + mOffset, mVec->data() + mOffset + size);
151 
152         mOffset += size;
153         return NO_ERROR;
154     }
155 
hasRemainingData()156     bool hasRemainingData() {
157         if (!mVec) {
158             return false;
159         }
160         return mVec->size() > mOffset;
161     }
162 
getRemainingSize()163     size_t getRemainingSize() {
164         if (!mVec) {
165             return 0;
166         }
167         return mVec->size() - mOffset;
168     }
169 
170 private:
171     const hidl_vec<uint8_t>* mVec;
172     size_t mOffset = 0;
173 };
174 
175 /**
176  * EncodeHelper is a function type that encodes T into the OutputHidlVec.
177  */
178 template<class T>
179 using EncodeHelper = status_t(*)(const T&, OutputHidlVec*);
180 
181 /**
182  * DecodeHelper is a function type that decodes InputHidlVec into T.
183  */
184 template<class T>
185 using DecodeHelper = status_t(*)(InputHidlVec*, T*);
186 
187 /**
188  * ErrorHandler is a function type that is called when the corresponding DecodeHelper function
189  * fails. ErrorHandler cleans up the object T so the caller doesn't receive a partially created
190  * T.
191  */
192 template<class T>
193 using ErrorHandler = void(*)(T*);
194 
195 status_t encodeMetadataType(const MetadataType& input, OutputHidlVec* output);
196 status_t validateMetadataType(InputHidlVec* input, const MetadataType& expectedMetadataType);
197 
198 /**
199  * encode/encodeMetadata are the main encoding functions. They take in T and uses the encodeHelper
200  * function to turn T into the hidl_vec byte stream.
201  *
202  * These functions first call the encodeHelper function to determine how large the hidl_vec
203  * needs to be. They resize the hidl_vec. Finally, it reruns the encodeHelper function which
204  * encodes T into the hidl_vec byte stream.
205  */
206 template <class T>
encode(const T & input,hidl_vec<uint8_t> * output,EncodeHelper<T> encodeHelper)207 status_t encode(const T& input, hidl_vec<uint8_t>* output, EncodeHelper<T> encodeHelper) {
208     OutputHidlVec outputHidlVec{output};
209 
210     status_t err = encodeHelper(input, &outputHidlVec);
211     if (err) {
212         return err;
213     }
214 
215     err = outputHidlVec.resize();
216     if (err) {
217         return err;
218     }
219 
220     return encodeHelper(input, &outputHidlVec);
221 }
222 
223 template <class T>
encodeMetadata(const MetadataType & metadataType,const T & input,hidl_vec<uint8_t> * output,EncodeHelper<T> encodeHelper)224 status_t encodeMetadata(const MetadataType& metadataType, const T& input, hidl_vec<uint8_t>* output,
225                 EncodeHelper<T> encodeHelper) {
226     OutputHidlVec outputHidlVec{output};
227 
228     status_t err = encodeMetadataType(metadataType, &outputHidlVec);
229     if (err) {
230         return err;
231     }
232 
233     err = encodeHelper(input, &outputHidlVec);
234     if (err) {
235         return err;
236     }
237 
238     err = outputHidlVec.resize();
239     if (err) {
240         return err;
241     }
242 
243     err = encodeMetadataType(metadataType, &outputHidlVec);
244     if (err) {
245         return err;
246     }
247 
248     return encodeHelper(input, &outputHidlVec);
249 }
250 
251 template <class T>
encodeOptionalMetadata(const MetadataType & metadataType,const std::optional<T> & input,hidl_vec<uint8_t> * output,EncodeHelper<T> encodeHelper)252 status_t encodeOptionalMetadata(const MetadataType& metadataType, const std::optional<T>& input,
253                         hidl_vec<uint8_t>* output, EncodeHelper<T> encodeHelper) {
254     if (!input) {
255         return NO_ERROR;
256     }
257     return encodeMetadata(metadataType, *input, output, encodeHelper);
258 }
259 
260 /**
261  * decode/decodeMetadata are the main decoding functions. They take in a hidl_vec and use the
262  * decodeHelper function to turn the hidl_vec byte stream into T. If an error occurs, the
263  * errorHandler function cleans up T.
264  */
265 template <class T>
decode(const hidl_vec<uint8_t> & input,T * output,DecodeHelper<T> decodeHelper,ErrorHandler<T> errorHandler=nullptr)266 status_t decode(const hidl_vec<uint8_t>& input, T* output, DecodeHelper<T> decodeHelper,
267                 ErrorHandler<T> errorHandler = nullptr) {
268     InputHidlVec inputHidlVec{&input};
269 
270     status_t err = decodeHelper(&inputHidlVec, output);
271     if (err) {
272         return err;
273     }
274 
275     err = inputHidlVec.hasRemainingData();
276     if (err) {
277         if (errorHandler) {
278             errorHandler(output);
279         }
280         return BAD_VALUE;
281     }
282 
283     return NO_ERROR;
284 }
285 
286 template <class T>
decodeMetadata(const MetadataType & metadataType,const hidl_vec<uint8_t> & input,T * output,DecodeHelper<T> decodeHelper,ErrorHandler<T> errorHandler=nullptr)287 status_t decodeMetadata(const MetadataType& metadataType, const hidl_vec<uint8_t>& input, T* output,
288                 DecodeHelper<T> decodeHelper, ErrorHandler<T> errorHandler = nullptr) {
289     InputHidlVec inputHidlVec{&input};
290 
291     status_t err = validateMetadataType(&inputHidlVec, metadataType);
292     if (err) {
293         return err;
294     }
295 
296     err = decodeHelper(&inputHidlVec, output);
297     if (err) {
298         return err;
299     }
300 
301     err = inputHidlVec.hasRemainingData();
302     if (err) {
303         if (errorHandler) {
304             errorHandler(output);
305         }
306         return BAD_VALUE;
307     }
308 
309     return NO_ERROR;
310 }
311 
312 template <class T>
decodeOptionalMetadata(const MetadataType & metadataType,const hidl_vec<uint8_t> & input,std::optional<T> * output,DecodeHelper<T> decodeHelper)313 status_t decodeOptionalMetadata(const MetadataType& metadataType, const hidl_vec<uint8_t>& input,
314                         std::optional<T>* output, DecodeHelper<T> decodeHelper) {
315     if (!output) {
316         return BAD_VALUE;
317     }
318     if (input.size() <= 0) {
319         output->reset();
320         return NO_ERROR;
321     }
322     T tmp;
323     status_t err = decodeMetadata(metadataType, input, &tmp, decodeHelper);
324     if (!err) {
325         *output = tmp;
326     }
327     return err;
328 }
329 
330 /**
331  * Private helper functions
332  */
333 template <class T>
encodeInteger(const T & input,OutputHidlVec * output)334 status_t encodeInteger(const T& input, OutputHidlVec* output) {
335     static_assert(std::is_same<T, uint32_t>::value || std::is_same<T, int32_t>::value ||
336                   std::is_same<T, uint64_t>::value || std::is_same<T, int64_t>::value ||
337                   std::is_same<T, float>::value || std::is_same<T, double>::value);
338     if (!output) {
339         return BAD_VALUE;
340     }
341 
342     const uint8_t* tmp = reinterpret_cast<const uint8_t*>(&input);
343     return output->encode(tmp, sizeof(input));
344 }
345 
346 template <class T>
decodeInteger(InputHidlVec * input,T * output)347 status_t decodeInteger(InputHidlVec* input, T* output) {
348     static_assert(std::is_same<T, uint32_t>::value || std::is_same<T, int32_t>::value ||
349                   std::is_same<T, uint64_t>::value || std::is_same<T, int64_t>::value ||
350                   std::is_same<T, float>::value || std::is_same<T, double>::value);
351     if (!output) {
352         return BAD_VALUE;
353     }
354 
355     uint8_t* tmp = reinterpret_cast<uint8_t*>(output);
356     return input->decode(tmp, sizeof(*output));
357 }
358 
encodeString(const std::string & input,OutputHidlVec * output)359 status_t encodeString(const std::string& input, OutputHidlVec* output) {
360     if (!output) {
361         return BAD_VALUE;
362     }
363 
364     status_t err = encodeInteger<int64_t>(input.size(), output);
365     if (err) {
366         return err;
367     }
368 
369     return output->encode(reinterpret_cast<const uint8_t*>(input.data()), input.size());
370 }
371 
decodeString(InputHidlVec * input,std::string * output)372 status_t decodeString(InputHidlVec* input, std::string* output) {
373     if (!output) {
374         return BAD_VALUE;
375     }
376 
377     int64_t size = 0;
378     status_t err = decodeInteger<int64_t>(input, &size);
379     if (err) {
380         return err;
381     }
382     if (size < 0) {
383         return BAD_VALUE;
384     }
385 
386     return input->decode(output, size);
387 }
388 
encodeByteVector(const std::vector<uint8_t> & input,OutputHidlVec * output)389 status_t encodeByteVector(const std::vector<uint8_t>& input, OutputHidlVec* output) {
390     if (!output) {
391         return BAD_VALUE;
392     }
393 
394     status_t err = encodeInteger<int64_t>(input.size(), output);
395     if (err) {
396         return err;
397     }
398 
399     return output->encode(input.data(), input.size());
400 }
401 
decodeByteVector(InputHidlVec * input,std::vector<uint8_t> * output)402 status_t decodeByteVector(InputHidlVec* input, std::vector<uint8_t>* output) {
403     if (!output) {
404         return BAD_VALUE;
405     }
406 
407     int64_t size = 0;
408     status_t err = decodeInteger<int64_t>(input, &size);
409     if (err || size < 0) {
410         return err;
411     }
412 
413     if (size > input->getRemainingSize()) {
414         return BAD_VALUE;
415     }
416     output->resize(size);
417 
418     return input->decode(output->data(), size);
419 }
420 
encodeExtendableType(const ExtendableType & input,OutputHidlVec * output)421 status_t encodeExtendableType(const ExtendableType& input, OutputHidlVec* output) {
422     status_t err = encodeString(input.name, output);
423     if (err) {
424         return err;
425     }
426 
427     err = encodeInteger<int64_t>(input.value, output);
428     if (err) {
429         return err;
430     }
431 
432     return NO_ERROR;
433 }
434 
decodeExtendableType(InputHidlVec * input,ExtendableType * output)435 status_t decodeExtendableType(InputHidlVec* input, ExtendableType* output) {
436     status_t err = decodeString(input, &output->name);
437     if (err) {
438         return err;
439     }
440 
441     err = decodeInteger<int64_t>(input, &output->value);
442     if (err) {
443         return err;
444     }
445 
446     return NO_ERROR;
447 }
448 
clearExtendableType(ExtendableType * output)449 void clearExtendableType(ExtendableType* output) {
450     if (!output) {
451         return;
452     }
453     output->name.clear();
454     output->value = 0;
455 }
456 
encodeMetadataType(const MetadataType & input,OutputHidlVec * output)457 status_t encodeMetadataType(const MetadataType& input, OutputHidlVec* output) {
458     status_t err = encodeString(input.name, output);
459     if (err) {
460         return err;
461     }
462 
463     err = encodeInteger<int64_t>(input.value, output);
464     if (err) {
465         return err;
466     }
467 
468     return NO_ERROR;
469 }
470 
decodeMetadataType(InputHidlVec * input,MetadataType * output)471 status_t decodeMetadataType(InputHidlVec* input, MetadataType* output) {
472     std::string name;
473     status_t err = decodeString(input, &name);
474     if (err) {
475         return err;
476     }
477     output->name = name;
478 
479     err = decodeInteger<int64_t>(input, &output->value);
480     if (err) {
481         return err;
482     }
483 
484     return NO_ERROR;
485 }
486 
validateMetadataType(InputHidlVec * input,const MetadataType & expectedMetadataType)487 status_t validateMetadataType(InputHidlVec* input, const MetadataType& expectedMetadataType) {
488     MetadataType receivedMetadataType;
489 
490     status_t err = decodeMetadataType(input, &receivedMetadataType);
491     if (err) {
492         return err;
493     }
494 
495     if (expectedMetadataType.name != receivedMetadataType.name) {
496         return BAD_VALUE;
497     }
498 
499     if (receivedMetadataType.value != expectedMetadataType.value) {
500         return BAD_VALUE;
501     }
502 
503     return NO_ERROR;
504 }
505 
encodeXyColor(const XyColor & input,OutputHidlVec * output)506 status_t encodeXyColor(const XyColor& input, OutputHidlVec* output) {
507     status_t err = encodeInteger<float>(input.x, output);
508     if (err) {
509         return err;
510     }
511     return encodeInteger<float>(input.y, output);
512 }
513 
decodeXyColor(InputHidlVec * input,XyColor * output)514 status_t decodeXyColor(InputHidlVec* input, XyColor* output) {
515     status_t err = decodeInteger<float>(input, &output->x);
516     if (err) {
517         return err;
518     }
519     return decodeInteger<float>(input, &output->y);
520 }
521 
clearXyColor(XyColor * output)522 void clearXyColor(XyColor* output) {
523     if (!output) {
524         return;
525     }
526     output->x = 0;
527     output->y = 0;
528 }
529 
encodeRect(const Rect & input,OutputHidlVec * output)530 status_t encodeRect(const Rect& input, OutputHidlVec* output) {
531     status_t err = encodeInteger<int32_t>(static_cast<int32_t>(input.left), output);
532     if (err) {
533         return err;
534     }
535     err = encodeInteger<int32_t>(static_cast<int32_t>(input.top), output);
536     if (err) {
537         return err;
538     }
539     err = encodeInteger<int32_t>(static_cast<int32_t>(input.right), output);
540     if (err) {
541         return err;
542     }
543     return encodeInteger<int32_t>(static_cast<int32_t>(input.bottom), output);
544 }
545 
decodeRect(InputHidlVec * input,Rect * output)546 status_t decodeRect(InputHidlVec* input, Rect* output) {
547     status_t err = decodeInteger<int32_t>(input, &output->left);
548     if (err) {
549         return err;
550     }
551     err = decodeInteger<int32_t>(input, &output->top);
552     if (err) {
553         return err;
554     }
555     err = decodeInteger<int32_t>(input, &output->right);
556     if (err) {
557         return err;
558     }
559     return decodeInteger<int32_t>(input, &output->bottom);
560 }
561 
encodeBufferDescriptorInfoHelper(const BufferDescriptorInfo & input,OutputHidlVec * output)562 status_t encodeBufferDescriptorInfoHelper(const BufferDescriptorInfo& input,
563         OutputHidlVec* output) {
564     status_t err = encodeString(input.name, output);
565     if (err) {
566         return err;
567     }
568     err = encodeInteger<uint32_t>(input.width, output);
569     if (err) {
570         return err;
571     }
572     err = encodeInteger<uint32_t>(input.height, output);
573     if (err) {
574         return err;
575     }
576     err = encodeInteger<uint32_t>(input.layerCount, output);
577     if (err) {
578         return err;
579     }
580     err = encodeInteger<int32_t>(static_cast<int32_t>(input.format), output);
581     if (err) {
582         return err;
583     }
584     err = encodeInteger<uint64_t>(input.usage, output);
585     if (err) {
586         return err;
587     }
588     return encodeInteger<uint64_t>(input.reservedSize, output);
589 }
590 
decodeBufferDescriptorInfoHelper(InputHidlVec * input,BufferDescriptorInfo * output)591 status_t decodeBufferDescriptorInfoHelper(InputHidlVec* input, BufferDescriptorInfo* output) {
592     std::string name;
593     status_t err = decodeString(input, &name);
594     if (err) {
595         return err;
596     }
597     output->name = name;
598 
599     err = decodeInteger<uint32_t>(input, &output->width);
600     if (err) {
601         return err;
602     }
603     err = decodeInteger<uint32_t>(input, &output->height);
604     if (err) {
605         return err;
606     }
607     err = decodeInteger<uint32_t>(input, &output->layerCount);
608     if (err) {
609         return err;
610     }
611     err = decodeInteger<int32_t>(input, reinterpret_cast<int32_t*>(&output->format));
612     if (err) {
613         return err;
614     }
615     err = decodeInteger<uint64_t>(input, &output->usage);
616     if (err) {
617         return err;
618     }
619     return decodeInteger<uint64_t>(input, &output->reservedSize);
620 }
621 
encodePlaneLayoutComponent(const PlaneLayoutComponent & input,OutputHidlVec * output)622 status_t encodePlaneLayoutComponent(const PlaneLayoutComponent& input, OutputHidlVec* output) {
623     if (!output) {
624         return BAD_VALUE;
625     }
626 
627     status_t err = encodeExtendableType(input.type, output);
628     if (err) {
629         return err;
630     }
631     err = encodeInteger<int64_t>(static_cast<int64_t>(input.offsetInBits), output);
632     if (err) {
633         return err;
634     }
635     return encodeInteger<int64_t>(static_cast<int64_t>(input.sizeInBits), output);
636 }
637 
decodePlaneLayoutComponent(InputHidlVec * input,PlaneLayoutComponent * output)638 status_t decodePlaneLayoutComponent(InputHidlVec* input, PlaneLayoutComponent* output) {
639     if (!output) {
640         return BAD_VALUE;
641     }
642 
643     status_t err = decodeExtendableType(input, &output->type);
644     if (err) {
645         return err;
646     }
647     err = decodeInteger<int64_t>(input, &output->offsetInBits);
648     if (err) {
649         return err;
650     }
651     return decodeInteger<int64_t>(input, &output->sizeInBits);
652 }
653 
encodePlaneLayoutComponents(const std::vector<PlaneLayoutComponent> & input,OutputHidlVec * output)654 status_t encodePlaneLayoutComponents(const std::vector<PlaneLayoutComponent>& input, OutputHidlVec* output) {
655     if (!output) {
656         return BAD_VALUE;
657     }
658 
659     status_t err = encodeInteger<int64_t>(static_cast<int64_t>(input.size()), output);
660     if (err) {
661         return err;
662     }
663 
664     for (const auto& planeLayoutComponent: input) {
665         err = encodePlaneLayoutComponent(planeLayoutComponent, output);
666         if (err) {
667             return err;
668         }
669     }
670 
671     return NO_ERROR;
672 }
673 
decodePlaneLayoutComponents(InputHidlVec * input,std::vector<PlaneLayoutComponent> * output)674 status_t decodePlaneLayoutComponents(InputHidlVec* input, std::vector<PlaneLayoutComponent>* output) {
675     if (!output) {
676         return BAD_VALUE;
677     }
678 
679     int64_t size = 0;
680     status_t err = decodeInteger<int64_t>(input, &size);
681     if (err) {
682         return err;
683     }
684     if (size < 0 || size > 10000) {
685         return BAD_VALUE;
686     }
687 
688     output->resize(size);
689 
690     for (auto& planeLayoutComponent : *output) {
691         err = decodePlaneLayoutComponent(input, &planeLayoutComponent);
692         if (err) {
693             return err;
694         }
695     }
696     return NO_ERROR;
697 }
698 
encodePlaneLayout(const PlaneLayout & input,OutputHidlVec * output)699 status_t encodePlaneLayout(const PlaneLayout& input, OutputHidlVec* output) {
700     if (!output) {
701         return BAD_VALUE;
702     }
703 
704     status_t err = encodePlaneLayoutComponents(input.components, output);
705     if (err) {
706         return err;
707     }
708 
709     err = encodeInteger<int64_t>(static_cast<int64_t>(input.offsetInBytes), output);
710     if (err) {
711         return err;
712     }
713     err = encodeInteger<int64_t>(static_cast<int64_t>(input.sampleIncrementInBits), output);
714     if (err) {
715         return err;
716     }
717     err = encodeInteger<int64_t>(static_cast<int64_t>(input.strideInBytes), output);
718     if (err) {
719         return err;
720     }
721     err = encodeInteger<int64_t>(static_cast<int64_t>(input.widthInSamples), output);
722     if (err) {
723         return err;
724     }
725     err = encodeInteger<int64_t>(static_cast<int64_t>(input.heightInSamples), output);
726     if (err) {
727         return err;
728     }
729     err = encodeInteger<int64_t>(static_cast<int64_t>(input.totalSizeInBytes), output);
730     if (err) {
731         return err;
732     }
733     err = encodeInteger<int64_t>(static_cast<int64_t>(input.horizontalSubsampling), output);
734     if (err) {
735         return err;
736     }
737     return encodeInteger<int64_t>(static_cast<int64_t>(input.verticalSubsampling), output);
738 }
739 
decodePlaneLayout(InputHidlVec * input,PlaneLayout * output)740 status_t decodePlaneLayout(InputHidlVec* input, PlaneLayout* output) {
741     if (!output) {
742         return BAD_VALUE;
743     }
744 
745     status_t err = decodePlaneLayoutComponents(input, &output->components);
746     if (err) {
747         return err;
748     }
749 
750     err = decodeInteger<int64_t>(input, &output->offsetInBytes);
751     if (err) {
752         return err;
753     }
754     err = decodeInteger<int64_t>(input, &output->sampleIncrementInBits);
755     if (err) {
756         return err;
757     }
758     err = decodeInteger<int64_t>(input, &output->strideInBytes);
759     if (err) {
760         return err;
761     }
762     err = decodeInteger<int64_t>(input, &output->widthInSamples);
763     if (err) {
764         return err;
765     }
766     err = decodeInteger<int64_t>(input, &output->heightInSamples);
767     if (err) {
768         return err;
769     }
770     err = decodeInteger<int64_t>(input, &output->totalSizeInBytes);
771     if (err) {
772         return err;
773     }
774     err = decodeInteger<int64_t>(input, &output->horizontalSubsampling);
775     if (err) {
776         return err;
777     }
778     return decodeInteger<int64_t>(input, &output->verticalSubsampling);
779 }
780 
encodePlaneLayoutsHelper(const std::vector<PlaneLayout> & planeLayouts,OutputHidlVec * outOutputHidlVec)781 status_t encodePlaneLayoutsHelper(const std::vector<PlaneLayout>& planeLayouts, OutputHidlVec* outOutputHidlVec) {
782     status_t err = encodeInteger<int64_t>(static_cast<int64_t>(planeLayouts.size()), outOutputHidlVec);
783     if (err) {
784         return err;
785     }
786 
787     for (const auto& planeLayout : planeLayouts) {
788         err = encodePlaneLayout(planeLayout, outOutputHidlVec);
789         if (err) {
790             return err;
791         }
792     }
793 
794     return NO_ERROR;
795 }
796 
decodePlaneLayoutsHelper(InputHidlVec * inputHidlVec,std::vector<PlaneLayout> * outPlaneLayouts)797 status_t decodePlaneLayoutsHelper(InputHidlVec* inputHidlVec, std::vector<PlaneLayout>* outPlaneLayouts) {
798     int64_t size = 0;
799     status_t err = decodeInteger<int64_t>(inputHidlVec, &size);
800     if (err) {
801         return err;
802     }
803     if (size < 0) {
804         return BAD_VALUE;
805     }
806 
807     for (size_t i = 0; i < size; i++) {
808         outPlaneLayouts->emplace_back();
809         err = decodePlaneLayout(inputHidlVec, &outPlaneLayouts->back());
810         if (err) {
811             return err;
812         }
813     }
814     return NO_ERROR;
815 }
816 
clearPlaneLayouts(std::vector<PlaneLayout> * output)817 void clearPlaneLayouts(std::vector<PlaneLayout>* output) {
818     if (!output) {
819         return;
820     }
821     output->clear();
822 }
823 
encodeCropHelper(const std::vector<Rect> & crops,OutputHidlVec * outOutputHidlVec)824 status_t encodeCropHelper(const std::vector<Rect>& crops, OutputHidlVec* outOutputHidlVec) {
825     status_t err = encodeInteger<int64_t>(static_cast<int64_t>(crops.size()), outOutputHidlVec);
826     if (err) {
827         return err;
828     }
829 
830     for (const auto& crop : crops) {
831         err = encodeRect(crop, outOutputHidlVec);
832         if (err) {
833             return err;
834         }
835     }
836 
837     return NO_ERROR;
838 }
839 
decodeCropHelper(InputHidlVec * inputHidlVec,std::vector<Rect> * outCrops)840 status_t decodeCropHelper(InputHidlVec* inputHidlVec, std::vector<Rect>* outCrops) {
841     int64_t size = 0;
842     status_t err = decodeInteger<int64_t>(inputHidlVec, &size);
843     if (err) {
844         return err;
845     }
846     if (size < 0) {
847         return BAD_VALUE;
848     }
849 
850     for (size_t i = 0; i < size; i++) {
851         outCrops->emplace_back();
852         err = decodeRect(inputHidlVec, &outCrops->back());
853         if (err) {
854             return err;
855         }
856     }
857     return NO_ERROR;
858 }
859 
clearCrop(std::vector<Rect> * output)860 void clearCrop(std::vector<Rect>* output) {
861     if (!output) {
862         return;
863     }
864     output->clear();
865 }
866 
encodeSmpte2086Helper(const Smpte2086 & smpte2086,OutputHidlVec * outOutputHidlVec)867 status_t encodeSmpte2086Helper(const Smpte2086& smpte2086, OutputHidlVec* outOutputHidlVec) {
868     status_t err = encodeXyColor(smpte2086.primaryRed, outOutputHidlVec);
869     if (err) {
870         return err;
871     }
872     err = encodeXyColor(smpte2086.primaryGreen, outOutputHidlVec);
873     if (err) {
874         return err;
875     }
876     err = encodeXyColor(smpte2086.primaryBlue, outOutputHidlVec);
877     if (err) {
878         return err;
879     }
880     err = encodeXyColor(smpte2086.whitePoint, outOutputHidlVec);
881     if (err) {
882         return err;
883     }
884     err = encodeInteger<float>(smpte2086.maxLuminance, outOutputHidlVec);
885     if (err) {
886         return err;
887     }
888     return encodeInteger<float>(smpte2086.minLuminance, outOutputHidlVec);
889 }
890 
decodeSmpte2086Helper(InputHidlVec * inputHidlVec,Smpte2086 * outSmpte2086)891 status_t decodeSmpte2086Helper(InputHidlVec* inputHidlVec, Smpte2086* outSmpte2086) {
892     status_t err = decodeXyColor(inputHidlVec, &outSmpte2086->primaryRed);
893     if (err) {
894         return err;
895     }
896     err = decodeXyColor(inputHidlVec, &outSmpte2086->primaryGreen);
897     if (err) {
898         return err;
899     }
900     err = decodeXyColor(inputHidlVec, &outSmpte2086->primaryBlue);
901     if (err) {
902         return err;
903     }
904     err = decodeXyColor(inputHidlVec, &outSmpte2086->whitePoint);
905     if (err) {
906         return err;
907     }
908     err = decodeInteger<float>(inputHidlVec, &outSmpte2086->maxLuminance);
909     if (err) {
910         return err;
911     }
912     return decodeInteger<float>(inputHidlVec, &outSmpte2086->minLuminance);
913 }
914 
encodeCta861_3Helper(const Cta861_3 & cta861_3,OutputHidlVec * outOutputHidlVec)915 status_t encodeCta861_3Helper(const Cta861_3& cta861_3, OutputHidlVec* outOutputHidlVec) {
916     status_t err = encodeInteger<float>(cta861_3.maxContentLightLevel, outOutputHidlVec);
917     if (err) {
918         return err;
919     }
920     return encodeInteger<float>(cta861_3.maxFrameAverageLightLevel, outOutputHidlVec);
921 }
922 
decodeCta861_3Helper(InputHidlVec * inputHidlVec,Cta861_3 * outCta861_3)923 status_t decodeCta861_3Helper(InputHidlVec* inputHidlVec, Cta861_3* outCta861_3) {
924     status_t err = decodeInteger<float>(inputHidlVec, &outCta861_3->maxContentLightLevel);
925     if (err) {
926         return err;
927     }
928     return decodeInteger<float>(inputHidlVec, &outCta861_3->maxFrameAverageLightLevel);
929 }
930 
931 /**
932  * Public API functions
933  */
encodeBufferDescriptorInfo(const BufferDescriptorInfo & bufferDescriptorInfo,hidl_vec<uint8_t> * outBufferDescriptorInfo)934 status_t encodeBufferDescriptorInfo(const BufferDescriptorInfo& bufferDescriptorInfo,
935         hidl_vec<uint8_t>* outBufferDescriptorInfo) {
936     return encode(bufferDescriptorInfo, outBufferDescriptorInfo, encodeBufferDescriptorInfoHelper);
937 }
938 
decodeBufferDescriptorInfo(const hidl_vec<uint8_t> & bufferDescriptorInfo,BufferDescriptorInfo * outBufferDescriptorInfo)939 status_t decodeBufferDescriptorInfo(const hidl_vec<uint8_t>& bufferDescriptorInfo,
940         BufferDescriptorInfo* outBufferDescriptorInfo) {
941     return decode(bufferDescriptorInfo, outBufferDescriptorInfo, decodeBufferDescriptorInfoHelper);
942 }
943 
encodeBufferId(uint64_t bufferId,hidl_vec<uint8_t> * outBufferId)944 status_t encodeBufferId(uint64_t bufferId, hidl_vec<uint8_t>* outBufferId) {
945     return encodeMetadata(MetadataType_BufferId, bufferId, outBufferId, encodeInteger);
946 }
947 
decodeBufferId(const hidl_vec<uint8_t> & bufferId,uint64_t * outBufferId)948 status_t decodeBufferId(const hidl_vec<uint8_t>& bufferId, uint64_t* outBufferId) {
949     return decodeMetadata(MetadataType_BufferId, bufferId, outBufferId, decodeInteger);
950 }
951 
encodeName(const std::string & name,hidl_vec<uint8_t> * outName)952 status_t encodeName(const std::string& name, hidl_vec<uint8_t>* outName) {
953     return encodeMetadata(MetadataType_Name, name, outName, encodeString);
954 }
955 
decodeName(const hidl_vec<uint8_t> & name,std::string * outName)956 status_t decodeName(const hidl_vec<uint8_t>& name, std::string* outName) {
957     return decodeMetadata(MetadataType_Name, name, outName, decodeString);
958 }
959 
encodeWidth(uint64_t width,hidl_vec<uint8_t> * outWidth)960 status_t encodeWidth(uint64_t width, hidl_vec<uint8_t>* outWidth) {
961     return encodeMetadata(MetadataType_Width, width, outWidth, encodeInteger);
962 }
963 
decodeWidth(const hidl_vec<uint8_t> & width,uint64_t * outWidth)964 status_t decodeWidth(const hidl_vec<uint8_t>& width, uint64_t* outWidth) {
965     return decodeMetadata(MetadataType_Width, width, outWidth, decodeInteger);
966 }
967 
encodeHeight(uint64_t height,hidl_vec<uint8_t> * outHeight)968 status_t encodeHeight(uint64_t height, hidl_vec<uint8_t>* outHeight) {
969     return encodeMetadata(MetadataType_Height, height, outHeight, encodeInteger);
970 }
971 
decodeHeight(const hidl_vec<uint8_t> & height,uint64_t * outHeight)972 status_t decodeHeight(const hidl_vec<uint8_t>& height, uint64_t* outHeight) {
973     return decodeMetadata(MetadataType_Height, height, outHeight, decodeInteger);
974 }
975 
encodeLayerCount(uint64_t layerCount,hidl_vec<uint8_t> * outLayerCount)976 status_t encodeLayerCount(uint64_t layerCount, hidl_vec<uint8_t>* outLayerCount) {
977     return encodeMetadata(MetadataType_LayerCount, layerCount, outLayerCount, encodeInteger);
978 }
979 
decodeLayerCount(const hidl_vec<uint8_t> & layerCount,uint64_t * outLayerCount)980 status_t decodeLayerCount(const hidl_vec<uint8_t>& layerCount, uint64_t* outLayerCount) {
981     return decodeMetadata(MetadataType_LayerCount, layerCount, outLayerCount, decodeInteger);
982 }
983 
encodePixelFormatRequested(const hardware::graphics::common::V1_2::PixelFormat & pixelFormatRequested,hidl_vec<uint8_t> * outPixelFormatRequested)984 status_t encodePixelFormatRequested(const hardware::graphics::common::V1_2::PixelFormat& pixelFormatRequested,
985         hidl_vec<uint8_t>* outPixelFormatRequested) {
986     return encodeMetadata(MetadataType_PixelFormatRequested, static_cast<int32_t>(pixelFormatRequested),
987                   outPixelFormatRequested, encodeInteger);
988 }
989 
decodePixelFormatRequested(const hidl_vec<uint8_t> & pixelFormatRequested,hardware::graphics::common::V1_2::PixelFormat * outPixelFormatRequested)990 status_t decodePixelFormatRequested(const hidl_vec<uint8_t>& pixelFormatRequested,
991         hardware::graphics::common::V1_2::PixelFormat* outPixelFormatRequested) {
992     return decodeMetadata(MetadataType_PixelFormatRequested, pixelFormatRequested,
993                   reinterpret_cast<int32_t*>(outPixelFormatRequested), decodeInteger);
994 }
995 
encodePixelFormatFourCC(uint32_t pixelFormatFourCC,hidl_vec<uint8_t> * outPixelFormatFourCC)996 status_t encodePixelFormatFourCC(uint32_t pixelFormatFourCC, hidl_vec<uint8_t>* outPixelFormatFourCC) {
997     return encodeMetadata(MetadataType_PixelFormatFourCC, pixelFormatFourCC, outPixelFormatFourCC,
998                   encodeInteger);
999 }
1000 
decodePixelFormatFourCC(const hidl_vec<uint8_t> & pixelFormatFourCC,uint32_t * outPixelFormatFourCC)1001 status_t decodePixelFormatFourCC(const hidl_vec<uint8_t>& pixelFormatFourCC, uint32_t* outPixelFormatFourCC) {
1002     return decodeMetadata(MetadataType_PixelFormatFourCC, pixelFormatFourCC, outPixelFormatFourCC,
1003                   decodeInteger);
1004 }
1005 
encodePixelFormatModifier(uint64_t pixelFormatModifier,hidl_vec<uint8_t> * outPixelFormatModifier)1006 status_t encodePixelFormatModifier(uint64_t pixelFormatModifier, hidl_vec<uint8_t>* outPixelFormatModifier) {
1007     return encodeMetadata(MetadataType_PixelFormatModifier, pixelFormatModifier, outPixelFormatModifier,
1008                   encodeInteger);
1009 }
1010 
decodePixelFormatModifier(const hidl_vec<uint8_t> & pixelFormatModifier,uint64_t * outPixelFormatModifier)1011 status_t decodePixelFormatModifier(const hidl_vec<uint8_t>& pixelFormatModifier, uint64_t* outPixelFormatModifier) {
1012     return decodeMetadata(MetadataType_PixelFormatModifier, pixelFormatModifier, outPixelFormatModifier,
1013                   decodeInteger);
1014 }
1015 
encodeUsage(uint64_t usage,hidl_vec<uint8_t> * outUsage)1016 status_t encodeUsage(uint64_t usage, hidl_vec<uint8_t>* outUsage) {
1017     return encodeMetadata(MetadataType_Usage, usage, outUsage, encodeInteger);
1018 }
1019 
decodeUsage(const hidl_vec<uint8_t> & usage,uint64_t * outUsage)1020 status_t decodeUsage(const hidl_vec<uint8_t>& usage, uint64_t* outUsage) {
1021     return decodeMetadata(MetadataType_Usage, usage, outUsage, decodeInteger);
1022 }
1023 
encodeAllocationSize(uint64_t allocationSize,hidl_vec<uint8_t> * outAllocationSize)1024 status_t encodeAllocationSize(uint64_t allocationSize, hidl_vec<uint8_t>* outAllocationSize) {
1025     return encodeMetadata(MetadataType_AllocationSize, allocationSize, outAllocationSize, encodeInteger);
1026 }
1027 
decodeAllocationSize(const hidl_vec<uint8_t> & allocationSize,uint64_t * outAllocationSize)1028 status_t decodeAllocationSize(const hidl_vec<uint8_t>& allocationSize, uint64_t* outAllocationSize) {
1029     return decodeMetadata(MetadataType_AllocationSize, allocationSize, outAllocationSize, decodeInteger);
1030 }
1031 
encodeProtectedContent(uint64_t protectedContent,hidl_vec<uint8_t> * outProtectedContent)1032 status_t encodeProtectedContent(uint64_t protectedContent, hidl_vec<uint8_t>* outProtectedContent) {
1033     return encodeMetadata(MetadataType_ProtectedContent, protectedContent, outProtectedContent,
1034                   encodeInteger);
1035 }
1036 
decodeProtectedContent(const hidl_vec<uint8_t> & protectedContent,uint64_t * outProtectedContent)1037 status_t decodeProtectedContent(const hidl_vec<uint8_t>& protectedContent, uint64_t* outProtectedContent) {
1038     return decodeMetadata(MetadataType_ProtectedContent, protectedContent, outProtectedContent,
1039                   decodeInteger);
1040 }
1041 
encodeCompression(const ExtendableType & compression,hidl_vec<uint8_t> * outCompression)1042 status_t encodeCompression(const ExtendableType& compression, hidl_vec<uint8_t>* outCompression) {
1043     return encodeMetadata(MetadataType_Compression, compression, outCompression, encodeExtendableType);
1044 }
1045 
decodeCompression(const hidl_vec<uint8_t> & compression,ExtendableType * outCompression)1046 status_t decodeCompression(const hidl_vec<uint8_t>& compression, ExtendableType* outCompression) {
1047     return decodeMetadata(MetadataType_Compression, compression, outCompression, decodeExtendableType,
1048                   clearExtendableType);
1049 }
1050 
encodeInterlaced(const ExtendableType & interlaced,hidl_vec<uint8_t> * outInterlaced)1051 status_t encodeInterlaced(const ExtendableType& interlaced, hidl_vec<uint8_t>* outInterlaced) {
1052     return encodeMetadata(MetadataType_Interlaced, interlaced, outInterlaced, encodeExtendableType);
1053 }
1054 
decodeInterlaced(const hidl_vec<uint8_t> & interlaced,ExtendableType * outInterlaced)1055 status_t decodeInterlaced(const hidl_vec<uint8_t>& interlaced, ExtendableType* outInterlaced) {
1056     return decodeMetadata(MetadataType_Interlaced, interlaced, outInterlaced, decodeExtendableType,
1057                   clearExtendableType);
1058 }
1059 
encodeChromaSiting(const ExtendableType & chromaSiting,hidl_vec<uint8_t> * outChromaSiting)1060 status_t encodeChromaSiting(const ExtendableType& chromaSiting, hidl_vec<uint8_t>* outChromaSiting) {
1061     return encodeMetadata(MetadataType_ChromaSiting, chromaSiting, outChromaSiting, encodeExtendableType);
1062 }
1063 
decodeChromaSiting(const hidl_vec<uint8_t> & chromaSiting,ExtendableType * outChromaSiting)1064 status_t decodeChromaSiting(const hidl_vec<uint8_t>& chromaSiting, ExtendableType* outChromaSiting) {
1065     return decodeMetadata(MetadataType_ChromaSiting, chromaSiting, outChromaSiting, decodeExtendableType,
1066                   clearExtendableType);
1067 }
1068 
encodePlaneLayouts(const std::vector<PlaneLayout> & planeLayouts,hidl_vec<uint8_t> * outPlaneLayouts)1069 status_t encodePlaneLayouts(const std::vector<PlaneLayout>& planeLayouts, hidl_vec<uint8_t>* outPlaneLayouts) {
1070     return encodeMetadata(MetadataType_PlaneLayouts, planeLayouts, outPlaneLayouts,
1071                   encodePlaneLayoutsHelper);
1072 }
1073 
decodePlaneLayouts(const hidl_vec<uint8_t> & planeLayouts,std::vector<PlaneLayout> * outPlaneLayouts)1074 status_t decodePlaneLayouts(const hidl_vec<uint8_t>& planeLayouts, std::vector<PlaneLayout>* outPlaneLayouts) {
1075     return decodeMetadata(MetadataType_PlaneLayouts, planeLayouts, outPlaneLayouts,
1076                   decodePlaneLayoutsHelper, clearPlaneLayouts);
1077 }
1078 
encodeCrop(const std::vector<Rect> & crop,hidl_vec<uint8_t> * outCrop)1079 status_t encodeCrop(const std::vector<Rect>& crop, hidl_vec<uint8_t>* outCrop) {
1080     return encodeMetadata(MetadataType_Crop, crop, outCrop, encodeCropHelper);
1081 }
1082 
decodeCrop(const hidl_vec<uint8_t> & crop,std::vector<Rect> * outCrop)1083 status_t decodeCrop(const hidl_vec<uint8_t>& crop, std::vector<Rect>* outCrop) {
1084     return decodeMetadata(MetadataType_Crop, crop, outCrop, decodeCropHelper, clearCrop);
1085 }
1086 
encodeDataspace(const Dataspace & dataspace,hidl_vec<uint8_t> * outDataspace)1087 status_t encodeDataspace(const Dataspace& dataspace, hidl_vec<uint8_t>* outDataspace) {
1088     return encodeMetadata(MetadataType_Dataspace, static_cast<int32_t>(dataspace), outDataspace,
1089                   encodeInteger);
1090 }
1091 
decodeDataspace(const hidl_vec<uint8_t> & dataspace,Dataspace * outDataspace)1092 status_t decodeDataspace(const hidl_vec<uint8_t>& dataspace, Dataspace* outDataspace) {
1093     return decodeMetadata(MetadataType_Dataspace, dataspace, reinterpret_cast<int32_t*>(outDataspace),
1094                   decodeInteger);
1095 }
1096 
encodeBlendMode(const BlendMode & blendMode,hidl_vec<uint8_t> * outBlendMode)1097 status_t encodeBlendMode(const BlendMode& blendMode, hidl_vec<uint8_t>* outBlendMode) {
1098     return encodeMetadata(MetadataType_BlendMode, static_cast<int32_t>(blendMode), outBlendMode,
1099                   encodeInteger);
1100 }
1101 
decodeBlendMode(const hidl_vec<uint8_t> & blendMode,BlendMode * outBlendMode)1102 status_t decodeBlendMode(const hidl_vec<uint8_t>& blendMode, BlendMode* outBlendMode) {
1103     return decodeMetadata(MetadataType_BlendMode, blendMode, reinterpret_cast<int32_t*>(outBlendMode),
1104                   decodeInteger);
1105 }
1106 
encodeSmpte2086(const std::optional<Smpte2086> & smpte2086,hidl_vec<uint8_t> * outSmpte2086)1107 status_t encodeSmpte2086(const std::optional<Smpte2086>& smpte2086,
1108                          hidl_vec<uint8_t>* outSmpte2086) {
1109     return encodeOptionalMetadata(MetadataType_Smpte2086, smpte2086, outSmpte2086, encodeSmpte2086Helper);
1110 }
1111 
decodeSmpte2086(const hidl_vec<uint8_t> & smpte2086,std::optional<Smpte2086> * outSmpte2086)1112 status_t decodeSmpte2086(const hidl_vec<uint8_t>& smpte2086,
1113                          std::optional<Smpte2086>* outSmpte2086) {
1114     return decodeOptionalMetadata(MetadataType_Smpte2086, smpte2086, outSmpte2086, decodeSmpte2086Helper);
1115 }
1116 
encodeCta861_3(const std::optional<Cta861_3> & cta861_3,hidl_vec<uint8_t> * outCta861_3)1117 status_t encodeCta861_3(const std::optional<Cta861_3>& cta861_3, hidl_vec<uint8_t>* outCta861_3) {
1118     return encodeOptionalMetadata(MetadataType_Cta861_3, cta861_3, outCta861_3, encodeCta861_3Helper);
1119 }
1120 
decodeCta861_3(const hidl_vec<uint8_t> & cta861_3,std::optional<Cta861_3> * outCta861_3)1121 status_t decodeCta861_3(const hidl_vec<uint8_t>& cta861_3, std::optional<Cta861_3>* outCta861_3) {
1122     return decodeOptionalMetadata(MetadataType_Cta861_3, cta861_3, outCta861_3, decodeCta861_3Helper);
1123 }
1124 
encodeSmpte2094_40(const std::optional<std::vector<uint8_t>> & smpte2094_40,hidl_vec<uint8_t> * outSmpte2094_40)1125 status_t encodeSmpte2094_40(const std::optional<std::vector<uint8_t>>& smpte2094_40,
1126                             hidl_vec<uint8_t>* outSmpte2094_40) {
1127     return encodeOptionalMetadata(MetadataType_Smpte2094_40, smpte2094_40, outSmpte2094_40,
1128                           encodeByteVector);
1129 }
1130 
decodeSmpte2094_40(const hidl_vec<uint8_t> & smpte2094_40,std::optional<std::vector<uint8_t>> * outSmpte2094_40)1131 status_t decodeSmpte2094_40(const hidl_vec<uint8_t>& smpte2094_40,
1132                             std::optional<std::vector<uint8_t>>* outSmpte2094_40) {
1133     return decodeOptionalMetadata(MetadataType_Smpte2094_40, smpte2094_40, outSmpte2094_40,
1134                           decodeByteVector);
1135 }
1136 
encodeSmpte2094_10(const std::optional<std::vector<uint8_t>> & smpte2094_10,hidl_vec<uint8_t> * outSmpte2094_10)1137 status_t encodeSmpte2094_10(const std::optional<std::vector<uint8_t>>& smpte2094_10,
1138                             hidl_vec<uint8_t>* outSmpte2094_10) {
1139     return encodeOptionalMetadata(MetadataType_Smpte2094_10, smpte2094_10, outSmpte2094_10,
1140                                   encodeByteVector);
1141 }
1142 
decodeSmpte2094_10(const hidl_vec<uint8_t> & smpte2094_10,std::optional<std::vector<uint8_t>> * outSmpte2094_10)1143 status_t decodeSmpte2094_10(const hidl_vec<uint8_t>& smpte2094_10,
1144                             std::optional<std::vector<uint8_t>>* outSmpte2094_10) {
1145     return decodeOptionalMetadata(MetadataType_Smpte2094_10, smpte2094_10, outSmpte2094_10,
1146                                   decodeByteVector);
1147 }
1148 
encodeUint32(const MetadataType & metadataType,uint32_t input,hidl_vec<uint8_t> * output)1149 status_t encodeUint32(const MetadataType& metadataType, uint32_t input,
1150                       hidl_vec<uint8_t>* output) {
1151     return encodeMetadata(metadataType, input, output, encodeInteger);
1152 }
1153 
decodeUint32(const MetadataType & metadataType,const hidl_vec<uint8_t> & input,uint32_t * output)1154 status_t decodeUint32(const MetadataType& metadataType, const hidl_vec<uint8_t>& input,
1155                       uint32_t* output) {
1156     return decodeMetadata(metadataType, input, output, decodeInteger);
1157 }
1158 
encodeInt32(const MetadataType & metadataType,int32_t input,hidl_vec<uint8_t> * output)1159 status_t encodeInt32(const MetadataType& metadataType, int32_t input,
1160                      hidl_vec<uint8_t>* output) {
1161     return encodeMetadata(metadataType, input, output, encodeInteger);
1162 }
1163 
decodeInt32(const MetadataType & metadataType,const hidl_vec<uint8_t> & input,int32_t * output)1164 status_t decodeInt32(const MetadataType& metadataType, const hidl_vec<uint8_t>& input,
1165                      int32_t* output) {
1166     return decodeMetadata(metadataType, input, output, decodeInteger);
1167 }
1168 
encodeUint64(const MetadataType & metadataType,uint64_t input,hidl_vec<uint8_t> * output)1169 status_t encodeUint64(const MetadataType& metadataType, uint64_t input,
1170                       hidl_vec<uint8_t>* output) {
1171     return encodeMetadata(metadataType, input, output, encodeInteger);
1172 }
1173 
decodeUint64(const MetadataType & metadataType,const hidl_vec<uint8_t> & input,uint64_t * output)1174 status_t decodeUint64(const MetadataType& metadataType, const hidl_vec<uint8_t>& input,
1175                       uint64_t* output) {
1176     return decodeMetadata(metadataType, input, output, decodeInteger);
1177 }
1178 
encodeInt64(const MetadataType & metadataType,int64_t input,hidl_vec<uint8_t> * output)1179 status_t encodeInt64(const MetadataType& metadataType, int64_t input,
1180                      hidl_vec<uint8_t>* output) {
1181     return encodeMetadata(metadataType, input, output, encodeInteger);
1182 }
1183 
decodeInt64(const MetadataType & metadataType,const hidl_vec<uint8_t> & input,int64_t * output)1184 status_t decodeInt64(const MetadataType& metadataType, const hidl_vec<uint8_t>& input,
1185                      int64_t* output) {
1186     return decodeMetadata(metadataType, input, output, decodeInteger);
1187 }
1188 
encodeFloat(const MetadataType & metadataType,float input,hidl_vec<uint8_t> * output)1189 status_t encodeFloat(const MetadataType& metadataType, float input,
1190                      hidl_vec<uint8_t>* output) {
1191     return encodeMetadata(metadataType, input, output, encodeInteger);
1192 }
1193 
decodeFloat(const MetadataType & metadataType,const hidl_vec<uint8_t> & input,float * output)1194 status_t decodeFloat(const MetadataType& metadataType, const hidl_vec<uint8_t>& input,
1195                      float* output) {
1196     return decodeMetadata(metadataType, input, output, decodeInteger);
1197 }
1198 
encodeDouble(const MetadataType & metadataType,double input,hidl_vec<uint8_t> * output)1199 status_t encodeDouble(const MetadataType& metadataType, double input,
1200                       hidl_vec<uint8_t>* output) {
1201     return encodeMetadata(metadataType, input, output, encodeInteger);
1202 }
1203 
decodeDouble(const MetadataType & metadataType,const hidl_vec<uint8_t> & input,double * output)1204 status_t decodeDouble(const MetadataType& metadataType, const hidl_vec<uint8_t>& input,
1205                       double* output) {
1206     return decodeMetadata(metadataType, input, output, decodeInteger);
1207 }
1208 
encodeString(const MetadataType & metadataType,const std::string & input,hidl_vec<uint8_t> * output)1209 status_t encodeString(const MetadataType& metadataType, const std::string& input,
1210                       hidl_vec<uint8_t>* output) {
1211     return encodeMetadata(metadataType, input, output, encodeString);
1212 }
1213 
decodeString(const MetadataType & metadataType,const hidl_vec<uint8_t> & input,std::string * output)1214 status_t decodeString(const MetadataType& metadataType, const hidl_vec<uint8_t>& input,
1215                       std::string* output) {
1216     return decodeMetadata(metadataType, input, output, decodeString);
1217 }
1218 
isStandardMetadataType(const MetadataType & metadataType)1219 bool isStandardMetadataType(const MetadataType& metadataType) {
1220     return !std::strncmp(metadataType.name.c_str(), GRALLOC4_STANDARD_METADATA_TYPE,
1221                          metadataType.name.size());
1222 }
1223 
isStandardCompression(const ExtendableType & compression)1224 bool isStandardCompression(const ExtendableType& compression) {
1225     return !std::strncmp(compression.name.c_str(), GRALLOC4_STANDARD_COMPRESSION,
1226                          compression.name.size());
1227 }
1228 
isStandardInterlaced(const ExtendableType & interlaced)1229 bool isStandardInterlaced(const ExtendableType& interlaced) {
1230     return !std::strncmp(interlaced.name.c_str(), GRALLOC4_STANDARD_INTERLACED,
1231                          interlaced.name.size());
1232 }
1233 
isStandardChromaSiting(const ExtendableType & chromaSiting)1234 bool isStandardChromaSiting(const ExtendableType& chromaSiting) {
1235     return !std::strncmp(chromaSiting.name.c_str(), GRALLOC4_STANDARD_CHROMA_SITING,
1236                          chromaSiting.name.size());
1237 }
1238 
isStandardPlaneLayoutComponentType(const ExtendableType & planeLayoutComponentType)1239 bool isStandardPlaneLayoutComponentType(const ExtendableType& planeLayoutComponentType) {
1240     return !std::strncmp(planeLayoutComponentType.name.c_str(), GRALLOC4_STANDARD_PLANE_LAYOUT_COMPONENT_TYPE,
1241                          planeLayoutComponentType.name.size());
1242 }
1243 
getStandardMetadataTypeValue(const MetadataType & metadataType)1244 StandardMetadataType getStandardMetadataTypeValue(const MetadataType& metadataType) {
1245     return static_cast<StandardMetadataType>(metadataType.value);
1246 }
1247 
getStandardCompressionValue(const ExtendableType & compression)1248 Compression getStandardCompressionValue(const ExtendableType& compression) {
1249     return static_cast<Compression>(compression.value);
1250 }
1251 
getStandardInterlacedValue(const ExtendableType & interlaced)1252 Interlaced getStandardInterlacedValue(const ExtendableType& interlaced) {
1253     return static_cast<Interlaced>(interlaced.value);
1254 }
1255 
getStandardChromaSitingValue(const ExtendableType & chromaSiting)1256 ChromaSiting getStandardChromaSitingValue(const ExtendableType& chromaSiting) {
1257     return static_cast<ChromaSiting>(chromaSiting.value);
1258 }
1259 
getStandardPlaneLayoutComponentTypeValue(const ExtendableType & planeLayoutComponentType)1260 PlaneLayoutComponentType getStandardPlaneLayoutComponentTypeValue(
1261         const ExtendableType& planeLayoutComponentType) {
1262     return static_cast<PlaneLayoutComponentType>(planeLayoutComponentType.value);
1263 }
1264 
getCompressionName(const ExtendableType & compression)1265 std::string getCompressionName(const ExtendableType& compression) {
1266     if (!isStandardCompression(compression)) {
1267         std::ostringstream stream;
1268         stream << compression.name << "#" << compression.value;
1269         return stream.str();
1270     }
1271     switch (getStandardCompressionValue(compression)) {
1272         case Compression::NONE:
1273             return "None";
1274         case Compression::DISPLAY_STREAM_COMPRESSION:
1275             return "DisplayStreamCompression";
1276     }
1277 }
1278 
getInterlacedName(const ExtendableType & interlaced)1279 std::string getInterlacedName(const ExtendableType& interlaced) {
1280     if (!isStandardInterlaced(interlaced)) {
1281         std::ostringstream stream;
1282         stream << interlaced.name << "#" << interlaced.value;
1283         return stream.str();
1284     }
1285     switch (getStandardInterlacedValue(interlaced)) {
1286         case Interlaced::NONE:
1287             return "None";
1288         case Interlaced::TOP_BOTTOM:
1289             return "TopBottom";
1290         case Interlaced::RIGHT_LEFT:
1291             return "RightLeft";
1292     }
1293 }
1294 
getChromaSitingName(const ExtendableType & chromaSiting)1295 std::string getChromaSitingName(const ExtendableType& chromaSiting) {
1296     if (!isStandardChromaSiting(chromaSiting)) {
1297         std::ostringstream stream;
1298         stream << chromaSiting.name << "#" << chromaSiting.value;
1299         return stream.str();
1300     }
1301     switch (getStandardChromaSitingValue(chromaSiting)) {
1302         case ChromaSiting::NONE:
1303             return "None";
1304         case ChromaSiting::UNKNOWN:
1305             return "Unknown";
1306         case ChromaSiting::SITED_INTERSTITIAL:
1307             return "SitedInterstitial";
1308         case ChromaSiting::COSITED_HORIZONTAL:
1309             return "CositedHorizontal";
1310         case ChromaSiting::COSITED_VERTICAL:
1311             return "CositedVertical";
1312         case ChromaSiting::COSITED_BOTH:
1313             return "CositedBoth";
1314     }
1315 }
1316 
getPlaneLayoutComponentTypeName(const ExtendableType & planeLayoutComponentType)1317 std::string getPlaneLayoutComponentTypeName(const ExtendableType& planeLayoutComponentType) {
1318     if (!isStandardPlaneLayoutComponentType(planeLayoutComponentType)) {
1319         std::ostringstream stream;
1320         stream << planeLayoutComponentType.name << "#" << planeLayoutComponentType.value;
1321         return stream.str();
1322     }
1323     switch (getStandardPlaneLayoutComponentTypeValue(planeLayoutComponentType)) {
1324         case PlaneLayoutComponentType::Y:
1325             return "Y";
1326         case PlaneLayoutComponentType::CB:
1327             return "Cb";
1328         case PlaneLayoutComponentType::CR:
1329             return "Cr";
1330         case PlaneLayoutComponentType::R:
1331             return "R";
1332         case PlaneLayoutComponentType::G:
1333             return "G";
1334         case PlaneLayoutComponentType::B:
1335             return "B";
1336         case PlaneLayoutComponentType::RAW:
1337             return "RAW";
1338         case PlaneLayoutComponentType::A:
1339             return "A";
1340     }
1341 }
1342 
1343 } // namespace gralloc4
1344 
1345 } // namespace android
1346