/* * Copyright (c) 2023 Huawei Device Co., Ltd. * 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. */ #include "display_buffer_vdi_impl.h" #include "cinttypes" #include "display_log.h" #include "display_gralloc_gbm.h" #include "hdf_base.h" #include "v1_0/display_composer_type.h" namespace OHOS { namespace HDI { namespace DISPLAY { using namespace OHOS::HDI::Display::Composer::V1_0; using namespace OHOS::HDI::Display::Buffer::V1_2; DisplayBufferVdiImpl::DisplayBufferVdiImpl() { #ifdef GRALLOC_GBM_SUPPORT int ret = GbmGrallocInitialize(); if (ret != HDF_SUCCESS) { DISPLAY_LOGE("gbm construct failed"); } #endif } DisplayBufferVdiImpl::~DisplayBufferVdiImpl() { #ifdef GRALLOC_GBM_SUPPORT if (GbmGrallocUninitialize() != HDF_SUCCESS) { DISPLAY_LOGE("gbm distruct failed"); } #endif } int32_t DisplayBufferVdiImpl::AllocMem(const AllocInfo& info, BufferHandle*& handle) const { return GbmAllocMem(&info, &handle); } void DisplayBufferVdiImpl::FreeMem(const BufferHandle& handle) const { GbmFreeMem(const_cast(&handle)); } void* DisplayBufferVdiImpl::Mmap(const BufferHandle& handle) const { return GbmMmap(const_cast(&handle)); } int32_t DisplayBufferVdiImpl::Unmap(const BufferHandle& handle) const { return GbmUnmap(const_cast(&handle)); } int32_t DisplayBufferVdiImpl::FlushCache(const BufferHandle& handle) const { return GbmFlushCache(const_cast(&handle)); } int32_t DisplayBufferVdiImpl::InvalidateCache(const BufferHandle& handle) const { return GbmInvalidateCache(const_cast(&handle)); } int32_t DisplayBufferVdiImpl::IsSupportedAlloc(const std::vector& infos, std::vector& supporteds) const { return DISPLAY_NOT_SUPPORT; } int32_t DisplayBufferVdiImpl::RegisterBuffer(const BufferHandle& handle) { DISPLAY_LOGE("%s is not supported", __func__); return DISPLAY_NOT_SUPPORT; } int32_t DisplayBufferVdiImpl::SetMetadata(const BufferHandle& handle, uint32_t key, const std::vector& value) { DISPLAY_LOGE("%s is not supported", __func__); return DISPLAY_NOT_SUPPORT; } int32_t DisplayBufferVdiImpl::GetMetadata(const BufferHandle& handle, uint32_t key, std::vector& value) { DISPLAY_LOGE("%s is not supported", __func__); return DISPLAY_NOT_SUPPORT; } int32_t DisplayBufferVdiImpl::ListMetadataKeys(const BufferHandle& handle, std::vector& keys) { DISPLAY_LOGE("%s is not supported", __func__); return DISPLAY_NOT_SUPPORT; } int32_t DisplayBufferVdiImpl::EraseMetadataKey(const BufferHandle& handle, uint32_t key) { DISPLAY_LOGE("%s is not supported", __func__); return DISPLAY_NOT_SUPPORT; } int32_t DisplayBufferVdiImpl::GetImageLayout(const BufferHandle& handle, ImageLayout& layout) const { DISPLAY_LOGE("%s is not supported", __func__); return DISPLAY_NOT_SUPPORT; } extern "C" IDisplayBufferVdi* CreateDisplayBufferVdi() { return new DisplayBufferVdiImpl(); } extern "C" void DestroyDisplayBufferVdi(IDisplayBufferVdi* vdi) { delete vdi; } } // namespace DISPLAY } // namespace HDI } // namespace OHOS