1 /*
2  * Copyright (c) 2017 Linaro Limited.
3  *
4  * SPDX-License-Identifier: Apache-2.0
5  */
6 
7 #define DT_DRV_COMPAT nxp_kinetis_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 mcux_entropy_config {
17 	TRNG_Type *base;
18 };
19 
entropy_mcux_trng_get_entropy(const struct device * dev,uint8_t * buffer,uint16_t length)20 static int entropy_mcux_trng_get_entropy(const struct device *dev,
21 					 uint8_t *buffer,
22 					 uint16_t length)
23 {
24 	const struct mcux_entropy_config *config = dev->config;
25 	status_t status;
26 
27 	status = TRNG_GetRandomData(config->base, buffer, length);
28 	__ASSERT_NO_MSG(!status);
29 
30 	return 0;
31 }
32 
33 static DEVICE_API(entropy, entropy_mcux_trng_api_funcs) = {
34 	.get_entropy = entropy_mcux_trng_get_entropy
35 };
36 
37 static struct mcux_entropy_config entropy_mcux_config = {
38 	.base = (TRNG_Type *)DT_INST_REG_ADDR(0)
39 };
40 
entropy_mcux_trng_init(const struct device * dev)41 static int entropy_mcux_trng_init(const struct device *dev)
42 {
43 	const struct mcux_entropy_config *config = dev->config;
44 	trng_config_t conf;
45 	status_t status;
46 
47 	status = TRNG_GetDefaultConfig(&conf);
48 	__ASSERT_NO_MSG(!status);
49 
50 	status = TRNG_Init(config->base, &conf);
51 	__ASSERT_NO_MSG(!status);
52 
53 	return 0;
54 }
55 
56 DEVICE_DT_INST_DEFINE(0,
57 		    entropy_mcux_trng_init, NULL, NULL,
58 		    &entropy_mcux_config,
59 		    PRE_KERNEL_1, CONFIG_ENTROPY_INIT_PRIORITY,
60 		    &entropy_mcux_trng_api_funcs);
61