merge branch 'pr-1475'
Add support for mips/mips64 Put signalMap in a separate file, so it may be arch-specific LGTMs: @crosbymichael @cyphar Closes #1475
This commit is contained in:
commit
d2ac52fe52
40
kill.go
40
kill.go
|
@ -8,49 +8,9 @@ import (
|
||||||
"strings"
|
"strings"
|
||||||
"syscall"
|
"syscall"
|
||||||
|
|
||||||
"golang.org/x/sys/unix"
|
|
||||||
|
|
||||||
"github.com/urfave/cli"
|
"github.com/urfave/cli"
|
||||||
)
|
)
|
||||||
|
|
||||||
var signalMap = map[string]syscall.Signal{
|
|
||||||
"ABRT": unix.SIGABRT,
|
|
||||||
"ALRM": unix.SIGALRM,
|
|
||||||
"BUS": unix.SIGBUS,
|
|
||||||
"CHLD": unix.SIGCHLD,
|
|
||||||
"CLD": unix.SIGCLD,
|
|
||||||
"CONT": unix.SIGCONT,
|
|
||||||
"FPE": unix.SIGFPE,
|
|
||||||
"HUP": unix.SIGHUP,
|
|
||||||
"ILL": unix.SIGILL,
|
|
||||||
"INT": unix.SIGINT,
|
|
||||||
"IO": unix.SIGIO,
|
|
||||||
"IOT": unix.SIGIOT,
|
|
||||||
"KILL": unix.SIGKILL,
|
|
||||||
"PIPE": unix.SIGPIPE,
|
|
||||||
"POLL": unix.SIGPOLL,
|
|
||||||
"PROF": unix.SIGPROF,
|
|
||||||
"PWR": unix.SIGPWR,
|
|
||||||
"QUIT": unix.SIGQUIT,
|
|
||||||
"SEGV": unix.SIGSEGV,
|
|
||||||
"STKFLT": unix.SIGSTKFLT,
|
|
||||||
"STOP": unix.SIGSTOP,
|
|
||||||
"SYS": unix.SIGSYS,
|
|
||||||
"TERM": unix.SIGTERM,
|
|
||||||
"TRAP": unix.SIGTRAP,
|
|
||||||
"TSTP": unix.SIGTSTP,
|
|
||||||
"TTIN": unix.SIGTTIN,
|
|
||||||
"TTOU": unix.SIGTTOU,
|
|
||||||
"UNUSED": unix.SIGUNUSED,
|
|
||||||
"URG": unix.SIGURG,
|
|
||||||
"USR1": unix.SIGUSR1,
|
|
||||||
"USR2": unix.SIGUSR2,
|
|
||||||
"VTALRM": unix.SIGVTALRM,
|
|
||||||
"WINCH": unix.SIGWINCH,
|
|
||||||
"XCPU": unix.SIGXCPU,
|
|
||||||
"XFSZ": unix.SIGXFSZ,
|
|
||||||
}
|
|
||||||
|
|
||||||
var killCommand = cli.Command{
|
var killCommand = cli.Command{
|
||||||
Name: "kill",
|
Name: "kill",
|
||||||
Usage: "kill sends the specified signal (default: SIGTERM) to the container's init process",
|
Usage: "kill sends the specified signal (default: SIGTERM) to the container's init process",
|
||||||
|
|
|
@ -0,0 +1,25 @@
|
||||||
|
// +build linux,mips linux,mipsle linux,mips64 linux,mips64le
|
||||||
|
|
||||||
|
package system
|
||||||
|
|
||||||
|
import (
|
||||||
|
"syscall"
|
||||||
|
)
|
||||||
|
|
||||||
|
// Setuid sets the uid of the calling thread to the specified uid.
|
||||||
|
func Setuid(uid int) (err error) {
|
||||||
|
_, _, e1 := syscall.RawSyscall(syscall.SYS_SETUID, uintptr(uid), 0, 0)
|
||||||
|
if e1 != 0 {
|
||||||
|
err = e1
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// Setgid sets the gid of the calling thread to the specified gid.
|
||||||
|
func Setgid(gid int) (err error) {
|
||||||
|
_, _, e1 := syscall.RawSyscall(syscall.SYS_SETGID, uintptr(gid), 0, 0)
|
||||||
|
if e1 != 0 {
|
||||||
|
err = e1
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
|
@ -0,0 +1,48 @@
|
||||||
|
// +build linux
|
||||||
|
// +build !mips,!mipsle,!mips64,!mips64le
|
||||||
|
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"syscall"
|
||||||
|
|
||||||
|
"golang.org/x/sys/unix"
|
||||||
|
)
|
||||||
|
|
||||||
|
var signalMap = map[string]syscall.Signal{
|
||||||
|
"ABRT": unix.SIGABRT,
|
||||||
|
"ALRM": unix.SIGALRM,
|
||||||
|
"BUS": unix.SIGBUS,
|
||||||
|
"CHLD": unix.SIGCHLD,
|
||||||
|
"CLD": unix.SIGCLD,
|
||||||
|
"CONT": unix.SIGCONT,
|
||||||
|
"FPE": unix.SIGFPE,
|
||||||
|
"HUP": unix.SIGHUP,
|
||||||
|
"ILL": unix.SIGILL,
|
||||||
|
"INT": unix.SIGINT,
|
||||||
|
"IO": unix.SIGIO,
|
||||||
|
"IOT": unix.SIGIOT,
|
||||||
|
"KILL": unix.SIGKILL,
|
||||||
|
"PIPE": unix.SIGPIPE,
|
||||||
|
"POLL": unix.SIGPOLL,
|
||||||
|
"PROF": unix.SIGPROF,
|
||||||
|
"PWR": unix.SIGPWR,
|
||||||
|
"QUIT": unix.SIGQUIT,
|
||||||
|
"SEGV": unix.SIGSEGV,
|
||||||
|
"STKFLT": unix.SIGSTKFLT,
|
||||||
|
"STOP": unix.SIGSTOP,
|
||||||
|
"SYS": unix.SIGSYS,
|
||||||
|
"TERM": unix.SIGTERM,
|
||||||
|
"TRAP": unix.SIGTRAP,
|
||||||
|
"TSTP": unix.SIGTSTP,
|
||||||
|
"TTIN": unix.SIGTTIN,
|
||||||
|
"TTOU": unix.SIGTTOU,
|
||||||
|
"UNUSED": unix.SIGUNUSED,
|
||||||
|
"URG": unix.SIGURG,
|
||||||
|
"USR1": unix.SIGUSR1,
|
||||||
|
"USR2": unix.SIGUSR2,
|
||||||
|
"VTALRM": unix.SIGVTALRM,
|
||||||
|
"WINCH": unix.SIGWINCH,
|
||||||
|
"XCPU": unix.SIGXCPU,
|
||||||
|
"XFSZ": unix.SIGXFSZ,
|
||||||
|
}
|
|
@ -0,0 +1,45 @@
|
||||||
|
// +build linux,mips linux,mipsle linux,mips64 linux,mips64le
|
||||||
|
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"syscall"
|
||||||
|
|
||||||
|
"golang.org/x/sys/unix"
|
||||||
|
)
|
||||||
|
|
||||||
|
var signalMap = map[string]syscall.Signal{
|
||||||
|
"ABRT": unix.SIGABRT,
|
||||||
|
"ALRM": unix.SIGALRM,
|
||||||
|
"BUS": unix.SIGBUS,
|
||||||
|
"CHLD": unix.SIGCHLD,
|
||||||
|
"CLD": unix.SIGCLD,
|
||||||
|
"CONT": unix.SIGCONT,
|
||||||
|
"FPE": unix.SIGFPE,
|
||||||
|
"HUP": unix.SIGHUP,
|
||||||
|
"ILL": unix.SIGILL,
|
||||||
|
"INT": unix.SIGINT,
|
||||||
|
"IO": unix.SIGIO,
|
||||||
|
"IOT": unix.SIGIOT,
|
||||||
|
"KILL": unix.SIGKILL,
|
||||||
|
"PIPE": unix.SIGPIPE,
|
||||||
|
"POLL": unix.SIGPOLL,
|
||||||
|
"PROF": unix.SIGPROF,
|
||||||
|
"PWR": unix.SIGPWR,
|
||||||
|
"QUIT": unix.SIGQUIT,
|
||||||
|
"SEGV": unix.SIGSEGV,
|
||||||
|
"STOP": unix.SIGSTOP,
|
||||||
|
"SYS": unix.SIGSYS,
|
||||||
|
"TERM": unix.SIGTERM,
|
||||||
|
"TRAP": unix.SIGTRAP,
|
||||||
|
"TSTP": unix.SIGTSTP,
|
||||||
|
"TTIN": unix.SIGTTIN,
|
||||||
|
"TTOU": unix.SIGTTOU,
|
||||||
|
"URG": unix.SIGURG,
|
||||||
|
"USR1": unix.SIGUSR1,
|
||||||
|
"USR2": unix.SIGUSR2,
|
||||||
|
"VTALRM": unix.SIGVTALRM,
|
||||||
|
"WINCH": unix.SIGWINCH,
|
||||||
|
"XCPU": unix.SIGXCPU,
|
||||||
|
"XFSZ": unix.SIGXFSZ,
|
||||||
|
}
|
Loading…
Reference in New Issue