/* * Copyright (C) 2021 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef DRM_HAL_HIDL_H_ #define DRM_HAL_HIDL_H_ #include #include #include #include #include #include #include #include #include #include #include #include #include namespace drm = ::android::hardware::drm; using drm::V1_0::EventType; using drm::V1_0::IDrmFactory; using drm::V1_0::IDrmPlugin; using drm::V1_0::IDrmPluginListener; using drm::V1_1::SecurityLevel; using drm::V1_2::KeyStatus; using drm::V1_2::OfflineLicenseState; using ::android::hardware::hidl_vec; using ::android::hardware::Return; using ::android::hardware::Void; typedef drm::V1_2::IDrmPluginListener IDrmPluginListener_V1_2; typedef drm::V1_0::KeyStatus KeyStatus_V1_0; namespace android { struct DrmSessionClientInterface; inline bool operator==(const Vector &l, const Vector &r) { if (l.size() != r.size()) return false; return memcmp(l.array(), r.array(), l.size()) == 0; } struct DrmHalHidl : public IDrm, public IDrmPluginListener_V1_2 { struct DrmSessionClient; DrmHalHidl(); virtual ~DrmHalHidl(); virtual DrmStatus initCheck() const; virtual DrmStatus isCryptoSchemeSupported(const uint8_t uuid[16], const String8& mimeType, DrmPlugin::SecurityLevel level, bool* isSupported); virtual DrmStatus createPlugin(const uint8_t uuid[16], const String8 &appPackageName); virtual DrmStatus destroyPlugin(); virtual DrmStatus openSession(DrmPlugin::SecurityLevel level, Vector &sessionId); virtual DrmStatus closeSession(Vector const &sessionId); virtual DrmStatus getKeyRequest(Vector const &sessionId, Vector const &initData, String8 const &mimeType, DrmPlugin::KeyType keyType, KeyedVector const &optionalParameters, Vector &request, String8 &defaultUrl, DrmPlugin::KeyRequestType *keyRequestType); virtual DrmStatus provideKeyResponse(Vector const &sessionId, Vector const &response, Vector &keySetId); virtual DrmStatus removeKeys(Vector const &keySetId); virtual DrmStatus restoreKeys(Vector const &sessionId, Vector const &keySetId); virtual DrmStatus queryKeyStatus(Vector const &sessionId, KeyedVector &infoMap) const; virtual DrmStatus getProvisionRequest(String8 const &certType, String8 const &certAuthority, Vector &request, String8 &defaultUrl); virtual DrmStatus provideProvisionResponse(Vector const &response, Vector &certificate, Vector &wrappedKey); virtual DrmStatus getSecureStops(List> &secureStops); virtual DrmStatus getSecureStopIds(List> &secureStopIds); virtual DrmStatus getSecureStop(Vector const &ssid, Vector &secureStop); virtual DrmStatus releaseSecureStops(Vector const &ssRelease); virtual DrmStatus removeSecureStop(Vector const &ssid); virtual DrmStatus removeAllSecureStops(); virtual DrmStatus getHdcpLevels(DrmPlugin::HdcpLevel *connectedLevel, DrmPlugin::HdcpLevel *maxLevel) const; virtual DrmStatus getNumberOfSessions(uint32_t *currentSessions, uint32_t *maxSessions) const; virtual DrmStatus getSecurityLevel(Vector const &sessionId, DrmPlugin::SecurityLevel *level) const; virtual DrmStatus getOfflineLicenseKeySetIds(List> &keySetIds) const; virtual DrmStatus removeOfflineLicense(Vector const &keySetId); virtual DrmStatus getOfflineLicenseState(Vector const &keySetId, DrmPlugin::OfflineLicenseState *licenseState) const; virtual DrmStatus getPropertyString(String8 const &name, String8 &value ) const; virtual DrmStatus getPropertyByteArray(String8 const &name, Vector &value ) const; virtual DrmStatus setPropertyString(String8 const &name, String8 const &value ) const; virtual DrmStatus setPropertyByteArray(String8 const &name, Vector const &value ) const; virtual DrmStatus getMetrics(const sp &consumer); virtual DrmStatus setCipherAlgorithm(Vector const &sessionId, String8 const &algorithm); virtual DrmStatus setMacAlgorithm(Vector const &sessionId, String8 const &algorithm); virtual DrmStatus encrypt(Vector const &sessionId, Vector const &keyId, Vector const &input, Vector const &iv, Vector &output); virtual DrmStatus decrypt(Vector const &sessionId, Vector const &keyId, Vector const &input, Vector const &iv, Vector &output); virtual DrmStatus sign(Vector const &sessionId, Vector const &keyId, Vector const &message, Vector &signature); virtual DrmStatus verify(Vector const &sessionId, Vector const &keyId, Vector const &message, Vector const &signature, bool &match); virtual DrmStatus signRSA(Vector const &sessionId, String8 const &algorithm, Vector const &message, Vector const &wrappedKey, Vector &signature); virtual DrmStatus setListener(const sp& listener); virtual DrmStatus requiresSecureDecoder(const char *mime, bool *required) const; virtual DrmStatus requiresSecureDecoder(const char *mime, DrmPlugin::SecurityLevel securityLevel, bool *required) const; virtual DrmStatus setPlaybackId( Vector const &sessionId, const char *playbackId); virtual DrmStatus getLogMessages(Vector &logs) const; virtual DrmStatus getSupportedSchemes(std::vector &schemes) const; // Methods of IDrmPluginListener Return sendEvent(EventType eventType, const hidl_vec& sessionId, const hidl_vec& data); Return sendExpirationUpdate(const hidl_vec& sessionId, int64_t expiryTimeInMS); Return sendKeysChange(const hidl_vec& sessionId, const hidl_vec& keyStatusList, bool hasNewUsableKey); Return sendKeysChange_1_2(const hidl_vec& sessionId, const hidl_vec& keyStatusList, bool hasNewUsableKey); Return sendSessionLostState(const hidl_vec& sessionId); private: static Mutex mLock; sp mListener; mutable Mutex mEventLock; mutable Mutex mNotifyLock; const std::vector> mFactories; sp mPlugin; sp mPluginV1_1; sp mPluginV1_2; sp mPluginV1_4; String8 mAppPackageName; // Mutable to allow modification within GetPropertyByteArray. mutable MediaDrmMetrics mMetrics; std::vector> mOpenSessions; void closeOpenSessions(); void cleanup(); /** * mInitCheck is: * NO_INIT if a plugin hasn't been created yet * ERROR_UNSUPPORTED if a plugin can't be created for the uuid * OK after a plugin has been created and mPlugin is valid */ status_t mInitCheck; std::vector> makeDrmFactories(); sp makeDrmPlugin(const sp& factory, const uint8_t uuid[16], const String8& appPackageName); void writeByteArray(Parcel &obj, const hidl_vec& array); std::string reportPluginMetrics() const; std::string reportFrameworkMetrics(const std::string& pluginMetrics) const; DrmStatus getPropertyStringInternal(String8 const &name, String8 &value) const; DrmStatus getPropertyByteArrayInternal(String8 const &name, Vector &value) const; DrmStatus matchMimeTypeAndSecurityLevel(const sp &factory, const uint8_t uuid[16], const String8 &mimeType, DrmPlugin::SecurityLevel level, bool *isSupported); DISALLOW_EVIL_CONSTRUCTORS(DrmHalHidl); }; } // namespace android #endif // DRM_HAL_HIDL_H_