/* * Copyright (C) 2017 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 STAGEFRIGHT_CODEC2_PLATFORM_SUPPORT_H_ #define STAGEFRIGHT_CODEC2_PLATFORM_SUPPORT_H_ #include #include #include #include namespace aidl::android::hardware::media::c2 { class IGraphicBufferAllocator; } namespace android { /** * Returns the platform allocator store. * \retval nullptr if the platform allocator store could not be obtained */ std::shared_ptr GetCodec2PlatformAllocatorStore(); /** * Platform allocator store IDs */ class C2PlatformAllocatorStore : public C2AllocatorStore { public: enum : id_t { /** * ID of the ion backed platform allocator. * * C2Handle consists of: * fd shared ion buffer handle * int size (lo 32 bits) * int size (hi 32 bits) * int magic '\xc2io\x00' */ ION = PLATFORM_START, /* * ID of the DMA-Buf Heap (ion replacement) backed platform allocator. * * C2Handle consists of: * fd shared dmabuf buffer handle * int size (lo 32 bits) * int size (hi 32 bits) * int magic '\xc2io\x00' */ DMABUFHEAP = ION, /** * ID of the gralloc backed platform allocator. * * C2Handle layout is not public. Use C2AllocatorGralloc::UnwrapNativeCodec2GrallocHandle * to get the underlying gralloc handle from a C2Handle, and WrapNativeCodec2GrallocHandle * to create a C2Handle from a gralloc handle - for C2Allocator::priorAllocation. */ GRALLOC, /** * ID of the bufferqueue backed platform allocator. * * C2Handle layout is not public. Use C2AllocatorGralloc::UnwrapNativeCodec2GrallocHandle * to get the underlying handle from a C2Handle, and WrapNativeCodec2GrallocHandle * to create a C2Handle from a handle - for C2Allocator::priorAllocation. */ BUFFERQUEUE, /** * ID of the gralloc backed platform allocator for linear blob buffer. * * C2Handle layout is not public. Use C2AllocatorGralloc::UnwrapNativeCodec2GrallocHandle * to get the underlying gralloc handle from a C2Handle, and WrapNativeCodec2GrallocHandle * to create a C2Handle from a gralloc handle - for C2Allocator::priorAllocation. */ BLOB, /** * ID of C2AIDL IGraphicBufferAllocator backed platform allocator. * * C2Handle layout is not public. Use C2AllocatorAhwb::UnwrapNativeCodec2AhwbHandle * to get the underlying gralloc handle from a C2Handle, and WrapNativeCodec2AhwbHandle * to create a C2Handle from a gralloc handle - for C2Allocator::priorAllocation. */ IGBA, /** * ID of indicating the end of platform allocator definition. * * \note always put this macro in the last place. * * Extended platform store plugin should use this macro as the start ID of its own allocator * types. */ PLATFORM_END, }; }; /** * Retrieves a block pool for a component. * * \param id the local ID of the block pool * \param component the component using the block pool (must be non-null) * \param pool pointer to where the obtained block pool shall be stored on success. nullptr * will be stored here on failure * * \retval C2_OK the operation was successful * \retval C2_BAD_VALUE the component is null * \retval C2_NOT_FOUND if the block pool does not exist * \retval C2_NO_MEMORY not enough memory to fetch the block pool (this return value is only * possible for basic pools) * \retval C2_TIMED_OUT the operation timed out (this return value is only possible for basic pools) * \retval C2_REFUSED no permission to complete any required allocation (this return value is only * possible for basic pools) * \retval C2_CORRUPTED some unknown, unrecoverable error occured during operation (unexpected, * this return value is only possible for basic pools) */ c2_status_t GetCodec2BlockPool( C2BlockPool::local_id_t id, std::shared_ptr component, std::shared_ptr *pool); /** * Creates a block pool. * \param allocatorId the allocator ID which is used to allocate blocks * \param component the component using the block pool (must be non-null) * \param pool pointer to where the created block pool shall be store on success. * nullptr will be stored here on failure * * \retval C2_OK the operation was successful * \retval C2_BAD_VALUE the component is null * \retval C2_NOT_FOUND if the allocator does not exist * \retval C2_NO_MEMORY not enough memory to create a block pool */ c2_status_t CreateCodec2BlockPool( C2PlatformAllocatorStore::id_t allocatorId, std::shared_ptr component, std::shared_ptr *pool); /** * Creates a block pool. * \param allocatorId the allocator ID which is used to allocate blocks * \param components the components using the block pool * \param pool pointer to where the created block pool shall be store on success. * nullptr will be stored here on failure * * \retval C2_OK the operation was successful * \retval C2_BAD_VALUE the component is null * \retval C2_NOT_FOUND if the allocator does not exist * \retval C2_NO_MEMORY not enough memory to create a block pool */ c2_status_t CreateCodec2BlockPool( C2PlatformAllocatorStore::id_t allocatorId, const std::vector> &components, std::shared_ptr *pool); /** * BlockPool creation parameters regarding allocator. * * igba, waitableFd are required only when allocatorId is * C2PlatformAllocatorStore::IGBA. */ struct C2PlatformAllocatorDesc { C2PlatformAllocatorStore::id_t allocatorId; std::shared_ptr<::aidl::android::hardware::media::c2::IGraphicBufferAllocator> igba; ::android::base::unique_fd waitableFd; // This will be passed and moved to C2Fence // implementation. }; /** * Creates a block pool. * \param allocator allocator ID and parameters which are used to allocate blocks * \param component the component using the block pool (must be non-null) * \param pool pointer to where the created block pool shall be store on success. * nullptr will be stored here on failure * * \retval C2_OK the operation was successful * \retval C2_BAD_VALUE the component is null * \retval C2_NOT_FOUND if the allocator does not exist * \retval C2_NO_MEMORY not enough memory to create a block pool */ c2_status_t CreateCodec2BlockPool( C2PlatformAllocatorDesc &allocator, std::shared_ptr component, std::shared_ptr *pool); /** * Creates a block pool. * \param allocator allocator ID and parameters which are used to allocate blocks * \param components the components using the block pool * \param pool pointer to where the created block pool shall be store on success. * nullptr will be stored here on failure * * \retval C2_OK the operation was successful * \retval C2_BAD_VALUE the component is null * \retval C2_NOT_FOUND if the allocator does not exist * \retval C2_NO_MEMORY not enough memory to create a block pool */ c2_status_t CreateCodec2BlockPool( C2PlatformAllocatorDesc &allocator, const std::vector> &components, std::shared_ptr *pool); /** * Returns the platform component store. * \retval nullptr if the platform component store could not be obtained */ std::shared_ptr GetCodec2PlatformComponentStore(); /** * Returns the platform component store. * NOTE: For testing only * \retval nullptr if the platform component store could not be obtained */ std::shared_ptr GetTestComponentStore( std::vector>); /** * Sets the preferred component store in this process for the sole purpose of accessing its * interface. If this is not called, the default IComponentStore HAL (if exists) is the preferred * store for this purpose. If the default IComponentStore HAL is not present, the platform * component store is used. */ void SetPreferredCodec2ComponentStore(std::shared_ptr store); /** * Returns the pool mask. * \retval the default pool mask should be adopted if it could not be obtained from property * "debug.stagefright.c2-poolmask" */ int GetCodec2PoolMask(); /** * Returns the preferred linear buffer allocator id from param poolMask. * C2PlatformAllocatorStore::ION should be chosen as fallback allocator if BLOB is not enabled from * param poolMask. */ C2PlatformAllocatorStore::id_t GetPreferredLinearAllocatorId(int poolMask); } // namespace android #endif // STAGEFRIGHT_CODEC2_PLATFORM_SUPPORT_H_