pthread_attr.c 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. #include <rtthread.h>
  2. #include "pthread.h"
  3. #include "sched.h"
  4. #include <string.h>
  5. #define DEFAULT_STACK_SIZE 2048
  6. #define DEFAULT_PRIORITY (RT_THREAD_PRIORITY_MAX/2 + RT_THREAD_PRIORITY_MAX/4)
  7. const pthread_attr_t pthread_default_attr =
  8. {
  9. 0, /* stack base */
  10. DEFAULT_STACK_SIZE, /* stack size */
  11. DEFAULT_PRIORITY, /* priority */
  12. PTHREAD_CREATE_JOINABLE, /* detach state */
  13. SCHED_FIFO, /* scheduler policy */
  14. PTHREAD_INHERIT_SCHED /* Inherit parent prio/policy */
  15. };
  16. int pthread_attr_init(pthread_attr_t *attr)
  17. {
  18. RT_ASSERT(attr != RT_NULL);
  19. *attr = pthread_default_attr;
  20. return 0;
  21. }
  22. int pthread_attr_destroy(pthread_attr_t *attr)
  23. {
  24. RT_ASSERT(attr != RT_NULL);
  25. memset(attr, 0, sizeof(pthread_attr_t));
  26. return 0;
  27. }
  28. int pthread_attr_setdetachstate(pthread_attr_t * attr, int state)
  29. {
  30. RT_ASSERT(attr != RT_NULL);
  31. if (state != PTHREAD_CREATE_JOINABLE && state != PTHREAD_CREATE_DETACHED)
  32. return EINVAL;
  33. attr->detachstate = state;
  34. return 0;
  35. }
  36. int pthread_attr_getdetachstate(pthread_attr_t const * attr, int *state)
  37. {
  38. RT_ASSERT(attr != RT_NULL);
  39. *state = (int)attr->detachstate;
  40. return 0;
  41. }
  42. int pthread_attr_setschedpolicy(pthread_attr_t * attr, int policy)
  43. {
  44. RT_ASSERT(attr != RT_NULL);
  45. attr->policy = policy;
  46. return 0;
  47. }
  48. int pthread_attr_getschedpolicy(pthread_attr_t const *attr, int *policy)
  49. {
  50. RT_ASSERT(attr != RT_NULL);
  51. *policy = (int)attr->policy;
  52. return 0;
  53. }
  54. int pthread_attr_setschedparam(pthread_attr_t *attr, struct sched_param const *param)
  55. {
  56. RT_ASSERT(attr != RT_NULL);
  57. RT_ASSERT(param != RT_NULL);
  58. attr->priority = param->sched_priority;
  59. return 0;
  60. }
  61. int pthread_attr_getschedparam(pthread_attr_t const *attr, struct sched_param *param)
  62. {
  63. RT_ASSERT(attr != RT_NULL);
  64. RT_ASSERT(param != RT_NULL);
  65. param->sched_priority = attr->priority;
  66. return 0;
  67. }
  68. int pthread_attr_setstacksize(pthread_attr_t * attr, size_t stack_size)
  69. {
  70. RT_ASSERT(attr != RT_NULL);
  71. attr->stack_size = stack_size;
  72. return 0;
  73. }
  74. int pthread_attr_getstacksize(pthread_attr_t const * attr, size_t *stack_size)
  75. {
  76. RT_ASSERT(attr != RT_NULL);
  77. *stack_size = attr->stack_size;
  78. return 0;
  79. }
  80. int pthread_attr_setstackaddr(pthread_attr_t * attr, void * stack_addr)
  81. {
  82. RT_ASSERT(attr != RT_NULL);
  83. return ENOTSUP;
  84. }
  85. int pthread_attr_getstackaddr(pthread_attr_t const * attr, void ** stack_addr)
  86. {
  87. RT_ASSERT(attr != RT_NULL);
  88. return ENOTSUP;
  89. }
  90. int pthread_attr_setstack(pthread_attr_t * attr, void *stack_base, size_t stack_size)
  91. {
  92. RT_ASSERT(attr != RT_NULL);
  93. attr->stack_base = stack_base;
  94. attr->stack_size = RT_ALIGN_DOWN(stack_size, RT_ALIGN_SIZE);
  95. return 0;
  96. }
  97. int pthread_attr_getstack(pthread_attr_t const * attr, void **stack_base, size_t *stack_size)
  98. {
  99. RT_ASSERT(attr != RT_NULL);
  100. *stack_base = attr->stack_base;
  101. *stack_size = attr->stack_size;
  102. return 0;
  103. }
  104. int pthread_attr_setguardsize(pthread_attr_t * attr, size_t guard_size)
  105. {
  106. return ENOTSUP;
  107. }
  108. int pthread_attr_getguardsize(pthread_attr_t const * attr, size_t *guard_size)
  109. {
  110. return ENOTSUP;
  111. }
  112. int pthread_attr_setscope(pthread_attr_t *attr, int scope)
  113. {
  114. if (scope == PTHREAD_SCOPE_SYSTEM)
  115. return 0;
  116. if (scope == PTHREAD_SCOPE_PROCESS)
  117. return ENOTSUP;
  118. return EINVAL;
  119. }
  120. int pthread_attr_getscope(pthread_attr_t const *attr)
  121. {
  122. return PTHREAD_SCOPE_SYSTEM;
  123. }