main.c 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. /**
  2. * Copyright (c) 2018 - 2019, Nordic Semiconductor ASA
  3. *
  4. * All rights reserved.
  5. *
  6. * Redistribution and use in source and binary forms, with or without modification,
  7. * are permitted provided that the following conditions are met:
  8. *
  9. * 1. Redistributions of source code must retain the above copyright notice, this
  10. * list of conditions and the following disclaimer.
  11. *
  12. * 2. Redistributions in binary form, except as embedded into a Nordic
  13. * Semiconductor ASA integrated circuit in a product or a software update for
  14. * such product, must reproduce the above copyright notice, this list of
  15. * conditions and the following disclaimer in the documentation and/or other
  16. * materials provided with the distribution.
  17. *
  18. * 3. Neither the name of Nordic Semiconductor ASA nor the names of its
  19. * contributors may be used to endorse or promote products derived from this
  20. * software without specific prior written permission.
  21. *
  22. * 4. This software, with or without modification, must only be used with a
  23. * Nordic Semiconductor ASA integrated circuit.
  24. *
  25. * 5. Any software provided in binary form under this license must not be reverse
  26. * engineered, decompiled, modified and/or disassembled.
  27. *
  28. * THIS SOFTWARE IS PROVIDED BY NORDIC SEMICONDUCTOR ASA "AS IS" AND ANY EXPRESS
  29. * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  30. * OF MERCHANTABILITY, NONINFRINGEMENT, AND FITNESS FOR A PARTICULAR PURPOSE ARE
  31. * DISCLAIMED. IN NO EVENT SHALL NORDIC SEMICONDUCTOR ASA OR CONTRIBUTORS BE
  32. * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
  33. * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
  34. * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  35. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  36. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
  37. * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  38. *
  39. */
  40. /** @file
  41. *
  42. * @defgroup nrf_crypto_rng main.c
  43. * @{
  44. * @ingroup nrf_crypto_rng
  45. * @brief Cryptographic Random Number Generator (RNG) Example Application main file.
  46. *
  47. * This file contains the source code for a sample application that demonstrates using the
  48. * nrf_crypto library to generate random numbers. Different backends can be used by adjusting
  49. * @ref sdk_config accordingly.
  50. *
  51. */
  52. #include <stdbool.h>
  53. #include <stdint.h>
  54. #include "boards.h"
  55. #include "nrf_log_default_backends.h"
  56. #include "nrf_log.h"
  57. #include "nrf_log_ctrl.h"
  58. #include "nrf_crypto.h"
  59. #define VECTOR_LENGTH 8
  60. #define ITERATIONS 5
  61. static uint8_t m_random_vector[VECTOR_LENGTH];
  62. static uint8_t m_min[VECTOR_LENGTH] = {0x00, 0x00, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF}; // Big-endian byte array
  63. static uint8_t m_max[VECTOR_LENGTH] = {0x00, 0x0F, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF}; // Big-endian byte array
  64. /**
  65. * @brief Function for initializing the nrf log module.
  66. */
  67. static void log_init(void)
  68. {
  69. ret_code_t ret_val = NRF_LOG_INIT(NULL);
  70. APP_ERROR_CHECK(ret_val);
  71. NRF_LOG_DEFAULT_BACKENDS_INIT();
  72. }
  73. /**
  74. * @brief Function for application main entry.
  75. */
  76. int main(void)
  77. {
  78. ret_code_t ret_val;
  79. log_init();
  80. NRF_LOG_INFO("RNG example started.");
  81. ret_val = nrf_crypto_init();
  82. APP_ERROR_CHECK(ret_val);
  83. // The RNG module is not explicitly initialized in this example, as
  84. // NRF_CRYPTO_RNG_AUTO_INIT_ENABLED and NRF_CRYPTO_RNG_STATIC_MEMORY_BUFFERS_ENABLED
  85. // are enabled in sdk_config.h.
  86. NRF_LOG_INFO("Generate %u random vectors of length %u:", ITERATIONS, VECTOR_LENGTH);
  87. for (int i = 0; i < ITERATIONS; i++)
  88. {
  89. ret_val = nrf_crypto_rng_vector_generate(m_random_vector, VECTOR_LENGTH);
  90. APP_ERROR_CHECK(ret_val);
  91. NRF_LOG_HEXDUMP_INFO(m_random_vector, VECTOR_LENGTH)
  92. }
  93. NRF_LOG_INFO("Generate %u constrained random vectors of length %u:", ITERATIONS, VECTOR_LENGTH);
  94. for (int i = 0; i < ITERATIONS; i++)
  95. {
  96. ret_val = nrf_crypto_rng_vector_generate_in_range(m_random_vector,
  97. m_min,
  98. m_max,
  99. VECTOR_LENGTH);
  100. APP_ERROR_CHECK(ret_val);
  101. NRF_LOG_HEXDUMP_INFO(m_random_vector, VECTOR_LENGTH)
  102. }
  103. NRF_LOG_INFO("RNG example executed successfully.");
  104. for (;;)
  105. {
  106. }
  107. }
  108. /**
  109. *@}
  110. **/