xref: /aosp_15_r20/hardware/interfaces/camera/common/default/include/CameraMetadata.h (revision 4d7e907c777eeecc4c5bd7cf640a754fac206ff7)
1*4d7e907cSAndroid Build Coastguard Worker /*
2*4d7e907cSAndroid Build Coastguard Worker  * Copyright (C) 2016 The Android Open Source Project
3*4d7e907cSAndroid Build Coastguard Worker  *
4*4d7e907cSAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*4d7e907cSAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*4d7e907cSAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*4d7e907cSAndroid Build Coastguard Worker  *
8*4d7e907cSAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*4d7e907cSAndroid Build Coastguard Worker  *
10*4d7e907cSAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*4d7e907cSAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*4d7e907cSAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*4d7e907cSAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*4d7e907cSAndroid Build Coastguard Worker  * limitations under the License.
15*4d7e907cSAndroid Build Coastguard Worker  */
16*4d7e907cSAndroid Build Coastguard Worker 
17*4d7e907cSAndroid Build Coastguard Worker #ifndef CAMERA_COMMON_1_0_CAMERAMETADATA_H
18*4d7e907cSAndroid Build Coastguard Worker #define CAMERA_COMMON_1_0_CAMERAMETADATA_H
19*4d7e907cSAndroid Build Coastguard Worker 
20*4d7e907cSAndroid Build Coastguard Worker #include "system/camera_metadata.h"
21*4d7e907cSAndroid Build Coastguard Worker 
22*4d7e907cSAndroid Build Coastguard Worker #include <utils/String8.h>
23*4d7e907cSAndroid Build Coastguard Worker #include <utils/Vector.h>
24*4d7e907cSAndroid Build Coastguard Worker 
25*4d7e907cSAndroid Build Coastguard Worker namespace android {
26*4d7e907cSAndroid Build Coastguard Worker namespace hardware {
27*4d7e907cSAndroid Build Coastguard Worker namespace camera {
28*4d7e907cSAndroid Build Coastguard Worker namespace common {
29*4d7e907cSAndroid Build Coastguard Worker namespace helper {
30*4d7e907cSAndroid Build Coastguard Worker 
31*4d7e907cSAndroid Build Coastguard Worker class VendorTagDescriptor;
32*4d7e907cSAndroid Build Coastguard Worker 
33*4d7e907cSAndroid Build Coastguard Worker /**
34*4d7e907cSAndroid Build Coastguard Worker  * A convenience wrapper around the C-based camera_metadata_t library.
35*4d7e907cSAndroid Build Coastguard Worker  */
36*4d7e907cSAndroid Build Coastguard Worker class CameraMetadata {
37*4d7e907cSAndroid Build Coastguard Worker   public:
38*4d7e907cSAndroid Build Coastguard Worker     /** Creates an empty object; best used when expecting to acquire contents
39*4d7e907cSAndroid Build Coastguard Worker      * from elsewhere */
40*4d7e907cSAndroid Build Coastguard Worker     CameraMetadata();
41*4d7e907cSAndroid Build Coastguard Worker     /** Creates an object with space for entryCapacity entries, with
42*4d7e907cSAndroid Build Coastguard Worker      * dataCapacity extra storage */
43*4d7e907cSAndroid Build Coastguard Worker     CameraMetadata(size_t entryCapacity, size_t dataCapacity = 10);
44*4d7e907cSAndroid Build Coastguard Worker 
45*4d7e907cSAndroid Build Coastguard Worker     ~CameraMetadata();
46*4d7e907cSAndroid Build Coastguard Worker 
47*4d7e907cSAndroid Build Coastguard Worker     /** Takes ownership of passed-in buffer */
48*4d7e907cSAndroid Build Coastguard Worker     CameraMetadata(camera_metadata_t* buffer);
49*4d7e907cSAndroid Build Coastguard Worker     /** Clones the metadata */
50*4d7e907cSAndroid Build Coastguard Worker     CameraMetadata(const CameraMetadata& other);
51*4d7e907cSAndroid Build Coastguard Worker 
52*4d7e907cSAndroid Build Coastguard Worker     /**
53*4d7e907cSAndroid Build Coastguard Worker      * Assignment clones metadata buffer.
54*4d7e907cSAndroid Build Coastguard Worker      */
55*4d7e907cSAndroid Build Coastguard Worker     CameraMetadata& operator=(const CameraMetadata& other);
56*4d7e907cSAndroid Build Coastguard Worker     CameraMetadata& operator=(const camera_metadata_t* buffer);
57*4d7e907cSAndroid Build Coastguard Worker 
58*4d7e907cSAndroid Build Coastguard Worker     /**
59*4d7e907cSAndroid Build Coastguard Worker      * Get reference to the underlying metadata buffer. Ownership remains with
60*4d7e907cSAndroid Build Coastguard Worker      * the CameraMetadata object, but non-const CameraMetadata methods will not
61*4d7e907cSAndroid Build Coastguard Worker      * work until unlock() is called. Note that the lock has nothing to do with
62*4d7e907cSAndroid Build Coastguard Worker      * thread-safety, it simply prevents the camera_metadata_t pointer returned
63*4d7e907cSAndroid Build Coastguard Worker      * here from being accidentally invalidated by CameraMetadata operations.
64*4d7e907cSAndroid Build Coastguard Worker      */
65*4d7e907cSAndroid Build Coastguard Worker     const camera_metadata_t* getAndLock() const;
66*4d7e907cSAndroid Build Coastguard Worker 
67*4d7e907cSAndroid Build Coastguard Worker     /**
68*4d7e907cSAndroid Build Coastguard Worker      * Unlock the CameraMetadata for use again. After this unlock, the pointer
69*4d7e907cSAndroid Build Coastguard Worker      * given from getAndLock() may no longer be used. The pointer passed out
70*4d7e907cSAndroid Build Coastguard Worker      * from getAndLock must be provided to guarantee that the right object is
71*4d7e907cSAndroid Build Coastguard Worker      * being unlocked.
72*4d7e907cSAndroid Build Coastguard Worker      */
73*4d7e907cSAndroid Build Coastguard Worker     status_t unlock(const camera_metadata_t* buffer) const;
74*4d7e907cSAndroid Build Coastguard Worker 
75*4d7e907cSAndroid Build Coastguard Worker     /**
76*4d7e907cSAndroid Build Coastguard Worker      * Release a raw metadata buffer to the caller. After this call,
77*4d7e907cSAndroid Build Coastguard Worker      * CameraMetadata no longer references the buffer, and the caller takes
78*4d7e907cSAndroid Build Coastguard Worker      * responsibility for freeing the raw metadata buffer (using
79*4d7e907cSAndroid Build Coastguard Worker      * free_camera_metadata()), or for handing it to another CameraMetadata
80*4d7e907cSAndroid Build Coastguard Worker      * instance.
81*4d7e907cSAndroid Build Coastguard Worker      */
82*4d7e907cSAndroid Build Coastguard Worker     camera_metadata_t* release();
83*4d7e907cSAndroid Build Coastguard Worker 
84*4d7e907cSAndroid Build Coastguard Worker     /**
85*4d7e907cSAndroid Build Coastguard Worker      * Clear the metadata buffer and free all storage used by it
86*4d7e907cSAndroid Build Coastguard Worker      */
87*4d7e907cSAndroid Build Coastguard Worker     void clear();
88*4d7e907cSAndroid Build Coastguard Worker 
89*4d7e907cSAndroid Build Coastguard Worker     /**
90*4d7e907cSAndroid Build Coastguard Worker      * Acquire a raw metadata buffer from the caller. After this call,
91*4d7e907cSAndroid Build Coastguard Worker      * the caller no longer owns the raw buffer, and must not free or manipulate it.
92*4d7e907cSAndroid Build Coastguard Worker      * If CameraMetadata already contains metadata, it is freed.
93*4d7e907cSAndroid Build Coastguard Worker      */
94*4d7e907cSAndroid Build Coastguard Worker     void acquire(camera_metadata_t* buffer);
95*4d7e907cSAndroid Build Coastguard Worker 
96*4d7e907cSAndroid Build Coastguard Worker     /**
97*4d7e907cSAndroid Build Coastguard Worker      * Acquires raw buffer from other CameraMetadata object. After the call, the argument
98*4d7e907cSAndroid Build Coastguard Worker      * object no longer has any metadata.
99*4d7e907cSAndroid Build Coastguard Worker      */
100*4d7e907cSAndroid Build Coastguard Worker     void acquire(CameraMetadata& other);
101*4d7e907cSAndroid Build Coastguard Worker 
102*4d7e907cSAndroid Build Coastguard Worker     /**
103*4d7e907cSAndroid Build Coastguard Worker      * Append metadata from another CameraMetadata object.
104*4d7e907cSAndroid Build Coastguard Worker      */
105*4d7e907cSAndroid Build Coastguard Worker     status_t append(const CameraMetadata& other);
106*4d7e907cSAndroid Build Coastguard Worker 
107*4d7e907cSAndroid Build Coastguard Worker     /**
108*4d7e907cSAndroid Build Coastguard Worker      * Append metadata from a raw camera_metadata buffer
109*4d7e907cSAndroid Build Coastguard Worker      */
110*4d7e907cSAndroid Build Coastguard Worker     status_t append(const camera_metadata* other);
111*4d7e907cSAndroid Build Coastguard Worker 
112*4d7e907cSAndroid Build Coastguard Worker     /**
113*4d7e907cSAndroid Build Coastguard Worker      * Number of metadata entries.
114*4d7e907cSAndroid Build Coastguard Worker      */
115*4d7e907cSAndroid Build Coastguard Worker     size_t entryCount() const;
116*4d7e907cSAndroid Build Coastguard Worker 
117*4d7e907cSAndroid Build Coastguard Worker     /**
118*4d7e907cSAndroid Build Coastguard Worker      * Is the buffer empty (no entires)
119*4d7e907cSAndroid Build Coastguard Worker      */
120*4d7e907cSAndroid Build Coastguard Worker     bool isEmpty() const;
121*4d7e907cSAndroid Build Coastguard Worker 
122*4d7e907cSAndroid Build Coastguard Worker     /**
123*4d7e907cSAndroid Build Coastguard Worker      * Sort metadata buffer for faster find
124*4d7e907cSAndroid Build Coastguard Worker      */
125*4d7e907cSAndroid Build Coastguard Worker     status_t sort();
126*4d7e907cSAndroid Build Coastguard Worker 
127*4d7e907cSAndroid Build Coastguard Worker     /**
128*4d7e907cSAndroid Build Coastguard Worker      * Update metadata entry. Will create entry if it doesn't exist already, and
129*4d7e907cSAndroid Build Coastguard Worker      * will reallocate the buffer if insufficient space exists. Overloaded for
130*4d7e907cSAndroid Build Coastguard Worker      * the various types of valid data.
131*4d7e907cSAndroid Build Coastguard Worker      */
132*4d7e907cSAndroid Build Coastguard Worker     status_t update(uint32_t tag, const uint8_t* data, size_t data_count);
133*4d7e907cSAndroid Build Coastguard Worker     status_t update(uint32_t tag, const int32_t* data, size_t data_count);
134*4d7e907cSAndroid Build Coastguard Worker     status_t update(uint32_t tag, const float* data, size_t data_count);
135*4d7e907cSAndroid Build Coastguard Worker     status_t update(uint32_t tag, const int64_t* data, size_t data_count);
136*4d7e907cSAndroid Build Coastguard Worker     status_t update(uint32_t tag, const double* data, size_t data_count);
137*4d7e907cSAndroid Build Coastguard Worker     status_t update(uint32_t tag, const camera_metadata_rational_t* data, size_t data_count);
138*4d7e907cSAndroid Build Coastguard Worker     status_t update(uint32_t tag, const String8& string);
139*4d7e907cSAndroid Build Coastguard Worker     status_t update(const camera_metadata_ro_entry& entry);
140*4d7e907cSAndroid Build Coastguard Worker 
141*4d7e907cSAndroid Build Coastguard Worker     template <typename T>
update(uint32_t tag,Vector<T> data)142*4d7e907cSAndroid Build Coastguard Worker     status_t update(uint32_t tag, Vector<T> data) {
143*4d7e907cSAndroid Build Coastguard Worker         return update(tag, data.array(), data.size());
144*4d7e907cSAndroid Build Coastguard Worker     }
145*4d7e907cSAndroid Build Coastguard Worker 
146*4d7e907cSAndroid Build Coastguard Worker     /**
147*4d7e907cSAndroid Build Coastguard Worker      * Check if a metadata entry exists for a given tag id
148*4d7e907cSAndroid Build Coastguard Worker      *
149*4d7e907cSAndroid Build Coastguard Worker      */
150*4d7e907cSAndroid Build Coastguard Worker     bool exists(uint32_t tag) const;
151*4d7e907cSAndroid Build Coastguard Worker 
152*4d7e907cSAndroid Build Coastguard Worker     /**
153*4d7e907cSAndroid Build Coastguard Worker      * Get metadata entry by tag id
154*4d7e907cSAndroid Build Coastguard Worker      */
155*4d7e907cSAndroid Build Coastguard Worker     camera_metadata_entry find(uint32_t tag);
156*4d7e907cSAndroid Build Coastguard Worker 
157*4d7e907cSAndroid Build Coastguard Worker     /**
158*4d7e907cSAndroid Build Coastguard Worker      * Get metadata entry by tag id, with no editing
159*4d7e907cSAndroid Build Coastguard Worker      */
160*4d7e907cSAndroid Build Coastguard Worker     camera_metadata_ro_entry find(uint32_t tag) const;
161*4d7e907cSAndroid Build Coastguard Worker 
162*4d7e907cSAndroid Build Coastguard Worker     /**
163*4d7e907cSAndroid Build Coastguard Worker      * Delete metadata entry by tag
164*4d7e907cSAndroid Build Coastguard Worker      */
165*4d7e907cSAndroid Build Coastguard Worker     status_t erase(uint32_t tag);
166*4d7e907cSAndroid Build Coastguard Worker 
167*4d7e907cSAndroid Build Coastguard Worker     /**
168*4d7e907cSAndroid Build Coastguard Worker      * Swap the underlying camera metadata between this and the other
169*4d7e907cSAndroid Build Coastguard Worker      * metadata object.
170*4d7e907cSAndroid Build Coastguard Worker      */
171*4d7e907cSAndroid Build Coastguard Worker     void swap(CameraMetadata& other);
172*4d7e907cSAndroid Build Coastguard Worker 
173*4d7e907cSAndroid Build Coastguard Worker     /**
174*4d7e907cSAndroid Build Coastguard Worker      * Dump contents into FD for debugging. The verbosity levels are
175*4d7e907cSAndroid Build Coastguard Worker      * 0: Tag entry information only, no data values
176*4d7e907cSAndroid Build Coastguard Worker      * 1: Level 0 plus at most 16 data values per entry
177*4d7e907cSAndroid Build Coastguard Worker      * 2: All information
178*4d7e907cSAndroid Build Coastguard Worker      *
179*4d7e907cSAndroid Build Coastguard Worker      * The indentation parameter sets the number of spaces to add to the start
180*4d7e907cSAndroid Build Coastguard Worker      * each line of output.
181*4d7e907cSAndroid Build Coastguard Worker      */
182*4d7e907cSAndroid Build Coastguard Worker     void dump(int fd, int verbosity = 1, int indentation = 0) const;
183*4d7e907cSAndroid Build Coastguard Worker 
184*4d7e907cSAndroid Build Coastguard Worker     /**
185*4d7e907cSAndroid Build Coastguard Worker      * Find tag id for a given tag name, also checking vendor tags if available.
186*4d7e907cSAndroid Build Coastguard Worker      * On success, returns OK and writes the tag id into tag.
187*4d7e907cSAndroid Build Coastguard Worker      *
188*4d7e907cSAndroid Build Coastguard Worker      * This is a slow method.
189*4d7e907cSAndroid Build Coastguard Worker      */
190*4d7e907cSAndroid Build Coastguard Worker     static status_t getTagFromName(const char* name, const VendorTagDescriptor* vTags,
191*4d7e907cSAndroid Build Coastguard Worker                                    uint32_t* tag);
192*4d7e907cSAndroid Build Coastguard Worker 
193*4d7e907cSAndroid Build Coastguard Worker   private:
194*4d7e907cSAndroid Build Coastguard Worker     camera_metadata_t* mBuffer;
195*4d7e907cSAndroid Build Coastguard Worker     mutable bool mLocked;
196*4d7e907cSAndroid Build Coastguard Worker 
197*4d7e907cSAndroid Build Coastguard Worker     /**
198*4d7e907cSAndroid Build Coastguard Worker      * Check if tag has a given type
199*4d7e907cSAndroid Build Coastguard Worker      */
200*4d7e907cSAndroid Build Coastguard Worker     status_t checkType(uint32_t tag, uint8_t expectedType);
201*4d7e907cSAndroid Build Coastguard Worker 
202*4d7e907cSAndroid Build Coastguard Worker     /**
203*4d7e907cSAndroid Build Coastguard Worker      * Base update entry method
204*4d7e907cSAndroid Build Coastguard Worker      */
205*4d7e907cSAndroid Build Coastguard Worker     status_t updateImpl(uint32_t tag, const void* data, size_t data_count);
206*4d7e907cSAndroid Build Coastguard Worker 
207*4d7e907cSAndroid Build Coastguard Worker     /**
208*4d7e907cSAndroid Build Coastguard Worker      * Resize metadata buffer if needed by reallocating it and copying it over.
209*4d7e907cSAndroid Build Coastguard Worker      */
210*4d7e907cSAndroid Build Coastguard Worker     status_t resizeIfNeeded(size_t extraEntries, size_t extraData);
211*4d7e907cSAndroid Build Coastguard Worker };
212*4d7e907cSAndroid Build Coastguard Worker 
213*4d7e907cSAndroid Build Coastguard Worker }  // namespace helper
214*4d7e907cSAndroid Build Coastguard Worker 
215*4d7e907cSAndroid Build Coastguard Worker // NOTE: Deprecated namespace. This namespace should no longer be used.
216*4d7e907cSAndroid Build Coastguard Worker namespace V1_0::helper {
217*4d7e907cSAndroid Build Coastguard Worker // Export symbols to the old namespace to preserve compatibility
218*4d7e907cSAndroid Build Coastguard Worker typedef android::hardware::camera::common::helper::CameraMetadata CameraMetadata;
219*4d7e907cSAndroid Build Coastguard Worker }  // namespace V1_0::helper
220*4d7e907cSAndroid Build Coastguard Worker 
221*4d7e907cSAndroid Build Coastguard Worker }  // namespace common
222*4d7e907cSAndroid Build Coastguard Worker }  // namespace camera
223*4d7e907cSAndroid Build Coastguard Worker }  // namespace hardware
224*4d7e907cSAndroid Build Coastguard Worker }  // namespace android
225*4d7e907cSAndroid Build Coastguard Worker 
226*4d7e907cSAndroid Build Coastguard Worker #endif
227