| /* |
| * Copyright (C) 2017 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 CRYPTO_HAL_H_ |
| |
| #define CRYPTO_HAL_H_ |
| |
| #include <android/hardware/drm/1.0/ICryptoFactory.h> |
| #include <android/hardware/drm/1.0/ICryptoPlugin.h> |
| #include <android/hardware/drm/1.1/ICryptoFactory.h> |
| #include <android/hardware/drm/1.2/ICryptoPlugin.h> |
| |
| #include <mediadrm/ICrypto.h> |
| #include <utils/KeyedVector.h> |
| #include <utils/threads.h> |
| |
| namespace drm = ::android::hardware::drm; |
| using drm::V1_0::ICryptoFactory; |
| using drm::V1_0::ICryptoPlugin; |
| using drm::V1_0::SharedBuffer; |
| |
| class IMemoryHeap; |
| |
| namespace android { |
| |
| struct CryptoHal : public BnCrypto { |
| CryptoHal(); |
| virtual ~CryptoHal(); |
| |
| virtual status_t initCheck() const; |
| |
| virtual bool isCryptoSchemeSupported(const uint8_t uuid[16]); |
| |
| virtual status_t createPlugin( |
| const uint8_t uuid[16], const void *data, size_t size); |
| |
| virtual status_t destroyPlugin(); |
| |
| virtual bool requiresSecureDecoderComponent( |
| const char *mime) const; |
| |
| virtual void notifyResolution(uint32_t width, uint32_t height); |
| |
| virtual status_t setMediaDrmSession(const Vector<uint8_t> &sessionId); |
| |
| virtual ssize_t decrypt(const uint8_t key[16], const uint8_t iv[16], |
| CryptoPlugin::Mode mode, const CryptoPlugin::Pattern &pattern, |
| const ICrypto::SourceBuffer &source, size_t offset, |
| const CryptoPlugin::SubSample *subSamples, size_t numSubSamples, |
| const ICrypto::DestinationBuffer &destination, |
| AString *errorDetailMsg); |
| |
| virtual int32_t setHeap(const sp<IMemoryHeap>& heap) { |
| return setHeapBase(heap); |
| } |
| virtual void unsetHeap(int32_t seqNum) { clearHeapBase(seqNum); } |
| |
| private: |
| mutable Mutex mLock; |
| |
| const Vector<sp<ICryptoFactory>> mFactories; |
| sp<ICryptoPlugin> mPlugin; |
| sp<drm::V1_2::ICryptoPlugin> mPluginV1_2; |
| |
| /** |
| * 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; |
| |
| struct HeapBase { |
| HeapBase() : mBufferId(0), mSize(0) {} |
| HeapBase(uint32_t bufferId, size_t size) : |
| mBufferId(bufferId), mSize(size) {} |
| |
| uint32_t getBufferId() const {return mBufferId;} |
| size_t getSize() const {return mSize;} |
| |
| private: |
| uint32_t mBufferId; |
| size_t mSize; |
| }; |
| |
| KeyedVector<int32_t, HeapBase> mHeapBases; |
| uint32_t mNextBufferId; |
| int32_t mHeapSeqNum; |
| |
| Vector<sp<ICryptoFactory>> makeCryptoFactories(); |
| sp<ICryptoPlugin> makeCryptoPlugin(const sp<ICryptoFactory>& factory, |
| const uint8_t uuid[16], const void *initData, size_t size); |
| |
| int32_t setHeapBase(const sp<IMemoryHeap>& heap); |
| void clearHeapBase(int32_t seqNum); |
| |
| status_t toSharedBuffer(const sp<IMemory>& memory, int32_t seqNum, ::SharedBuffer* buffer); |
| |
| DISALLOW_EVIL_CONSTRUCTORS(CryptoHal); |
| }; |
| |
| } // namespace android |
| |
| #endif // CRYPTO_HAL_H_ |