/* * Copyright 2019 NXP * * SPDX-License-Identifier: Apache-2.0 */ #define DT_DRV_COMPAT openisa_rv32m1_trng #include #include #include #include #include "fsl_trng.h" struct rv32m1_entropy_config { TRNG_Type *base; }; static int entropy_rv32m1_trng_get_entropy(struct device *dev, u8_t *buffer, u16_t length) { const struct rv32m1_entropy_config *config = dev->config->config_info; status_t status; ARG_UNUSED(dev); status = TRNG_GetRandomData(config->base, buffer, length); __ASSERT_NO_MSG(!status); return 0; } static const struct entropy_driver_api entropy_rv32m1_trng_api_funcs = { .get_entropy = entropy_rv32m1_trng_get_entropy }; static struct rv32m1_entropy_config entropy_rv32m1_config = { .base = (TRNG_Type *)DT_INST_REG_ADDR(0) }; static int entropy_rv32m1_trng_init(struct device *); DEVICE_AND_API_INIT(entropy_rv32m1_trng, DT_INST_LABEL(0), entropy_rv32m1_trng_init, NULL, &entropy_rv32m1_config, PRE_KERNEL_1, CONFIG_KERNEL_INIT_PRIORITY_DEVICE, &entropy_rv32m1_trng_api_funcs); static int entropy_rv32m1_trng_init(struct device *dev) { const struct rv32m1_entropy_config *config = dev->config->config_info; trng_config_t conf; status_t status; ARG_UNUSED(dev); status = TRNG_GetDefaultConfig(&conf); __ASSERT_NO_MSG(!status); status = TRNG_Init(config->base, &conf); __ASSERT_NO_MSG(!status); return 0; }