/* * Copyright 2016 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_UI_GRALLOC2_H #define ANDROID_UI_GRALLOC2_H #include <string> #include <android/hardware/graphics/allocator/2.0/IAllocator.h> #include <android/hardware/graphics/common/1.1/types.h> #include <android/hardware/graphics/mapper/2.0/IMapper.h> #include <android/hardware/graphics/mapper/2.1/IMapper.h> #include <utils/StrongPointer.h> namespace android { namespace Gralloc2 { using hardware::graphics::allocator::V2_0::IAllocator; using hardware::graphics::common::V1_1::BufferUsage; using hardware::graphics::common::V1_1::PixelFormat; using hardware::graphics::mapper::V2_1::IMapper; using hardware::graphics::mapper::V2_0::BufferDescriptor; using hardware::graphics::mapper::V2_0::Error; using hardware::graphics::mapper::V2_0::YCbCrLayout; // A wrapper to IMapper class Mapper { public: static void preload(); Mapper(); Error createDescriptor( const IMapper::BufferDescriptorInfo& descriptorInfo, BufferDescriptor* outDescriptor) const; // Import a buffer that is from another HAL, another process, or is // cloned. // // The returned handle must be freed with freeBuffer. Error importBuffer(const hardware::hidl_handle& rawHandle, buffer_handle_t* outBufferHandle) const; void freeBuffer(buffer_handle_t bufferHandle) const; Error validateBufferSize(buffer_handle_t bufferHandle, const IMapper::BufferDescriptorInfo& descriptorInfo, uint32_t stride) const; void getTransportSize(buffer_handle_t bufferHandle, uint32_t* outNumFds, uint32_t* outNumInts) const; // The ownership of acquireFence is always transferred to the callee, even // on errors. Error lock(buffer_handle_t bufferHandle, uint64_t usage, const IMapper::Rect& accessRegion, int acquireFence, void** outData) const; // The ownership of acquireFence is always transferred to the callee, even // on errors. Error lock(buffer_handle_t bufferHandle, uint64_t usage, const IMapper::Rect& accessRegion, int acquireFence, YCbCrLayout* outLayout) const; // unlock returns a fence sync object (or -1) and the fence sync object is // owned by the caller int unlock(buffer_handle_t bufferHandle) const; private: // Determines whether the passed info is compatible with the mapper. Error validateBufferDescriptorInfo( const IMapper::BufferDescriptorInfo& descriptorInfo) const; sp<hardware::graphics::mapper::V2_0::IMapper> mMapper; sp<IMapper> mMapperV2_1; }; // A wrapper to IAllocator class Allocator { public: // An allocator relies on a mapper, and that mapper must be alive at all // time. Allocator(const Mapper& mapper); std::string dumpDebugInfo() const; /* * The returned buffers are already imported and must not be imported * again. outBufferHandles must point to a space that can contain at * least "count" buffer_handle_t. */ Error allocate(BufferDescriptor descriptor, uint32_t count, uint32_t* outStride, buffer_handle_t* outBufferHandles) const; Error allocate(BufferDescriptor descriptor, uint32_t* outStride, buffer_handle_t* outBufferHandle) const { return allocate(descriptor, 1, outStride, outBufferHandle); } Error allocate(const IMapper::BufferDescriptorInfo& descriptorInfo, uint32_t count, uint32_t* outStride, buffer_handle_t* outBufferHandles) const { BufferDescriptor descriptor; Error error = mMapper.createDescriptor(descriptorInfo, &descriptor); if (error == Error::NONE) { error = allocate(descriptor, count, outStride, outBufferHandles); } return error; } Error allocate(const IMapper::BufferDescriptorInfo& descriptorInfo, uint32_t* outStride, buffer_handle_t* outBufferHandle) const { return allocate(descriptorInfo, 1, outStride, outBufferHandle); } private: const Mapper& mMapper; sp<IAllocator> mAllocator; }; } // namespace Gralloc2 } // namespace android #endif // ANDROID_UI_GRALLOC2_H