1 /*
2  * Copyright (C) 2016 YunOS Project. All rights reserved.
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *   http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 #include <k_api.h>
18 
cpu_task_stack_init(cpu_stack_t * stack_base,size_t stack_size,void * arg,task_entry_t entry)19 void *cpu_task_stack_init(cpu_stack_t *stack_base, size_t stack_size,
20                           void *arg, task_entry_t entry)
21 {
22     cpu_stack_t *stk;
23     register int *gp asm("x3");
24     uint32_t temp = (uint32_t)(stack_base + stack_size);
25 
26     temp &= 0xFFFFFFF8UL;
27 
28     stk = (cpu_stack_t *)temp;
29 
30     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
31     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
32     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
33     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
34     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
35     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
36     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
37     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
38     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
39     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
40     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
41     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
42     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
43     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
44     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
45     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
46     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
47     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
48     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
49     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
50     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
51     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
52     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
53     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
54     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
55     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
56     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
57     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
58     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
59     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
60     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
61     *(--stk)  = (uint32_t)0x12345678L;          *(--stk)  = (uint32_t)0x87654321L;
62 
63     *(--stk) = (uint32_t)entry;                   /* PC            */
64     *(--stk) = (uint32_t)0x31313131L;             /* X31           */
65     *(--stk) = (uint32_t)0x30303030L;             /* X30           */
66     *(--stk) = (uint32_t)0x29292929L;             /* X29           */
67     *(--stk) = (uint32_t)0x28282828L;             /* X28           */
68     *(--stk) = (uint32_t)0x27272727L;             /* X27           */
69     *(--stk) = (uint32_t)0x26262626L;             /* X26           */
70     *(--stk) = (uint32_t)0x25252525L;             /* X25           */
71     *(--stk) = (uint32_t)0x24242424L;             /* X24           */
72     *(--stk) = (uint32_t)0x23232323L;             /* X23           */
73     *(--stk) = (uint32_t)0x22222222L;             /* X22           */
74     *(--stk) = (uint32_t)0x21212121L;             /* X21           */
75     *(--stk) = (uint32_t)0x20202020L;             /* X20           */
76     *(--stk) = (uint32_t)0x19191919L;             /* X19           */
77     *(--stk) = (uint32_t)0x18181818L;             /* X18           */
78     *(--stk) = (uint32_t)0x17171717L;             /* X17           */
79     *(--stk) = (uint32_t)0x16161616L;             /* X16           */
80     *(--stk) = (uint32_t)0x15151515L;             /* X15           */
81     *(--stk) = (uint32_t)0x14141414L;             /* X14           */
82     *(--stk) = (uint32_t)0x13131313L;             /* X13           */
83     *(--stk) = (uint32_t)0x12121212L;             /* X12           */
84     *(--stk) = (uint32_t)0x11111111L;             /* X11           */
85     *(--stk) = (uint32_t)arg;                     /* X10           */
86     *(--stk) = (uint32_t)0x09090909L;             /* X9            */
87     *(--stk) = (uint32_t)0x08080808L;             /* X8            */
88     *(--stk) = (uint32_t)0x07070707L;             /* X7            */
89     *(--stk) = (uint32_t)0x06060606L;             /* X6            */
90     *(--stk) = (uint32_t)0x05050505L;             /* X5            */
91     *(--stk) = (uint32_t)0x04040404L;             /* X4            */
92     *(--stk) = (uint32_t)gp;                      /* X3            */
93     *(--stk) = (uint32_t)krhino_task_deathbed;    /* X1            */
94 
95     return stk;
96 }
97 
98