/* * 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 #include #include #include #include namespace android { struct YCbCrLayout { void* y; void* cb; void* cr; uint32_t yStride; uint32_t cStride; uint32_t chromaStep; }; namespace hardware { typedef buffer_handle_t hidl_handle; } // namespace hardware namespace Gralloc2 { using android::PixelFormat; using android::YCbCrLayout; namespace IMapper { struct BufferDescriptorInfo { uint32_t width; uint32_t height; uint32_t layerCount; uint32_t format; uint32_t usage; }; struct Rect { int32_t left; int32_t top; int32_t width; int32_t height; }; } // namespace IMapper typedef IMapper::BufferDescriptorInfo* BufferDescriptor; enum Error { NONE = 0, BAD_VALUE = -22, NO_RESOURCES = -12, }; // 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; }; // 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; }; } // namespace Gralloc2 } // namespace android #endif // ANDROID_UI_GRALLOC2_H