sched.h 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. /*
  2. * Amazon FreeRTOS POSIX V1.1.0
  3. * Copyright (C) 2019 Amazon.com, Inc. or its affiliates. All Rights Reserved.
  4. *
  5. * Permission is hereby granted, free of charge, to any person obtaining a copy of
  6. * this software and associated documentation files (the "Software"), to deal in
  7. * the Software without restriction, including without limitation the rights to
  8. * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
  9. * the Software, and to permit persons to whom the Software is furnished to do so,
  10. * subject to the following conditions:
  11. *
  12. * The above copyright notice and this permission notice shall be included in all
  13. * copies or substantial portions of the Software.
  14. *
  15. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  16. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
  17. * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
  18. * COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
  19. * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
  20. * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  21. *
  22. * http://aws.amazon.com/freertos
  23. * http://www.FreeRTOS.org
  24. */
  25. /**
  26. * @file sched.h
  27. * @brief Execution scheduling.
  28. *
  29. * http://pubs.opengroup.org/onlinepubs/9699919799/basedefs/sched.h.html
  30. */
  31. #ifndef _FREERTOS_POSIX_SCHED_H_
  32. #define _FREERTOS_POSIX_SCHED_H_
  33. /**
  34. * @name Scheduling Policies
  35. */
  36. /**@{ */
  37. #define SCHED_OTHER 0 /**< Another scheduling policy. */
  38. /**@} */
  39. /**
  40. * @brief Scheduling parameters required for implementation of each supported
  41. * scheduling policy.
  42. */
  43. struct sched_param
  44. {
  45. int sched_priority; /**< Process or thread execution scheduling priority. */
  46. };
  47. /**
  48. * @brief Get priority limit (max).
  49. *
  50. * http://pubs.opengroup.org/onlinepubs/9699919799/functions/sched_get_priority_max.html
  51. *
  52. * @note policy is ignored.
  53. *
  54. * @return the maximum priority value (0-based) system configuration allows.
  55. * <br>
  56. * e.g. if configMAX_PRIORITIES == 7, this function returns (configMAX_PRIORITIES - 1).
  57. * configMAX_PRIORITIES is configured in application FreeRTOSConfig.h file.
  58. */
  59. int sched_get_priority_max( int policy );
  60. /**
  61. * @brief Get priority limit (min).
  62. *
  63. * http://pubs.opengroup.org/onlinepubs/9699919799/functions/sched_get_priority_min.html
  64. *
  65. * @note policy is ignored.
  66. */
  67. int sched_get_priority_min( int policy );
  68. /**
  69. * @brief Yield the processor.
  70. *
  71. * http://pubs.opengroup.org/onlinepubs/9699919799/functions/sched_yield.html
  72. *
  73. * @retval 0 - Upon successful completion
  74. */
  75. int sched_yield( void );
  76. #endif /* ifndef _FREERTOS_POSIX_SCHED_H_ */