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