|  | /* | 
|  | * 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 |