secure_heap.h 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  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_HEAP_H__
  29. #define __SECURE_HEAP_H__
  30. /* Standard includes. */
  31. #include <stdlib.h>
  32. /**
  33. * @brief Allocates memory from heap.
  34. *
  35. * @param[in] xWantedSize The size of the memory to be allocated.
  36. *
  37. * @return Pointer to the memory region if the allocation is successful, NULL
  38. * otherwise.
  39. */
  40. void * pvPortMalloc( size_t xWantedSize );
  41. /**
  42. * @brief Frees the previously allocated memory.
  43. *
  44. * @param[in] pv Pointer to the memory to be freed.
  45. */
  46. void vPortFree( void * pv );
  47. /**
  48. * @brief Get the free heap size.
  49. *
  50. * @return Free heap size.
  51. */
  52. size_t xPortGetFreeHeapSize( void );
  53. /**
  54. * @brief Get the minimum ever free heap size.
  55. *
  56. * @return Minimum ever free heap size.
  57. */
  58. size_t xPortGetMinimumEverFreeHeapSize( void );
  59. #endif /* __SECURE_HEAP_H__ */