air105_trng.h 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. /*
  2. * Copyright (c) 2022 OpenLuat & AirM2M
  3. *
  4. * Permission is hereby granted, free of charge, to any person obtaining a copy of
  5. * this software and associated documentation files (the "Software"), to deal in
  6. * the Software without restriction, including without limitation the rights to
  7. * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
  8. * the Software, and to permit persons to whom the Software is furnished to do so,
  9. * subject to the following conditions:
  10. *
  11. * The above copyright notice and this permission notice shall be included in all
  12. * copies or substantial portions of the Software.
  13. *
  14. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  15. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
  16. * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
  17. * COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
  18. * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
  19. * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  20. */
  21. #ifndef __AIR105_TRNG_H
  22. #define __AIR105_TRNG_H
  23. #ifdef __cplusplus
  24. extern "C" {
  25. #endif
  26. /* Includes ------------------------------------------------------------------*/
  27. #include "air105.h"
  28. /** @defgroup RNG_Exported_Types
  29. * @{
  30. */
  31. typedef enum{
  32. TRNG0
  33. } TRNG_ChannelTypeDef;
  34. #define IS_TRNG_CHANNEL(CHANNEL) (((CHANNEL) == TRNG0))
  35. #define TRNG_IT_RNG0_S128 ((uint32_t)0x00000001)
  36. #define TRNG_IT_RNG0_ATTACK ((uint32_t)0x00000004)
  37. #define IS_TRNG_GET_IT(IT) (((IT) == TRNG_IT_RNG0_S128) || \
  38. ((IT) == TRNG_IT_RNG0_ATTACK))
  39. /** @defgroup RNG_Exported_Functions
  40. * @{
  41. */
  42. void TRNG_Start(TRNG_ChannelTypeDef TRNGx);
  43. void TRNG_Stop(TRNG_ChannelTypeDef TRNGx);
  44. uint32_t TRNG_Get(uint32_t rand[4], TRNG_ChannelTypeDef TRNGx);
  45. void TRNG_SetPseudoRandom(uint32_t PseudoRandom);
  46. void TRNG_DirectOutANA(TRNG_ChannelTypeDef TRNGx, FunctionalState NewState);
  47. void TRNG_ITConfig(FunctionalState NewState);
  48. ITStatus TRNG_GetITStatus(uint32_t TRNG_IT);
  49. void TRNG_ClearITPendingBit(uint32_t TRNG_IT);
  50. #ifdef __cplusplus
  51. }
  52. #endif
  53. #endif
  54. /************************** (C) COPYRIGHT Megahunt *****END OF FILE****/