1 /* 2 * Copyright (C) 2016-2018 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 #ifndef ANDROID_SERVERS_CAMERA3_SHARED_OUTPUT_STREAM_H 18 #define ANDROID_SERVERS_CAMERA3_SHARED_OUTPUT_STREAM_H 19 20 #include <array> 21 #include "Camera3StreamSplitter.h" 22 #include "Camera3OutputStream.h" 23 24 namespace android { 25 26 namespace camera3 { 27 28 class Camera3SharedOutputStream : 29 public Camera3OutputStream { 30 public: 31 /** 32 * Set up a stream for formats that have 2 dimensions, with multiple 33 * surfaces. A valid stream set id needs to be set to support buffer 34 * sharing between multiple streams. 35 */ 36 Camera3SharedOutputStream(int id, const std::vector<sp<Surface>>& surfaces, 37 uint32_t width, uint32_t height, int format, 38 uint64_t consumerUsage, android_dataspace dataSpace, 39 camera_stream_rotation_t rotation, nsecs_t timestampOffset, 40 const String8& physicalCameraId, 41 const std::unordered_set<int32_t> &sensorPixelModesUsed, IPCTransport transport, 42 int setId = CAMERA3_STREAM_SET_ID_INVALID, 43 bool useHalBufManager = false, 44 int64_t dynamicProfile = ANDROID_REQUEST_AVAILABLE_DYNAMIC_RANGE_PROFILES_MAP_STANDARD, 45 int64_t streamUseCase = ANDROID_SCALER_AVAILABLE_STREAM_USE_CASES_DEFAULT, 46 bool deviceTimeBaseIsRealtime = false, 47 int timestampBase = OutputConfiguration::TIMESTAMP_BASE_DEFAULT, 48 int mirrorMode = OutputConfiguration::MIRROR_MODE_AUTO); 49 50 virtual ~Camera3SharedOutputStream(); 51 52 virtual status_t notifyBufferReleased(ANativeWindowBuffer *buffer); 53 54 virtual bool isConsumerConfigurationDeferred(size_t surface_id) const; 55 56 virtual status_t setConsumers(const std::vector<sp<Surface>>& consumers); 57 58 virtual ssize_t getSurfaceId(const sp<Surface> &surface); 59 60 /** 61 * Query the unique surface IDs of current surfaceIds. 62 * When passing unique surface IDs in returnBuffer(), if the 63 * surfaceId has been removed from the stream, the output corresponding to 64 * the unique surface ID will be ignored and not delivered to client. 65 */ 66 virtual status_t getUniqueSurfaceIds(const std::vector<size_t>& surfaceIds, 67 /*out*/std::vector<size_t>* outUniqueIds) override; 68 69 virtual status_t updateStream(const std::vector<sp<Surface>> &outputSurfaces, 70 const std::vector<OutputStreamInfo> &outputInfo, 71 const std::vector<size_t> &removedSurfaceIds, 72 KeyedVector<sp<Surface>, size_t> *outputMap/*out*/); 73 getOfflineProcessingSupport()74 virtual bool getOfflineProcessingSupport() const { 75 // As per Camera spec. shared streams currently do not support 76 // offline mode. 77 return false; 78 } 79 80 private: 81 82 static const size_t kMaxOutputs = 4; 83 84 // Whether HAL is in control for buffer management. Surface sharing behavior 85 // depends on this flag. 86 const bool mUseHalBufManager; 87 88 // Pair of an output Surface and its unique ID 89 typedef std::pair<sp<Surface>, size_t> SurfaceUniqueId; 90 91 // Map surfaceId -> (output surface, unique surface ID) 92 std::array<SurfaceUniqueId, kMaxOutputs> mSurfaceUniqueIds; 93 94 size_t mNextUniqueSurfaceId = 0; 95 96 ssize_t getNextSurfaceIdLocked(); 97 98 status_t revertPartialUpdateLocked(const KeyedVector<sp<Surface>, size_t> &removedSurfaces, 99 const KeyedVector<sp<Surface>, size_t> &attachedSurfaces); 100 101 /** 102 * The Camera3StreamSplitter object this stream uses for stream 103 * sharing. 104 */ 105 sp<Camera3StreamSplitter> mStreamSplitter; 106 107 /** 108 * Initialize stream splitter. 109 */ 110 status_t connectStreamSplitterLocked(); 111 112 /** 113 * Attach the output buffer to stream splitter. 114 * When camera service is doing buffer management, this method will be called 115 * before the buffer is handed out to HAL in request thread. 116 * When HAL is doing buffer management, this method will be called when 117 * the buffer is returned from HAL in hwbinder callback thread. 118 */ 119 status_t attachBufferToSplitterLocked(ANativeWindowBuffer* anb, 120 const std::vector<size_t>& surface_ids); 121 122 /** 123 * Internal Camera3Stream interface 124 */ 125 virtual status_t getBufferLocked(camera_stream_buffer *buffer, 126 const std::vector<size_t>& surface_ids); 127 128 virtual status_t queueBufferToConsumer(sp<ANativeWindow>& consumer, 129 ANativeWindowBuffer* buffer, int anwReleaseFence, 130 const std::vector<size_t>& uniqueSurfaceIds); 131 132 virtual status_t configureQueueLocked(); 133 134 virtual status_t disconnectLocked(); 135 136 virtual status_t getEndpointUsage(uint64_t *usage) const; 137 138 }; // class Camera3SharedOutputStream 139 140 } // namespace camera3 141 142 } // namespace android 143 144 #endif // ANDROID_SERVERS_CAMERA3_SHARED_OUTPUT_STREAM_H 145