1 /*
2 * Copyright 2019 NXP
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
7 #define DT_DRV_COMPAT openisa_rv32m1_trng
8
9 #include <zephyr/device.h>
10 #include <zephyr/drivers/entropy.h>
11 #include <zephyr/random/random.h>
12 #include <zephyr/init.h>
13
14 #include "fsl_trng.h"
15
16 struct rv32m1_entropy_config {
17 TRNG_Type *base;
18 };
19
entropy_rv32m1_trng_get_entropy(const struct device * dev,uint8_t * buffer,uint16_t length)20 static int entropy_rv32m1_trng_get_entropy(const struct device *dev,
21 uint8_t *buffer,
22 uint16_t length)
23 {
24 const struct rv32m1_entropy_config *config = dev->config;
25 status_t status;
26
27 ARG_UNUSED(dev);
28
29 status = TRNG_GetRandomData(config->base, buffer, length);
30 __ASSERT_NO_MSG(!status);
31
32 return 0;
33 }
34
35 static DEVICE_API(entropy, entropy_rv32m1_trng_api_funcs) = {
36 .get_entropy = entropy_rv32m1_trng_get_entropy
37 };
38
39 static struct rv32m1_entropy_config entropy_rv32m1_config = {
40 .base = (TRNG_Type *)DT_INST_REG_ADDR(0)
41 };
42
43 static int entropy_rv32m1_trng_init(const struct device *);
44
45 DEVICE_DT_INST_DEFINE(0,
46 entropy_rv32m1_trng_init, NULL,
47 NULL, &entropy_rv32m1_config,
48 PRE_KERNEL_1, CONFIG_ENTROPY_INIT_PRIORITY,
49 &entropy_rv32m1_trng_api_funcs);
50
entropy_rv32m1_trng_init(const struct device * dev)51 static int entropy_rv32m1_trng_init(const struct device *dev)
52 {
53 const struct rv32m1_entropy_config *config = dev->config;
54 trng_config_t conf;
55 status_t status;
56
57 ARG_UNUSED(dev);
58
59 status = TRNG_GetDefaultConfig(&conf);
60 __ASSERT_NO_MSG(!status);
61
62 status = TRNG_Init(config->base, &conf);
63 __ASSERT_NO_MSG(!status);
64
65 return 0;
66 }
67