github.com/fjballest/golang@v0.0.0-20151209143359-e4c5fe594ca8/src/runtime/sys_linux_mips64x.s (about) 1 // Copyright 2015 The Go Authors. All rights reserved. 2 // Use of this source code is governed by a BSD-style 3 // license that can be found in the LICENSE file. 4 5 // +build linux 6 // +build mips64 mips64le 7 8 // 9 // System calls and other sys.stuff for mips64, Linux 10 // 11 12 #include "go_asm.h" 13 #include "go_tls.h" 14 #include "textflag.h" 15 16 #define SYS_exit 5058 17 #define SYS_read 5000 18 #define SYS_write 5001 19 #define SYS_open 5002 20 #define SYS_close 5003 21 #define SYS_getpid 5038 22 #define SYS_kill 5060 23 #define SYS_fcntl 5080 24 #define SYS_gettimeofday 5094 25 #define SYS_mmap 5009 26 #define SYS_munmap 5011 27 #define SYS_setitimer 5036 28 #define SYS_clone 5055 29 #define SYS_newselect 5022 30 #define SYS_sched_yield 5023 31 #define SYS_rt_sigreturn 5211 32 #define SYS_rt_sigaction 5013 33 #define SYS_rt_sigprocmask 5014 34 #define SYS_sigaltstack 5129 35 #define SYS_getrlimit 5095 36 #define SYS_madvise 5027 37 #define SYS_mincore 5026 38 #define SYS_gettid 5178 39 #define SYS_tkill 5192 40 #define SYS_futex 5194 41 #define SYS_sched_getaffinity 5196 42 #define SYS_exit_group 5205 43 #define SYS_epoll_create 5207 44 #define SYS_epoll_ctl 5208 45 #define SYS_epoll_wait 5209 46 #define SYS_clock_gettime 5222 47 #define SYS_epoll_create1 5285 48 49 TEXT runtime·exit(SB),NOSPLIT,$-8-4 50 MOVW code+0(FP), R4 51 MOVV $SYS_exit_group, R2 52 SYSCALL 53 RET 54 55 TEXT runtime·exit1(SB),NOSPLIT,$-8-4 56 MOVW code+0(FP), R4 57 MOVV $SYS_exit, R2 58 SYSCALL 59 RET 60 61 TEXT runtime·open(SB),NOSPLIT,$-8-20 62 MOVV name+0(FP), R4 63 MOVW mode+8(FP), R5 64 MOVW perm+12(FP), R6 65 MOVV $SYS_open, R2 66 SYSCALL 67 BEQ R7, 2(PC) 68 MOVW $-1, R2 69 MOVW R2, ret+16(FP) 70 RET 71 72 TEXT runtime·closefd(SB),NOSPLIT,$-8-12 73 MOVW fd+0(FP), R4 74 MOVV $SYS_close, R2 75 SYSCALL 76 BEQ R7, 2(PC) 77 MOVW $-1, R2 78 MOVW R2, ret+8(FP) 79 RET 80 81 TEXT runtime·write(SB),NOSPLIT,$-8-28 82 MOVV fd+0(FP), R4 83 MOVV p+8(FP), R5 84 MOVW n+16(FP), R6 85 MOVV $SYS_write, R2 86 SYSCALL 87 BEQ R7, 2(PC) 88 MOVW $-1, R2 89 MOVW R2, ret+24(FP) 90 RET 91 92 TEXT runtime·read(SB),NOSPLIT,$-8-28 93 MOVW fd+0(FP), R4 94 MOVV p+8(FP), R5 95 MOVW n+16(FP), R6 96 MOVV $SYS_read, R2 97 SYSCALL 98 BEQ R7, 2(PC) 99 MOVW $-1, R2 100 MOVW R2, ret+24(FP) 101 RET 102 103 TEXT runtime·getrlimit(SB),NOSPLIT,$-8-20 104 MOVW kind+0(FP), R4 // _RLIMIT_AS = 6 on linux/mips 105 MOVV limit+8(FP), R5 106 MOVV $SYS_getrlimit, R2 107 SYSCALL 108 MOVW R2, ret+16(FP) 109 RET 110 111 TEXT runtime·usleep(SB),NOSPLIT,$16-4 112 MOVWU usec+0(FP), R3 113 MOVV R3, R5 114 MOVW $1000000, R4 115 DIVVU R4, R3 116 MOVV LO, R3 117 MOVV R3, 8(R29) 118 MULVU R3, R4 119 MOVV LO, R4 120 SUBVU R4, R5 121 MOVV R5, 16(R29) 122 123 // select(0, 0, 0, 0, &tv) 124 MOVW $0, R4 125 MOVW $0, R5 126 MOVW $0, R6 127 MOVW $0, R7 128 ADDV $8, R29, R8 129 MOVV $SYS_newselect, R2 130 SYSCALL 131 RET 132 133 TEXT runtime·gettid(SB),NOSPLIT,$0-4 134 MOVV $SYS_gettid, R2 135 SYSCALL 136 MOVW R2, ret+0(FP) 137 RET 138 139 TEXT runtime·raise(SB),NOSPLIT,$-8 140 MOVV $SYS_gettid, R2 141 SYSCALL 142 MOVW R2, R4 // arg 1 tid 143 MOVW sig+0(FP), R5 // arg 2 144 MOVV $SYS_tkill, R2 145 SYSCALL 146 RET 147 148 TEXT runtime·raiseproc(SB),NOSPLIT,$-8 149 MOVV $SYS_getpid, R2 150 SYSCALL 151 MOVW R2, R4 // arg 1 pid 152 MOVW sig+0(FP), R5 // arg 2 153 MOVV $SYS_kill, R2 154 SYSCALL 155 RET 156 157 TEXT runtime·setitimer(SB),NOSPLIT,$-8-24 158 MOVW mode+0(FP), R4 159 MOVV new+8(FP), R5 160 MOVV old+16(FP), R6 161 MOVV $SYS_setitimer, R2 162 SYSCALL 163 RET 164 165 TEXT runtime·mincore(SB),NOSPLIT,$-8-28 166 MOVV addr+0(FP), R4 167 MOVV n+8(FP), R5 168 MOVV dst+16(FP), R6 169 MOVV $SYS_mincore, R2 170 SYSCALL 171 MOVW R2, ret+24(FP) 172 RET 173 174 // func now() (sec int64, nsec int32) 175 TEXT time·now(SB),NOSPLIT,$16 176 MOVV $0(R29), R4 177 MOVV $0, R5 178 MOVV $SYS_gettimeofday, R2 179 SYSCALL 180 MOVV 0(R29), R3 // sec 181 MOVV 8(R29), R5 // usec 182 MOVV $1000, R4 183 MULVU R4, R5 184 MOVV LO, R5 185 MOVV R3, sec+0(FP) 186 MOVW R5, nsec+8(FP) 187 RET 188 189 TEXT runtime·nanotime(SB),NOSPLIT,$16 190 MOVW $1, R4 // CLOCK_MONOTONIC 191 MOVV $0(R29), R5 192 MOVV $SYS_clock_gettime, R2 193 SYSCALL 194 MOVV 0(R29), R3 // sec 195 MOVV 8(R29), R5 // nsec 196 // sec is in R3, nsec in R5 197 // return nsec in R3 198 MOVV $1000000000, R4 199 MULVU R4, R3 200 MOVV LO, R3 201 ADDVU R5, R3 202 MOVV R3, ret+0(FP) 203 RET 204 205 TEXT runtime·rtsigprocmask(SB),NOSPLIT,$-8-28 206 MOVW sig+0(FP), R4 207 MOVV new+8(FP), R5 208 MOVV old+16(FP), R6 209 MOVW size+24(FP), R7 210 MOVV $SYS_rt_sigprocmask, R2 211 SYSCALL 212 BEQ R7, 2(PC) 213 MOVV R0, 0xf1(R0) // crash 214 RET 215 216 TEXT runtime·rt_sigaction(SB),NOSPLIT,$-8-36 217 MOVV sig+0(FP), R4 218 MOVV new+8(FP), R5 219 MOVV old+16(FP), R6 220 MOVV size+24(FP), R7 221 MOVV $SYS_rt_sigaction, R2 222 SYSCALL 223 MOVW R2, ret+32(FP) 224 RET 225 226 TEXT runtime·sigfwd(SB),NOSPLIT,$0-32 227 MOVW sig+8(FP), R4 228 MOVV info+16(FP), R5 229 MOVV ctx+24(FP), R6 230 MOVV fn+0(FP), R1 231 JAL (R1) 232 RET 233 234 TEXT runtime·sigtramp(SB),NOSPLIT,$64 235 // initialize essential registers (just in case) 236 JAL runtime·reginit(SB) 237 238 // this might be called in external code context, 239 // where g is not set. 240 MOVB runtime·iscgo(SB), R1 241 BEQ R1, 2(PC) 242 JAL runtime·load_g(SB) 243 244 MOVW R4, 8(R29) 245 MOVV R5, 16(R29) 246 MOVV R6, 24(R29) 247 MOVV $runtime·sigtrampgo(SB), R1 248 JAL (R1) 249 RET 250 251 TEXT runtime·mmap(SB),NOSPLIT,$-8 252 MOVV addr+0(FP), R4 253 MOVV n+8(FP), R5 254 MOVW prot+16(FP), R6 255 MOVW flags+20(FP), R7 256 MOVW fd+24(FP), R8 257 MOVW off+28(FP), R9 258 259 MOVV $SYS_mmap, R2 260 SYSCALL 261 MOVV R2, ret+32(FP) 262 RET 263 264 TEXT runtime·munmap(SB),NOSPLIT,$-8 265 MOVV addr+0(FP), R4 266 MOVV n+8(FP), R5 267 MOVV $SYS_munmap, R2 268 SYSCALL 269 BEQ R7, 2(PC) 270 MOVV R0, 0xf3(R0) // crash 271 RET 272 273 TEXT runtime·madvise(SB),NOSPLIT,$-8 274 MOVV addr+0(FP), R4 275 MOVV n+8(FP), R5 276 MOVW flags+16(FP), R6 277 MOVV $SYS_madvise, R2 278 SYSCALL 279 // ignore failure - maybe pages are locked 280 RET 281 282 // int64 futex(int32 *uaddr, int32 op, int32 val, 283 // struct timespec *timeout, int32 *uaddr2, int32 val2); 284 TEXT runtime·futex(SB),NOSPLIT,$-8 285 MOVV addr+0(FP), R4 286 MOVW op+8(FP), R5 287 MOVW val+12(FP), R6 288 MOVV ts+16(FP), R7 289 MOVV addr2+24(FP), R8 290 MOVW val3+32(FP), R9 291 MOVV $SYS_futex, R2 292 SYSCALL 293 MOVW R2, ret+40(FP) 294 RET 295 296 // int64 clone(int32 flags, void *stk, M *mp, G *gp, void (*fn)(void)); 297 TEXT runtime·clone(SB),NOSPLIT,$-8 298 MOVW flags+0(FP), R4 299 MOVV stk+8(FP), R5 300 301 // Copy mp, gp, fn off parent stack for use by child. 302 // Careful: Linux system call clobbers ???. 303 MOVV mm+16(FP), R16 304 MOVV gg+24(FP), R17 305 MOVV fn+32(FP), R18 306 307 MOVV R16, -8(R5) 308 MOVV R17, -16(R5) 309 MOVV R18, -24(R5) 310 MOVV $1234, R16 311 MOVV R16, -32(R5) 312 313 MOVV $SYS_clone, R2 314 SYSCALL 315 316 // In parent, return. 317 BEQ R2, 3(PC) 318 MOVW R2, ret+40(FP) 319 RET 320 321 // In child, on new stack. 322 // initialize essential registers 323 JAL runtime·reginit(SB) 324 MOVV -32(R29), R16 325 MOVV $1234, R1 326 BEQ R16, R1, 2(PC) 327 MOVV R0, 0(R0) 328 329 // Initialize m->procid to Linux tid 330 MOVV $SYS_gettid, R2 331 SYSCALL 332 333 MOVV -24(R29), R18 // fn 334 MOVV -16(R29), R17 // g 335 MOVV -8(R29), R16 // m 336 337 BEQ R16, nog 338 BEQ R17, nog 339 340 MOVV R2, m_procid(R16) 341 342 // TODO: setup TLS. 343 344 // In child, set up new stack 345 MOVV R16, g_m(R17) 346 MOVV R17, g 347 //CALL runtime·stackcheck(SB) 348 349 nog: 350 // Call fn 351 JAL (R18) 352 353 // It shouldn't return. If it does, exit that thread. 354 MOVW $111, R4 355 MOVV $SYS_exit, R2 356 SYSCALL 357 JMP -3(PC) // keep exiting 358 359 TEXT runtime·sigaltstack(SB),NOSPLIT,$-8 360 MOVV new+0(FP), R4 361 MOVV old+8(FP), R5 362 MOVV $SYS_sigaltstack, R2 363 SYSCALL 364 BEQ R7, 2(PC) 365 MOVV R0, 0xf1(R0) // crash 366 RET 367 368 TEXT runtime·osyield(SB),NOSPLIT,$-8 369 MOVV $SYS_sched_yield, R2 370 SYSCALL 371 RET 372 373 TEXT runtime·sched_getaffinity(SB),NOSPLIT,$-8 374 MOVV pid+0(FP), R4 375 MOVV len+8(FP), R5 376 MOVV buf+16(FP), R6 377 MOVV $SYS_sched_getaffinity, R2 378 SYSCALL 379 MOVW R2, ret+24(FP) 380 RET 381 382 // int32 runtime·epollcreate(int32 size); 383 TEXT runtime·epollcreate(SB),NOSPLIT,$-8 384 MOVW size+0(FP), R4 385 MOVV $SYS_epoll_create, R2 386 SYSCALL 387 MOVW R2, ret+8(FP) 388 RET 389 390 // int32 runtime·epollcreate1(int32 flags); 391 TEXT runtime·epollcreate1(SB),NOSPLIT,$-8 392 MOVW flags+0(FP), R4 393 MOVV $SYS_epoll_create1, R2 394 SYSCALL 395 MOVW R2, ret+8(FP) 396 RET 397 398 // func epollctl(epfd, op, fd int32, ev *epollEvent) int 399 TEXT runtime·epollctl(SB),NOSPLIT,$-8 400 MOVW epfd+0(FP), R4 401 MOVW op+4(FP), R5 402 MOVW fd+8(FP), R6 403 MOVV ev+16(FP), R7 404 MOVV $SYS_epoll_ctl, R2 405 SYSCALL 406 MOVW R2, ret+24(FP) 407 RET 408 409 // int32 runtime·epollwait(int32 epfd, EpollEvent *ev, int32 nev, int32 timeout); 410 TEXT runtime·epollwait(SB),NOSPLIT,$-8 411 MOVW epfd+0(FP), R4 412 MOVV ev+8(FP), R5 413 MOVW nev+16(FP), R6 414 MOVW timeout+20(FP), R7 415 MOVV $SYS_epoll_wait, R2 416 SYSCALL 417 MOVW R2, ret+24(FP) 418 RET 419 420 // void runtime·closeonexec(int32 fd); 421 TEXT runtime·closeonexec(SB),NOSPLIT,$-8 422 MOVW fd+0(FP), R4 // fd 423 MOVV $2, R5 // F_SETFD 424 MOVV $1, R6 // FD_CLOEXEC 425 MOVV $SYS_fcntl, R2 426 SYSCALL 427 RET