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