X7ROOT File Manager
Current Path:
/opt/golang/1.19.4/src/runtime
opt
/
golang
/
1.19.4
/
src
/
runtime
/
馃搧
..
馃搫
HACKING.md
(15.29 KB)
馃搫
Makefile
(178 B)
馃搫
abi_test.go
(2.83 KB)
馃搫
alg.go
(9.45 KB)
馃搫
align_runtime_test.go
(2.73 KB)
馃搫
align_test.go
(5.26 KB)
馃搧
asan
馃搫
asan.go
(1.55 KB)
馃搫
asan0.go
(761 B)
馃搫
asan_amd64.s
(2.46 KB)
馃搫
asan_arm64.s
(2.15 KB)
馃搫
asan_riscv64.s
(1.92 KB)
馃搫
asm.s
(278 B)
馃搫
asm_386.s
(40.43 KB)
馃搫
asm_amd64.h
(411 B)
馃搫
asm_amd64.s
(57.44 KB)
馃搫
asm_arm.s
(30.2 KB)
馃搫
asm_arm64.s
(41.41 KB)
馃搫
asm_loong64.s
(21.79 KB)
馃搫
asm_mips64x.s
(22.43 KB)
馃搫
asm_mipsx.s
(24.41 KB)
馃搫
asm_ppc64x.h
(1023 B)
馃搫
asm_ppc64x.s
(35.21 KB)
馃搫
asm_riscv64.s
(26.43 KB)
馃搫
asm_s390x.s
(26.08 KB)
馃搫
asm_wasm.s
(9.38 KB)
馃搫
atomic_arm64.s
(259 B)
馃搫
atomic_loong64.s
(245 B)
馃搫
atomic_mips64x.s
(300 B)
馃搫
atomic_mipsx.s
(262 B)
馃搫
atomic_pointer.go
(2.62 KB)
馃搫
atomic_ppc64x.s
(437 B)
馃搫
atomic_riscv64.s
(275 B)
馃搫
auxv_none.go
(298 B)
馃搫
callers_test.go
(8.44 KB)
馃搧
cgo
馃搫
cgo.go
(2 KB)
馃搫
cgo_mmap.go
(2.4 KB)
馃搫
cgo_ppc64x.go
(418 B)
馃搫
cgo_sigaction.go
(3.28 KB)
馃搫
cgocall.go
(19.12 KB)
馃搫
cgocallback.go
(317 B)
馃搫
cgocheck.go
(6.86 KB)
馃搫
chan.go
(23.73 KB)
馃搫
chan_test.go
(23.37 KB)
馃搫
chanbarrier_test.go
(1.4 KB)
馃搫
checkptr.go
(3.29 KB)
馃搫
checkptr_test.go
(2.73 KB)
馃搫
closure_test.go
(937 B)
馃搫
compiler.go
(410 B)
馃搫
complex.go
(1.59 KB)
馃搫
complex_test.go
(1.05 KB)
馃搫
conv_wasm_test.go
(2.96 KB)
馃搫
cpuflags.go
(810 B)
馃搫
cpuflags_amd64.go
(533 B)
馃搫
cpuflags_arm64.go
(334 B)
馃搫
cpuprof.go
(7.78 KB)
馃搫
cputicks.go
(449 B)
馃搫
crash_cgo_test.go
(18.14 KB)
馃搫
crash_test.go
(21.77 KB)
馃搫
crash_unix_test.go
(8.39 KB)
馃搧
debug
馃搫
debug.go
(3.23 KB)
馃搫
debug_test.go
(7.98 KB)
馃搫
debugcall.go
(6.19 KB)
馃搫
debuglog.go
(17.87 KB)
馃搫
debuglog_off.go
(357 B)
馃搫
debuglog_on.go
(1.09 KB)
馃搫
debuglog_test.go
(4.56 KB)
馃搫
defer_test.go
(11.56 KB)
馃搫
defs1_linux.go
(845 B)
馃搫
defs1_netbsd_386.go
(2.83 KB)
馃搫
defs1_netbsd_amd64.go
(3.06 KB)
馃搫
defs1_netbsd_arm.go
(2.94 KB)
馃搫
defs1_netbsd_arm64.go
(3.17 KB)
馃搫
defs1_solaris_amd64.go
(4 KB)
馃搫
defs2_linux.go
(3.51 KB)
馃搫
defs3_linux.go
(1.09 KB)
馃搫
defs_aix.go
(4.16 KB)
馃搫
defs_aix_ppc64.go
(3.61 KB)
馃搫
defs_arm_linux.go
(2.67 KB)
馃搫
defs_darwin.go
(3.78 KB)
馃搫
defs_darwin_amd64.go
(6.07 KB)
馃搫
defs_darwin_arm64.go
(3.89 KB)
馃搫
defs_dragonfly.go
(2.59 KB)
馃搫
defs_dragonfly_amd64.go
(3.29 KB)
馃搫
defs_freebsd.go
(3.82 KB)
馃搫
defs_freebsd_386.go
(4.36 KB)
馃搫
defs_freebsd_amd64.go
(4.63 KB)
馃搫
defs_freebsd_arm.go
(3.69 KB)
馃搫
defs_freebsd_arm64.go
(4.01 KB)
馃搫
defs_illumos_amd64.go
(285 B)
馃搫
defs_linux.go
(3.25 KB)
馃搫
defs_linux_386.go
(4.42 KB)
馃搫
defs_linux_amd64.go
(4.93 KB)
馃搫
defs_linux_arm.go
(4.11 KB)
馃搫
defs_linux_arm64.go
(3.86 KB)
馃搫
defs_linux_loong64.go
(3.68 KB)
馃搫
defs_linux_mips64x.go
(3.85 KB)
馃搫
defs_linux_mipsx.go
(3.83 KB)
馃搫
defs_linux_ppc64.go
(3.93 KB)
馃搫
defs_linux_ppc64le.go
(3.93 KB)
馃搫
defs_linux_riscv64.go
(4.06 KB)
馃搫
defs_linux_s390x.go
(3.41 KB)
馃搫
defs_netbsd.go
(2.72 KB)
馃搫
defs_netbsd_386.go
(855 B)
馃搫
defs_netbsd_amd64.go
(1.01 KB)
馃搫
defs_netbsd_arm.go
(764 B)
馃搫
defs_openbsd.go
(3.09 KB)
馃搫
defs_openbsd_386.go
(2.87 KB)
馃搫
defs_openbsd_amd64.go
(3.07 KB)
馃搫
defs_openbsd_arm.go
(2.99 KB)
馃搫
defs_openbsd_arm64.go
(2.74 KB)
馃搫
defs_openbsd_mips64.go
(2.64 KB)
馃搫
defs_plan9_386.go
(1.63 KB)
馃搫
defs_plan9_amd64.go
(1.82 KB)
馃搫
defs_plan9_arm.go
(1.73 KB)
馃搫
defs_solaris.go
(3.31 KB)
馃搫
defs_solaris_amd64.go
(1004 B)
馃搫
defs_windows.go
(2.09 KB)
馃搫
defs_windows_386.go
(1.98 KB)
馃搫
defs_windows_amd64.go
(2.71 KB)
馃搫
defs_windows_arm.go
(2.11 KB)
馃搫
defs_windows_arm64.go
(2.63 KB)
馃搫
duff_386.s
(8.24 KB)
馃搫
duff_amd64.s
(5.62 KB)
馃搫
duff_arm.s
(7.11 KB)
馃搫
duff_arm64.s
(5.27 KB)
馃搫
duff_loong64.s
(12 KB)
馃搫
duff_mips64x.s
(11.28 KB)
馃搫
duff_ppc64x.s
(7.06 KB)
馃搫
duff_riscv64.s
(11.4 KB)
馃搫
duff_s390x.s
(507 B)
馃搫
env_plan9.go
(3 KB)
馃搫
env_posix.go
(1.79 KB)
馃搫
env_test.go
(1.16 KB)
馃搫
error.go
(9.21 KB)
馃搫
example_test.go
(1.55 KB)
馃搫
export_aix_test.go
(234 B)
馃搫
export_arm_test.go
(226 B)
馃搫
export_darwin_test.go
(382 B)
馃搫
export_debug_amd64_test.go
(3.6 KB)
馃搫
export_debug_arm64_test.go
(3.49 KB)
馃搫
export_debug_test.go
(5.05 KB)
馃搫
export_debuglog_test.go
(1.24 KB)
馃搫
export_linux_test.go
(550 B)
馃搫
export_mmap_test.go
(429 B)
馃搫
export_pipe2_test.go
(310 B)
馃搫
export_pipe_test.go
(219 B)
馃搫
export_solaris_test.go
(282 B)
馃搫
export_test.go
(38.87 KB)
馃搫
export_unix_test.go
(2.18 KB)
馃搫
export_windows_test.go
(677 B)
馃搫
extern.go
(13.62 KB)
馃搫
fastlog2.go
(1.22 KB)
馃搫
fastlog2_test.go
(784 B)
馃搫
fastlog2table.go
(904 B)
馃搫
float.go
(1.35 KB)
馃搫
float_test.go
(699 B)
馃搫
funcdata.h
(2.55 KB)
馃搫
gc_test.go
(20.04 KB)
馃搫
gcinfo_test.go
(5.59 KB)
馃搫
go_tls.h
(366 B)
馃搫
hash32.go
(1.58 KB)
馃搫
hash64.go
(1.95 KB)
馃搫
hash_test.go
(16.77 KB)
馃搫
heapdump.go
(17.65 KB)
馃搫
histogram.go
(6.19 KB)
馃搫
histogram_test.go
(3.42 KB)
馃搫
iface.go
(15.66 KB)
馃搫
iface_test.go
(7.45 KB)
馃搧
internal
馃搫
lfstack.go
(1.77 KB)
馃搫
lfstack_32bit.go
(532 B)
馃搫
lfstack_64bit.go
(2.18 KB)
馃搫
lfstack_test.go
(2.77 KB)
馃搫
libfuzzer.go
(6.5 KB)
馃搫
libfuzzer_amd64.s
(5.01 KB)
馃搫
libfuzzer_arm64.s
(3.15 KB)
馃搫
lock_futex.go
(5.19 KB)
馃搫
lock_js.go
(6.14 KB)
馃搫
lock_sema.go
(6.74 KB)
馃搫
lockrank.go
(13.26 KB)
馃搫
lockrank_off.go
(1.14 KB)
馃搫
lockrank_on.go
(9.83 KB)
馃搫
lockrank_test.go
(1.15 KB)
馃搫
malloc.go
(51.01 KB)
馃搫
malloc_test.go
(10.78 KB)
馃搫
map.go
(43.52 KB)
馃搫
map_benchmark_test.go
(10.48 KB)
馃搫
map_fast32.go
(12.72 KB)
馃搫
map_fast64.go
(12.91 KB)
馃搫
map_faststr.go
(14.3 KB)
馃搫
map_test.go
(27.44 KB)
馃搫
mbarrier.go
(12.43 KB)
馃搫
mbitmap.go
(66.08 KB)
馃搫
mcache.go
(10 KB)
馃搫
mcentral.go
(7.9 KB)
馃搫
mcheckmark.go
(2.81 KB)
馃搫
mem.go
(6.23 KB)
馃搫
mem_aix.go
(1.9 KB)
馃搫
mem_bsd.go
(2.03 KB)
馃搫
mem_darwin.go
(1.84 KB)
馃搫
mem_js.go
(2.25 KB)
馃搫
mem_linux.go
(6.15 KB)
馃搫
mem_plan9.go
(4.32 KB)
馃搫
mem_windows.go
(3.76 KB)
馃搫
memclr_386.s
(2.38 KB)
馃搫
memclr_amd64.s
(4.91 KB)
馃搫
memclr_arm.s
(2.6 KB)
馃搫
memclr_arm64.s
(3.62 KB)
馃搫
memclr_loong64.s
(778 B)
馃搫
memclr_mips64x.s
(1.72 KB)
馃搫
memclr_mipsx.s
(1.32 KB)
馃搫
memclr_plan9_386.s
(983 B)
馃搫
memclr_plan9_amd64.s
(511 B)
馃搫
memclr_ppc64x.s
(4.23 KB)
馃搫
memclr_riscv64.s
(978 B)
馃搫
memclr_s390x.s
(1.96 KB)
馃搫
memclr_wasm.s
(622 B)
馃搫
memmove_386.s
(4.42 KB)
馃搫
memmove_amd64.s
(12.48 KB)
馃搫
memmove_arm.s
(5.9 KB)
馃搫
memmove_arm64.s
(5.96 KB)
馃搫
memmove_linux_amd64_test.go
(1.6 KB)
馃搫
memmove_loong64.s
(1.8 KB)
馃搫
memmove_mips64x.s
(1.83 KB)
馃搫
memmove_mipsx.s
(4.4 KB)
馃搫
memmove_plan9_386.s
(3.06 KB)
馃搫
memmove_plan9_amd64.s
(3.04 KB)
馃搫
memmove_ppc64x.s
(4.58 KB)
馃搫
memmove_riscv64.s
(1.86 KB)
馃搫
memmove_s390x.s
(2.92 KB)
馃搫
memmove_test.go
(14.03 KB)
馃搫
memmove_wasm.s
(1.74 KB)
馃搧
metrics
馃搫
metrics.go
(18.71 KB)
馃搫
metrics_test.go
(14.74 KB)
馃搫
mfinal.go
(16.34 KB)
馃搫
mfinal_test.go
(6.19 KB)
馃搫
mfixalloc.go
(3.07 KB)
馃搫
mgc.go
(56.37 KB)
馃搫
mgclimit.go
(17.26 KB)
馃搫
mgclimit_test.go
(9.02 KB)
馃搫
mgcmark.go
(47.47 KB)
馃搫
mgcpacer.go
(60.12 KB)
馃搫
mgcpacer_test.go
(40.43 KB)
馃搫
mgcscavenge.go
(41.29 KB)
馃搫
mgcscavenge_test.go
(20.33 KB)
馃搫
mgcstack.go
(10.58 KB)
馃搫
mgcsweep.go
(27.89 KB)
馃搫
mgcwork.go
(12.86 KB)
馃搫
mheap.go
(69.14 KB)
馃搫
mkduff.go
(8.01 KB)
馃搫
mkfastlog2table.go
(3.08 KB)
馃搫
mkpreempt.go
(15.12 KB)
馃搫
mksizeclasses.go
(9.3 KB)
馃搫
mmap.go
(821 B)
馃搫
mpagealloc.go
(36.84 KB)
馃搫
mpagealloc_32bit.go
(3.81 KB)
馃搫
mpagealloc_64bit.go
(9.44 KB)
馃搫
mpagealloc_test.go
(32.59 KB)
馃搫
mpagecache.go
(5.46 KB)
馃搫
mpagecache_test.go
(10.79 KB)
馃搫
mpallocbits.go
(12.6 KB)
馃搫
mpallocbits_test.go
(13.69 KB)
馃搫
mprof.go
(38.51 KB)
馃搫
mranges.go
(13.64 KB)
馃搫
mranges_test.go
(5.68 KB)
馃搧
msan
馃搫
msan.go
(1.5 KB)
馃搫
msan0.go
(725 B)
馃搫
msan_amd64.s
(2.31 KB)
馃搫
msan_arm64.s
(1.99 KB)
馃搫
msize.go
(777 B)
馃搫
mspanset.go
(12.21 KB)
馃搫
mstats.go
(30.07 KB)
馃搫
mwbbuf.go
(9.28 KB)
馃搫
nbpipe_fcntl_libc_test.go
(470 B)
馃搫
nbpipe_fcntl_unix_test.go
(458 B)
馃搫
nbpipe_pipe.go
(405 B)
馃搫
nbpipe_pipe2.go
(344 B)
馃搫
nbpipe_pipe_test.go
(706 B)
馃搫
nbpipe_test.go
(1.68 KB)
馃搫
net_plan9.go
(645 B)
馃搫
netpoll.go
(18.27 KB)
馃搫
netpoll_aix.go
(4.83 KB)
馃搫
netpoll_epoll.go
(4.16 KB)
馃搫
netpoll_fake.go
(652 B)
馃搫
netpoll_kqueue.go
(4.56 KB)
馃搫
netpoll_os_test.go
(360 B)
馃搫
netpoll_solaris.go
(10.76 KB)
馃搫
netpoll_stub.go
(1.41 KB)
馃搫
netpoll_windows.go
(3.75 KB)
馃搫
norace_linux_test.go
(915 B)
馃搫
norace_test.go
(983 B)
馃搫
numcpu_freebsd_test.go
(381 B)
馃搫
os2_aix.go
(20.45 KB)
馃搫
os2_freebsd.go
(302 B)
馃搫
os2_openbsd.go
(296 B)
馃搫
os2_plan9.go
(1.48 KB)
馃搫
os2_solaris.go
(320 B)
馃搫
os3_plan9.go
(3.93 KB)
馃搫
os3_solaris.go
(17.22 KB)
馃搫
os_aix.go
(8.61 KB)
馃搫
os_android.go
(463 B)
馃搫
os_darwin.go
(12 KB)
馃搫
os_darwin_arm64.go
(416 B)
馃搫
os_dragonfly.go
(6.96 KB)
馃搫
os_freebsd.go
(11.61 KB)
馃搫
os_freebsd2.go
(603 B)
馃搫
os_freebsd_amd64.go
(658 B)
馃搫
os_freebsd_arm.go
(1.32 KB)
馃搫
os_freebsd_arm64.go
(398 B)
馃搫
os_freebsd_noauxv.go
(241 B)
馃搫
os_illumos.go
(3.93 KB)
馃搫
os_js.go
(3.28 KB)
馃搫
os_linux.go
(26.14 KB)
馃搫
os_linux_arm.go
(1.35 KB)
馃搫
os_linux_arm64.go
(556 B)
馃搫
os_linux_be64.go
(824 B)
馃搫
os_linux_generic.go
(888 B)
馃搫
os_linux_loong64.go
(485 B)
馃搫
os_linux_mips64x.go
(1.07 KB)
馃搫
os_linux_mipsx.go
(1.06 KB)
馃搫
os_linux_noauxv.go
(337 B)
馃搫
os_linux_novdso.go
(347 B)
馃搫
os_linux_ppc64x.go
(526 B)
馃搫
os_linux_riscv64.go
(198 B)
馃搫
os_linux_s390x.go
(316 B)
馃搫
os_linux_x86.go
(234 B)
馃搫
os_netbsd.go
(9.8 KB)
馃搫
os_netbsd_386.go
(617 B)
馃搫
os_netbsd_amd64.go
(614 B)
馃搫
os_netbsd_arm.go
(1.16 KB)
馃搫
os_netbsd_arm64.go
(856 B)
馃搫
os_nonopenbsd.go
(437 B)
馃搫
os_only_solaris.go
(357 B)
馃搫
os_openbsd.go
(6.55 KB)
馃搫
os_openbsd_arm.go
(749 B)
馃搫
os_openbsd_arm64.go
(416 B)
馃搫
os_openbsd_libc.go
(1.71 KB)
馃搫
os_openbsd_mips64.go
(416 B)
馃搫
os_openbsd_syscall.go
(1.27 KB)
馃搫
os_openbsd_syscall1.go
(441 B)
馃搫
os_openbsd_syscall2.go
(2.46 KB)
馃搫
os_plan9.go
(10.3 KB)
馃搫
os_plan9_arm.go
(462 B)
馃搫
os_solaris.go
(6.55 KB)
馃搫
os_windows.go
(44.43 KB)
馃搫
os_windows_arm.go
(511 B)
馃搫
os_windows_arm64.go
(339 B)
馃搫
panic.go
(40.25 KB)
馃搫
panic32.go
(4.8 KB)
馃搫
panic_test.go
(1.71 KB)
馃搫
plugin.go
(4.26 KB)
馃搧
pprof
馃搫
preempt.go
(15.21 KB)
馃搫
preempt_386.s
(824 B)
馃搫
preempt_amd64.s
(1.62 KB)
馃搫
preempt_arm.s
(1.48 KB)
馃搫
preempt_arm64.s
(1.97 KB)
馃搫
preempt_loong64.s
(2.35 KB)
馃搫
preempt_mips64x.s
(2.72 KB)
馃搫
preempt_mipsx.s
(2.68 KB)
馃搫
preempt_nonwindows.go
(290 B)
馃搫
preempt_ppc64x.s
(2.72 KB)
馃搫
preempt_riscv64.s
(2.26 KB)
馃搫
preempt_s390x.s
(1.01 KB)
馃搫
preempt_wasm.s
(176 B)
馃搫
print.go
(5.95 KB)
馃搫
proc.go
(176.84 KB)
馃搫
proc_runtime_test.go
(1.38 KB)
馃搫
proc_test.go
(25.66 KB)
馃搫
profbuf.go
(18.26 KB)
馃搫
profbuf_test.go
(8.65 KB)
馃搫
proflabel.go
(1.52 KB)
馃搧
race
馃搫
race.go
(18.58 KB)
馃搫
race0.go
(2.79 KB)
馃搫
race_amd64.s
(13.82 KB)
馃搫
race_arm64.s
(14.21 KB)
馃搫
race_ppc64le.s
(17.89 KB)
馃搫
race_s390x.s
(12 KB)
馃搫
rand_test.go
(907 B)
馃搫
rdebug.go
(553 B)
馃搫
relax_stub.go
(598 B)
馃搫
rt0_aix_ppc64.s
(4.33 KB)
馃搫
rt0_android_386.s
(822 B)
馃搫
rt0_android_amd64.s
(754 B)
馃搫
rt0_android_arm.s
(843 B)
馃搫
rt0_android_arm64.s
(941 B)
馃搫
rt0_darwin_amd64.s
(399 B)
馃搫
rt0_darwin_arm64.s
(1.69 KB)
馃搫
rt0_dragonfly_amd64.s
(448 B)
馃搫
rt0_freebsd_386.s
(454 B)
馃搫
rt0_freebsd_amd64.s
(442 B)
馃搫
rt0_freebsd_arm.s
(298 B)
馃搫
rt0_freebsd_arm64.s
(1.88 KB)
馃搫
rt0_illumos_amd64.s
(311 B)
馃搫
rt0_ios_amd64.s
(425 B)
馃搫
rt0_ios_arm64.s
(425 B)
馃搫
rt0_js_wasm.s
(2.3 KB)
馃搫
rt0_linux_386.s
(450 B)
馃搫
rt0_linux_amd64.s
(307 B)
馃搫
rt0_linux_arm.s
(1007 B)
馃搫
rt0_linux_arm64.s
(1.81 KB)
馃搫
rt0_linux_loong64.s
(716 B)
馃搫
rt0_linux_mips64x.s
(1014 B)
馃搫
rt0_linux_mipsx.s
(797 B)
馃搫
rt0_linux_ppc64.s
(928 B)
馃搫
rt0_linux_ppc64le.s
(4.35 KB)
馃搫
rt0_linux_riscv64.s
(2.65 KB)
馃搫
rt0_linux_s390x.s
(676 B)
馃搫
rt0_netbsd_386.s
(452 B)
馃搫
rt0_netbsd_amd64.s
(309 B)
馃搫
rt0_netbsd_arm.s
(296 B)
馃搫
rt0_netbsd_arm64.s
(1.8 KB)
馃搫
rt0_openbsd_386.s
(454 B)
馃搫
rt0_openbsd_amd64.s
(311 B)
馃搫
rt0_openbsd_arm.s
(298 B)
馃搫
rt0_openbsd_arm64.s
(1.96 KB)
馃搫
rt0_openbsd_mips64.s
(976 B)
馃搫
rt0_plan9_386.s
(523 B)
馃搫
rt0_plan9_amd64.s
(481 B)
馃搫
rt0_plan9_arm.s
(397 B)
馃搫
rt0_solaris_amd64.s
(311 B)
馃搫
rt0_windows_386.s
(1.28 KB)
馃搫
rt0_windows_amd64.s
(986 B)
馃搫
rt0_windows_arm.s
(386 B)
馃搫
rt0_windows_arm64.s
(725 B)
馃搫
runtime-gdb.py
(15.33 KB)
馃搫
runtime-gdb_test.go
(20.93 KB)
馃搫
runtime-lldb_test.go
(4.95 KB)
馃搫
runtime.go
(1.45 KB)
馃搫
runtime1.go
(13.06 KB)
馃搫
runtime2.go
(43.07 KB)
馃搫
runtime_boring.go
(606 B)
馃搫
runtime_linux_test.go
(1.95 KB)
馃搫
runtime_mmap_test.go
(1.77 KB)
馃搫
runtime_test.go
(11.79 KB)
馃搫
runtime_unix_test.go
(1.22 KB)
馃搫
rwmutex.go
(3.53 KB)
馃搫
rwmutex_test.go
(4.19 KB)
馃搫
select.go
(14.84 KB)
馃搫
sema.go
(16.16 KB)
馃搫
sema_test.go
(4.21 KB)
馃搫
semasleep_test.go
(3.05 KB)
馃搫
sigaction.go
(489 B)
馃搫
signal_386.go
(1.72 KB)
馃搫
signal_aix_ppc64.go
(3.55 KB)
馃搫
signal_amd64.go
(2.73 KB)
馃搫
signal_arm.go
(2.54 KB)
馃搫
signal_arm64.go
(3.21 KB)
馃搫
signal_darwin.go
(2.13 KB)
馃搫
signal_darwin_amd64.go
(4 KB)
馃搫
signal_darwin_arm64.go
(3.6 KB)
馃搫
signal_dragonfly.go
(2.17 KB)
馃搫
signal_dragonfly_amd64.go
(2.01 KB)
馃搫
signal_freebsd.go
(2.2 KB)
馃搫
signal_freebsd_386.go
(1.55 KB)
馃搫
signal_freebsd_amd64.go
(2.03 KB)
馃搫
signal_freebsd_arm.go
(2.18 KB)
馃搫
signal_freebsd_arm64.go
(3.23 KB)
馃搫
signal_linux_386.go
(1.59 KB)
馃搫
signal_linux_amd64.go
(2.05 KB)
馃搫
signal_linux_arm.go
(2.12 KB)
馃搫
signal_linux_arm64.go
(2.95 KB)
馃搫
signal_linux_loong64.go
(3.22 KB)
馃搫
signal_linux_mips64x.go
(3.35 KB)
馃搫
signal_linux_mipsx.go
(3.67 KB)
馃搫
signal_linux_ppc64x.go
(3.42 KB)
馃搫
signal_linux_riscv64.go
(2.92 KB)
馃搫
signal_linux_s390x.go
(4.49 KB)
馃搫
signal_loong64.go
(3.09 KB)
馃搫
signal_mips64x.go
(3.18 KB)
馃搫
signal_mipsx.go
(3.06 KB)
馃搫
signal_netbsd.go
(2.18 KB)
馃搫
signal_netbsd_386.go
(1.76 KB)
馃搫
signal_netbsd_amd64.go
(2.33 KB)
馃搫
signal_netbsd_arm.go
(2.3 KB)
馃搫
signal_netbsd_arm64.go
(3.4 KB)
馃搫
signal_openbsd.go
(2.18 KB)
馃搫
signal_openbsd_386.go
(1.58 KB)
馃搫
signal_openbsd_amd64.go
(2.04 KB)
馃搫
signal_openbsd_arm.go
(2.12 KB)
馃搫
signal_openbsd_arm64.go
(3.38 KB)
馃搫
signal_openbsd_mips64.go
(3.28 KB)
馃搫
signal_plan9.go
(1.93 KB)
馃搫
signal_ppc64x.go
(3.64 KB)
馃搫
signal_riscv64.go
(2.89 KB)
馃搫
signal_solaris.go
(4.5 KB)
馃搫
signal_solaris_amd64.go
(2.47 KB)
馃搫
signal_unix.go
(41.88 KB)
馃搫
signal_windows.go
(9.27 KB)
馃搫
signal_windows_test.go
(5.29 KB)
馃搫
sigqueue.go
(7.66 KB)
馃搫
sigqueue_note.go
(648 B)
馃搫
sigqueue_plan9.go
(3.25 KB)
馃搫
sigtab_aix.go
(11.3 KB)
馃搫
sigtab_linux_generic.go
(3.52 KB)
馃搫
sigtab_linux_mipsx.go
(5.95 KB)
馃搫
sizeclasses.go
(9.14 KB)
馃搫
sizeof_test.go
(893 B)
馃搫
slice.go
(9.87 KB)
馃搫
slice_test.go
(10.32 KB)
馃搫
softfloat64.go
(11.54 KB)
馃搫
softfloat64_test.go
(4.04 KB)
馃搫
stack.go
(45.05 KB)
馃搫
stack_test.go
(22.39 KB)
馃搫
string.go
(13.18 KB)
馃搫
string_test.go
(12.61 KB)
馃搫
stubs.go
(19.37 KB)
馃搫
stubs2.go
(1.13 KB)
馃搫
stubs3.go
(274 B)
馃搫
stubs_386.go
(550 B)
馃搫
stubs_amd64.go
(1.2 KB)
馃搫
stubs_arm.go
(531 B)
馃搫
stubs_arm64.go
(555 B)
馃搫
stubs_linux.go
(650 B)
馃搫
stubs_loong64.go
(276 B)
馃搫
stubs_mips64x.go
(364 B)
馃搫
stubs_mipsx.go
(283 B)
馃搫
stubs_nonlinux.go
(298 B)
馃搫
stubs_ppc64.go
(301 B)
馃搫
stubs_ppc64x.go
(453 B)
馃搫
stubs_riscv64.go
(460 B)
馃搫
stubs_s390x.go
(256 B)
馃搫
symtab.go
(35.81 KB)
馃搫
symtab_test.go
(7.48 KB)
馃搫
sys_aix_ppc64.s
(7.42 KB)
馃搫
sys_arm.go
(521 B)
馃搫
sys_arm64.go
(469 B)
馃搫
sys_darwin.go
(17.92 KB)
馃搫
sys_darwin_amd64.s
(19.12 KB)
馃搫
sys_darwin_arm64.go
(1.74 KB)
馃搫
sys_darwin_arm64.s
(15.95 KB)
馃搫
sys_dragonfly_amd64.s
(8.03 KB)
馃搫
sys_freebsd_386.s
(8.41 KB)
馃搫
sys_freebsd_amd64.s
(10.7 KB)
馃搫
sys_freebsd_arm.s
(10.12 KB)
馃搫
sys_freebsd_arm64.s
(9.4 KB)
馃搫
sys_libc.go
(1.84 KB)
馃搫
sys_linux_386.s
(18.31 KB)
馃搫
sys_linux_amd64.s
(16.57 KB)
馃搫
sys_linux_arm.s
(16.12 KB)
馃搫
sys_linux_arm64.s
(18.09 KB)
馃搫
sys_linux_loong64.s
(12.15 KB)
馃搫
sys_linux_mips64x.s
(13.5 KB)
馃搫
sys_linux_mipsx.s
(11.09 KB)
馃搫
sys_linux_ppc64x.s
(22.1 KB)
馃搫
sys_linux_riscv64.s
(12.59 KB)
馃搫
sys_linux_s390x.s
(13.78 KB)
馃搫
sys_loong64.go
(489 B)
馃搫
sys_mips64x.go
(500 B)
馃搫
sys_mipsx.go
(496 B)
馃搫
sys_netbsd_386.s
(9.55 KB)
馃搫
sys_netbsd_amd64.s
(9.51 KB)
馃搫
sys_netbsd_arm.s
(10.41 KB)
馃搫
sys_netbsd_arm64.s
(9.38 KB)
馃搫
sys_nonppc64x.go
(245 B)
馃搫
sys_openbsd.go
(2.59 KB)
馃搫
sys_openbsd1.go
(1.23 KB)
馃搫
sys_openbsd2.go
(8.36 KB)
馃搫
sys_openbsd3.go
(3.37 KB)
馃搫
sys_openbsd_386.s
(20.03 KB)
馃搫
sys_openbsd_amd64.s
(16.64 KB)
馃搫
sys_openbsd_arm.s
(18.15 KB)
馃搫
sys_openbsd_arm64.s
(14.84 KB)
馃搫
sys_openbsd_mips64.s
(8.6 KB)
馃搫
sys_plan9_386.s
(4.48 KB)
馃搫
sys_plan9_amd64.s
(4.55 KB)
馃搫
sys_plan9_arm.s
(7.03 KB)
馃搫
sys_ppc64x.go
(532 B)
馃搫
sys_riscv64.go
(469 B)
馃搫
sys_s390x.go
(469 B)
馃搫
sys_solaris_amd64.s
(6.42 KB)
馃搫
sys_wasm.go
(754 B)
馃搫
sys_wasm.s
(2.65 KB)
馃搫
sys_windows_386.s
(7.65 KB)
馃搫
sys_windows_amd64.s
(8.88 KB)
馃搫
sys_windows_arm.s
(11.97 KB)
馃搫
sys_windows_arm64.s
(11.45 KB)
馃搫
sys_x86.go
(552 B)
馃搫
syscall2_solaris.go
(1.65 KB)
馃搫
syscall_aix.go
(6 KB)
馃搫
syscall_solaris.go
(8.01 KB)
馃搫
syscall_windows.go
(16.95 KB)
馃搫
syscall_windows_test.go
(32.96 KB)
馃搧
testdata
馃搫
textflag.h
(1.52 KB)
馃搫
time.go
(30.75 KB)
馃搫
time_fake.go
(2.5 KB)
馃搫
time_linux_amd64.s
(2.02 KB)
馃搫
time_nofake.go
(709 B)
馃搫
time_test.go
(2.03 KB)
馃搫
time_windows.h
(753 B)
馃搫
time_windows_386.s
(1.79 KB)
馃搫
time_windows_amd64.s
(871 B)
馃搫
time_windows_arm.s
(2.1 KB)
馃搫
time_windows_arm64.s
(1021 B)
馃搫
timeasm.go
(418 B)
馃搫
timestub.go
(532 B)
馃搫
timestub2.go
(314 B)
馃搫
tls_arm.s
(3.45 KB)
馃搫
tls_arm64.h
(1.1 KB)
馃搫
tls_arm64.s
(1.2 KB)
馃搫
tls_loong64.s
(589 B)
馃搫
tls_mips64x.s
(733 B)
馃搫
tls_mipsx.s
(709 B)
馃搫
tls_ppc64x.s
(1.5 KB)
馃搫
tls_riscv64.s
(726 B)
馃搫
tls_s390x.s
(1.55 KB)
馃搫
tls_stub.go
(260 B)
馃搫
tls_windows_amd64.go
(294 B)
馃搧
trace
馃搫
trace.go
(45.8 KB)
馃搫
traceback.go
(48.18 KB)
馃搫
traceback_test.go
(11.64 KB)
馃搫
type.go
(17.43 KB)
馃搫
typekind.go
(742 B)
馃搫
utf8.go
(3.39 KB)
馃搫
vdso_elf32.go
(2.76 KB)
馃搫
vdso_elf64.go
(2.84 KB)
馃搫
vdso_freebsd.go
(2.44 KB)
馃搫
vdso_freebsd_arm.go
(454 B)
馃搫
vdso_freebsd_arm64.go
(443 B)
馃搫
vdso_freebsd_x86.go
(1.85 KB)
馃搫
vdso_in_none.go
(443 B)
馃搫
vdso_linux.go
(7.77 KB)
馃搫
vdso_linux_386.go
(669 B)
馃搫
vdso_linux_amd64.go
(685 B)
馃搫
vdso_linux_arm.go
(669 B)
馃搫
vdso_linux_arm64.go
(670 B)
馃搫
vdso_linux_loong64.go
(793 B)
馃搫
vdso_linux_mips64x.go
(850 B)
馃搫
vdso_linux_ppc64x.go
(672 B)
馃搫
vdso_linux_riscv64.go
(666 B)
馃搫
vdso_linux_s390x.go
(681 B)
馃搫
vlop_386.s
(2.02 KB)
馃搫
vlop_arm.s
(7.06 KB)
馃搫
vlop_arm_test.go
(3.75 KB)
馃搫
vlrt.go
(6.71 KB)
馃搫
wincallback.go
(3.45 KB)
馃搫
write_err.go
(291 B)
馃搫
write_err_android.go
(4.65 KB)
馃搫
zcallback_windows.go
(155 B)
馃搫
zcallback_windows.s
(63.02 KB)
馃搫
zcallback_windows_arm.s
(89.32 KB)
馃搫
zcallback_windows_arm64.s
(89.32 KB)
Editing: asm_mipsx.s
// Copyright 2016 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. //go:build mips || mipsle #include "go_asm.h" #include "go_tls.h" #include "funcdata.h" #include "textflag.h" #define REGCTXT R22 TEXT runtime路rt0_go(SB),NOSPLIT|TOPFRAME,$0 // R29 = stack; R4 = argc; R5 = argv ADDU $-12, R29 MOVW R4, 4(R29) // argc MOVW R5, 8(R29) // argv // create istack out of the given (operating system) stack. // _cgo_init may update stackguard. MOVW $runtime路g0(SB), g MOVW $(-64*1024), R23 ADD R23, R29, R1 MOVW R1, g_stackguard0(g) MOVW R1, g_stackguard1(g) MOVW R1, (g_stack+stack_lo)(g) MOVW R29, (g_stack+stack_hi)(g) // if there is a _cgo_init, call it using the gcc ABI. MOVW _cgo_init(SB), R25 BEQ R25, nocgo ADDU $-16, R29 MOVW R0, R7 // arg 3: not used MOVW R0, R6 // arg 2: not used MOVW $setg_gcc<>(SB), R5 // arg 1: setg MOVW g, R4 // arg 0: G JAL (R25) ADDU $16, R29 nocgo: // update stackguard after _cgo_init MOVW (g_stack+stack_lo)(g), R1 ADD $const__StackGuard, R1 MOVW R1, g_stackguard0(g) MOVW R1, g_stackguard1(g) // set the per-goroutine and per-mach "registers" MOVW $runtime路m0(SB), R1 // save m->g0 = g0 MOVW g, m_g0(R1) // save m0 to g0->m MOVW R1, g_m(g) JAL runtime路check(SB) // args are already prepared JAL runtime路args(SB) JAL runtime路osinit(SB) JAL runtime路schedinit(SB) // create a new goroutine to start program MOVW $runtime路mainPC(SB), R1 // entry ADDU $-8, R29 MOVW R1, 4(R29) MOVW R0, 0(R29) JAL runtime路newproc(SB) ADDU $8, R29 // start this M JAL runtime路mstart(SB) UNDEF RET DATA runtime路mainPC+0(SB)/4,$runtime路main(SB) GLOBL runtime路mainPC(SB),RODATA,$4 TEXT runtime路breakpoint(SB),NOSPLIT,$0-0 BREAK RET TEXT runtime路asminit(SB),NOSPLIT,$0-0 RET TEXT runtime路mstart(SB),NOSPLIT|TOPFRAME,$0 JAL runtime路mstart0(SB) RET // not reached /* * go-routine */ // void gogo(Gobuf*) // restore state from Gobuf; longjmp TEXT runtime路gogo(SB),NOSPLIT|NOFRAME,$0-4 MOVW buf+0(FP), R3 MOVW gobuf_g(R3), R4 MOVW 0(R4), R5 // make sure g != nil JMP gogo<>(SB) TEXT gogo<>(SB),NOSPLIT|NOFRAME,$0 MOVW R4, g JAL runtime路save_g(SB) MOVW gobuf_sp(R3), R29 MOVW gobuf_lr(R3), R31 MOVW gobuf_ret(R3), R1 MOVW gobuf_ctxt(R3), REGCTXT MOVW R0, gobuf_sp(R3) MOVW R0, gobuf_ret(R3) MOVW R0, gobuf_lr(R3) MOVW R0, gobuf_ctxt(R3) MOVW gobuf_pc(R3), R4 JMP (R4) // void mcall(fn func(*g)) // Switch to m->g0's stack, call fn(g). // Fn must never return. It should gogo(&g->sched) // to keep running g. TEXT runtime路mcall(SB),NOSPLIT|NOFRAME,$0-4 // Save caller state in g->sched MOVW R29, (g_sched+gobuf_sp)(g) MOVW R31, (g_sched+gobuf_pc)(g) MOVW R0, (g_sched+gobuf_lr)(g) // Switch to m->g0 & its stack, call fn. MOVW g, R1 MOVW g_m(g), R3 MOVW m_g0(R3), g JAL runtime路save_g(SB) BNE g, R1, 2(PC) JMP runtime路badmcall(SB) MOVW fn+0(FP), REGCTXT // context MOVW 0(REGCTXT), R4 // code pointer MOVW (g_sched+gobuf_sp)(g), R29 // sp = m->g0->sched.sp ADDU $-8, R29 // make room for 1 arg and fake LR MOVW R1, 4(R29) MOVW R0, 0(R29) JAL (R4) JMP runtime路badmcall2(SB) // systemstack_switch is a dummy routine that systemstack leaves at the bottom // of the G stack. We need to distinguish the routine that // lives at the bottom of the G stack from the one that lives // at the top of the system stack because the one at the top of // the system stack terminates the stack walk (see topofstack()). TEXT runtime路systemstack_switch(SB),NOSPLIT,$0-0 UNDEF JAL (R31) // make sure this function is not leaf RET // func systemstack(fn func()) TEXT runtime路systemstack(SB),NOSPLIT,$0-4 MOVW fn+0(FP), R1 // R1 = fn MOVW R1, REGCTXT // context MOVW g_m(g), R2 // R2 = m MOVW m_gsignal(R2), R3 // R3 = gsignal BEQ g, R3, noswitch MOVW m_g0(R2), R3 // R3 = g0 BEQ g, R3, noswitch MOVW m_curg(R2), R4 BEQ g, R4, switch // Bad: g is not gsignal, not g0, not curg. What is it? // Hide call from linker nosplit analysis. MOVW $runtime路badsystemstack(SB), R4 JAL (R4) JAL runtime路abort(SB) switch: // save our state in g->sched. Pretend to // be systemstack_switch if the G stack is scanned. JAL gosave_systemstack_switch<>(SB) // switch to g0 MOVW R3, g JAL runtime路save_g(SB) MOVW (g_sched+gobuf_sp)(g), R1 MOVW R1, R29 // call target function MOVW 0(REGCTXT), R4 // code pointer JAL (R4) // switch back to g MOVW g_m(g), R1 MOVW m_curg(R1), g JAL runtime路save_g(SB) MOVW (g_sched+gobuf_sp)(g), R29 MOVW R0, (g_sched+gobuf_sp)(g) RET noswitch: // already on m stack, just call directly // Using a tail call here cleans up tracebacks since we won't stop // at an intermediate systemstack. MOVW 0(REGCTXT), R4 // code pointer MOVW 0(R29), R31 // restore LR ADD $4, R29 JMP (R4) /* * support for morestack */ // Called during function prolog when more stack is needed. // Caller has already loaded: // R1: framesize, R2: argsize, R3: LR // // The traceback routines see morestack on a g0 as being // the top of a stack (for example, morestack calling newstack // calling the scheduler calling newm calling gc), so we must // record an argument size. For that purpose, it has no arguments. TEXT runtime路morestack(SB),NOSPLIT|NOFRAME,$0-0 // Cannot grow scheduler stack (m->g0). MOVW g_m(g), R7 MOVW m_g0(R7), R8 BNE g, R8, 3(PC) JAL runtime路badmorestackg0(SB) JAL runtime路abort(SB) // Cannot grow signal stack (m->gsignal). MOVW m_gsignal(R7), R8 BNE g, R8, 3(PC) JAL runtime路badmorestackgsignal(SB) JAL runtime路abort(SB) // Called from f. // Set g->sched to context in f. MOVW R29, (g_sched+gobuf_sp)(g) MOVW R31, (g_sched+gobuf_pc)(g) MOVW R3, (g_sched+gobuf_lr)(g) MOVW REGCTXT, (g_sched+gobuf_ctxt)(g) // Called from f. // Set m->morebuf to f's caller. MOVW R3, (m_morebuf+gobuf_pc)(R7) // f's caller's PC MOVW R29, (m_morebuf+gobuf_sp)(R7) // f's caller's SP MOVW g, (m_morebuf+gobuf_g)(R7) // Call newstack on m->g0's stack. MOVW m_g0(R7), g JAL runtime路save_g(SB) MOVW (g_sched+gobuf_sp)(g), R29 // Create a stack frame on g0 to call newstack. MOVW R0, -4(R29) // Zero saved LR in frame ADDU $-4, R29 JAL runtime路newstack(SB) // Not reached, but make sure the return PC from the call to newstack // is still in this function, and not the beginning of the next. UNDEF TEXT runtime路morestack_noctxt(SB),NOSPLIT,$0-0 // Force SPWRITE. This function doesn't actually write SP, // but it is called with a special calling convention where // the caller doesn't save LR on stack but passes it as a // register (R3), and the unwinder currently doesn't understand. // Make it SPWRITE to stop unwinding. (See issue 54332) MOVW R29, R29 MOVW R0, REGCTXT JMP runtime路morestack(SB) // reflectcall: call a function with the given argument list // func call(stackArgsType *_type, f *FuncVal, stackArgs *byte, stackArgsSize, stackRetOffset, frameSize uint32, regArgs *abi.RegArgs). // we don't have variable-sized frames, so we use a small number // of constant-sized-frame functions to encode a few bits of size in the pc. #define DISPATCH(NAME,MAXSIZE) \ MOVW $MAXSIZE, R23; \ SGTU R1, R23, R23; \ BNE R23, 3(PC); \ MOVW $NAME(SB), R4; \ JMP (R4) TEXT 路reflectcall(SB),NOSPLIT|NOFRAME,$0-28 MOVW frameSize+20(FP), R1 DISPATCH(runtime路call16, 16) DISPATCH(runtime路call32, 32) DISPATCH(runtime路call64, 64) DISPATCH(runtime路call128, 128) DISPATCH(runtime路call256, 256) DISPATCH(runtime路call512, 512) DISPATCH(runtime路call1024, 1024) DISPATCH(runtime路call2048, 2048) DISPATCH(runtime路call4096, 4096) DISPATCH(runtime路call8192, 8192) DISPATCH(runtime路call16384, 16384) DISPATCH(runtime路call32768, 32768) DISPATCH(runtime路call65536, 65536) DISPATCH(runtime路call131072, 131072) DISPATCH(runtime路call262144, 262144) DISPATCH(runtime路call524288, 524288) DISPATCH(runtime路call1048576, 1048576) DISPATCH(runtime路call2097152, 2097152) DISPATCH(runtime路call4194304, 4194304) DISPATCH(runtime路call8388608, 8388608) DISPATCH(runtime路call16777216, 16777216) DISPATCH(runtime路call33554432, 33554432) DISPATCH(runtime路call67108864, 67108864) DISPATCH(runtime路call134217728, 134217728) DISPATCH(runtime路call268435456, 268435456) DISPATCH(runtime路call536870912, 536870912) DISPATCH(runtime路call1073741824, 1073741824) MOVW $runtime路badreflectcall(SB), R4 JMP (R4) #define CALLFN(NAME,MAXSIZE) \ TEXT NAME(SB),WRAPPER,$MAXSIZE-28; \ NO_LOCAL_POINTERS; \ /* copy arguments to stack */ \ MOVW stackArgs+8(FP), R1; \ MOVW stackArgsSize+12(FP), R2; \ MOVW R29, R3; \ ADDU $4, R3; \ ADDU R3, R2; \ BEQ R3, R2, 6(PC); \ MOVBU (R1), R4; \ ADDU $1, R1; \ MOVBU R4, (R3); \ ADDU $1, R3; \ JMP -5(PC); \ /* call function */ \ MOVW f+4(FP), REGCTXT; \ MOVW (REGCTXT), R4; \ PCDATA $PCDATA_StackMapIndex, $0; \ JAL (R4); \ /* copy return values back */ \ MOVW stackArgsType+0(FP), R5; \ MOVW stackArgs+8(FP), R1; \ MOVW stackArgsSize+12(FP), R2; \ MOVW stackRetOffset+16(FP), R4; \ ADDU $4, R29, R3; \ ADDU R4, R3; \ ADDU R4, R1; \ SUBU R4, R2; \ JAL callRet<>(SB); \ RET // callRet copies return values back at the end of call*. This is a // separate function so it can allocate stack space for the arguments // to reflectcallmove. It does not follow the Go ABI; it expects its // arguments in registers. TEXT callRet<>(SB), NOSPLIT, $20-0 MOVW R5, 4(R29) MOVW R1, 8(R29) MOVW R3, 12(R29) MOVW R2, 16(R29) MOVW $0, 20(R29) JAL runtime路reflectcallmove(SB) RET CALLFN(路call16, 16) CALLFN(路call32, 32) CALLFN(路call64, 64) CALLFN(路call128, 128) CALLFN(路call256, 256) CALLFN(路call512, 512) CALLFN(路call1024, 1024) CALLFN(路call2048, 2048) CALLFN(路call4096, 4096) CALLFN(路call8192, 8192) CALLFN(路call16384, 16384) CALLFN(路call32768, 32768) CALLFN(路call65536, 65536) CALLFN(路call131072, 131072) CALLFN(路call262144, 262144) CALLFN(路call524288, 524288) CALLFN(路call1048576, 1048576) CALLFN(路call2097152, 2097152) CALLFN(路call4194304, 4194304) CALLFN(路call8388608, 8388608) CALLFN(路call16777216, 16777216) CALLFN(路call33554432, 33554432) CALLFN(路call67108864, 67108864) CALLFN(路call134217728, 134217728) CALLFN(路call268435456, 268435456) CALLFN(路call536870912, 536870912) CALLFN(路call1073741824, 1073741824) TEXT runtime路procyield(SB),NOSPLIT,$0-4 RET // Save state of caller into g->sched, // but using fake PC from systemstack_switch. // Must only be called from functions with no locals ($0) // or else unwinding from systemstack_switch is incorrect. // Smashes R1. TEXT gosave_systemstack_switch<>(SB),NOSPLIT|NOFRAME,$0 MOVW $runtime路systemstack_switch(SB), R1 ADDU $8, R1 // get past prologue MOVW R1, (g_sched+gobuf_pc)(g) MOVW R29, (g_sched+gobuf_sp)(g) MOVW R0, (g_sched+gobuf_lr)(g) MOVW R0, (g_sched+gobuf_ret)(g) // Assert ctxt is zero. See func save. MOVW (g_sched+gobuf_ctxt)(g), R1 BEQ R1, 2(PC) JAL runtime路abort(SB) RET // func asmcgocall(fn, arg unsafe.Pointer) int32 // Call fn(arg) on the scheduler stack, // aligned appropriately for the gcc ABI. // See cgocall.go for more details. TEXT 路asmcgocall(SB),NOSPLIT,$0-12 MOVW fn+0(FP), R25 MOVW arg+4(FP), R4 MOVW R29, R3 // save original stack pointer MOVW g, R2 // Figure out if we need to switch to m->g0 stack. // We get called to create new OS threads too, and those // come in on the m->g0 stack already. Or we might already // be on the m->gsignal stack. MOVW g_m(g), R5 MOVW m_gsignal(R5), R6 BEQ R6, g, g0 MOVW m_g0(R5), R6 BEQ R6, g, g0 JAL gosave_systemstack_switch<>(SB) MOVW R6, g JAL runtime路save_g(SB) MOVW (g_sched+gobuf_sp)(g), R29 // Now on a scheduling stack (a pthread-created stack). g0: // Save room for two of our pointers and O32 frame. ADDU $-24, R29 AND $~7, R29 // O32 ABI expects 8-byte aligned stack on function entry MOVW R2, 16(R29) // save old g on stack MOVW (g_stack+stack_hi)(R2), R2 SUBU R3, R2 MOVW R2, 20(R29) // save depth in old g stack (can't just save SP, as stack might be copied during a callback) JAL (R25) // Restore g, stack pointer. R2 is return value. MOVW 16(R29), g JAL runtime路save_g(SB) MOVW (g_stack+stack_hi)(g), R5 MOVW 20(R29), R6 SUBU R6, R5 MOVW R5, R29 MOVW R2, ret+8(FP) RET // cgocallback(fn, frame unsafe.Pointer, ctxt uintptr) // See cgocall.go for more details. TEXT 路cgocallback(SB),NOSPLIT,$12-12 NO_LOCAL_POINTERS // Load m and g from thread-local storage. MOVB runtime路iscgo(SB), R1 BEQ R1, nocgo JAL runtime路load_g(SB) nocgo: // If g is nil, Go did not create the current thread. // Call needm to obtain one for temporary use. // In this case, we're running on the thread stack, so there's // lots of space, but the linker doesn't know. Hide the call from // the linker analysis by using an indirect call. BEQ g, needm MOVW g_m(g), R3 MOVW R3, savedm-4(SP) JMP havem needm: MOVW g, savedm-4(SP) // g is zero, so is m. MOVW $runtime路needm(SB), R4 JAL (R4) // Set m->sched.sp = SP, so that if a panic happens // during the function we are about to execute, it will // have a valid SP to run on the g0 stack. // The next few lines (after the havem label) // will save this SP onto the stack and then write // the same SP back to m->sched.sp. That seems redundant, // but if an unrecovered panic happens, unwindm will // restore the g->sched.sp from the stack location // and then systemstack will try to use it. If we don't set it here, // that restored SP will be uninitialized (typically 0) and // will not be usable. MOVW g_m(g), R3 MOVW m_g0(R3), R1 MOVW R29, (g_sched+gobuf_sp)(R1) havem: // Now there's a valid m, and we're running on its m->g0. // Save current m->g0->sched.sp on stack and then set it to SP. // Save current sp in m->g0->sched.sp in preparation for // switch back to m->curg stack. // NOTE: unwindm knows that the saved g->sched.sp is at 4(R29) aka savedsp-8(SP). MOVW m_g0(R3), R1 MOVW (g_sched+gobuf_sp)(R1), R2 MOVW R2, savedsp-12(SP) // must match frame size MOVW R29, (g_sched+gobuf_sp)(R1) // Switch to m->curg stack and call runtime.cgocallbackg. // Because we are taking over the execution of m->curg // but *not* resuming what had been running, we need to // save that information (m->curg->sched) so we can restore it. // We can restore m->curg->sched.sp easily, because calling // runtime.cgocallbackg leaves SP unchanged upon return. // To save m->curg->sched.pc, we push it onto the curg stack and // open a frame the same size as cgocallback's g0 frame. // Once we switch to the curg stack, the pushed PC will appear // to be the return PC of cgocallback, so that the traceback // will seamlessly trace back into the earlier calls. MOVW m_curg(R3), g JAL runtime路save_g(SB) MOVW (g_sched+gobuf_sp)(g), R2 // prepare stack as R2 MOVW (g_sched+gobuf_pc)(g), R4 MOVW R4, -(12+4)(R2) // "saved LR"; must match frame size // Gather our arguments into registers. MOVW fn+0(FP), R5 MOVW frame+4(FP), R6 MOVW ctxt+8(FP), R7 MOVW $-(12+4)(R2), R29 // switch stack; must match frame size MOVW R5, 4(R29) MOVW R6, 8(R29) MOVW R7, 12(R29) JAL runtime路cgocallbackg(SB) // Restore g->sched (== m->curg->sched) from saved values. MOVW 0(R29), R4 MOVW R4, (g_sched+gobuf_pc)(g) MOVW $(12+4)(R29), R2 // must match frame size MOVW R2, (g_sched+gobuf_sp)(g) // Switch back to m->g0's stack and restore m->g0->sched.sp. // (Unlike m->curg, the g0 goroutine never uses sched.pc, // so we do not have to restore it.) MOVW g_m(g), R3 MOVW m_g0(R3), g JAL runtime路save_g(SB) MOVW (g_sched+gobuf_sp)(g), R29 MOVW savedsp-12(SP), R2 // must match frame size MOVW R2, (g_sched+gobuf_sp)(g) // If the m on entry was nil, we called needm above to borrow an m // for the duration of the call. Since the call is over, return it with dropm. MOVW savedm-4(SP), R3 BNE R3, droppedm MOVW $runtime路dropm(SB), R4 JAL (R4) droppedm: // Done! RET // void setg(G*); set g. for use by needm. // This only happens if iscgo, so jump straight to save_g TEXT runtime路setg(SB),NOSPLIT,$0-4 MOVW gg+0(FP), g JAL runtime路save_g(SB) RET // void setg_gcc(G*); set g in C TLS. // Must obey the gcc calling convention. TEXT setg_gcc<>(SB),NOSPLIT,$0 MOVW R4, g JAL runtime路save_g(SB) RET TEXT runtime路abort(SB),NOSPLIT,$0-0 UNDEF // AES hashing not implemented for mips TEXT runtime路memhash(SB),NOSPLIT|NOFRAME,$0-16 JMP runtime路memhashFallback(SB) TEXT runtime路strhash(SB),NOSPLIT|NOFRAME,$0-12 JMP runtime路strhashFallback(SB) TEXT runtime路memhash32(SB),NOSPLIT|NOFRAME,$0-12 JMP runtime路memhash32Fallback(SB) TEXT runtime路memhash64(SB),NOSPLIT|NOFRAME,$0-12 JMP runtime路memhash64Fallback(SB) TEXT runtime路return0(SB),NOSPLIT,$0 MOVW $0, R1 RET // Called from cgo wrappers, this function returns g->m->curg.stack.hi. // Must obey the gcc calling convention. TEXT _cgo_topofstack(SB),NOSPLIT|NOFRAME,$0 // g (R30), R3 and REGTMP (R23) might be clobbered by load_g. R30 and R23 // are callee-save in the gcc calling convention, so save them. MOVW R23, R8 MOVW g, R9 MOVW R31, R10 // this call frame does not save LR JAL runtime路load_g(SB) MOVW g_m(g), R1 MOVW m_curg(R1), R1 MOVW (g_stack+stack_hi)(R1), R2 // return value in R2 MOVW R8, R23 MOVW R9, g MOVW R10, R31 RET // The top-most function running on a goroutine // returns to goexit+PCQuantum. TEXT runtime路goexit(SB),NOSPLIT|NOFRAME|TOPFRAME,$0-0 NOR R0, R0 // NOP JAL runtime路goexit1(SB) // does not return // traceback from goexit1 must hit code range of goexit NOR R0, R0 // NOP TEXT 路checkASM(SB),NOSPLIT,$0-1 MOVW $1, R1 MOVB R1, ret+0(FP) RET // gcWriteBarrier performs a heap pointer write and informs the GC. // // gcWriteBarrier does NOT follow the Go ABI. It takes two arguments: // - R20 is the destination of the write // - R21 is the value being written at R20. // It clobbers R23 (the linker temp register). // The act of CALLing gcWriteBarrier will clobber R31 (LR). // It does not clobber any other general-purpose registers, // but may clobber others (e.g., floating point registers). TEXT runtime路gcWriteBarrier(SB),NOSPLIT,$104 // Save the registers clobbered by the fast path. MOVW R1, 100(R29) MOVW R2, 104(R29) MOVW g_m(g), R1 MOVW m_p(R1), R1 MOVW (p_wbBuf+wbBuf_next)(R1), R2 // Increment wbBuf.next position. ADD $8, R2 MOVW R2, (p_wbBuf+wbBuf_next)(R1) MOVW (p_wbBuf+wbBuf_end)(R1), R1 MOVW R1, R23 // R23 is linker temp register // Record the write. MOVW R21, -8(R2) // Record value MOVW (R20), R1 // TODO: This turns bad writes into bad reads. MOVW R1, -4(R2) // Record *slot // Is the buffer full? BEQ R2, R23, flush ret: MOVW 100(R29), R1 MOVW 104(R29), R2 // Do the write. MOVW R21, (R20) RET flush: // Save all general purpose registers since these could be // clobbered by wbBufFlush and were not saved by the caller. MOVW R20, 4(R29) // Also first argument to wbBufFlush MOVW R21, 8(R29) // Also second argument to wbBufFlush // R1 already saved // R2 already saved MOVW R3, 12(R29) MOVW R4, 16(R29) MOVW R5, 20(R29) MOVW R6, 24(R29) MOVW R7, 28(R29) MOVW R8, 32(R29) MOVW R9, 36(R29) MOVW R10, 40(R29) MOVW R11, 44(R29) MOVW R12, 48(R29) MOVW R13, 52(R29) MOVW R14, 56(R29) MOVW R15, 60(R29) MOVW R16, 64(R29) MOVW R17, 68(R29) MOVW R18, 72(R29) MOVW R19, 76(R29) MOVW R20, 80(R29) // R21 already saved // R22 already saved. MOVW R22, 84(R29) // R23 is tmp register. MOVW R24, 88(R29) MOVW R25, 92(R29) // R26 is reserved by kernel. // R27 is reserved by kernel. MOVW R28, 96(R29) // R29 is SP. // R30 is g. // R31 is LR, which was saved by the prologue. // This takes arguments R20 and R21. CALL runtime路wbBufFlush(SB) MOVW 4(R29), R20 MOVW 8(R29), R21 MOVW 12(R29), R3 MOVW 16(R29), R4 MOVW 20(R29), R5 MOVW 24(R29), R6 MOVW 28(R29), R7 MOVW 32(R29), R8 MOVW 36(R29), R9 MOVW 40(R29), R10 MOVW 44(R29), R11 MOVW 48(R29), R12 MOVW 52(R29), R13 MOVW 56(R29), R14 MOVW 60(R29), R15 MOVW 64(R29), R16 MOVW 68(R29), R17 MOVW 72(R29), R18 MOVW 76(R29), R19 MOVW 80(R29), R20 MOVW 84(R29), R22 MOVW 88(R29), R24 MOVW 92(R29), R25 MOVW 96(R29), R28 JMP ret // Note: these functions use a special calling convention to save generated code space. // Arguments are passed in registers, but the space for those arguments are allocated // in the caller's stack frame. These stubs write the args into that stack space and // then tail call to the corresponding runtime handler. // The tail call makes these stubs disappear in backtraces. TEXT runtime路panicIndex(SB),NOSPLIT,$0-8 MOVW R1, x+0(FP) MOVW R2, y+4(FP) JMP runtime路goPanicIndex(SB) TEXT runtime路panicIndexU(SB),NOSPLIT,$0-8 MOVW R1, x+0(FP) MOVW R2, y+4(FP) JMP runtime路goPanicIndexU(SB) TEXT runtime路panicSliceAlen(SB),NOSPLIT,$0-8 MOVW R2, x+0(FP) MOVW R3, y+4(FP) JMP runtime路goPanicSliceAlen(SB) TEXT runtime路panicSliceAlenU(SB),NOSPLIT,$0-8 MOVW R2, x+0(FP) MOVW R3, y+4(FP) JMP runtime路goPanicSliceAlenU(SB) TEXT runtime路panicSliceAcap(SB),NOSPLIT,$0-8 MOVW R2, x+0(FP) MOVW R3, y+4(FP) JMP runtime路goPanicSliceAcap(SB) TEXT runtime路panicSliceAcapU(SB),NOSPLIT,$0-8 MOVW R2, x+0(FP) MOVW R3, y+4(FP) JMP runtime路goPanicSliceAcapU(SB) TEXT runtime路panicSliceB(SB),NOSPLIT,$0-8 MOVW R1, x+0(FP) MOVW R2, y+4(FP) JMP runtime路goPanicSliceB(SB) TEXT runtime路panicSliceBU(SB),NOSPLIT,$0-8 MOVW R1, x+0(FP) MOVW R2, y+4(FP) JMP runtime路goPanicSliceBU(SB) TEXT runtime路panicSlice3Alen(SB),NOSPLIT,$0-8 MOVW R3, x+0(FP) MOVW R4, y+4(FP) JMP runtime路goPanicSlice3Alen(SB) TEXT runtime路panicSlice3AlenU(SB),NOSPLIT,$0-8 MOVW R3, x+0(FP) MOVW R4, y+4(FP) JMP runtime路goPanicSlice3AlenU(SB) TEXT runtime路panicSlice3Acap(SB),NOSPLIT,$0-8 MOVW R3, x+0(FP) MOVW R4, y+4(FP) JMP runtime路goPanicSlice3Acap(SB) TEXT runtime路panicSlice3AcapU(SB),NOSPLIT,$0-8 MOVW R3, x+0(FP) MOVW R4, y+4(FP) JMP runtime路goPanicSlice3AcapU(SB) TEXT runtime路panicSlice3B(SB),NOSPLIT,$0-8 MOVW R2, x+0(FP) MOVW R3, y+4(FP) JMP runtime路goPanicSlice3B(SB) TEXT runtime路panicSlice3BU(SB),NOSPLIT,$0-8 MOVW R2, x+0(FP) MOVW R3, y+4(FP) JMP runtime路goPanicSlice3BU(SB) TEXT runtime路panicSlice3C(SB),NOSPLIT,$0-8 MOVW R1, x+0(FP) MOVW R2, y+4(FP) JMP runtime路goPanicSlice3C(SB) TEXT runtime路panicSlice3CU(SB),NOSPLIT,$0-8 MOVW R1, x+0(FP) MOVW R2, y+4(FP) JMP runtime路goPanicSlice3CU(SB) TEXT runtime路panicSliceConvert(SB),NOSPLIT,$0-8 MOVW R3, x+0(FP) MOVW R4, y+4(FP) JMP runtime路goPanicSliceConvert(SB) // Extended versions for 64-bit indexes. TEXT runtime路panicExtendIndex(SB),NOSPLIT,$0-12 MOVW R5, hi+0(FP) MOVW R1, lo+4(FP) MOVW R2, y+8(FP) JMP runtime路goPanicExtendIndex(SB) TEXT runtime路panicExtendIndexU(SB),NOSPLIT,$0-12 MOVW R5, hi+0(FP) MOVW R1, lo+4(FP) MOVW R2, y+8(FP) JMP runtime路goPanicExtendIndexU(SB) TEXT runtime路panicExtendSliceAlen(SB),NOSPLIT,$0-12 MOVW R5, hi+0(FP) MOVW R2, lo+4(FP) MOVW R3, y+8(FP) JMP runtime路goPanicExtendSliceAlen(SB) TEXT runtime路panicExtendSliceAlenU(SB),NOSPLIT,$0-12 MOVW R5, hi+0(FP) MOVW R2, lo+4(FP) MOVW R3, y+8(FP) JMP runtime路goPanicExtendSliceAlenU(SB) TEXT runtime路panicExtendSliceAcap(SB),NOSPLIT,$0-12 MOVW R5, hi+0(FP) MOVW R2, lo+4(FP) MOVW R3, y+8(FP) JMP runtime路goPanicExtendSliceAcap(SB) TEXT runtime路panicExtendSliceAcapU(SB),NOSPLIT,$0-12 MOVW R5, hi+0(FP) MOVW R2, lo+4(FP) MOVW R3, y+8(FP) JMP runtime路goPanicExtendSliceAcapU(SB) TEXT runtime路panicExtendSliceB(SB),NOSPLIT,$0-12 MOVW R5, hi+0(FP) MOVW R1, lo+4(FP) MOVW R2, y+8(FP) JMP runtime路goPanicExtendSliceB(SB) TEXT runtime路panicExtendSliceBU(SB),NOSPLIT,$0-12 MOVW R5, hi+0(FP) MOVW R1, lo+4(FP) MOVW R2, y+8(FP) JMP runtime路goPanicExtendSliceBU(SB) TEXT runtime路panicExtendSlice3Alen(SB),NOSPLIT,$0-12 MOVW R5, hi+0(FP) MOVW R3, lo+4(FP) MOVW R4, y+8(FP) JMP runtime路goPanicExtendSlice3Alen(SB) TEXT runtime路panicExtendSlice3AlenU(SB),NOSPLIT,$0-12 MOVW R5, hi+0(FP) MOVW R3, lo+4(FP) MOVW R4, y+8(FP) JMP runtime路goPanicExtendSlice3AlenU(SB) TEXT runtime路panicExtendSlice3Acap(SB),NOSPLIT,$0-12 MOVW R5, hi+0(FP) MOVW R3, lo+4(FP) MOVW R4, y+8(FP) JMP runtime路goPanicExtendSlice3Acap(SB) TEXT runtime路panicExtendSlice3AcapU(SB),NOSPLIT,$0-12 MOVW R5, hi+0(FP) MOVW R3, lo+4(FP) MOVW R4, y+8(FP) JMP runtime路goPanicExtendSlice3AcapU(SB) TEXT runtime路panicExtendSlice3B(SB),NOSPLIT,$0-12 MOVW R5, hi+0(FP) MOVW R2, lo+4(FP) MOVW R3, y+8(FP) JMP runtime路goPanicExtendSlice3B(SB) TEXT runtime路panicExtendSlice3BU(SB),NOSPLIT,$0-12 MOVW R5, hi+0(FP) MOVW R2, lo+4(FP) MOVW R3, y+8(FP) JMP runtime路goPanicExtendSlice3BU(SB) TEXT runtime路panicExtendSlice3C(SB),NOSPLIT,$0-12 MOVW R5, hi+0(FP) MOVW R1, lo+4(FP) MOVW R2, y+8(FP) JMP runtime路goPanicExtendSlice3C(SB) TEXT runtime路panicExtendSlice3CU(SB),NOSPLIT,$0-12 MOVW R5, hi+0(FP) MOVW R1, lo+4(FP) MOVW R2, y+8(FP) JMP runtime路goPanicExtendSlice3CU(SB)
Upload File
Create Folder