stack.c 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. /*
  2. * Copyright (c) 2006-2022, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2011-02-14 Fred the first version
  9. */
  10. #include <rtthread.h>
  11. /**
  12. * @addtogroup PowerPC
  13. */
  14. /*@{*/
  15. /**
  16. * This function will initialize thread stack
  17. *
  18. * @param tentry the entry of thread
  19. * @param parameter the parameter of entry
  20. * @param stack_addr the beginning stack address
  21. * @param texit the function will be called when thread exit
  22. *
  23. * @return stack address
  24. */
  25. rt_uint8_t *rt_hw_stack_init(void *tentry, void *parameter,
  26. rt_uint8_t *stack_addr, void *texit)
  27. {
  28. unsigned long *stk;
  29. rt_uint32_t msr;
  30. __asm__ __volatile__("mfmsr %0\n" : "=r" (msr));
  31. msr |= 0x00028000;
  32. stk = (unsigned long *)stack_addr;
  33. --stk;
  34. *(--stk) = msr; /* srr0: machine status register */
  35. *(--stk) = (rt_uint32_t)tentry; /* srr1: entry point */
  36. *(--stk) = (rt_uint32_t)texit; /* lr: link register */
  37. *(--stk) = 0x0F0F0F0F; /* ctr: counter register */
  38. *(--stk) = 0x0F0F0F0F; /* xer: fixed-point exception register */
  39. *(--stk) = 0x0F0F0F0F; /* cr : condition register */
  40. *(--stk) = 0x00; /* usprg0 */
  41. *(--stk) = 0x31; /* r31 */
  42. *(--stk) = 0x30; /* r30 */
  43. *(--stk) = 0x29; /* r29 */
  44. *(--stk) = 0x28; /* r28 */
  45. *(--stk) = 0x27; /* r27 */
  46. *(--stk) = 0x26; /* r26 */
  47. *(--stk) = 0x25; /* r25 */
  48. *(--stk) = 0x24; /* r24 */
  49. *(--stk) = 0x23; /* r23 */
  50. *(--stk) = 0x22; /* r22 */
  51. *(--stk) = 0x21; /* r21 */
  52. *(--stk) = 0x20; /* r20 */
  53. *(--stk) = 0x19; /* r19 */
  54. *(--stk) = 0x18; /* r18 */
  55. *(--stk) = 0x17; /* r17 */
  56. *(--stk) = 0x16; /* r16 */
  57. *(--stk) = 0x15; /* r15 */
  58. *(--stk) = 0x14; /* r14 */
  59. *(--stk) = 0x13; /* r13: thread id */
  60. *(--stk) = 0x12; /* r12 */
  61. *(--stk) = 0x11; /* r11 */
  62. *(--stk) = 0x10; /* r10 */
  63. *(--stk) = 0x09; /* r09 */
  64. *(--stk) = 0x08; /* r08 */
  65. *(--stk) = 0x07; /* r07 */
  66. *(--stk) = 0x06; /* r06 */
  67. *(--stk) = 0x05; /* r05 */
  68. *(--stk) = 0x04; /* r04 */
  69. *(--stk) = (rt_uint32_t)parameter; /* r03: parameter and return */
  70. *(--stk) = 0x02; /* r02: toc */
  71. /* r01: sp */
  72. *(--stk) = 0x0; /* r00 */
  73. /* return task's current stack address */
  74. return (rt_uint8_t *)stk;
  75. }
  76. /*@}*/