1 /*
2  * Copyright (c) 2024 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 "rs_surface_buffer_callback_proxy.h"
17 #include <message_option.h>
18 #include <message_parcel.h>
19 #include "platform/common/rs_log.h"
20 
21 namespace OHOS {
22 namespace Rosen {
RSSurfaceBufferCallbackProxy(const sptr<IRemoteObject> & impl)23 RSSurfaceBufferCallbackProxy::RSSurfaceBufferCallbackProxy(const sptr<IRemoteObject>& impl)
24     : IRemoteProxy<RSISurfaceBufferCallback>(impl)
25 {
26 }
27 
OnFinish(const FinishCallbackRet & ret)28 void RSSurfaceBufferCallbackProxy::OnFinish(const FinishCallbackRet& ret)
29 {
30     MessageParcel data;
31     MessageParcel reply;
32     MessageOption option;
33     if (!data.WriteInterfaceToken(RSISurfaceBufferCallback::GetDescriptor())) {
34         ROSEN_LOGE("RSSurfaceBufferCallbackProxy::OnFinish data.WriteInterfaceToken error");
35         return;
36     }
37     if (!data.WriteUint64(ret.uid)) {
38         ROSEN_LOGE("RSSurfaceBufferCallbackProxy::OnFinish write uid error");
39         return;
40     }
41     if (!data.WriteUInt32Vector(ret.surfaceBufferIds)) {
42         ROSEN_LOGE("RSSurfaceBufferCallbackProxy::OnFinish write surfaceBufferIds error");
43         return;
44     }
45     if (!data.WriteUInt8Vector(ret.isRenderedFlags)) {
46         ROSEN_LOGE("RSSurfaceBufferCallbackProxy::OnFinish write isRenderedFlags error");
47         return;
48     }
49     if (!data.WriteBool(ret.isUniRender)) {
50         ROSEN_LOGE("RSSurfaceBufferCallbackProxy::OnFinish write isUniRender error");
51         return;
52     }
53 #ifdef ROSEN_OHOS
54     if (!data.WriteUint64(static_cast<uint64_t>(ret.releaseFences.size()))) {
55         ROSEN_LOGE("RSSurfaceBufferCallbackProxy::OnFinish write releaseFences Size error");
56         return;
57     }
58     for (auto& releaseFence : ret.releaseFences) {
59         releaseFence->WriteToMessageParcel(data);
60     }
61 #endif
62     option.SetFlags(MessageOption::TF_ASYNC);
63     uint32_t code = static_cast<uint32_t>(RSISurfaceBufferCallbackInterfaceCode::ON_FINISH);
64     int32_t err = Remote()->SendRequest(code, data, reply, option);
65     if (err != NO_ERROR) {
66         ROSEN_LOGE("RSSurfaceBufferCallbackProxy: Remote()->SendRequest() error");
67     }
68 }
69 
OnAfterAcquireBuffer(const AfterAcquireBufferRet & ret)70 void RSSurfaceBufferCallbackProxy::OnAfterAcquireBuffer(const AfterAcquireBufferRet& ret)
71 {
72     MessageParcel data;
73     MessageParcel reply;
74     MessageOption option;
75     if (!data.WriteInterfaceToken(RSISurfaceBufferCallback::GetDescriptor())) {
76         ROSEN_LOGE("RSSurfaceBufferCallbackProxy::OnAfterAcquireBuffer data.WriteInterfaceToken error");
77         return;
78     }
79     if (!data.WriteUint64(ret.uid)) {
80         ROSEN_LOGE("RSSurfaceBufferCallbackProxy::OnAfterAcquireBuffer write uid error");
81         return;
82     }
83     if (!data.WriteBool(ret.isUniRender)) {
84         ROSEN_LOGE("RSSurfaceBufferCallbackProxy::OnAfterAcquireBuffer write isUniRender error");
85         return;
86     }
87     option.SetFlags(MessageOption::TF_ASYNC);
88     uint32_t code = static_cast<uint32_t>(RSISurfaceBufferCallbackInterfaceCode::ON_AFTER_ACQUIRE_BUFFER);
89     int32_t err = Remote()->SendRequest(code, data, reply, option);
90     if (err != NO_ERROR) {
91         ROSEN_LOGE("RSSurfaceBufferCallbackProxy: Remote()->SendRequest() error");
92     }
93 }
94 } // namespace Rosen
95 } // namespace OHOS
96