blob: 542d30085249f1feee1ad7531ee359a35bb83dc9 [file] [log] [blame]
Jeff Tinkera53d6552017-01-20 00:31:46 -08001/*
2 * Copyright (C) 2017 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#ifndef DRM_HAL_H_
18
19#define DRM_HAL_H_
20
Jeff Tinkera53d6552017-01-20 00:31:46 -080021#include <android/hardware/drm/1.0/IDrmFactory.h>
Jeff Tinkere307dc42018-02-11 19:53:54 +000022#include <android/hardware/drm/1.0/IDrmPlugin.h>
Jeff Tinkere307dc42018-02-11 19:53:54 +000023#include <android/hardware/drm/1.1/IDrmFactory.h>
24#include <android/hardware/drm/1.1/IDrmPlugin.h>
Jeff Tinkerc8baaba2018-10-23 11:32:36 -070025#include <android/hardware/drm/1.2/IDrmFactory.h>
26#include <android/hardware/drm/1.2/IDrmPlugin.h>
Jeff Tinkerb8684f32018-12-12 08:41:31 -080027#include <android/hardware/drm/1.2/IDrmPluginListener.h>
Jeff Tinkera53d6552017-01-20 00:31:46 -080028
Robert Shihc3af31b2019-09-20 21:45:01 -070029#include <media/IResourceManagerService.h>
Adam Stoneab394d12017-12-22 12:34:20 -080030#include <media/MediaAnalyticsItem.h>
Jeff Tinker7d2c6e82018-02-16 16:14:59 -080031#include <mediadrm/DrmMetrics.h>
Robert Shihc3af31b2019-09-20 21:45:01 -070032#include <mediadrm/DrmSessionManager.h>
Jeff Tinker7d2c6e82018-02-16 16:14:59 -080033#include <mediadrm/IDrm.h>
34#include <mediadrm/IDrmClient.h>
Jeff Tinkera53d6552017-01-20 00:31:46 -080035#include <utils/threads.h>
36
Jeff Tinker6d998b62017-12-18 14:37:43 -080037namespace drm = ::android::hardware::drm;
38using drm::V1_0::EventType;
39using drm::V1_0::IDrmFactory;
40using drm::V1_0::IDrmPlugin;
41using drm::V1_0::IDrmPluginListener;
Jeff Tinker99dbfa82019-01-17 17:27:06 -080042using drm::V1_1::SecurityLevel;
Robert Shiha5033262019-05-06 14:15:12 -070043using drm::V1_2::KeyStatus;
Jeff Tinkerc8baaba2018-10-23 11:32:36 -070044using drm::V1_2::OfflineLicenseState;
Jeff Tinkera53d6552017-01-20 00:31:46 -080045using ::android::hardware::hidl_vec;
46using ::android::hardware::Return;
47using ::android::hardware::Void;
48
Jeff Tinkerb8684f32018-12-12 08:41:31 -080049typedef drm::V1_2::IDrmPluginListener IDrmPluginListener_V1_2;
Robert Shiha5033262019-05-06 14:15:12 -070050typedef drm::V1_0::KeyStatus KeyStatus_V1_0;
Jeff Tinkerb8684f32018-12-12 08:41:31 -080051
Jeff Tinkera53d6552017-01-20 00:31:46 -080052namespace android {
53
54struct DrmSessionClientInterface;
55
Jeff Tinker61332812017-05-15 16:53:10 -070056inline bool operator==(const Vector<uint8_t> &l, const Vector<uint8_t> &r) {
57 if (l.size() != r.size()) return false;
58 return memcmp(l.array(), r.array(), l.size()) == 0;
59}
60
Jeff Tinkera53d6552017-01-20 00:31:46 -080061struct DrmHal : public BnDrm,
Robert Shiha5033262019-05-06 14:15:12 -070062 public IBinder::DeathRecipient,
Jeff Tinkerb8684f32018-12-12 08:41:31 -080063 public IDrmPluginListener_V1_2 {
Robert Shihc3af31b2019-09-20 21:45:01 -070064
65 struct DrmSessionClient : public BnResourceManagerClient {
66 explicit DrmSessionClient(DrmHal* drm, const Vector<uint8_t>& sessionId)
67 : mSessionId(sessionId),
68 mDrm(drm) {}
69
70 virtual bool reclaimResource();
71 virtual String8 getName();
72
73 const Vector<uint8_t> mSessionId;
74
75 protected:
76 virtual ~DrmSessionClient();
77
78 private:
79 wp<DrmHal> mDrm;
80
81 DISALLOW_EVIL_CONSTRUCTORS(DrmSessionClient);
82 };
83
Jeff Tinkera53d6552017-01-20 00:31:46 -080084 DrmHal();
85 virtual ~DrmHal();
86
87 virtual status_t initCheck() const;
88
Jeff Tinkerdb3fa5f2019-01-25 22:56:56 -080089 virtual status_t isCryptoSchemeSupported(const uint8_t uuid[16],
90 const String8& mimeType,
91 DrmPlugin::SecurityLevel level,
92 bool *isSupported);
Jeff Tinkera53d6552017-01-20 00:31:46 -080093
Edwin Wong68b3d9f2017-01-06 19:07:54 -080094 virtual status_t createPlugin(const uint8_t uuid[16],
95 const String8 &appPackageName);
Jeff Tinkera53d6552017-01-20 00:31:46 -080096
97 virtual status_t destroyPlugin();
98
Jeff Tinker41d279a2018-02-11 19:52:08 +000099 virtual status_t openSession(DrmPlugin::SecurityLevel level,
100 Vector<uint8_t> &sessionId);
Jeff Tinkera53d6552017-01-20 00:31:46 -0800101
102 virtual status_t closeSession(Vector<uint8_t> const &sessionId);
103
104 virtual status_t
105 getKeyRequest(Vector<uint8_t> const &sessionId,
106 Vector<uint8_t> const &initData,
107 String8 const &mimeType, DrmPlugin::KeyType keyType,
108 KeyedVector<String8, String8> const &optionalParameters,
109 Vector<uint8_t> &request, String8 &defaultUrl,
110 DrmPlugin::KeyRequestType *keyRequestType);
111
112 virtual status_t provideKeyResponse(Vector<uint8_t> const &sessionId,
113 Vector<uint8_t> const &response,
114 Vector<uint8_t> &keySetId);
115
116 virtual status_t removeKeys(Vector<uint8_t> const &keySetId);
117
118 virtual status_t restoreKeys(Vector<uint8_t> const &sessionId,
119 Vector<uint8_t> const &keySetId);
120
121 virtual status_t queryKeyStatus(Vector<uint8_t> const &sessionId,
122 KeyedVector<String8, String8> &infoMap) const;
123
124 virtual status_t getProvisionRequest(String8 const &certType,
125 String8 const &certAuthority,
126 Vector<uint8_t> &request,
127 String8 &defaulUrl);
128
129 virtual status_t provideProvisionResponse(Vector<uint8_t> const &response,
130 Vector<uint8_t> &certificate,
131 Vector<uint8_t> &wrappedKey);
132
Jeff Tinkerabeb36a2017-02-17 09:42:46 -0800133 virtual status_t getSecureStops(List<Vector<uint8_t>> &secureStops);
Jeff Tinker15177d72018-01-25 12:57:55 -0800134 virtual status_t getSecureStopIds(List<Vector<uint8_t>> &secureStopIds);
Jeff Tinkera53d6552017-01-20 00:31:46 -0800135 virtual status_t getSecureStop(Vector<uint8_t> const &ssid, Vector<uint8_t> &secureStop);
136
137 virtual status_t releaseSecureStops(Vector<uint8_t> const &ssRelease);
Jeff Tinker15177d72018-01-25 12:57:55 -0800138 virtual status_t removeSecureStop(Vector<uint8_t> const &ssid);
139 virtual status_t removeAllSecureStops();
Jeff Tinkera53d6552017-01-20 00:31:46 -0800140
Jeff Tinker6d998b62017-12-18 14:37:43 -0800141 virtual status_t getHdcpLevels(DrmPlugin::HdcpLevel *connectedLevel,
142 DrmPlugin::HdcpLevel *maxLevel) const;
143 virtual status_t getNumberOfSessions(uint32_t *currentSessions,
144 uint32_t *maxSessions) const;
145 virtual status_t getSecurityLevel(Vector<uint8_t> const &sessionId,
146 DrmPlugin::SecurityLevel *level) const;
Jeff Tinker6d998b62017-12-18 14:37:43 -0800147
Jeff Tinkerc8baaba2018-10-23 11:32:36 -0700148 virtual status_t getOfflineLicenseKeySetIds(List<Vector<uint8_t>> &keySetIds) const;
149 virtual status_t removeOfflineLicense(Vector<uint8_t> const &keySetId);
150 virtual status_t getOfflineLicenseState(Vector<uint8_t> const &keySetId,
151 DrmPlugin::OfflineLicenseState *licenseState) const;
152
Jeff Tinkera53d6552017-01-20 00:31:46 -0800153 virtual status_t getPropertyString(String8 const &name, String8 &value ) const;
154 virtual status_t getPropertyByteArray(String8 const &name,
155 Vector<uint8_t> &value ) const;
156 virtual status_t setPropertyString(String8 const &name, String8 const &value ) const;
157 virtual status_t setPropertyByteArray(String8 const &name,
158 Vector<uint8_t> const &value ) const;
Adam Stone637b7852018-01-30 12:09:36 -0800159 virtual status_t getMetrics(os::PersistableBundle *metrics);
Jeff Tinkera53d6552017-01-20 00:31:46 -0800160
161 virtual status_t setCipherAlgorithm(Vector<uint8_t> const &sessionId,
162 String8 const &algorithm);
163
164 virtual status_t setMacAlgorithm(Vector<uint8_t> const &sessionId,
165 String8 const &algorithm);
166
167 virtual status_t encrypt(Vector<uint8_t> const &sessionId,
168 Vector<uint8_t> const &keyId,
169 Vector<uint8_t> const &input,
170 Vector<uint8_t> const &iv,
171 Vector<uint8_t> &output);
172
173 virtual status_t decrypt(Vector<uint8_t> const &sessionId,
174 Vector<uint8_t> const &keyId,
175 Vector<uint8_t> const &input,
176 Vector<uint8_t> const &iv,
177 Vector<uint8_t> &output);
178
179 virtual status_t sign(Vector<uint8_t> const &sessionId,
180 Vector<uint8_t> const &keyId,
181 Vector<uint8_t> const &message,
182 Vector<uint8_t> &signature);
183
184 virtual status_t verify(Vector<uint8_t> const &sessionId,
185 Vector<uint8_t> const &keyId,
186 Vector<uint8_t> const &message,
187 Vector<uint8_t> const &signature,
188 bool &match);
189
190 virtual status_t signRSA(Vector<uint8_t> const &sessionId,
191 String8 const &algorithm,
192 Vector<uint8_t> const &message,
193 Vector<uint8_t> const &wrappedKey,
194 Vector<uint8_t> &signature);
195
196 virtual status_t setListener(const sp<IDrmClient>& listener);
197
198 // Methods of IDrmPluginListener
199 Return<void> sendEvent(EventType eventType,
200 const hidl_vec<uint8_t>& sessionId, const hidl_vec<uint8_t>& data);
201
202 Return<void> sendExpirationUpdate(const hidl_vec<uint8_t>& sessionId,
203 int64_t expiryTimeInMS);
204
205 Return<void> sendKeysChange(const hidl_vec<uint8_t>& sessionId,
Robert Shiha5033262019-05-06 14:15:12 -0700206 const hidl_vec<KeyStatus_V1_0>& keyStatusList, bool hasNewUsableKey);
207
208 Return<void> sendKeysChange_1_2(const hidl_vec<uint8_t>& sessionId,
Jeff Tinkera53d6552017-01-20 00:31:46 -0800209 const hidl_vec<KeyStatus>& keyStatusList, bool hasNewUsableKey);
210
Jeff Tinkerb8684f32018-12-12 08:41:31 -0800211 Return<void> sendSessionLostState(const hidl_vec<uint8_t>& sessionId);
212
Jeff Tinkera53d6552017-01-20 00:31:46 -0800213 virtual void binderDied(const wp<IBinder> &the_late_who);
214
215private:
216 static Mutex mLock;
217
Jeff Tinkera53d6552017-01-20 00:31:46 -0800218 sp<IDrmClient> mListener;
219 mutable Mutex mEventLock;
220 mutable Mutex mNotifyLock;
221
Jeff Tinkerabeb36a2017-02-17 09:42:46 -0800222 const Vector<sp<IDrmFactory>> mFactories;
Jeff Tinkera53d6552017-01-20 00:31:46 -0800223 sp<IDrmPlugin> mPlugin;
Jeff Tinker6d998b62017-12-18 14:37:43 -0800224 sp<drm::V1_1::IDrmPlugin> mPluginV1_1;
Jeff Tinkerc8baaba2018-10-23 11:32:36 -0700225 sp<drm::V1_2::IDrmPlugin> mPluginV1_2;
Adam Stone32494f52018-02-26 22:53:27 -0800226 String8 mAppPackageName;
Jeff Tinkera53d6552017-01-20 00:31:46 -0800227
Adam Stonecea91ce2018-01-22 19:23:28 -0800228 // Mutable to allow modification within GetPropertyByteArray.
229 mutable MediaDrmMetrics mMetrics;
Adam Stoneaaf87dd2018-01-08 11:55:06 -0800230
Robert Shihc3af31b2019-09-20 21:45:01 -0700231 Vector<sp<DrmSessionClient>> mOpenSessions;
Jeff Tinker61332812017-05-15 16:53:10 -0700232 void closeOpenSessions();
Jeff Tinker7dfe28f2018-02-15 12:17:40 -0800233 void cleanup();
Jeff Tinker61332812017-05-15 16:53:10 -0700234
Jeff Tinkera53d6552017-01-20 00:31:46 -0800235 /**
236 * mInitCheck is:
237 * NO_INIT if a plugin hasn't been created yet
238 * ERROR_UNSUPPORTED if a plugin can't be created for the uuid
239 * OK after a plugin has been created and mPlugin is valid
240 */
241 status_t mInitCheck;
242
Jeff Tinkerabeb36a2017-02-17 09:42:46 -0800243 Vector<sp<IDrmFactory>> makeDrmFactories();
244 sp<IDrmPlugin> makeDrmPlugin(const sp<IDrmFactory>& factory,
245 const uint8_t uuid[16], const String8& appPackageName);
Jeff Tinkera53d6552017-01-20 00:31:46 -0800246
247 void writeByteArray(Parcel &obj, const hidl_vec<uint8_t>& array);
248
Adam Stonefb679e32018-02-07 10:25:48 -0800249 void reportPluginMetrics() const;
250 void reportFrameworkMetrics() const;
John W. Bruce33ecc4f2017-04-03 16:49:05 -0700251 status_t getPropertyStringInternal(String8 const &name, String8 &value) const;
252 status_t getPropertyByteArrayInternal(String8 const &name,
253 Vector<uint8_t> &value) const;
Jeff Tinkerdb3fa5f2019-01-25 22:56:56 -0800254 status_t matchMimeTypeAndSecurityLevel(const sp<IDrmFactory> &factory,
255 const uint8_t uuid[16],
256 const String8 &mimeType,
257 DrmPlugin::SecurityLevel level,
258 bool *isSupported);
John W. Bruce33ecc4f2017-04-03 16:49:05 -0700259
Jeff Tinkera53d6552017-01-20 00:31:46 -0800260 DISALLOW_EVIL_CONSTRUCTORS(DrmHal);
261};
262
263} // namespace android
264
265#endif // DRM_HAL_H_