blob: 3b4639bec6eab29e595a65d6d6dd648cc4a99c25 [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
Jeff Tinker7d2c6e82018-02-16 16:14:59 -080029#include <mediadrm/DrmMetrics.h>
Robert Shihc3af31b2019-09-20 21:45:01 -070030#include <mediadrm/DrmSessionManager.h>
Jeff Tinker7d2c6e82018-02-16 16:14:59 -080031#include <mediadrm/IDrm.h>
32#include <mediadrm/IDrmClient.h>
Robert Shih93538812019-11-12 12:21:35 -080033#include <mediadrm/IDrmMetricsConsumer.h>
Jeff Tinkera53d6552017-01-20 00:31:46 -080034#include <utils/threads.h>
35
Jeff Tinker6d998b62017-12-18 14:37:43 -080036namespace drm = ::android::hardware::drm;
37using drm::V1_0::EventType;
38using drm::V1_0::IDrmFactory;
39using drm::V1_0::IDrmPlugin;
40using drm::V1_0::IDrmPluginListener;
Jeff Tinker99dbfa82019-01-17 17:27:06 -080041using drm::V1_1::SecurityLevel;
Robert Shiha5033262019-05-06 14:15:12 -070042using drm::V1_2::KeyStatus;
Jeff Tinkerc8baaba2018-10-23 11:32:36 -070043using drm::V1_2::OfflineLicenseState;
Jeff Tinkera53d6552017-01-20 00:31:46 -080044using ::android::hardware::hidl_vec;
45using ::android::hardware::Return;
46using ::android::hardware::Void;
47
Jeff Tinkerb8684f32018-12-12 08:41:31 -080048typedef drm::V1_2::IDrmPluginListener IDrmPluginListener_V1_2;
Robert Shiha5033262019-05-06 14:15:12 -070049typedef drm::V1_0::KeyStatus KeyStatus_V1_0;
Jeff Tinkerb8684f32018-12-12 08:41:31 -080050
Jeff Tinkera53d6552017-01-20 00:31:46 -080051namespace android {
52
53struct DrmSessionClientInterface;
54
Jeff Tinker61332812017-05-15 16:53:10 -070055inline bool operator==(const Vector<uint8_t> &l, const Vector<uint8_t> &r) {
56 if (l.size() != r.size()) return false;
57 return memcmp(l.array(), r.array(), l.size()) == 0;
58}
59
Robert Shih9ad15742019-08-02 14:15:01 -070060struct DrmHal : public IDrm,
Jeff Tinkerb8684f32018-12-12 08:41:31 -080061 public IDrmPluginListener_V1_2 {
Robert Shihc3af31b2019-09-20 21:45:01 -070062
Chong Zhang181e6952019-10-09 13:23:39 -070063 struct DrmSessionClient;
Robert Shihc3af31b2019-09-20 21:45:01 -070064
Jeff Tinkera53d6552017-01-20 00:31:46 -080065 DrmHal();
66 virtual ~DrmHal();
67
68 virtual status_t initCheck() const;
69
Jeff Tinkerdb3fa5f2019-01-25 22:56:56 -080070 virtual status_t isCryptoSchemeSupported(const uint8_t uuid[16],
71 const String8& mimeType,
72 DrmPlugin::SecurityLevel level,
73 bool *isSupported);
Jeff Tinkera53d6552017-01-20 00:31:46 -080074
Edwin Wong68b3d9f2017-01-06 19:07:54 -080075 virtual status_t createPlugin(const uint8_t uuid[16],
76 const String8 &appPackageName);
Jeff Tinkera53d6552017-01-20 00:31:46 -080077
78 virtual status_t destroyPlugin();
79
Jeff Tinker41d279a2018-02-11 19:52:08 +000080 virtual status_t openSession(DrmPlugin::SecurityLevel level,
81 Vector<uint8_t> &sessionId);
Jeff Tinkera53d6552017-01-20 00:31:46 -080082
83 virtual status_t closeSession(Vector<uint8_t> const &sessionId);
84
85 virtual status_t
86 getKeyRequest(Vector<uint8_t> const &sessionId,
87 Vector<uint8_t> const &initData,
88 String8 const &mimeType, DrmPlugin::KeyType keyType,
89 KeyedVector<String8, String8> const &optionalParameters,
90 Vector<uint8_t> &request, String8 &defaultUrl,
91 DrmPlugin::KeyRequestType *keyRequestType);
92
93 virtual status_t provideKeyResponse(Vector<uint8_t> const &sessionId,
94 Vector<uint8_t> const &response,
95 Vector<uint8_t> &keySetId);
96
97 virtual status_t removeKeys(Vector<uint8_t> const &keySetId);
98
99 virtual status_t restoreKeys(Vector<uint8_t> const &sessionId,
100 Vector<uint8_t> const &keySetId);
101
102 virtual status_t queryKeyStatus(Vector<uint8_t> const &sessionId,
103 KeyedVector<String8, String8> &infoMap) const;
104
105 virtual status_t getProvisionRequest(String8 const &certType,
106 String8 const &certAuthority,
107 Vector<uint8_t> &request,
108 String8 &defaulUrl);
109
110 virtual status_t provideProvisionResponse(Vector<uint8_t> const &response,
111 Vector<uint8_t> &certificate,
112 Vector<uint8_t> &wrappedKey);
113
Jeff Tinkerabeb36a2017-02-17 09:42:46 -0800114 virtual status_t getSecureStops(List<Vector<uint8_t>> &secureStops);
Jeff Tinker15177d72018-01-25 12:57:55 -0800115 virtual status_t getSecureStopIds(List<Vector<uint8_t>> &secureStopIds);
Jeff Tinkera53d6552017-01-20 00:31:46 -0800116 virtual status_t getSecureStop(Vector<uint8_t> const &ssid, Vector<uint8_t> &secureStop);
117
118 virtual status_t releaseSecureStops(Vector<uint8_t> const &ssRelease);
Jeff Tinker15177d72018-01-25 12:57:55 -0800119 virtual status_t removeSecureStop(Vector<uint8_t> const &ssid);
120 virtual status_t removeAllSecureStops();
Jeff Tinkera53d6552017-01-20 00:31:46 -0800121
Jeff Tinker6d998b62017-12-18 14:37:43 -0800122 virtual status_t getHdcpLevels(DrmPlugin::HdcpLevel *connectedLevel,
123 DrmPlugin::HdcpLevel *maxLevel) const;
124 virtual status_t getNumberOfSessions(uint32_t *currentSessions,
125 uint32_t *maxSessions) const;
126 virtual status_t getSecurityLevel(Vector<uint8_t> const &sessionId,
127 DrmPlugin::SecurityLevel *level) const;
Jeff Tinker6d998b62017-12-18 14:37:43 -0800128
Jeff Tinkerc8baaba2018-10-23 11:32:36 -0700129 virtual status_t getOfflineLicenseKeySetIds(List<Vector<uint8_t>> &keySetIds) const;
130 virtual status_t removeOfflineLicense(Vector<uint8_t> const &keySetId);
131 virtual status_t getOfflineLicenseState(Vector<uint8_t> const &keySetId,
132 DrmPlugin::OfflineLicenseState *licenseState) const;
133
Jeff Tinkera53d6552017-01-20 00:31:46 -0800134 virtual status_t getPropertyString(String8 const &name, String8 &value ) const;
135 virtual status_t getPropertyByteArray(String8 const &name,
136 Vector<uint8_t> &value ) const;
137 virtual status_t setPropertyString(String8 const &name, String8 const &value ) const;
138 virtual status_t setPropertyByteArray(String8 const &name,
139 Vector<uint8_t> const &value ) const;
Robert Shih93538812019-11-12 12:21:35 -0800140 virtual status_t getMetrics(const sp<IDrmMetricsConsumer> &consumer);
Jeff Tinkera53d6552017-01-20 00:31:46 -0800141
142 virtual status_t setCipherAlgorithm(Vector<uint8_t> const &sessionId,
143 String8 const &algorithm);
144
145 virtual status_t setMacAlgorithm(Vector<uint8_t> const &sessionId,
146 String8 const &algorithm);
147
148 virtual status_t encrypt(Vector<uint8_t> const &sessionId,
149 Vector<uint8_t> const &keyId,
150 Vector<uint8_t> const &input,
151 Vector<uint8_t> const &iv,
152 Vector<uint8_t> &output);
153
154 virtual status_t decrypt(Vector<uint8_t> const &sessionId,
155 Vector<uint8_t> const &keyId,
156 Vector<uint8_t> const &input,
157 Vector<uint8_t> const &iv,
158 Vector<uint8_t> &output);
159
160 virtual status_t sign(Vector<uint8_t> const &sessionId,
161 Vector<uint8_t> const &keyId,
162 Vector<uint8_t> const &message,
163 Vector<uint8_t> &signature);
164
165 virtual status_t verify(Vector<uint8_t> const &sessionId,
166 Vector<uint8_t> const &keyId,
167 Vector<uint8_t> const &message,
168 Vector<uint8_t> const &signature,
169 bool &match);
170
171 virtual status_t signRSA(Vector<uint8_t> const &sessionId,
172 String8 const &algorithm,
173 Vector<uint8_t> const &message,
174 Vector<uint8_t> const &wrappedKey,
175 Vector<uint8_t> &signature);
176
177 virtual status_t setListener(const sp<IDrmClient>& listener);
178
179 // Methods of IDrmPluginListener
180 Return<void> sendEvent(EventType eventType,
181 const hidl_vec<uint8_t>& sessionId, const hidl_vec<uint8_t>& data);
182
183 Return<void> sendExpirationUpdate(const hidl_vec<uint8_t>& sessionId,
184 int64_t expiryTimeInMS);
185
186 Return<void> sendKeysChange(const hidl_vec<uint8_t>& sessionId,
Robert Shiha5033262019-05-06 14:15:12 -0700187 const hidl_vec<KeyStatus_V1_0>& keyStatusList, bool hasNewUsableKey);
188
189 Return<void> sendKeysChange_1_2(const hidl_vec<uint8_t>& sessionId,
Jeff Tinkera53d6552017-01-20 00:31:46 -0800190 const hidl_vec<KeyStatus>& keyStatusList, bool hasNewUsableKey);
191
Jeff Tinkerb8684f32018-12-12 08:41:31 -0800192 Return<void> sendSessionLostState(const hidl_vec<uint8_t>& sessionId);
193
Jeff Tinkera53d6552017-01-20 00:31:46 -0800194private:
195 static Mutex mLock;
196
Jeff Tinkera53d6552017-01-20 00:31:46 -0800197 sp<IDrmClient> mListener;
198 mutable Mutex mEventLock;
199 mutable Mutex mNotifyLock;
200
Robert Shihc0d1d0e2019-11-24 13:21:04 -0800201 const std::vector<sp<IDrmFactory>> mFactories;
Jeff Tinkera53d6552017-01-20 00:31:46 -0800202 sp<IDrmPlugin> mPlugin;
Jeff Tinker6d998b62017-12-18 14:37:43 -0800203 sp<drm::V1_1::IDrmPlugin> mPluginV1_1;
Jeff Tinkerc8baaba2018-10-23 11:32:36 -0700204 sp<drm::V1_2::IDrmPlugin> mPluginV1_2;
Adam Stone32494f52018-02-26 22:53:27 -0800205 String8 mAppPackageName;
Jeff Tinkera53d6552017-01-20 00:31:46 -0800206
Adam Stonecea91ce2018-01-22 19:23:28 -0800207 // Mutable to allow modification within GetPropertyByteArray.
208 mutable MediaDrmMetrics mMetrics;
Adam Stoneaaf87dd2018-01-08 11:55:06 -0800209
Robert Shih0f3a8a02019-11-14 15:43:39 -0800210 std::vector<std::shared_ptr<DrmSessionClient>> mOpenSessions;
Jeff Tinker61332812017-05-15 16:53:10 -0700211 void closeOpenSessions();
Jeff Tinker7dfe28f2018-02-15 12:17:40 -0800212 void cleanup();
Jeff Tinker61332812017-05-15 16:53:10 -0700213
Jeff Tinkera53d6552017-01-20 00:31:46 -0800214 /**
215 * mInitCheck is:
216 * NO_INIT if a plugin hasn't been created yet
217 * ERROR_UNSUPPORTED if a plugin can't be created for the uuid
218 * OK after a plugin has been created and mPlugin is valid
219 */
220 status_t mInitCheck;
221
Robert Shihc0d1d0e2019-11-24 13:21:04 -0800222 std::vector<sp<IDrmFactory>> makeDrmFactories();
Jeff Tinkerabeb36a2017-02-17 09:42:46 -0800223 sp<IDrmPlugin> makeDrmPlugin(const sp<IDrmFactory>& factory,
224 const uint8_t uuid[16], const String8& appPackageName);
Jeff Tinkera53d6552017-01-20 00:31:46 -0800225
226 void writeByteArray(Parcel &obj, const hidl_vec<uint8_t>& array);
227
Adam Stonefb679e32018-02-07 10:25:48 -0800228 void reportPluginMetrics() const;
229 void reportFrameworkMetrics() const;
John W. Bruce33ecc4f2017-04-03 16:49:05 -0700230 status_t getPropertyStringInternal(String8 const &name, String8 &value) const;
231 status_t getPropertyByteArrayInternal(String8 const &name,
232 Vector<uint8_t> &value) const;
Jeff Tinkerdb3fa5f2019-01-25 22:56:56 -0800233 status_t matchMimeTypeAndSecurityLevel(const sp<IDrmFactory> &factory,
234 const uint8_t uuid[16],
235 const String8 &mimeType,
236 DrmPlugin::SecurityLevel level,
237 bool *isSupported);
John W. Bruce33ecc4f2017-04-03 16:49:05 -0700238
Jeff Tinkera53d6552017-01-20 00:31:46 -0800239 DISALLOW_EVIL_CONSTRUCTORS(DrmHal);
240};
241
242} // namespace android
243
244#endif // DRM_HAL_H_