/* * Copyright (C) 2014-2018 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef ANDROID_SERVERS_CAMERA3_FAKE_STREAM_H #define ANDROID_SERVERS_CAMERA3_FAKE_STREAM_H #include #include #include "Camera3Stream.h" #include "Camera3IOStreamBase.h" #include "Camera3OutputStreamInterface.h" namespace android { namespace camera3 { /** * A fake output stream class, to be used as a placeholder when no valid * streams are configured by the client. * This is necessary because camera HAL v3.2 or older disallow configuring * 0 output streams, while the public camera2 API allows for it. */ class Camera3FakeStream : public Camera3IOStreamBase, public Camera3OutputStreamInterface { public: /** * Set up a fake stream; doesn't actually connect to anything, and uses * a default fake format and size. */ explicit Camera3FakeStream(int id); virtual ~Camera3FakeStream(); /** * Camera3Stream interface */ virtual void dump(int fd, const Vector &args) const; status_t setTransform(int transform); virtual status_t detachBuffer(sp* buffer, int* fenceFd); /** * Drop buffers for stream of streamId if dropping is true. If dropping is false, do not * drop buffers for stream of streamId. */ virtual status_t dropBuffers(bool /*dropping*/) override; /** * Query the physical camera id for the output stream. */ virtual const String8& getPhysicalCameraId() const override; /** * Return if this output stream is for video encoding. */ bool isVideoStream() const; /** * Return if the consumer configuration of this stream is deferred. */ virtual bool isConsumerConfigurationDeferred(size_t surface_id) const; /** * Set the consumer surfaces to the output stream. */ virtual status_t setConsumers(const std::vector>& consumers); /** * Query the output surface id. */ virtual ssize_t getSurfaceId(const sp &/*surface*/) { return 0; } virtual status_t getUniqueSurfaceIds(const std::vector&, /*out*/std::vector*) { return INVALID_OPERATION; }; /** * Update the stream output surfaces. */ virtual status_t updateStream(const std::vector> &outputSurfaces, const std::vector &outputInfo, const std::vector &removedSurfaceIds, KeyedVector, size_t> *outputMap/*out*/); virtual status_t setBatchSize(size_t batchSize) override; protected: /** * Note that we release the lock briefly in this function */ virtual status_t returnBufferCheckedLocked( const camera_stream_buffer &buffer, nsecs_t timestamp, bool output, const std::vector& surface_ids, /*out*/ sp *releaseFenceOut); virtual status_t disconnectLocked(); private: // Default fake parameters; 320x240 is a required size for all devices, // otherwise act like a SurfaceView would. static const int FAKE_WIDTH = 320; static const int FAKE_HEIGHT = 240; static const int FAKE_FORMAT = HAL_PIXEL_FORMAT_IMPLEMENTATION_DEFINED; static const android_dataspace FAKE_DATASPACE = HAL_DATASPACE_UNKNOWN; static const camera_stream_rotation_t FAKE_ROTATION = CAMERA_STREAM_ROTATION_0; static const uint64_t FAKE_USAGE = GRALLOC_USAGE_HW_COMPOSER; static const String8 FAKE_ID; /** * Internal Camera3Stream interface */ virtual status_t getBufferLocked(camera_stream_buffer *buffer, const std::vector& surface_ids = std::vector()); virtual status_t returnBufferLocked( const camera_stream_buffer &buffer, nsecs_t timestamp, const std::vector& surface_ids); virtual status_t configureQueueLocked(); virtual status_t getEndpointUsage(uint64_t *usage) const; }; // class Camera3FakeStream } // namespace camera3 } // namespace android #endif