added SAMA TRNG driver
git-svn-id: svn://svn.code.sf.net/p/chibios/svn/trunk@11003 35acf78f-673a-0410-8e92-d51de3d6d3f4
This commit is contained in:
parent
006e9f17a4
commit
060f9c5954
|
@ -0,0 +1,5 @@
|
||||||
|
PLATFORMSRC +=$(CHIBIOS)/os/hal/ports/SAMA/LLD/TRNGv1/sama_trng_lld.c
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
PLATFORMINC +=$(CHIBIOS)/os/hal/ports/SAMA/LLD/TRNGv1
|
|
@ -0,0 +1,53 @@
|
||||||
|
/*
|
||||||
|
ChibiOS - Copyright (C) 2006..2016 Giovanni Di Sirio
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
*/
|
||||||
|
#include "hal.h"
|
||||||
|
#include "sama_trng_lld.h"
|
||||||
|
|
||||||
|
|
||||||
|
void trng_lld_init(void) {
|
||||||
|
pmcEnableTRNG();
|
||||||
|
}
|
||||||
|
|
||||||
|
void trng_lld_start(void) {
|
||||||
|
|
||||||
|
TRNG->TRNG_CR = TRNG_CR_ENABLE | TRNG_CR_KEY_PASSWD;
|
||||||
|
//enable interrupt
|
||||||
|
// TRNG->TRNG_IER = TRNG_IER_DATRDY;
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void trng_lld_getrandom(uint32_t * random) {
|
||||||
|
|
||||||
|
//generate a random every 84 clock cycles.
|
||||||
|
while (!(TRNG->TRNG_ISR & TRNG_ISR_DATRDY));
|
||||||
|
|
||||||
|
*random = TRNG->TRNG_ODATA;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void trng_lld_stop(void) {
|
||||||
|
//disable interrupt
|
||||||
|
//TRNG->TRNG_IDR = TRNG_IDR_DATRDY;
|
||||||
|
TRNG->TRNG_CR = TRNG_CR_KEY_PASSWD;
|
||||||
|
pmcDisableTRNG();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,36 @@
|
||||||
|
/*
|
||||||
|
ChibiOS - Copyright (C) 2006..2016 Giovanni Di Sirio
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
*/
|
||||||
|
#ifndef HAL_LLD_SAMA_TRNG_H_
|
||||||
|
#define HAL_LLD_SAMA_TRNG_H_
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
extern void trng_lld_init(void);
|
||||||
|
extern void trng_lld_start(void);
|
||||||
|
extern void trng_lld_stop(void);
|
||||||
|
extern void trng_lld_getrandom(uint32_t * random);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#endif /* HAL_LLD_SAMA_TRNG_H_ */
|
Loading…
Reference in New Issue