| // Copyright 2009 The Go Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style |
| // license that can be found in the LICENSE file. |
| |
| // |
| // System calls and other sys.stuff for AMD64, Linux |
| // |
| |
| TEXT sys·Exit(SB),7,$0-8 |
| MOVL 8(SP), DI |
| MOVL $231, AX // exitgroup - force all os threads to exi |
| SYSCALL |
| RET |
| |
| TEXT exit1(SB),7,$0-8 |
| MOVL 8(SP), DI |
| MOVL $60, AX // exit - exit the current os thread |
| SYSCALL |
| RET |
| |
| TEXT open(SB),7,$0-16 |
| MOVQ 8(SP), DI |
| MOVL 16(SP), SI |
| MOVL 20(SP), DX |
| MOVL $2, AX // syscall entry |
| SYSCALL |
| RET |
| |
| TEXT close(SB),7,$0-8 |
| MOVL 8(SP), DI |
| MOVL $3, AX // syscall entry |
| SYSCALL |
| RET |
| |
| TEXT fstat(SB),7,$0-16 |
| MOVL 8(SP), DI |
| MOVQ 16(SP), SI |
| MOVL $5, AX // syscall entry |
| SYSCALL |
| RET |
| |
| TEXT read(SB),7,$0-24 |
| MOVL 8(SP), DI |
| MOVQ 16(SP), SI |
| MOVL 24(SP), DX |
| MOVL $0, AX // syscall entry |
| SYSCALL |
| RET |
| |
| TEXT write(SB),7,$0-24 |
| MOVL 8(SP), DI |
| MOVQ 16(SP), SI |
| MOVL 24(SP), DX |
| MOVL $1, AX // syscall entry |
| SYSCALL |
| RET |
| |
| TEXT sys·write(SB),7,$0-24 |
| MOVL 8(SP), DI |
| MOVQ 16(SP), SI |
| MOVL 24(SP), DX |
| MOVL $1, AX // syscall entry |
| SYSCALL |
| RET |
| |
| TEXT rt_sigaction(SB),7,$0-32 |
| MOVL 8(SP), DI |
| MOVQ 16(SP), SI |
| MOVQ 24(SP), DX |
| MOVQ 32(SP), R10 |
| MOVL $13, AX // syscall entry |
| SYSCALL |
| RET |
| |
| TEXT sigtramp(SB),7,$24-16 |
| MOVQ 32(R14), R15 // g = m->gsignal |
| MOVQ DI,0(SP) |
| MOVQ SI,8(SP) |
| MOVQ DX,16(SP) |
| CALL sighandler(SB) |
| RET |
| |
| TEXT sigignore(SB),7,$0 |
| RET |
| |
| TEXT sigreturn(SB),7,$0 |
| MOVL $15, AX // rt_sigreturn |
| SYSCALL |
| INT $3 // not reached |
| |
| TEXT sys·mmap(SB),7,$0-32 |
| MOVQ 8(SP), DI |
| MOVQ $0, SI |
| MOVL 16(SP), SI |
| MOVL 20(SP), DX |
| MOVL 24(SP), R10 |
| MOVL 28(SP), R8 |
| MOVL 32(SP), R9 |
| |
| /* flags arg for ANON is 1000 but sb 20 */ |
| MOVL CX, AX |
| ANDL $~0x1000, CX |
| ANDL $0x1000, AX |
| SHRL $7, AX |
| ORL AX, CX |
| |
| MOVL CX, R10 |
| MOVL $9, AX // syscall entry |
| SYSCALL |
| CMPQ AX, $0xfffffffffffff001 |
| JLS 2(PC) |
| CALL notok(SB) |
| RET |
| |
| TEXT notok(SB),7,$0 |
| MOVQ $0xf1, BP |
| MOVQ BP, (BP) |
| RET |
| |
| TEXT sys·memclr(SB),7,$0-16 |
| MOVQ 8(SP), DI // arg 1 addr |
| MOVL 16(SP), CX // arg 2 count (cannot be zero) |
| ADDL $7, CX |
| SHRL $3, CX |
| MOVQ $0, AX |
| CLD |
| REP |
| STOSQ |
| RET |
| |
| TEXT sys·getcallerpc+0(SB),7,$0 |
| MOVQ x+0(FP),AX // addr of first arg |
| MOVQ -8(AX),AX // get calling pc |
| RET |
| |
| TEXT sys·setcallerpc+0(SB),7,$0 |
| MOVQ x+0(FP),AX // addr of first arg |
| MOVQ x+8(FP), BX |
| MOVQ BX, -8(AX) // set calling pc |
| RET |
| |
| // int64 futex(int32 *uaddr, int32 op, int32 val, |
| // struct timespec *timeout, int32 *uaddr2, int32 val2); |
| TEXT futex(SB),7,$0 |
| MOVQ 8(SP), DI |
| MOVL 16(SP), SI |
| MOVL 20(SP), DX |
| MOVQ 24(SP), R10 |
| MOVQ 32(SP), R8 |
| MOVL 40(SP), R9 |
| MOVL $202, AX |
| SYSCALL |
| RET |
| |
| // int64 clone(int32 flags, void *stack, M *m, G *g, void (*fn)(void)); |
| TEXT clone(SB),7,$0 |
| MOVL flags+8(SP), DI |
| MOVQ stack+16(SP), SI |
| |
| // Copy m, g, fn off parent stack for use by child. |
| // Careful: Linux system call clobbers CX and R11. |
| MOVQ m+24(SP), R8 |
| MOVQ g+32(SP), R9 |
| MOVQ fn+40(SP), R12 |
| |
| MOVL $56, AX |
| SYSCALL |
| |
| // In parent, return. |
| CMPQ AX, $0 |
| JEQ 2(PC) |
| RET |
| |
| // In child, set up new stack |
| MOVQ SI, SP |
| MOVQ R8, R14 // m |
| MOVQ R9, R15 // g |
| |
| // Initialize m->procid to Linux tid |
| MOVL $186, AX // gettid |
| SYSCALL |
| MOVQ AX, 24(R14) |
| |
| // Call fn |
| CALL R12 |
| |
| // It shouldn't return. If it does, exi |
| MOVL $111, DI |
| MOVL $60, AX |
| SYSCALL |
| JMP -3(PC) // keep exiting |
| |
| TEXT sigaltstack(SB),7,$-8 |
| MOVQ new+8(SP), DI |
| MOVQ old+16(SP), SI |
| MOVQ $131, AX |
| SYSCALL |
| CMPQ AX, $0xfffffffffffff001 |
| JLS 2(PC) |
| CALL notok(SB) |
| RET |