* 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.
*/
#ifndef OHOS_HDI_DISPLAY_V1_0_LAYER_CACHE_H
#define OHOS_HDI_DISPLAY_V1_0_LAYER_CACHE_H
#include <functional>
#include <memory>
#include <unordered_map>
#include "base/native_buffer.h"
#include "cache_manager.h"
#include "nocopyable.h"
#include "v1_2/mapper_stub.h"
#include "v1_1/imetadata.h"
namespace OHOS {
namespace HDI {
namespace Display {
namespace Composer {
using namespace OHOS::HDI::Base;
class LayerCache : public NoCopyable {
public:
~LayerCache();
static LayerCache* Create(uint32_t id);
int32_t SetLayerBuffer(BufferHandle*& buffer, uint32_t seqNo, bool &needFreeBuffer,
const std::vector<uint32_t>& deletingList, std::function<int32_t (const BufferHandle&)> realFunc);
int32_t SetBufferCacheMaxCount(uint32_t cacheCount);
int32_t ResetLayerBuffer();
bool IsBufferCacheNotExist();
void Dump() const;
static void NativeBufferInit(sptr<NativeBuffer>& buffer);
static void NativeBufferCleanUp(sptr<NativeBuffer>& buffer);
private:
explicit LayerCache(uint32_t id);
int32_t Init();
static sptr<Buffer::V1_2::IMapper> GetMapperService();
static sptr<Buffer::V1_1::IMetadata> GetMetaService();
static int32_t Mmap(sptr<NativeBuffer>& buffer);
static int32_t Unmap(sptr<NativeBuffer>& buffer);
static int32_t FreeMem(sptr<NativeBuffer>& buffer);
static int32_t RegisterBuffer(sptr<NativeBuffer>& buffer);
uint32_t layerId_;
std::shared_ptr<CacheManager<uint32_t, NativeBuffer>> bufferCaches_;
};
}
}
}
}
#endif