Android-cuttlefish cvd tool
tpm_random_source.h
Go to the documentation of this file.
1//
2// Copyright (C) 2020 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#pragma once
17
18#include <keymaster/random_source.h>
19
21
22namespace cuttlefish {
23
29class TpmRandomSource : public keymaster::RandomSource {
30public:
31 TpmRandomSource(TpmResourceManager& resource_manager);
32 virtual ~TpmRandomSource() = default;
33
34 keymaster_error_t GenerateRandom(uint8_t* buffer,
35 size_t length) const override;
36
37 keymaster_error_t AddRngEntropy(const uint8_t*, size_t) const;
38
39private:
41};
42
43} // namespace cuttlefish
Definition: tpm_random_source.h:29
TpmRandomSource(TpmResourceManager &resource_manager)
Definition: tpm_random_source.cpp:25
virtual ~TpmRandomSource()=default
TpmResourceManager & resource_manager_
Definition: tpm_random_source.h:40
keymaster_error_t GenerateRandom(uint8_t *buffer, size_t length) const override
Definition: tpm_random_source.cpp:28
keymaster_error_t AddRngEntropy(const uint8_t *, size_t) const
Definition: tpm_random_source.cpp:67
Definition: tpm_resource_manager.h:50
Definition: alloc_utils.cpp:23