Sughosh Ganu | 90592ed | 2019-12-28 23:58:27 +0530 | [diff] [blame] | 1 | // SPDX-License-Identifier: GPL-2.0+ |
| 2 | /* |
| 3 | * Copyright (c) 2019, Linaro Limited |
| 4 | */ |
| 5 | |
| 6 | #if !defined _RNG_H_ |
| 7 | #define _RNG_H_ |
| 8 | |
Heinrich Schuchardt | 10a45cc | 2024-02-13 00:44:47 +0100 | [diff] [blame] | 9 | #include <linux/types.h> |
| 10 | |
Sughosh Ganu | 90592ed | 2019-12-28 23:58:27 +0530 | [diff] [blame] | 11 | struct udevice; |
| 12 | |
| 13 | /** |
| 14 | * dm_rng_read() - read a random number seed from the rng device |
Sughosh Ganu | 90592ed | 2019-12-28 23:58:27 +0530 | [diff] [blame] | 15 | * |
Heinrich Schuchardt | 40bb4e7 | 2020-06-13 12:29:52 +0200 | [diff] [blame] | 16 | * The function blocks until the requested number of bytes is read. |
| 17 | * |
| 18 | * @dev: random number generator device |
| 19 | * @buffer: input buffer to put the read random seed into |
| 20 | * @size: number of random bytes to read |
| 21 | * Return: 0 if OK, -ve on error |
Sughosh Ganu | 90592ed | 2019-12-28 23:58:27 +0530 | [diff] [blame] | 22 | */ |
| 23 | int dm_rng_read(struct udevice *dev, void *buffer, size_t size); |
| 24 | |
Heinrich Schuchardt | 40bb4e7 | 2020-06-13 12:29:52 +0200 | [diff] [blame] | 25 | /** |
| 26 | * struct dm_rng_ops - operations for the hwrng uclass |
| 27 | * |
| 28 | * This structures contains the function implemented by a hardware random |
| 29 | * number generation device. |
| 30 | */ |
Sughosh Ganu | 90592ed | 2019-12-28 23:58:27 +0530 | [diff] [blame] | 31 | struct dm_rng_ops { |
| 32 | /** |
Heinrich Schuchardt | 40bb4e7 | 2020-06-13 12:29:52 +0200 | [diff] [blame] | 33 | * @read: read a random bytes |
Sughosh Ganu | 90592ed | 2019-12-28 23:58:27 +0530 | [diff] [blame] | 34 | * |
Heinrich Schuchardt | 40bb4e7 | 2020-06-13 12:29:52 +0200 | [diff] [blame] | 35 | * The function blocks until the requested number of bytes is read. |
Sughosh Ganu | 90592ed | 2019-12-28 23:58:27 +0530 | [diff] [blame] | 36 | * |
Heinrich Schuchardt | 40bb4e7 | 2020-06-13 12:29:52 +0200 | [diff] [blame] | 37 | * @read.dev: random number generator device |
| 38 | * @read.data: input buffer to read the random seed into |
| 39 | * @read.max: number of random bytes to read |
| 40 | * @read.Return: 0 if OK, -ve on error |
Sughosh Ganu | 90592ed | 2019-12-28 23:58:27 +0530 | [diff] [blame] | 41 | */ |
| 42 | int (*read)(struct udevice *dev, void *data, size_t max); |
| 43 | }; |
| 44 | |
| 45 | #endif /* _RNG_H_ */ |