secure_init.h 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. /*
  2. * FreeRTOS Kernel V10.4.6
  3. * Copyright (C) 2021 Amazon.com, Inc. or its affiliates. All Rights Reserved.
  4. *
  5. * SPDX-License-Identifier: MIT
  6. *
  7. * Permission is hereby granted, free of charge, to any person obtaining a copy of
  8. * this software and associated documentation files (the "Software"), to deal in
  9. * the Software without restriction, including without limitation the rights to
  10. * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
  11. * the Software, and to permit persons to whom the Software is furnished to do so,
  12. * subject to the following conditions:
  13. *
  14. * The above copyright notice and this permission notice shall be included in all
  15. * copies or substantial portions of the Software.
  16. *
  17. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  18. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
  19. * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
  20. * COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
  21. * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
  22. * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  23. *
  24. * https://www.FreeRTOS.org
  25. * https://github.com/FreeRTOS
  26. *
  27. */
  28. #ifndef __SECURE_INIT_H__
  29. #define __SECURE_INIT_H__
  30. /**
  31. * @brief De-prioritizes the non-secure exceptions.
  32. *
  33. * This is needed to ensure that the non-secure PendSV runs at the lowest
  34. * priority. Context switch is done in the non-secure PendSV handler.
  35. *
  36. * @note This function must be called in the handler mode. It is no-op if called
  37. * in the thread mode.
  38. */
  39. void SecureInit_DePrioritizeNSExceptions( void );
  40. /**
  41. * @brief Sets up the Floating Point Unit (FPU) for Non-Secure access.
  42. *
  43. * Also sets FPCCR.TS=1 to ensure that the content of the Floating Point
  44. * Registers are not leaked to the non-secure side.
  45. *
  46. * @note This function must be called in the handler mode. It is no-op if called
  47. * in the thread mode.
  48. */
  49. void SecureInit_EnableNSFPUAccess( void );
  50. #endif /* __SECURE_INIT_H__ */