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