• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (c) 2023 Huawei Device Co., Ltd.
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at
6  *
7  *     http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  */
15 
16 #include "layer_cache.h"
17 
18 #include "buffer_cache_utils.h"
19 #include "common/include/display_interface_utils.h"
20 #include "hdf_base.h"
21 #include "hdf_log.h"
22 #include "v1_0/display_composer_type.h"
23 
24 namespace OHOS {
25 namespace HDI {
26 namespace Display {
27 namespace Composer {
28 
29 bool LayerCache::needMap_ = false;
Create(uint32_t id)30 LayerCache* LayerCache::Create(uint32_t id)
31 {
32     LayerCache* layer = new LayerCache(id);
33     DISPLAY_CHK_RETURN(layer == nullptr, nullptr, HDF_LOGE("%{public}s: create layer cache failed", __func__));
34 
35     int32_t ret = layer->Init();
36     if (ret != HDF_SUCCESS) {
37         delete layer;
38         layer = nullptr;
39         HDF_LOGE("%{public}s: layer cache init failed", __func__);
40     }
41 
42     return layer;
43 }
44 
LayerCache(uint32_t id)45 LayerCache::LayerCache(uint32_t id) : layerId_(id)
46 {
47 }
48 
~LayerCache()49 LayerCache::~LayerCache()
50 {
51 }
52 
IsBufferCacheNotExist()53 bool LayerCache::IsBufferCacheNotExist()
54 {
55     if (bufferCaches_ == nullptr) {
56         return true;
57     }
58     return bufferCaches_->Size() == 0;
59 }
60 
Init()61 int32_t LayerCache::Init()
62 {
63     bufferCaches_.reset(new CacheManager<uint32_t, NativeBuffer>());
64     DISPLAY_CHK_RETURN(bufferCaches_ == nullptr, HDF_FAILURE,
65         HDF_LOGE("%{public}s: create buffer caches failed", __func__));
66 
67     bufferCaches_->SetInitFunc(NativeBufferInit);
68     bufferCaches_->SetCleanUpFunc(NativeBufferCleanUp);
69     return HDF_SUCCESS;
70 }
71 
SetBufferCacheMaxCount(uint32_t cacheCount)72 int32_t LayerCache::SetBufferCacheMaxCount(uint32_t cacheCount)
73 {
74     bool ret = bufferCaches_->SetCacheMaxCount(cacheCount);
75     DISPLAY_CHK_RETURN(ret == false, HDF_FAILURE, HDF_LOGE("%{public}s: failed", __func__));
76     return HDF_SUCCESS;
77 }
78 
SetLayerBuffer(BufferHandle * & buffer,uint32_t seqNo,bool & needFreeBuffer,const std::vector<uint32_t> & deletingList,std::function<int32_t (const BufferHandle &)> realFunc)79 int32_t LayerCache::SetLayerBuffer(BufferHandle*& buffer, uint32_t seqNo, bool &needFreeBuffer,
80     const std::vector<uint32_t>& deletingList, std::function<int32_t (const BufferHandle&)> realFunc)
81 {
82     if (buffer != nullptr) {
83         HDF_LOGI("%{public}s, seqNo %{public}u, fd %{public}d, size %{public}d", __func__, seqNo, buffer->fd,
84                  buffer->size);
85     }
86     for (auto num : deletingList) {
87         (void)bufferCaches_->EraseCache(num);
88     }
89 
90     BufferHandle* handle = BufferCacheUtils::NativeBufferCache(bufferCaches_, buffer, seqNo, layerId_, needFreeBuffer);
91     DISPLAY_CHK_RETURN(handle == nullptr, HDF_FAILURE,
92         HDF_LOGE("%{public}s: call NativeBufferCache fail", __func__));
93     int32_t ret = realFunc(*handle);
94     if (ret != HDF_SUCCESS) {
95         HDF_LOGE("%{public}s: call realFunc fail", __func__);
96     }
97 
98     return HDF_SUCCESS;
99 }
100 
ResetLayerBuffer()101 int32_t LayerCache::ResetLayerBuffer()
102 {
103     HDF_LOGI("%{public}s", __func__);
104     return Init();
105 }
106 
NativeBufferInit(sptr<NativeBuffer> & buffer)107 void LayerCache::NativeBufferInit(sptr<NativeBuffer>& buffer)
108 {
109     if (buffer == nullptr) {
110         HDF_LOGW("NativeBufferInit buffer nullptr!");
111         return;
112     }
113     int32_t ret = RegisterBuffer(buffer);
114     if (ret != HDF_SUCCESS) {
115         HDF_LOGE("%{public}s: RegisterBuffer failed with %{public}d!", __func__, ret);
116     }
117 }
118 
NativeBufferCleanUp(sptr<NativeBuffer> & buffer)119 void LayerCache::NativeBufferCleanUp(sptr<NativeBuffer>& buffer)
120 {
121     if (buffer == nullptr) {
122         HDF_LOGW("NativeBufferCleanUp buffer nullptr!");
123         return;
124     }
125     int32_t ret = FreeMem(buffer);
126     if (ret != HDF_SUCCESS) {
127         HDF_LOGE("%{public}s: FreeMem failed with %{public}d!", __func__, ret);
128     }
129 }
130 
GetMetaService()131 sptr<Buffer::V1_1::IMetadata> LayerCache::GetMetaService()
132 {
133     static sptr<Buffer::V1_1::IMetadata> metaService = nullptr;
134     if (metaService == nullptr) {
135         metaService = Buffer::V1_1::IMetadata::Get(true);
136     }
137     return metaService;
138 }
139 
GetMapperService()140 sptr<Buffer::V1_2::IMapper> LayerCache::GetMapperService()
141 {
142     static sptr<Buffer::V1_2::IMapper> mapperService = nullptr;
143     if (mapperService == nullptr) {
144         mapperService = Buffer::V1_2::IMapper::Get(true);
145     }
146     return mapperService;
147 }
148 
Mmap(sptr<NativeBuffer> & buffer)149 int32_t LayerCache::Mmap(sptr<NativeBuffer>& buffer)
150 {
151     auto mapperService = GetMapperService();
152     if (mapperService == nullptr) {
153         HDF_LOGE("GetMapperService failed!");
154         return HDF_FAILURE;
155     }
156     return mapperService->Mmap(buffer);
157 }
158 
Unmap(sptr<NativeBuffer> & buffer)159 int32_t LayerCache::Unmap(sptr<NativeBuffer>& buffer)
160 {
161     auto mapperService = GetMapperService();
162     if (mapperService == nullptr) {
163         HDF_LOGE("GetMapperService failed!");
164         return HDF_FAILURE;
165     }
166     return mapperService->Unmap(buffer);
167 }
168 
FreeMem(sptr<NativeBuffer> & buffer)169 int32_t LayerCache::FreeMem(sptr<NativeBuffer>& buffer)
170 {
171     auto mapperService = GetMapperService();
172     if (mapperService == nullptr) {
173         HDF_LOGE("GetMapperService failed!");
174         return HDF_FAILURE;
175     }
176     if (needMap_) {
177         if (buffer != nullptr && buffer->GetBufferHandle() != nullptr &&
178             ((buffer->GetBufferHandle()->usage & V1_0::HBM_USE_PROTECTED) != V1_0::HBM_USE_PROTECTED)) {
179             int32_t ret = Unmap(buffer);
180             if (ret != HDF_SUCCESS) {
181                 HDF_LOGE("Unmap failed!");
182             }
183         }
184     }
185 
186     return mapperService->FreeMem(buffer);
187 }
188 
RegisterBuffer(sptr<NativeBuffer> & buffer)189 int32_t LayerCache::RegisterBuffer(sptr<NativeBuffer>& buffer)
190 {
191     auto metaService = GetMetaService();
192     if (metaService == nullptr) {
193         return HDF_FAILURE;
194     }
195     int32_t ret = metaService->RegisterBuffer(buffer);
196     if (ret != HDF_SUCCESS) {
197         HDF_LOGE("Register Buffer failed!");
198         return ret;
199     }
200 
201     if (needMap_) {
202         if (buffer != nullptr && buffer->GetBufferHandle() != nullptr &&
203             ((buffer->GetBufferHandle()->usage & V1_0::HBM_USE_PROTECTED) != V1_0::HBM_USE_PROTECTED)) {
204             ret = Mmap(buffer);
205             if (ret != HDF_SUCCESS) {
206                 HDF_LOGE("Mmap failed!");
207             }
208         }
209     }
210     return HDF_SUCCESS;
211 }
212 
Dump() const213 void LayerCache::Dump() const
214 {
215     bufferCaches_->TravelCaches([this](const int32_t id, const NativeBuffer& buffer)->void {
216         auto info = buffer.Dump();
217         HDF_LOGE("layerId-%{public}d, buffer[%{public}d]: %{public}s", layerId_, id, info.c_str());
218     });
219 }
220 } // namespace Composer
221 } // namespace Display
222 } // namespace HDI
223 } // namespace OHOS
224