From: Angus Lees Date: Fri, 13 May 2016 07:32:40 +0000 (+1000) Subject: pkg/ns: evaluate syscall number at compile-time X-Git-Url: https://git.halfball.org/?a=commitdiff_plain;h=734bf1ba5bbb2e99feeb81a437ab7fff47d88873;p=plugins.git pkg/ns: evaluate syscall number at compile-time Previously this code used a run-time map lookup keyed by runtime.GOOS/GOARCH. This version uses conditional compilation to make this choice at compile time, giving immediate feedback for unsupported platforms. --- diff --git a/ns/consts_linux_386.go b/ns/consts_linux_386.go new file mode 100644 index 0000000..fd6ed8a --- /dev/null +++ b/ns/consts_linux_386.go @@ -0,0 +1,17 @@ +// Copyright 2015 CNI authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +package ns + +const setNsNr = 346 diff --git a/ns/consts_linux_amd64.go b/ns/consts_linux_amd64.go new file mode 100644 index 0000000..a86a68a --- /dev/null +++ b/ns/consts_linux_amd64.go @@ -0,0 +1,17 @@ +// Copyright 2015 CNI authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +package ns + +const setNsNr = 308 diff --git a/ns/consts_linux_arm.go b/ns/consts_linux_arm.go new file mode 100644 index 0000000..5beaaf3 --- /dev/null +++ b/ns/consts_linux_arm.go @@ -0,0 +1,17 @@ +// Copyright 2015 CNI authors +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +package ns + +const setNsNr = 375 diff --git a/ns/ns.go b/ns/ns.go index ea84822..7253399 100644 --- a/ns/ns.go +++ b/ns/ns.go @@ -21,24 +21,9 @@ import ( "syscall" ) -var setNsMap = map[string]uintptr{ - "386": 346, - "amd64": 308, - "arm": 375, -} - // SetNS sets the network namespace on a target file. func SetNS(f *os.File, flags uintptr) error { - if runtime.GOOS != "linux" { - return fmt.Errorf("unsupported OS: %s", runtime.GOOS) - } - - trap, ok := setNsMap[runtime.GOARCH] - if !ok { - return fmt.Errorf("unsupported arch: %s", runtime.GOARCH) - } - - _, _, err := syscall.RawSyscall(trap, f.Fd(), flags, 0) + _, _, err := syscall.RawSyscall(setNsNr, f.Fd(), flags, 0) if err != 0 { return err }