2020-06-16 13:38:43 +00:00
|
|
|
/*-*- mode:unix-assembly; indent-tabs-mode:t; tab-width:8; coding:utf-8 -*-│
|
2020-06-15 14:18:57 +00:00
|
|
|
│vi: set et ft=asm ts=8 tw=8 fenc=utf-8 :vi│
|
|
|
|
╞══════════════════════════════════════════════════════════════════════════════╡
|
|
|
|
│ Copyright 2020 Justine Alexandra Roberts Tunney │
|
|
|
|
│ │
|
2020-12-28 01:18:44 +00:00
|
|
|
│ Permission to use, copy, modify, and/or distribute this software for │
|
|
|
|
│ any purpose with or without fee is hereby granted, provided that the │
|
|
|
|
│ above copyright notice and this permission notice appear in all copies. │
|
2020-06-15 14:18:57 +00:00
|
|
|
│ │
|
2020-12-28 01:18:44 +00:00
|
|
|
│ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL │
|
|
|
|
│ WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED │
|
|
|
|
│ WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE │
|
|
|
|
│ AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL │
|
|
|
|
│ DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR │
|
|
|
|
│ PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER │
|
|
|
|
│ TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR │
|
|
|
|
│ PERFORMANCE OF THIS SOFTWARE. │
|
2020-06-15 14:18:57 +00:00
|
|
|
╚─────────────────────────────────────────────────────────────────────────────*/
|
2021-03-01 07:42:35 +00:00
|
|
|
#include "libc/macros.internal.h"
|
2020-06-15 14:18:57 +00:00
|
|
|
#include "libc/notice.inc"
|
2020-09-28 08:13:56 +00:00
|
|
|
#include "libc/sysv/consts/prot.h"
|
|
|
|
#include "libc/sysv/consts/map.h"
|
2022-09-13 06:10:38 +00:00
|
|
|
#include "libc/intrin/strace.internal.h"
|
2022-05-12 13:43:59 +00:00
|
|
|
#include "libc/sysv/consts/map.h"
|
2020-06-15 14:18:57 +00:00
|
|
|
#include "libc/dce.h"
|
|
|
|
.text.startup
|
|
|
|
|
2021-02-08 17:19:00 +00:00
|
|
|
// Cosmopolitan runtime.
|
|
|
|
//
|
|
|
|
// @param edi is argc
|
|
|
|
// @param rsi is argv
|
|
|
|
// @param rdx is environ
|
|
|
|
// @param rcx is auxv
|
|
|
|
// @noreturn
|
2021-02-01 11:33:13 +00:00
|
|
|
cosmo: push %rbp
|
2020-08-25 11:23:25 +00:00
|
|
|
mov %rsp,%rbp
|
|
|
|
mov %edi,%r12d
|
|
|
|
mov %rsi,%r13
|
|
|
|
mov %rdx,%r14
|
|
|
|
mov %rcx,%r15
|
2022-08-14 08:19:58 +00:00
|
|
|
|
Introduce --strace flag for system call tracing
This is similar to the --ftrace (c function call trace) flag, except
it's less noisy since it only logs system calls to stderr. Having this
flag is valuable because (1) system call tracing tells us a lot about
the behavior of complex programs and (2) it's usually very hard to get
system call tracing on various operating systems, e.g. strace, ktrace,
dtruss, truss, nttrace, etc. Especially on Apple platforms where even
with the special boot trick, debuggers still aren't guaranteed to work.
make -j8 o//examples
o//examples/hello.com --strace
This is enabled by default in MODE=, MODE=opt, and MODE=dbg. In MODE=dbg
extra information will be printed.
make -j8 MODE=dbg o/dbg/examples
o/dbg/examples/hello.com --strace |& less
This change also changes:
- Rename IsText() → _istext()
- Rename IsUtf8() → _isutf8()
- Fix madvise() on Windows NT
- Fix empty string case of inet_ntop()
- vfork() wrapper now saves and restores errno
- Update xsigaction() to yoink syscall support
2022-03-19 01:07:28 +00:00
|
|
|
#ifdef SYSDEBUG
|
|
|
|
call __strace_init
|
|
|
|
mov %eax,%r12d
|
|
|
|
#endif /* SYSDEBUG */
|
2022-08-14 08:19:58 +00:00
|
|
|
|
2021-02-01 11:33:13 +00:00
|
|
|
#ifdef __FAST_MATH__
|
2021-02-08 12:04:42 +00:00
|
|
|
push %rax
|
|
|
|
stmxcsr (%rsp)
|
|
|
|
orl $0x8040,(%rsp)
|
|
|
|
ldmxcsr (%rsp)
|
|
|
|
pop %rax
|
2021-02-01 11:33:13 +00:00
|
|
|
#endif
|
2022-08-14 08:19:58 +00:00
|
|
|
|
|
|
|
// run assembly init
|
2021-02-01 11:33:13 +00:00
|
|
|
call _init
|
2022-08-14 08:19:58 +00:00
|
|
|
|
|
|
|
// call constructors
|
2021-02-08 12:04:42 +00:00
|
|
|
ezlea __init_array_start,ax # static ctors in forward order
|
|
|
|
.weak __init_array_start # could be called multiple times
|
|
|
|
ezlea __init_array_end,cx # idempotency recommended
|
|
|
|
.weak __init_array_end # @see ape/ape.lds
|
|
|
|
1: cmp %rax,%rcx
|
|
|
|
je 2f
|
|
|
|
push %rax
|
|
|
|
push %rcx
|
|
|
|
call .Largs
|
|
|
|
call *(%rax)
|
|
|
|
pop %rcx
|
|
|
|
pop %rax
|
|
|
|
add $8,%rax
|
|
|
|
jmp 1b
|
2022-08-14 08:19:58 +00:00
|
|
|
|
|
|
|
// call main()
|
2021-09-28 05:58:51 +00:00
|
|
|
2: call .Largs
|
2020-06-15 14:18:57 +00:00
|
|
|
.weak main
|
2020-11-09 23:41:11 +00:00
|
|
|
call main
|
|
|
|
xchg %eax,%edi
|
2020-06-15 14:18:57 +00:00
|
|
|
call exit
|
2022-08-14 08:19:58 +00:00
|
|
|
|
2021-02-08 12:04:42 +00:00
|
|
|
.Largs: mov %r12d,%edi
|
|
|
|
mov %r13,%rsi
|
|
|
|
mov %r14,%rdx
|
|
|
|
mov %r15,%rcx
|
|
|
|
ret
|
|
|
|
.endfn cosmo,weak
|
2020-06-15 14:18:57 +00:00
|
|
|
|
2022-07-19 05:26:11 +00:00
|
|
|
// Enables Thread Local Storage.
|
2022-07-10 15:27:50 +00:00
|
|
|
.init.start 304,_init_tls
|
|
|
|
push %rdi
|
|
|
|
push %rsi
|
|
|
|
call __enable_tls
|
|
|
|
pop %rsi
|
|
|
|
pop %rdi
|
2022-07-19 05:26:11 +00:00
|
|
|
.init.end 304,_init_tls
|
2022-07-10 15:27:50 +00:00
|
|
|
|
2022-05-12 13:43:59 +00:00
|
|
|
#if !IsTiny()
|
2022-05-14 11:33:58 +00:00
|
|
|
// Creates deterministically addressed stack we can use
|
|
|
|
//
|
|
|
|
// This helps debugging be more comprehensible, because
|
|
|
|
// when diagnosing low-level problems when error report
|
|
|
|
// isn't working, sometimes numbers are all you have to
|
|
|
|
// go on, and we can't use them if kernel hardening has
|
|
|
|
// configured that meaningful data to be randomized.
|
|
|
|
//
|
|
|
|
// Having deterministic addresses is also key to ensure
|
|
|
|
// builds, execution, and other things are reproducible
|
2022-05-12 13:43:59 +00:00
|
|
|
.init.start 304,_init_stack
|
|
|
|
testb IsWindows()
|
|
|
|
jnz 9f
|
2022-08-13 23:14:02 +00:00
|
|
|
testb IsMetal()
|
|
|
|
jnz 9f
|
2022-05-12 13:43:59 +00:00
|
|
|
push %rdi
|
|
|
|
push %rsi
|
2022-08-14 08:19:58 +00:00
|
|
|
|
2022-05-12 13:43:59 +00:00
|
|
|
// allocate stack
|
|
|
|
movabs $ape_stack_vaddr,%rdi
|
|
|
|
mov $ape_stack_memsz,%esi
|
|
|
|
mov $ape_stack_prot,%edx
|
|
|
|
mov $MAP_STACK,%ecx
|
|
|
|
or MAP_ANONYMOUS,%ecx
|
|
|
|
or $-1,%r8
|
|
|
|
xor %r9d,%r9d
|
|
|
|
push %rsi
|
|
|
|
call mmap
|
|
|
|
pop %r8
|
|
|
|
pop %rsi
|
|
|
|
pop %rdi
|
|
|
|
cmp $-1,%rax
|
|
|
|
je 9f
|
2022-08-14 08:19:58 +00:00
|
|
|
|
2022-05-12 13:43:59 +00:00
|
|
|
// switch stacks
|
2022-08-14 08:19:58 +00:00
|
|
|
//
|
|
|
|
// we subtract 8 because the openbsd kernel always checks rsp
|
|
|
|
// is on a MAP_STACK interval non-inclusively of stack + size
|
2022-05-12 13:43:59 +00:00
|
|
|
leave
|
2022-08-14 08:19:58 +00:00
|
|
|
pop %rcx # return address
|
|
|
|
sub $8,%r8d # openbsd:stackbound
|
2022-05-12 13:43:59 +00:00
|
|
|
lea (%rax,%r8),%rsp
|
2022-08-14 08:19:58 +00:00
|
|
|
mov $ape_stack_align,%eax
|
2022-08-13 23:14:02 +00:00
|
|
|
neg %rax
|
|
|
|
and %rax,%rsp
|
2022-05-12 13:43:59 +00:00
|
|
|
push %rcx
|
|
|
|
push %rbp
|
|
|
|
mov %rsp,%rbp
|
2022-08-14 08:19:58 +00:00
|
|
|
|
2022-05-12 13:43:59 +00:00
|
|
|
9: nop
|
|
|
|
.init.end 304,_init_stack
|
|
|
|
.weak ape_stack_prot
|
|
|
|
.weak ape_stack_vaddr
|
|
|
|
.weak ape_stack_memsz
|
|
|
|
.weak ape_stack_align
|
|
|
|
#endif
|
|
|
|
|
2022-06-13 05:20:59 +00:00
|
|
|
#if IsAsan()
|
|
|
|
.init.start 305,_init_symbols
|
2020-06-15 14:18:57 +00:00
|
|
|
push %rdi
|
|
|
|
push %rsi
|
2022-06-13 05:20:59 +00:00
|
|
|
call __init_symbols
|
2020-10-11 04:18:53 +00:00
|
|
|
pop %rsi
|
2020-06-15 14:18:57 +00:00
|
|
|
pop %rdi
|
2022-06-13 05:20:59 +00:00
|
|
|
.init.end 305,_init_symbols
|
Introduce --strace flag for system call tracing
This is similar to the --ftrace (c function call trace) flag, except
it's less noisy since it only logs system calls to stderr. Having this
flag is valuable because (1) system call tracing tells us a lot about
the behavior of complex programs and (2) it's usually very hard to get
system call tracing on various operating systems, e.g. strace, ktrace,
dtruss, truss, nttrace, etc. Especially on Apple platforms where even
with the special boot trick, debuggers still aren't guaranteed to work.
make -j8 o//examples
o//examples/hello.com --strace
This is enabled by default in MODE=, MODE=opt, and MODE=dbg. In MODE=dbg
extra information will be printed.
make -j8 MODE=dbg o/dbg/examples
o/dbg/examples/hello.com --strace |& less
This change also changes:
- Rename IsText() → _istext()
- Rename IsUtf8() → _isutf8()
- Fix madvise() on Windows NT
- Fix empty string case of inet_ntop()
- vfork() wrapper now saves and restores errno
- Update xsigaction() to yoink syscall support
2022-03-19 01:07:28 +00:00
|
|
|
#endif
|
|
|
|
|
2022-06-13 05:20:59 +00:00
|
|
|
#ifdef __PG__
|
|
|
|
.init.start 306,_init_ftrace
|
2022-05-21 01:51:41 +00:00
|
|
|
push %rdi
|
|
|
|
push %rsi
|
2022-06-13 05:20:59 +00:00
|
|
|
call ftrace_init
|
|
|
|
mov %eax,%r12d
|
2022-05-21 01:51:41 +00:00
|
|
|
pop %rsi
|
|
|
|
pop %rdi
|
2022-06-13 05:20:59 +00:00
|
|
|
.init.end 306,_init_ftrace
|
2022-05-21 01:51:41 +00:00
|
|
|
#endif
|
|
|
|
|
Introduce --strace flag for system call tracing
This is similar to the --ftrace (c function call trace) flag, except
it's less noisy since it only logs system calls to stderr. Having this
flag is valuable because (1) system call tracing tells us a lot about
the behavior of complex programs and (2) it's usually very hard to get
system call tracing on various operating systems, e.g. strace, ktrace,
dtruss, truss, nttrace, etc. Especially on Apple platforms where even
with the special boot trick, debuggers still aren't guaranteed to work.
make -j8 o//examples
o//examples/hello.com --strace
This is enabled by default in MODE=, MODE=opt, and MODE=dbg. In MODE=dbg
extra information will be printed.
make -j8 MODE=dbg o/dbg/examples
o/dbg/examples/hello.com --strace |& less
This change also changes:
- Rename IsText() → _istext()
- Rename IsUtf8() → _isutf8()
- Fix madvise() on Windows NT
- Fix empty string case of inet_ntop()
- vfork() wrapper now saves and restores errno
- Update xsigaction() to yoink syscall support
2022-03-19 01:07:28 +00:00
|
|
|
#if IsModeDbg()
|
|
|
|
#ifdef SYSDEBUG
|
|
|
|
.init.start 307,_init_printargs
|
2022-04-16 17:40:23 +00:00
|
|
|
cmpl $0,__strace(%rip)
|
|
|
|
jz 1f
|
Introduce --strace flag for system call tracing
This is similar to the --ftrace (c function call trace) flag, except
it's less noisy since it only logs system calls to stderr. Having this
flag is valuable because (1) system call tracing tells us a lot about
the behavior of complex programs and (2) it's usually very hard to get
system call tracing on various operating systems, e.g. strace, ktrace,
dtruss, truss, nttrace, etc. Especially on Apple platforms where even
with the special boot trick, debuggers still aren't guaranteed to work.
make -j8 o//examples
o//examples/hello.com --strace
This is enabled by default in MODE=, MODE=opt, and MODE=dbg. In MODE=dbg
extra information will be printed.
make -j8 MODE=dbg o/dbg/examples
o/dbg/examples/hello.com --strace |& less
This change also changes:
- Rename IsText() → _istext()
- Rename IsUtf8() → _isutf8()
- Fix madvise() on Windows NT
- Fix empty string case of inet_ntop()
- vfork() wrapper now saves and restores errno
- Update xsigaction() to yoink syscall support
2022-03-19 01:07:28 +00:00
|
|
|
push %rdi
|
|
|
|
push %rsi
|
2022-04-16 17:40:23 +00:00
|
|
|
loadstr STRACE_PROLOGUE,di
|
Introduce --strace flag for system call tracing
This is similar to the --ftrace (c function call trace) flag, except
it's less noisy since it only logs system calls to stderr. Having this
flag is valuable because (1) system call tracing tells us a lot about
the behavior of complex programs and (2) it's usually very hard to get
system call tracing on various operating systems, e.g. strace, ktrace,
dtruss, truss, nttrace, etc. Especially on Apple platforms where even
with the special boot trick, debuggers still aren't guaranteed to work.
make -j8 o//examples
o//examples/hello.com --strace
This is enabled by default in MODE=, MODE=opt, and MODE=dbg. In MODE=dbg
extra information will be printed.
make -j8 MODE=dbg o/dbg/examples
o/dbg/examples/hello.com --strace |& less
This change also changes:
- Rename IsText() → _istext()
- Rename IsUtf8() → _isutf8()
- Fix madvise() on Windows NT
- Fix empty string case of inet_ntop()
- vfork() wrapper now saves and restores errno
- Update xsigaction() to yoink syscall support
2022-03-19 01:07:28 +00:00
|
|
|
call __printargs
|
|
|
|
pop %rsi
|
|
|
|
pop %rdi
|
2022-04-16 17:40:23 +00:00
|
|
|
1: .init.end 307,_init_printargs
|
Introduce --strace flag for system call tracing
This is similar to the --ftrace (c function call trace) flag, except
it's less noisy since it only logs system calls to stderr. Having this
flag is valuable because (1) system call tracing tells us a lot about
the behavior of complex programs and (2) it's usually very hard to get
system call tracing on various operating systems, e.g. strace, ktrace,
dtruss, truss, nttrace, etc. Especially on Apple platforms where even
with the special boot trick, debuggers still aren't guaranteed to work.
make -j8 o//examples
o//examples/hello.com --strace
This is enabled by default in MODE=, MODE=opt, and MODE=dbg. In MODE=dbg
extra information will be printed.
make -j8 MODE=dbg o/dbg/examples
o/dbg/examples/hello.com --strace |& less
This change also changes:
- Rename IsText() → _istext()
- Rename IsUtf8() → _isutf8()
- Fix madvise() on Windows NT
- Fix empty string case of inet_ntop()
- vfork() wrapper now saves and restores errno
- Update xsigaction() to yoink syscall support
2022-03-19 01:07:28 +00:00
|
|
|
#endif
|
2020-10-11 04:18:53 +00:00
|
|
|
#endif
|