aes_callback.c 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. /**
  2. *
  3. * \file
  4. *
  5. * \brief SAM Advanced Encryption Standard driver.
  6. *
  7. * This file defines a useful set of functions for the AES on SAM devices.
  8. *
  9. * Copyright (c) 2014-2016 Atmel Corporation. All rights reserved.
  10. *
  11. * \asf_license_start
  12. *
  13. * \page License
  14. *
  15. * Redistribution and use in source and binary forms, with or without
  16. * modification, are permitted provided that the following conditions are met:
  17. *
  18. * 1. Redistributions of source code must retain the above copyright notice,
  19. * this list of conditions and the following disclaimer.
  20. *
  21. * 2. Redistributions in binary form must reproduce the above copyright notice,
  22. * this list of conditions and the following disclaimer in the documentation
  23. * and/or other materials provided with the distribution.
  24. *
  25. * 3. The name of Atmel may not be used to endorse or promote products derived
  26. * from this software without specific prior written permission.
  27. *
  28. * 4. This software may only be redistributed and used in connection with an
  29. * Atmel microcontroller product.
  30. *
  31. * THIS SOFTWARE IS PROVIDED BY ATMEL "AS IS" AND ANY EXPRESS OR IMPLIED
  32. * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
  33. * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT ARE
  34. * EXPRESSLY AND SPECIFICALLY DISCLAIMED. IN NO EVENT SHALL ATMEL BE LIABLE FOR
  35. * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  36. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  37. * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  38. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
  39. * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
  40. * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  41. * POSSIBILITY OF SUCH DAMAGE.
  42. *
  43. * \asf_license_stop
  44. *
  45. */
  46. /*
  47. * Support and FAQ: visit <a href="http://www.atmel.com/design-support/">Atmel Support</a>
  48. */
  49. #include "aes.h"
  50. #include "aes_callback.h"
  51. /** \internal Max number of callback type. */
  52. #define AES_CALLBACK_TYPE_NUM 2
  53. /**
  54. * \internal
  55. * \brief AES callback function pointer
  56. */
  57. aes_callback_t aes_callback_pointer[AES_CALLBACK_TYPE_NUM]={NULL,NULL};
  58. enum status_code aes_register_callback(
  59. const aes_callback_t callback,
  60. const enum aes_callback_type type)
  61. {
  62. if (type >= AES_CALLBACK_TYPE_NUM){
  63. Assert(false);
  64. return STATUS_ERR_INVALID_ARG;
  65. }
  66. aes_callback_pointer[type] = callback;
  67. return STATUS_OK;
  68. }
  69. enum status_code aes_unregister_callback(
  70. const aes_callback_t callback,
  71. const enum aes_callback_type type)
  72. {
  73. if (type >= AES_CALLBACK_TYPE_NUM){
  74. Assert(false);
  75. return STATUS_ERR_INVALID_ARG;
  76. }
  77. aes_callback_pointer[type] = NULL;
  78. return STATUS_OK;
  79. }
  80. /**
  81. * \internal The AES interrupt handler.
  82. */
  83. void AES_Handler(void)
  84. {
  85. uint32_t status = AES->INTFLAG.reg;
  86. if (status & AES_INTFLAG_ENCCMP) {
  87. if (aes_callback_pointer[AES_CALLBACK_ENCRYPTION_COMPLETE]) {
  88. AES->INTFLAG.reg = AES_INTFLAG_ENCCMP;
  89. aes_callback_pointer[AES_CALLBACK_ENCRYPTION_COMPLETE]();
  90. }
  91. }
  92. if (status & AES_INTFLAG_GFMCMP) {
  93. if (aes_callback_pointer[AES_CALLBACK_ENCRYPTION_COMPLETE]) {
  94. AES->INTFLAG.reg = AES_INTFLAG_GFMCMP;
  95. aes_callback_pointer[AES_CALLBACK_ENCRYPTION_COMPLETE]();
  96. }
  97. }
  98. }