xref: /aosp_15_r20/frameworks/av/media/module/service.mediatranscoding/MediaTranscodingService.cpp (revision ec779b8e0859a360c3d303172224686826e6e0e1)
1*ec779b8eSAndroid Build Coastguard Worker /*
2*ec779b8eSAndroid Build Coastguard Worker  * Copyright (C) 2019 The Android Open Source Project
3*ec779b8eSAndroid Build Coastguard Worker  *
4*ec779b8eSAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*ec779b8eSAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*ec779b8eSAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*ec779b8eSAndroid Build Coastguard Worker  *
8*ec779b8eSAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*ec779b8eSAndroid Build Coastguard Worker  *
10*ec779b8eSAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*ec779b8eSAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*ec779b8eSAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*ec779b8eSAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*ec779b8eSAndroid Build Coastguard Worker  * limitations under the License.
15*ec779b8eSAndroid Build Coastguard Worker  */
16*ec779b8eSAndroid Build Coastguard Worker 
17*ec779b8eSAndroid Build Coastguard Worker //#define LOG_NDEBUG 0
18*ec779b8eSAndroid Build Coastguard Worker #define LOG_TAG "MediaTranscodingService"
19*ec779b8eSAndroid Build Coastguard Worker #include "MediaTranscodingService.h"
20*ec779b8eSAndroid Build Coastguard Worker 
21*ec779b8eSAndroid Build Coastguard Worker #include <android/binder_manager.h>
22*ec779b8eSAndroid Build Coastguard Worker #include <android/binder_process.h>
23*ec779b8eSAndroid Build Coastguard Worker #include <android/permission_manager.h>
24*ec779b8eSAndroid Build Coastguard Worker #include <cutils/properties.h>
25*ec779b8eSAndroid Build Coastguard Worker #include <media/TranscoderWrapper.h>
26*ec779b8eSAndroid Build Coastguard Worker #include <media/TranscodingClientManager.h>
27*ec779b8eSAndroid Build Coastguard Worker #include <media/TranscodingDefs.h>
28*ec779b8eSAndroid Build Coastguard Worker #include <media/TranscodingLogger.h>
29*ec779b8eSAndroid Build Coastguard Worker #include <media/TranscodingResourcePolicy.h>
30*ec779b8eSAndroid Build Coastguard Worker #include <media/TranscodingSessionController.h>
31*ec779b8eSAndroid Build Coastguard Worker #include <media/TranscodingThermalPolicy.h>
32*ec779b8eSAndroid Build Coastguard Worker #include <media/TranscodingUidPolicy.h>
33*ec779b8eSAndroid Build Coastguard Worker #include <utils/Log.h>
34*ec779b8eSAndroid Build Coastguard Worker #include <utils/Vector.h>
35*ec779b8eSAndroid Build Coastguard Worker 
36*ec779b8eSAndroid Build Coastguard Worker #include "SimulatedTranscoder.h"
37*ec779b8eSAndroid Build Coastguard Worker 
38*ec779b8eSAndroid Build Coastguard Worker namespace android {
39*ec779b8eSAndroid Build Coastguard Worker 
40*ec779b8eSAndroid Build Coastguard Worker // Convenience methods for constructing binder::Status objects for error returns
41*ec779b8eSAndroid Build Coastguard Worker #define STATUS_ERROR_FMT(errorCode, errorString, ...) \
42*ec779b8eSAndroid Build Coastguard Worker     Status::fromServiceSpecificErrorWithMessage(      \
43*ec779b8eSAndroid Build Coastguard Worker             errorCode,                                \
44*ec779b8eSAndroid Build Coastguard Worker             String8::format("%s:%d: " errorString, __FUNCTION__, __LINE__, ##__VA_ARGS__))
45*ec779b8eSAndroid Build Coastguard Worker 
46*ec779b8eSAndroid Build Coastguard Worker static constexpr int64_t kTranscoderHeartBeatIntervalUs = 1000000LL;
47*ec779b8eSAndroid Build Coastguard Worker 
MediaTranscodingService()48*ec779b8eSAndroid Build Coastguard Worker MediaTranscodingService::MediaTranscodingService()
49*ec779b8eSAndroid Build Coastguard Worker       : mUidPolicy(new TranscodingUidPolicy()),
50*ec779b8eSAndroid Build Coastguard Worker         mResourcePolicy(new TranscodingResourcePolicy()),
51*ec779b8eSAndroid Build Coastguard Worker         mThermalPolicy(new TranscodingThermalPolicy()),
52*ec779b8eSAndroid Build Coastguard Worker         mLogger(new TranscodingLogger()) {
53*ec779b8eSAndroid Build Coastguard Worker     ALOGV("MediaTranscodingService is created");
54*ec779b8eSAndroid Build Coastguard Worker     bool simulated = property_get_bool("debug.transcoding.simulated_transcoder", false);
55*ec779b8eSAndroid Build Coastguard Worker     if (simulated) {
56*ec779b8eSAndroid Build Coastguard Worker         // Overrid default config params with shorter values for testing.
57*ec779b8eSAndroid Build Coastguard Worker         TranscodingSessionController::ControllerConfig config = {
58*ec779b8eSAndroid Build Coastguard Worker                 .pacerBurstThresholdMs = 500,
59*ec779b8eSAndroid Build Coastguard Worker                 .pacerBurstCountQuota = 10,
60*ec779b8eSAndroid Build Coastguard Worker                 .pacerBurstTimeQuotaSeconds = 3,
61*ec779b8eSAndroid Build Coastguard Worker         };
62*ec779b8eSAndroid Build Coastguard Worker         mSessionController.reset(new TranscodingSessionController(
63*ec779b8eSAndroid Build Coastguard Worker                 [](const std::shared_ptr<TranscoderCallbackInterface>& cb)
64*ec779b8eSAndroid Build Coastguard Worker                         -> std::shared_ptr<TranscoderInterface> {
65*ec779b8eSAndroid Build Coastguard Worker                     return std::make_shared<SimulatedTranscoder>(cb);
66*ec779b8eSAndroid Build Coastguard Worker                 },
67*ec779b8eSAndroid Build Coastguard Worker                 mUidPolicy, mResourcePolicy, mThermalPolicy, &config));
68*ec779b8eSAndroid Build Coastguard Worker     } else {
69*ec779b8eSAndroid Build Coastguard Worker         int32_t overrideBurstCountQuota =
70*ec779b8eSAndroid Build Coastguard Worker                 property_get_int32("persist.transcoding.burst_count_quota", -1);
71*ec779b8eSAndroid Build Coastguard Worker         int32_t pacerBurstTimeQuotaSeconds =
72*ec779b8eSAndroid Build Coastguard Worker                 property_get_int32("persist.transcoding.burst_time_quota_seconds", -1);
73*ec779b8eSAndroid Build Coastguard Worker         // Override default config params with properties if present.
74*ec779b8eSAndroid Build Coastguard Worker         TranscodingSessionController::ControllerConfig config;
75*ec779b8eSAndroid Build Coastguard Worker         if (overrideBurstCountQuota > 0) {
76*ec779b8eSAndroid Build Coastguard Worker             config.pacerBurstCountQuota = overrideBurstCountQuota;
77*ec779b8eSAndroid Build Coastguard Worker         }
78*ec779b8eSAndroid Build Coastguard Worker         if (pacerBurstTimeQuotaSeconds > 0) {
79*ec779b8eSAndroid Build Coastguard Worker             config.pacerBurstTimeQuotaSeconds = pacerBurstTimeQuotaSeconds;
80*ec779b8eSAndroid Build Coastguard Worker         }
81*ec779b8eSAndroid Build Coastguard Worker         mSessionController.reset(new TranscodingSessionController(
82*ec779b8eSAndroid Build Coastguard Worker                 [logger = mLogger](const std::shared_ptr<TranscoderCallbackInterface>& cb)
83*ec779b8eSAndroid Build Coastguard Worker                         -> std::shared_ptr<TranscoderInterface> {
84*ec779b8eSAndroid Build Coastguard Worker                     return std::make_shared<TranscoderWrapper>(cb, logger,
85*ec779b8eSAndroid Build Coastguard Worker                                                                kTranscoderHeartBeatIntervalUs);
86*ec779b8eSAndroid Build Coastguard Worker                 },
87*ec779b8eSAndroid Build Coastguard Worker                 mUidPolicy, mResourcePolicy, mThermalPolicy, &config));
88*ec779b8eSAndroid Build Coastguard Worker     }
89*ec779b8eSAndroid Build Coastguard Worker     mClientManager.reset(new TranscodingClientManager(mSessionController));
90*ec779b8eSAndroid Build Coastguard Worker     mUidPolicy->setCallback(mSessionController);
91*ec779b8eSAndroid Build Coastguard Worker     mResourcePolicy->setCallback(mSessionController);
92*ec779b8eSAndroid Build Coastguard Worker     mThermalPolicy->setCallback(mSessionController);
93*ec779b8eSAndroid Build Coastguard Worker }
94*ec779b8eSAndroid Build Coastguard Worker 
~MediaTranscodingService()95*ec779b8eSAndroid Build Coastguard Worker MediaTranscodingService::~MediaTranscodingService() {
96*ec779b8eSAndroid Build Coastguard Worker     ALOGE("Should not be in ~MediaTranscodingService");
97*ec779b8eSAndroid Build Coastguard Worker }
98*ec779b8eSAndroid Build Coastguard Worker 
dump(int fd,const char **,uint32_t)99*ec779b8eSAndroid Build Coastguard Worker binder_status_t MediaTranscodingService::dump(int fd, const char** /*args*/, uint32_t /*numArgs*/) {
100*ec779b8eSAndroid Build Coastguard Worker     String8 result;
101*ec779b8eSAndroid Build Coastguard Worker 
102*ec779b8eSAndroid Build Coastguard Worker     uid_t callingUid = AIBinder_getCallingUid();
103*ec779b8eSAndroid Build Coastguard Worker     pid_t callingPid = AIBinder_getCallingPid();
104*ec779b8eSAndroid Build Coastguard Worker     if (__builtin_available(android __TRANSCODING_MIN_API__, *)) {
105*ec779b8eSAndroid Build Coastguard Worker         int32_t permissionResult;
106*ec779b8eSAndroid Build Coastguard Worker         if (APermissionManager_checkPermission("android.permission.DUMP", callingPid, callingUid,
107*ec779b8eSAndroid Build Coastguard Worker                                                &permissionResult) != PERMISSION_MANAGER_STATUS_OK ||
108*ec779b8eSAndroid Build Coastguard Worker             permissionResult != PERMISSION_MANAGER_PERMISSION_GRANTED) {
109*ec779b8eSAndroid Build Coastguard Worker             result.format(
110*ec779b8eSAndroid Build Coastguard Worker                     "Permission Denial: "
111*ec779b8eSAndroid Build Coastguard Worker                     "can't dump MediaTranscodingService from pid=%d, uid=%d\n",
112*ec779b8eSAndroid Build Coastguard Worker                     AIBinder_getCallingPid(), AIBinder_getCallingUid());
113*ec779b8eSAndroid Build Coastguard Worker             write(fd, result.c_str(), result.size());
114*ec779b8eSAndroid Build Coastguard Worker             return PERMISSION_DENIED;
115*ec779b8eSAndroid Build Coastguard Worker         }
116*ec779b8eSAndroid Build Coastguard Worker     }
117*ec779b8eSAndroid Build Coastguard Worker 
118*ec779b8eSAndroid Build Coastguard Worker     const size_t SIZE = 256;
119*ec779b8eSAndroid Build Coastguard Worker     char buffer[SIZE];
120*ec779b8eSAndroid Build Coastguard Worker 
121*ec779b8eSAndroid Build Coastguard Worker     snprintf(buffer, SIZE, "MediaTranscodingService: %p\n", this);
122*ec779b8eSAndroid Build Coastguard Worker     result.append(buffer);
123*ec779b8eSAndroid Build Coastguard Worker     write(fd, result.c_str(), result.size());
124*ec779b8eSAndroid Build Coastguard Worker 
125*ec779b8eSAndroid Build Coastguard Worker     Vector<String16> args;
126*ec779b8eSAndroid Build Coastguard Worker     mClientManager->dumpAllClients(fd, args);
127*ec779b8eSAndroid Build Coastguard Worker     mSessionController->dumpAllSessions(fd, args);
128*ec779b8eSAndroid Build Coastguard Worker     return OK;
129*ec779b8eSAndroid Build Coastguard Worker }
130*ec779b8eSAndroid Build Coastguard Worker 
131*ec779b8eSAndroid Build Coastguard Worker //static
instantiate()132*ec779b8eSAndroid Build Coastguard Worker void MediaTranscodingService::instantiate() {
133*ec779b8eSAndroid Build Coastguard Worker     std::shared_ptr<MediaTranscodingService> service =
134*ec779b8eSAndroid Build Coastguard Worker             ::ndk::SharedRefBase::make<MediaTranscodingService>();
135*ec779b8eSAndroid Build Coastguard Worker     if (__builtin_available(android __TRANSCODING_MIN_API__, *)) {
136*ec779b8eSAndroid Build Coastguard Worker         // Once service is started, we want it to stay even is client side perished.
137*ec779b8eSAndroid Build Coastguard Worker         AServiceManager_forceLazyServicesPersist(true /*persist*/);
138*ec779b8eSAndroid Build Coastguard Worker         (void)AServiceManager_registerLazyService(service->asBinder().get(), getServiceName());
139*ec779b8eSAndroid Build Coastguard Worker     }
140*ec779b8eSAndroid Build Coastguard Worker }
141*ec779b8eSAndroid Build Coastguard Worker 
registerClient(const std::shared_ptr<ITranscodingClientCallback> & in_callback,const std::string & in_clientName,const std::string & in_opPackageName,std::shared_ptr<ITranscodingClient> * _aidl_return)142*ec779b8eSAndroid Build Coastguard Worker Status MediaTranscodingService::registerClient(
143*ec779b8eSAndroid Build Coastguard Worker         const std::shared_ptr<ITranscodingClientCallback>& in_callback,
144*ec779b8eSAndroid Build Coastguard Worker         const std::string& in_clientName, const std::string& in_opPackageName,
145*ec779b8eSAndroid Build Coastguard Worker         std::shared_ptr<ITranscodingClient>* _aidl_return) {
146*ec779b8eSAndroid Build Coastguard Worker     if (in_callback == nullptr) {
147*ec779b8eSAndroid Build Coastguard Worker         *_aidl_return = nullptr;
148*ec779b8eSAndroid Build Coastguard Worker         return STATUS_ERROR_FMT(ERROR_ILLEGAL_ARGUMENT, "Client callback cannot be null!");
149*ec779b8eSAndroid Build Coastguard Worker     }
150*ec779b8eSAndroid Build Coastguard Worker 
151*ec779b8eSAndroid Build Coastguard Worker     // Creates the client and uses its process id as client id.
152*ec779b8eSAndroid Build Coastguard Worker     std::shared_ptr<ITranscodingClient> newClient;
153*ec779b8eSAndroid Build Coastguard Worker 
154*ec779b8eSAndroid Build Coastguard Worker     status_t err =
155*ec779b8eSAndroid Build Coastguard Worker             mClientManager->addClient(in_callback, in_clientName, in_opPackageName, &newClient);
156*ec779b8eSAndroid Build Coastguard Worker     if (err != OK) {
157*ec779b8eSAndroid Build Coastguard Worker         *_aidl_return = nullptr;
158*ec779b8eSAndroid Build Coastguard Worker         return STATUS_ERROR_FMT(err, "Failed to add client to TranscodingClientManager");
159*ec779b8eSAndroid Build Coastguard Worker     }
160*ec779b8eSAndroid Build Coastguard Worker 
161*ec779b8eSAndroid Build Coastguard Worker     *_aidl_return = newClient;
162*ec779b8eSAndroid Build Coastguard Worker     return Status::ok();
163*ec779b8eSAndroid Build Coastguard Worker }
164*ec779b8eSAndroid Build Coastguard Worker 
getNumOfClients(int32_t * _aidl_return)165*ec779b8eSAndroid Build Coastguard Worker Status MediaTranscodingService::getNumOfClients(int32_t* _aidl_return) {
166*ec779b8eSAndroid Build Coastguard Worker     ALOGD("MediaTranscodingService::getNumOfClients");
167*ec779b8eSAndroid Build Coastguard Worker     *_aidl_return = mClientManager->getNumOfClients();
168*ec779b8eSAndroid Build Coastguard Worker     return Status::ok();
169*ec779b8eSAndroid Build Coastguard Worker }
170*ec779b8eSAndroid Build Coastguard Worker 
171*ec779b8eSAndroid Build Coastguard Worker }  // namespace android
172