Documentation
¶
Overview ¶
Package psx provides support for system calls that are run simultanously on all pthreads.
This property can be used to work around a lack of native Go support for such a feature. Something that is the subject of:
https://github.com/golang/go/issues/1435
The package works via CGo wrappers for system call functions that call the C [lib]psx functions of these names. This ensures that the system calls execute simultaneously on all the pthreads of the Go (and CGo) combined runtime. Since Go's runtime freely migrates code execution between pthreads, support of this type is required for any successful attempt to fully drop or modify user privilege of a Go program under Linux. More info on how privilege works can be found here:
https://sites.google.com/site/fullycapable
Correct compilation of this package may require an extra step:
If your Go compiler is older than go1.15, a workaround may be required to be able to link this package. In order to do what it needs to, this package employs some unusual linking flags. You will need to do this for any Go toolchain that that does not include this patch:
https://go-review.googlesource.com/c/go/+/236139/
As of the time of writing, that is all release tags prior to go1.15rc1 .
The workaround is to build with the following CGO_LDFLAGS_ALLOW in effect:
export CGO_LDFLAGS_ALLOW="-Wl,-?-wrap[=,][^-.@][^,]*"
------------------------------------------------------------------ Copyright (c) 2019,20 Andrew G. Morgan <morgan@kernel.org>
The psx package is licensed with a (you choose) BSD 3-clause or GPL2. See LICENSE file for details.
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func Syscall3 ¶
Syscall3 performs a 3 argument syscall using the libpsx C function psx_syscall3(). Syscall3 differs from syscall.[Raw]Syscall() insofar as it is simultaneously executed on every pthread of the combined Go and CGo runtimes.
func Syscall6 ¶
func Syscall6(syscallnr, arg1, arg2, arg3, arg4, arg5, arg6 uintptr) (uintptr, uintptr, syscall.Errno)
Syscall6 performs a 6 argument syscall using the libpsx C function psx_syscall6(). Syscall6 differs from syscall.[Raw]Syscall6() insofar as it is simultaneously executed on every pthread of the combined Go and CGo runtimes.
Types ¶
This section is empty.
Source Files
¶
- psx.go