blob: f261d898d029455dbedf749ed0bad487885dd110 [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>
Jeff Tinkera53d6552017-01-20 00:31:46 -080033#include <utils/threads.h>
34
Jeff Tinker6d998b62017-12-18 14:37:43 -080035namespace drm = ::android::hardware::drm;
36using drm::V1_0::EventType;
37using drm::V1_0::IDrmFactory;
38using drm::V1_0::IDrmPlugin;
39using drm::V1_0::IDrmPluginListener;
Jeff Tinker99dbfa82019-01-17 17:27:06 -080040using drm::V1_1::SecurityLevel;
Robert Shiha5033262019-05-06 14:15:12 -070041using drm::V1_2::KeyStatus;
Jeff Tinkerc8baaba2018-10-23 11:32:36 -070042using drm::V1_2::OfflineLicenseState;
Jeff Tinkera53d6552017-01-20 00:31:46 -080043using ::android::hardware::hidl_vec;
44using ::android::hardware::Return;
45using ::android::hardware::Void;
46
Jeff Tinkerb8684f32018-12-12 08:41:31 -080047typedef drm::V1_2::IDrmPluginListener IDrmPluginListener_V1_2;
Robert Shiha5033262019-05-06 14:15:12 -070048typedef drm::V1_0::KeyStatus KeyStatus_V1_0;
Jeff Tinkerb8684f32018-12-12 08:41:31 -080049
Jeff Tinkera53d6552017-01-20 00:31:46 -080050namespace android {
51
52struct DrmSessionClientInterface;
53
Jeff Tinker61332812017-05-15 16:53:10 -070054inline bool operator==(const Vector<uint8_t> &l, const Vector<uint8_t> &r) {
55 if (l.size() != r.size()) return false;
56 return memcmp(l.array(), r.array(), l.size()) == 0;
57}
58
Robert Shih9ad15742019-08-02 14:15:01 -070059struct DrmHal : public IDrm,
Jeff Tinkerb8684f32018-12-12 08:41:31 -080060 public IDrmPluginListener_V1_2 {
Robert Shihc3af31b2019-09-20 21:45:01 -070061
Chong Zhang181e6952019-10-09 13:23:39 -070062 struct DrmSessionClient;
Robert Shihc3af31b2019-09-20 21:45:01 -070063
Jeff Tinkera53d6552017-01-20 00:31:46 -080064 DrmHal();
65 virtual ~DrmHal();
66
67 virtual status_t initCheck() const;
68
Jeff Tinkerdb3fa5f2019-01-25 22:56:56 -080069 virtual status_t isCryptoSchemeSupported(const uint8_t uuid[16],
70 const String8& mimeType,
71 DrmPlugin::SecurityLevel level,
72 bool *isSupported);
Jeff Tinkera53d6552017-01-20 00:31:46 -080073
Edwin Wong68b3d9f2017-01-06 19:07:54 -080074 virtual status_t createPlugin(const uint8_t uuid[16],
75 const String8 &appPackageName);
Jeff Tinkera53d6552017-01-20 00:31:46 -080076
77 virtual status_t destroyPlugin();
78
Jeff Tinker41d279a2018-02-11 19:52:08 +000079 virtual status_t openSession(DrmPlugin::SecurityLevel level,
80 Vector<uint8_t> &sessionId);
Jeff Tinkera53d6552017-01-20 00:31:46 -080081
82 virtual status_t closeSession(Vector<uint8_t> const &sessionId);
83
84 virtual status_t
85 getKeyRequest(Vector<uint8_t> const &sessionId,
86 Vector<uint8_t> const &initData,
87 String8 const &mimeType, DrmPlugin::KeyType keyType,
88 KeyedVector<String8, String8> const &optionalParameters,
89 Vector<uint8_t> &request, String8 &defaultUrl,
90 DrmPlugin::KeyRequestType *keyRequestType);
91
92 virtual status_t provideKeyResponse(Vector<uint8_t> const &sessionId,
93 Vector<uint8_t> const &response,
94 Vector<uint8_t> &keySetId);
95
96 virtual status_t removeKeys(Vector<uint8_t> const &keySetId);
97
98 virtual status_t restoreKeys(Vector<uint8_t> const &sessionId,
99 Vector<uint8_t> const &keySetId);
100
101 virtual status_t queryKeyStatus(Vector<uint8_t> const &sessionId,
102 KeyedVector<String8, String8> &infoMap) const;
103
104 virtual status_t getProvisionRequest(String8 const &certType,
105 String8 const &certAuthority,
106 Vector<uint8_t> &request,
107 String8 &defaulUrl);
108
109 virtual status_t provideProvisionResponse(Vector<uint8_t> const &response,
110 Vector<uint8_t> &certificate,
111 Vector<uint8_t> &wrappedKey);
112
Jeff Tinkerabeb36a2017-02-17 09:42:46 -0800113 virtual status_t getSecureStops(List<Vector<uint8_t>> &secureStops);
Jeff Tinker15177d72018-01-25 12:57:55 -0800114 virtual status_t getSecureStopIds(List<Vector<uint8_t>> &secureStopIds);
Jeff Tinkera53d6552017-01-20 00:31:46 -0800115 virtual status_t getSecureStop(Vector<uint8_t> const &ssid, Vector<uint8_t> &secureStop);
116
117 virtual status_t releaseSecureStops(Vector<uint8_t> const &ssRelease);
Jeff Tinker15177d72018-01-25 12:57:55 -0800118 virtual status_t removeSecureStop(Vector<uint8_t> const &ssid);
119 virtual status_t removeAllSecureStops();
Jeff Tinkera53d6552017-01-20 00:31:46 -0800120
Jeff Tinker6d998b62017-12-18 14:37:43 -0800121 virtual status_t getHdcpLevels(DrmPlugin::HdcpLevel *connectedLevel,
122 DrmPlugin::HdcpLevel *maxLevel) const;
123 virtual status_t getNumberOfSessions(uint32_t *currentSessions,
124 uint32_t *maxSessions) const;
125 virtual status_t getSecurityLevel(Vector<uint8_t> const &sessionId,
126 DrmPlugin::SecurityLevel *level) const;
Jeff Tinker6d998b62017-12-18 14:37:43 -0800127
Jeff Tinkerc8baaba2018-10-23 11:32:36 -0700128 virtual status_t getOfflineLicenseKeySetIds(List<Vector<uint8_t>> &keySetIds) const;
129 virtual status_t removeOfflineLicense(Vector<uint8_t> const &keySetId);
130 virtual status_t getOfflineLicenseState(Vector<uint8_t> const &keySetId,
131 DrmPlugin::OfflineLicenseState *licenseState) const;
132
Jeff Tinkera53d6552017-01-20 00:31:46 -0800133 virtual status_t getPropertyString(String8 const &name, String8 &value ) const;
134 virtual status_t getPropertyByteArray(String8 const &name,
135 Vector<uint8_t> &value ) const;
136 virtual status_t setPropertyString(String8 const &name, String8 const &value ) const;
137 virtual status_t setPropertyByteArray(String8 const &name,
138 Vector<uint8_t> const &value ) const;
Adam Stone637b7852018-01-30 12:09:36 -0800139 virtual status_t getMetrics(os::PersistableBundle *metrics);
Jeff Tinkera53d6552017-01-20 00:31:46 -0800140
141 virtual status_t setCipherAlgorithm(Vector<uint8_t> const &sessionId,
142 String8 const &algorithm);
143
144 virtual status_t setMacAlgorithm(Vector<uint8_t> const &sessionId,
145 String8 const &algorithm);
146
147 virtual status_t encrypt(Vector<uint8_t> const &sessionId,
148 Vector<uint8_t> const &keyId,
149 Vector<uint8_t> const &input,
150 Vector<uint8_t> const &iv,
151 Vector<uint8_t> &output);
152
153 virtual status_t decrypt(Vector<uint8_t> const &sessionId,
154 Vector<uint8_t> const &keyId,
155 Vector<uint8_t> const &input,
156 Vector<uint8_t> const &iv,
157 Vector<uint8_t> &output);
158
159 virtual status_t sign(Vector<uint8_t> const &sessionId,
160 Vector<uint8_t> const &keyId,
161 Vector<uint8_t> const &message,
162 Vector<uint8_t> &signature);
163
164 virtual status_t verify(Vector<uint8_t> const &sessionId,
165 Vector<uint8_t> const &keyId,
166 Vector<uint8_t> const &message,
167 Vector<uint8_t> const &signature,
168 bool &match);
169
170 virtual status_t signRSA(Vector<uint8_t> const &sessionId,
171 String8 const &algorithm,
172 Vector<uint8_t> const &message,
173 Vector<uint8_t> const &wrappedKey,
174 Vector<uint8_t> &signature);
175
176 virtual status_t setListener(const sp<IDrmClient>& listener);
177
178 // Methods of IDrmPluginListener
179 Return<void> sendEvent(EventType eventType,
180 const hidl_vec<uint8_t>& sessionId, const hidl_vec<uint8_t>& data);
181
182 Return<void> sendExpirationUpdate(const hidl_vec<uint8_t>& sessionId,
183 int64_t expiryTimeInMS);
184
185 Return<void> sendKeysChange(const hidl_vec<uint8_t>& sessionId,
Robert Shiha5033262019-05-06 14:15:12 -0700186 const hidl_vec<KeyStatus_V1_0>& keyStatusList, bool hasNewUsableKey);
187
188 Return<void> sendKeysChange_1_2(const hidl_vec<uint8_t>& sessionId,
Jeff Tinkera53d6552017-01-20 00:31:46 -0800189 const hidl_vec<KeyStatus>& keyStatusList, bool hasNewUsableKey);
190
Jeff Tinkerb8684f32018-12-12 08:41:31 -0800191 Return<void> sendSessionLostState(const hidl_vec<uint8_t>& sessionId);
192
Jeff Tinkera53d6552017-01-20 00:31:46 -0800193private:
194 static Mutex mLock;
195
Jeff Tinkera53d6552017-01-20 00:31:46 -0800196 sp<IDrmClient> mListener;
197 mutable Mutex mEventLock;
198 mutable Mutex mNotifyLock;
199
Jeff Tinkerabeb36a2017-02-17 09:42:46 -0800200 const Vector<sp<IDrmFactory>> mFactories;
Jeff Tinkera53d6552017-01-20 00:31:46 -0800201 sp<IDrmPlugin> mPlugin;
Jeff Tinker6d998b62017-12-18 14:37:43 -0800202 sp<drm::V1_1::IDrmPlugin> mPluginV1_1;
Jeff Tinkerc8baaba2018-10-23 11:32:36 -0700203 sp<drm::V1_2::IDrmPlugin> mPluginV1_2;
Adam Stone32494f52018-02-26 22:53:27 -0800204 String8 mAppPackageName;
Jeff Tinkera53d6552017-01-20 00:31:46 -0800205
Adam Stonecea91ce2018-01-22 19:23:28 -0800206 // Mutable to allow modification within GetPropertyByteArray.
207 mutable MediaDrmMetrics mMetrics;
Adam Stoneaaf87dd2018-01-08 11:55:06 -0800208
Robert Shih0f3a8a02019-11-14 15:43:39 -0800209 std::vector<std::shared_ptr<DrmSessionClient>> mOpenSessions;
Jeff Tinker61332812017-05-15 16:53:10 -0700210 void closeOpenSessions();
Jeff Tinker7dfe28f2018-02-15 12:17:40 -0800211 void cleanup();
Jeff Tinker61332812017-05-15 16:53:10 -0700212
Jeff Tinkera53d6552017-01-20 00:31:46 -0800213 /**
214 * mInitCheck is:
215 * NO_INIT if a plugin hasn't been created yet
216 * ERROR_UNSUPPORTED if a plugin can't be created for the uuid
217 * OK after a plugin has been created and mPlugin is valid
218 */
219 status_t mInitCheck;
220
Jeff Tinkerabeb36a2017-02-17 09:42:46 -0800221 Vector<sp<IDrmFactory>> makeDrmFactories();
222 sp<IDrmPlugin> makeDrmPlugin(const sp<IDrmFactory>& factory,
223 const uint8_t uuid[16], const String8& appPackageName);
Jeff Tinkera53d6552017-01-20 00:31:46 -0800224
225 void writeByteArray(Parcel &obj, const hidl_vec<uint8_t>& array);
226
Adam Stonefb679e32018-02-07 10:25:48 -0800227 void reportPluginMetrics() const;
228 void reportFrameworkMetrics() const;
John W. Bruce33ecc4f2017-04-03 16:49:05 -0700229 status_t getPropertyStringInternal(String8 const &name, String8 &value) const;
230 status_t getPropertyByteArrayInternal(String8 const &name,
231 Vector<uint8_t> &value) const;
Jeff Tinkerdb3fa5f2019-01-25 22:56:56 -0800232 status_t matchMimeTypeAndSecurityLevel(const sp<IDrmFactory> &factory,
233 const uint8_t uuid[16],
234 const String8 &mimeType,
235 DrmPlugin::SecurityLevel level,
236 bool *isSupported);
John W. Bruce33ecc4f2017-04-03 16:49:05 -0700237
Jeff Tinkera53d6552017-01-20 00:31:46 -0800238 DISALLOW_EVIL_CONSTRUCTORS(DrmHal);
239};
240
241} // namespace android
242
243#endif // DRM_HAL_H_