esp_crypto_lock.c 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. // Copyright 2015-2020 Espressif Systems (Shanghai) PTE LTD
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. // http://www.apache.org/licenses/LICENSE-2.0
  7. //
  8. // Unless required by applicable law or agreed to in writing, software
  9. // distributed under the License is distributed on an "AS IS" BASIS,
  10. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  11. // See the License for the specific language governing permissions and
  12. // limitations under the License.
  13. #include <sys/lock.h>
  14. #include "esp_crypto_lock.h"
  15. /* Lock overview:
  16. SHA: peripheral independent, but DMA is shared with AES
  17. AES: peripheral independent, but DMA is shared with SHA
  18. MPI/RSA: independent
  19. HMAC: needs SHA
  20. DS: needs HMAC (which needs SHA), AES and MPI
  21. */
  22. /* Lock for DS peripheral */
  23. static _lock_t s_crypto_ds_lock;
  24. /* Lock for HMAC peripheral */
  25. static _lock_t s_crypto_hmac_lock;
  26. /* Lock for the MPI/RSA peripheral, also used by the DS peripheral */
  27. static _lock_t s_crypto_mpi_lock;
  28. /* Single lock for SHA and AES, sharing a reserved GDMA channel */
  29. static _lock_t s_crypto_sha_aes_lock;
  30. void esp_crypto_hmac_lock_acquire(void)
  31. {
  32. _lock_acquire(&s_crypto_hmac_lock);
  33. esp_crypto_sha_aes_lock_acquire();
  34. }
  35. void esp_crypto_hmac_lock_release(void)
  36. {
  37. esp_crypto_sha_aes_lock_release();
  38. _lock_release(&s_crypto_hmac_lock);
  39. }
  40. void esp_crypto_ds_lock_acquire(void)
  41. {
  42. _lock_acquire(&s_crypto_ds_lock);
  43. esp_crypto_hmac_lock_acquire();
  44. esp_crypto_mpi_lock_acquire();
  45. }
  46. void esp_crypto_ds_lock_release(void)
  47. {
  48. esp_crypto_mpi_lock_release();
  49. esp_crypto_hmac_lock_release();
  50. _lock_release(&s_crypto_ds_lock);
  51. }
  52. void esp_crypto_sha_aes_lock_acquire(void)
  53. {
  54. _lock_acquire(&s_crypto_sha_aes_lock);
  55. }
  56. void esp_crypto_sha_aes_lock_release(void)
  57. {
  58. _lock_release(&s_crypto_sha_aes_lock);
  59. }
  60. void esp_crypto_mpi_lock_acquire(void)
  61. {
  62. _lock_acquire(&s_crypto_mpi_lock);
  63. }
  64. void esp_crypto_mpi_lock_release(void)
  65. {
  66. _lock_release(&s_crypto_mpi_lock);
  67. }