Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
go
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
go
Commits
4497d7eb
Commit
4497d7eb
authored
Nov 03, 2019
by
Cherry Zhang
Browse files
Options
Browse Files
Download
Plain Diff
[dev.link] all: merge branch 'master' into dev.link
Clean merge. Change-Id: I26a4e3d4c09a928c9fd95e394304ee10319ca7c5
parents
32190b0a
35cfe059
Changes
46
Show whitespace changes
Inline
Side-by-side
Showing
46 changed files
with
5221 additions
and
144 deletions
+5221
-144
misc/cgo/testcarchive/carchive_test.go
misc/cgo/testcarchive/carchive_test.go
+49
-0
misc/cgo/testcarchive/testdata/libgo7/sink.go
misc/cgo/testcarchive/testdata/libgo7/sink.go
+17
-0
misc/cgo/testcarchive/testdata/main7.c
misc/cgo/testcarchive/testdata/main7.c
+17
-0
src/cmd/compile/internal/gc/typecheck.go
src/cmd/compile/internal/gc/typecheck.go
+1
-1
src/cmd/go/internal/cfg/cfg.go
src/cmd/go/internal/cfg/cfg.go
+1
-0
src/cmd/go/internal/modfetch/cache.go
src/cmd/go/internal/modfetch/cache.go
+16
-6
src/cmd/go/internal/modfetch/fetch.go
src/cmd/go/internal/modfetch/fetch.go
+0
-4
src/cmd/go/internal/modfetch/repo.go
src/cmd/go/internal/modfetch/repo.go
+15
-6
src/cmd/go/internal/modget/get.go
src/cmd/go/internal/modget/get.go
+26
-2
src/cmd/go/internal/modload/init.go
src/cmd/go/internal/modload/init.go
+31
-16
src/cmd/go/internal/modload/load.go
src/cmd/go/internal/modload/load.go
+1
-0
src/cmd/go/internal/modload/query.go
src/cmd/go/internal/modload/query.go
+15
-0
src/cmd/go/internal/modload/stat_openfile.go
src/cmd/go/internal/modload/stat_openfile.go
+27
-0
src/cmd/go/internal/modload/stat_unix.go
src/cmd/go/internal/modload/stat_unix.go
+31
-0
src/cmd/go/internal/modload/stat_windows.go
src/cmd/go/internal/modload/stat_windows.go
+23
-0
src/cmd/go/script_test.go
src/cmd/go/script_test.go
+5
-1
src/cmd/go/testdata/script/mod_get_newcycle.txt
src/cmd/go/testdata/script/mod_get_newcycle.txt
+0
-1
src/cmd/go/testdata/script/mod_getmode_vendor.txt
src/cmd/go/testdata/script/mod_getmode_vendor.txt
+1
-1
src/cmd/go/testdata/script/mod_load_badchain.txt
src/cmd/go/testdata/script/mod_load_badchain.txt
+4
-0
src/cmd/go/testdata/script/mod_readonly.txt
src/cmd/go/testdata/script/mod_readonly.txt
+10
-2
src/cmd/go/testdata/script/mod_vendor_auto.txt
src/cmd/go/testdata/script/mod_vendor_auto.txt
+0
-2
src/crypto/dsa/dsa.go
src/crypto/dsa/dsa.go
+2
-2
src/encoding/binary/binary.go
src/encoding/binary/binary.go
+17
-2
src/encoding/binary/binary_test.go
src/encoding/binary/binary_test.go
+62
-0
src/go/build/deps_test.go
src/go/build/deps_test.go
+51
-52
src/hash/maphash/maphash.go
src/hash/maphash/maphash.go
+3
-3
src/hash/maphash/maphash_test.go
src/hash/maphash/maphash_test.go
+13
-13
src/hash/maphash/smhasher_test.go
src/hash/maphash/smhasher_test.go
+6
-6
src/make.bash
src/make.bash
+2
-1
src/net/http/header.go
src/net/http/header.go
+1
-0
src/net/http/main_test.go
src/net/http/main_test.go
+1
-1
src/net/http/transport_test.go
src/net/http/transport_test.go
+0
-4
src/runtime/mgcscavenge.go
src/runtime/mgcscavenge.go
+7
-3
src/runtime/netpoll_solaris.go
src/runtime/netpoll_solaris.go
+12
-4
src/runtime/proc.go
src/runtime/proc.go
+3
-0
src/runtime/time.go
src/runtime/time.go
+9
-7
src/syscall/asm_linux_riscv64.s
src/syscall/asm_linux_riscv64.s
+115
-0
src/syscall/endian_little.go
src/syscall/endian_little.go
+1
-1
src/syscall/mkall.sh
src/syscall/mkall.sh
+9
-0
src/syscall/syscall_linux_riscv64.go
src/syscall/syscall_linux_riscv64.go
+203
-0
src/syscall/types_linux.go
src/syscall/types_linux.go
+3
-3
src/syscall/zerrors_linux_riscv64.go
src/syscall/zerrors_linux_riscv64.go
+1878
-0
src/syscall/zsyscall_linux_riscv64.go
src/syscall/zsyscall_linux_riscv64.go
+1624
-0
src/syscall/zsysnum_linux_riscv64.go
src/syscall/zsysnum_linux_riscv64.go
+273
-0
src/syscall/ztypes_linux_riscv64.go
src/syscall/ztypes_linux_riscv64.go
+631
-0
src/time/zoneinfo.go
src/time/zoneinfo.go
+5
-0
No files found.
misc/cgo/testcarchive/carchive_test.go
View file @
4497d7eb
...
...
@@ -813,3 +813,52 @@ func TestCachedInstall(t *testing.T) {
t
.
Errorf
(
"p.h not installed in second run: %v"
,
err
)
}
}
// Issue 35294.
func
TestManyCalls
(
t
*
testing
.
T
)
{
t
.
Parallel
()
defer
func
()
{
os
.
Remove
(
"testp7"
+
exeSuffix
)
os
.
Remove
(
"libgo7.a"
)
os
.
Remove
(
"libgo7.h"
)
}()
cmd
:=
exec
.
Command
(
"go"
,
"build"
,
"-buildmode=c-archive"
,
"-o"
,
"libgo7.a"
,
"./libgo7"
)
if
out
,
err
:=
cmd
.
CombinedOutput
();
err
!=
nil
{
t
.
Logf
(
"%s"
,
out
)
t
.
Fatal
(
err
)
}
checkLineComments
(
t
,
"libgo7.h"
)
ccArgs
:=
append
(
cc
,
"-o"
,
"testp7"
+
exeSuffix
,
"main7.c"
,
"libgo7.a"
)
if
runtime
.
Compiler
==
"gccgo"
{
ccArgs
=
append
(
ccArgs
,
"-lgo"
)
}
if
out
,
err
:=
exec
.
Command
(
ccArgs
[
0
],
ccArgs
[
1
:
]
...
)
.
CombinedOutput
();
err
!=
nil
{
t
.
Logf
(
"%s"
,
out
)
t
.
Fatal
(
err
)
}
argv
:=
cmdToRun
(
"./testp7"
)
cmd
=
exec
.
Command
(
argv
[
0
],
argv
[
1
:
]
...
)
var
sb
strings
.
Builder
cmd
.
Stdout
=
&
sb
cmd
.
Stderr
=
&
sb
if
err
:=
cmd
.
Start
();
err
!=
nil
{
t
.
Fatal
(
err
)
}
timer
:=
time
.
AfterFunc
(
time
.
Minute
,
func
()
{
t
.
Error
(
"test program timed out"
)
cmd
.
Process
.
Kill
()
},
)
defer
timer
.
Stop
()
if
err
:=
cmd
.
Wait
();
err
!=
nil
{
t
.
Log
(
sb
.
String
())
t
.
Error
(
err
)
}
}
misc/cgo/testcarchive/testdata/libgo7/sink.go
0 → 100644
View file @
4497d7eb
// Copyright 2019 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.
package
main
import
"C"
var
sink
[]
byte
//export GoFunction7
func
GoFunction7
()
{
sink
=
make
([]
byte
,
4096
)
}
func
main
()
{
}
misc/cgo/testcarchive/testdata/main7.c
0 → 100644
View file @
4497d7eb
// Copyright 2019 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.
// Test that lots of calls don't deadlock.
#include <stdio.h>
#include "libgo7.h"
int
main
()
{
int
i
;
for
(
i
=
0
;
i
<
100000
;
i
++
)
{
GoFunction7
();
}
}
src/cmd/compile/internal/gc/typecheck.go
View file @
4497d7eb
...
...
@@ -2809,7 +2809,7 @@ func typecheckcomplit(n *Node) (res *Node) {
n
.
Right
=
nil
case
TSLICE
:
length
:=
typecheckarraylit
(
t
.
Elem
(),
-
2
,
n
.
List
.
Slice
(),
"slice literal"
)
length
:=
typecheckarraylit
(
t
.
Elem
(),
-
1
,
n
.
List
.
Slice
(),
"slice literal"
)
n
.
Op
=
OSLICELIT
n
.
Right
=
nodintconst
(
length
)
...
...
src/cmd/go/internal/cfg/cfg.go
View file @
4497d7eb
...
...
@@ -27,6 +27,7 @@ var (
BuildBuildmode
string
// -buildmode flag
BuildContext
=
defaultContext
()
BuildMod
string
// -mod flag
BuildModReason
string
// reason -mod flag is set, if set by default
BuildI
bool
// -i flag
BuildLinkshared
bool
// -linkshared flag
BuildMSan
bool
// -msan flag
...
...
src/cmd/go/internal/modfetch/cache.go
View file @
4497d7eb
...
...
@@ -13,6 +13,7 @@ import (
"os"
"path/filepath"
"strings"
"time"
"cmd/go/internal/base"
"cmd/go/internal/cfg"
...
...
@@ -25,10 +26,10 @@ import (
"golang.org/x/mod/semver"
)
var
QuietLookup
bool
// do not print about lookups
var
PkgMod
string
// $GOPATH/pkg/mod; set by package modload
const
logFindingDelay
=
1
*
time
.
Second
func
cacheDir
(
path
string
)
(
string
,
error
)
{
if
PkgMod
==
""
{
return
""
,
fmt
.
Errorf
(
"internal error: modfetch.PkgMod not set"
)
...
...
@@ -140,6 +141,11 @@ func (r *cachingRepo) Versions(prefix string) ([]string, error) {
err
error
}
c
:=
r
.
cache
.
Do
(
"versions:"
+
prefix
,
func
()
interface
{}
{
logTimer
:=
time
.
AfterFunc
(
logFindingDelay
,
func
()
{
fmt
.
Fprintf
(
os
.
Stderr
,
"go: finding versions for %s
\n
"
,
r
.
path
)
})
defer
logTimer
.
Stop
()
list
,
err
:=
r
.
r
.
Versions
(
prefix
)
return
cached
{
list
,
err
}
})
.
(
cached
)
...
...
@@ -162,9 +168,11 @@ func (r *cachingRepo) Stat(rev string) (*RevInfo, error) {
return
cachedInfo
{
info
,
nil
}
}
if
!
QuietLookup
{
logTimer
:=
time
.
AfterFunc
(
logFindingDelay
,
func
()
{
fmt
.
Fprintf
(
os
.
Stderr
,
"go: finding %s %s
\n
"
,
r
.
path
,
rev
)
}
})
defer
logTimer
.
Stop
()
info
,
err
=
r
.
r
.
Stat
(
rev
)
if
err
==
nil
{
// If we resolved, say, 1234abcde to v0.0.0-20180604122334-1234abcdef78,
...
...
@@ -192,9 +200,11 @@ func (r *cachingRepo) Stat(rev string) (*RevInfo, error) {
func
(
r
*
cachingRepo
)
Latest
()
(
*
RevInfo
,
error
)
{
c
:=
r
.
cache
.
Do
(
"latest:"
,
func
()
interface
{}
{
if
!
QuietLookup
{
logTimer
:=
time
.
AfterFunc
(
logFindingDelay
,
func
()
{
fmt
.
Fprintf
(
os
.
Stderr
,
"go: finding %s latest
\n
"
,
r
.
path
)
}
})
defer
logTimer
.
Stop
()
info
,
err
:=
r
.
r
.
Latest
()
// Save info for likely future Stat call.
...
...
src/cmd/go/internal/modfetch/fetch.go
View file @
4497d7eb
...
...
@@ -71,10 +71,6 @@ func download(mod module.Version, dir string) (err error) {
return
err
}
if
cfg
.
CmdName
!=
"mod download"
{
fmt
.
Fprintf
(
os
.
Stderr
,
"go: extracting %s %s
\n
"
,
mod
.
Path
,
mod
.
Version
)
}
unlock
,
err
:=
lockVersion
(
mod
)
if
err
!=
nil
{
return
err
...
...
src/cmd/go/internal/modfetch/repo.go
View file @
4497d7eb
...
...
@@ -5,7 +5,6 @@
package
modfetch
import
(
"errors"
"fmt"
"io"
"os"
...
...
@@ -215,7 +214,7 @@ func Lookup(proxy, path string) (Repo, error) {
// lookup returns the module with the given module path.
func
lookup
(
proxy
,
path
string
)
(
r
Repo
,
err
error
)
{
if
cfg
.
BuildMod
==
"vendor"
{
return
nil
,
err
ModVendor
return
nil
,
err
LookupDisabled
}
if
str
.
GlobsMatchPath
(
cfg
.
GONOPROXY
,
path
)
{
...
...
@@ -239,8 +238,18 @@ func lookup(proxy, path string) (r Repo, err error) {
}
}
type
lookupDisabledError
struct
{}
func
(
lookupDisabledError
)
Error
()
string
{
if
cfg
.
BuildModReason
==
""
{
return
fmt
.
Sprintf
(
"module lookup disabled by -mod=%s"
,
cfg
.
BuildMod
)
}
return
fmt
.
Sprintf
(
"module lookup disabled by -mod=%s
\n\t
(%s)"
,
cfg
.
BuildMod
,
cfg
.
BuildModReason
)
}
var
errLookupDisabled
error
=
lookupDisabledError
{}
var
(
errModVendor
=
errors
.
New
(
"module lookup disabled by -mod=vendor"
)
errProxyOff
=
notExistError
(
"module lookup disabled by GOPROXY=off"
)
errNoproxy
error
=
notExistError
(
"disabled by GOPRIVATE/GONOPROXY"
)
errUseProxy
error
=
notExistError
(
"path does not match GOPRIVATE/GONOPROXY"
)
...
...
src/cmd/go/internal/modget/get.go
View file @
4497d7eb
...
...
@@ -372,7 +372,7 @@ func runGet(cmd *base.Command, args []string) {
continue
default
:
// The argument is a package path.
// The argument is a package
or module
path.
if
pkgs
:=
modload
.
TargetPackages
(
path
);
len
(
pkgs
)
!=
0
{
// The path is in the main module. Nothing to query.
if
vers
!=
"upgrade"
&&
vers
!=
"patch"
{
...
...
@@ -763,6 +763,9 @@ func getQuery(path, vers string, prevM module.Version, forceModulePath bool) (mo
info
,
err
:=
modload
.
Query
(
path
,
vers
,
prevM
.
Version
,
modload
.
Allowed
)
if
err
==
nil
{
if
info
.
Version
!=
vers
&&
info
.
Version
!=
prevM
.
Version
{
logOncef
(
"go: %s %s => %s"
,
path
,
vers
,
info
.
Version
)
}
return
module
.
Version
{
Path
:
path
,
Version
:
info
.
Version
},
nil
}
...
...
@@ -791,6 +794,9 @@ func getQuery(path, vers string, prevM module.Version, forceModulePath bool) (mo
if
!
strings
.
Contains
(
path
,
"..."
)
{
var
modErr
*
modload
.
PackageNotInModuleError
if
errors
.
As
(
err
,
&
modErr
)
&&
modErr
.
Mod
.
Path
==
path
{
if
modErr
.
Mod
.
Version
!=
vers
{
logOncef
(
"go: %s %s => %s"
,
path
,
vers
,
modErr
.
Mod
.
Version
)
}
return
modErr
.
Mod
,
nil
}
}
...
...
@@ -798,7 +804,13 @@ func getQuery(path, vers string, prevM module.Version, forceModulePath bool) (mo
return
module
.
Version
{},
err
}
return
results
[
0
]
.
Mod
,
nil
m
:=
results
[
0
]
.
Mod
if
m
.
Path
!=
path
{
logOncef
(
"go: found %s in %s %s"
,
path
,
m
.
Path
,
m
.
Version
)
}
else
if
m
.
Version
!=
vers
{
logOncef
(
"go: %s %s => %s"
,
path
,
vers
,
m
.
Version
)
}
return
m
,
nil
}
// An upgrader adapts an underlying mvs.Reqs to apply an
...
...
@@ -955,6 +967,9 @@ func (u *upgrader) Upgrade(m module.Version) (module.Version, error) {
return
m
,
nil
}
if
info
.
Version
!=
m
.
Version
{
logOncef
(
"go: %s %s => %s"
,
m
.
Path
,
getU
,
info
.
Version
)
}
return
module
.
Version
{
Path
:
m
.
Path
,
Version
:
info
.
Version
},
nil
}
...
...
@@ -983,3 +998,12 @@ func (r *lostUpgradeReqs) Required(mod module.Version) ([]module.Version, error)
}
return
r
.
Reqs
.
Required
(
mod
)
}
var
loggedLines
sync
.
Map
func
logOncef
(
format
string
,
args
...
interface
{})
{
msg
:=
fmt
.
Sprintf
(
format
,
args
...
)
if
_
,
dup
:=
loggedLines
.
LoadOrStore
(
msg
,
true
);
!
dup
{
fmt
.
Fprintln
(
os
.
Stderr
,
msg
)
}
}
src/cmd/go/internal/modload/init.go
View file @
4497d7eb
...
...
@@ -460,7 +460,10 @@ func setDefaultBuildMod() {
// manipulate the build list.
return
}
if
modRoot
!=
""
{
if
modRoot
==
""
{
return
}
if
fi
,
err
:=
os
.
Stat
(
filepath
.
Join
(
modRoot
,
"vendor"
));
err
==
nil
&&
fi
.
IsDir
()
{
modGo
:=
"unspecified"
if
modFile
.
Go
!=
nil
{
...
...
@@ -468,17 +471,25 @@ func setDefaultBuildMod() {
// The Go version is at least 1.14, and a vendor directory exists.
// Set -mod=vendor by default.
cfg
.
BuildMod
=
"vendor"
cfg
.
BuildModReason
=
"Go version in go.mod is at least 1.14 and vendor directory exists."
return
}
else
{
modGo
=
modFile
.
Go
.
Version
}
}
fmt
.
Fprintf
(
os
.
Stderr
,
"go: not defaulting to -mod=vendor because go.mod 'go' version is %s
\n
"
,
modGo
)
}
// Since a vendor directory exists, we have a non-trivial reason for
// choosing -mod=mod, although it probably won't be used for anything.
// Record the reason anyway for consistency.
// It may be overridden if we switch to mod=readonly below.
cfg
.
BuildModReason
=
fmt
.
Sprintf
(
"Go version in go.mod is %s."
,
modGo
)
}
// TODO(golang.org/issue/33326): set -mod=readonly implicitly if the go.mod
// file is itself read-only?
p
:=
ModFilePath
()
if
fi
,
err
:=
os
.
Stat
(
p
);
err
==
nil
&&
!
hasWritePerm
(
p
,
fi
)
{
cfg
.
BuildMod
=
"readonly"
cfg
.
BuildModReason
=
"go.mod file is read-only."
}
}
// checkVendorConsistency verifies that the vendor/modules.txt file matches (if
...
...
@@ -858,8 +869,12 @@ func WriteGoMod() {
if
dirty
&&
cfg
.
BuildMod
==
"readonly"
{
// If we're about to fail due to -mod=readonly,
// prefer to report a dirty go.mod over a dirty go.sum
if
cfg
.
BuildModReason
!=
""
{
base
.
Fatalf
(
"go: updates to go.mod needed, disabled by -mod=readonly
\n\t
(%s)"
,
cfg
.
BuildModReason
)
}
else
{
base
.
Fatalf
(
"go: updates to go.mod needed, disabled by -mod=readonly"
)
}
}
// Always update go.sum, even if we didn't change go.mod: we may have
// downloaded modules that we didn't have before.
modfetch
.
WriteGoSum
()
...
...
src/cmd/go/internal/modload/load.go
View file @
4497d7eb
...
...
@@ -626,6 +626,7 @@ func (ld *loader) load(roots func() []string) {
added
[
pkg
.
path
]
=
true
numAdded
++
if
!
haveMod
[
err
.
Module
]
{
fmt
.
Fprintf
(
os
.
Stderr
,
"go: found %s in %s %s
\n
"
,
pkg
.
path
,
err
.
Module
.
Path
,
err
.
Module
.
Version
)
haveMod
[
err
.
Module
]
=
true
modAddedBy
[
err
.
Module
]
=
pkg
buildList
=
append
(
buildList
,
err
.
Module
)
...
...
src/cmd/go/internal/modload/query.go
View file @
4497d7eb
...
...
@@ -12,6 +12,7 @@ import (
"strings"
"sync"
"cmd/go/internal/cfg"
"cmd/go/internal/imports"
"cmd/go/internal/modfetch"
"cmd/go/internal/search"
...
...
@@ -62,10 +63,24 @@ func Query(path, query, current string, allowed func(module.Version) bool) (*mod
return
info
,
err
}
var
errQueryDisabled
error
=
queryDisabledError
{}
type
queryDisabledError
struct
{}
func
(
queryDisabledError
)
Error
()
string
{
if
cfg
.
BuildModReason
==
""
{
return
fmt
.
Sprintf
(
"cannot query module due to -mod=%s"
,
cfg
.
BuildMod
)
}
return
fmt
.
Sprintf
(
"cannot query module due to -mod=%s
\n\t
(%s)"
,
cfg
.
BuildMod
,
cfg
.
BuildModReason
)
}
func
queryProxy
(
proxy
,
path
,
query
,
current
string
,
allowed
func
(
module
.
Version
)
bool
)
(
*
modfetch
.
RevInfo
,
error
)
{
if
current
!=
""
&&
!
semver
.
IsValid
(
current
)
{
return
nil
,
fmt
.
Errorf
(
"invalid previous version %q"
,
current
)
}
if
cfg
.
BuildMod
!=
""
&&
cfg
.
BuildMod
!=
"mod"
{
return
nil
,
errQueryDisabled
}
if
allowed
==
nil
{
allowed
=
func
(
module
.
Version
)
bool
{
return
true
}
}
...
...
src/cmd/go/internal/modload/stat_openfile.go
0 → 100644
View file @
4497d7eb
// Copyright 2019 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.
// +build aix js,wasm plan9
// On plan9, per http://9p.io/magic/man2html/2/access: “Since file permissions
// are checked by the server and group information is not known to the client,
// access must open the file to check permissions.”
//
// aix and js,wasm are similar, in that they do not define syscall.Access.
package
modload
import
(
"os"
)
// hasWritePerm reports whether the current user has permission to write to the
// file with the given info.
func
hasWritePerm
(
path
string
,
_
os
.
FileInfo
)
bool
{
if
f
,
err
:=
os
.
OpenFile
(
path
,
os
.
O_WRONLY
,
0
);
err
==
nil
{
f
.
Close
()
return
true
}
return
false
}
src/cmd/go/internal/modload/stat_unix.go
0 → 100644
View file @
4497d7eb
// Copyright 2019 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.
// +build darwin dragonfly freebsd linux netbsd openbsd solaris
package
modload
import
(
"os"
"syscall"
)
// hasWritePerm reports whether the current user has permission to write to the
// file with the given info.
//
// Although the root user on most Unix systems can write to files even without
// permission, hasWritePerm reports false if no appropriate permission bit is
// set even if the current user is root.
func
hasWritePerm
(
path
string
,
fi
os
.
FileInfo
)
bool
{
if
os
.
Getuid
()
==
0
{
// The root user can access any file, but we still want to default to
// read-only mode if the go.mod file is marked as globally non-writable.
// (If the user really intends not to be in readonly mode, they can
// pass -mod=mod explicitly.)
return
fi
.
Mode
()
&
0222
!=
0
}
const
W_OK
=
0x2
return
syscall
.
Access
(
path
,
W_OK
)
==
nil
}
src/cmd/go/internal/modload/stat_windows.go
0 → 100644
View file @
4497d7eb
// Copyright 2019 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.
// +build windows
package
modload
import
(
"os"
)
// hasWritePerm reports whether the current user has permission to write to the
// file with the given info.
func
hasWritePerm
(
_
string
,
fi
os
.
FileInfo
)
bool
{
// Windows has a read-only attribute independent of ACLs, so use that to
// determine whether the file is intended to be overwritten.
//
// Per https://golang.org/pkg/os/#Chmod:
// “On Windows, only the 0200 bit (owner writable) of mode is used; it
// controls whether the file's read-only attribute is set or cleared.”
return
fi
.
Mode
()
&
0200
!=
0
}
src/cmd/go/script_test.go
View file @
4497d7eb
...
...
@@ -431,7 +431,11 @@ func (ts *testScript) cmdChmod(neg bool, args []string) {
if
err
!=
nil
||
perm
&
uint64
(
os
.
ModePerm
)
!=
perm
{
ts
.
fatalf
(
"invalid mode: %s"
,
args
[
0
])
}
for
_
,
path
:=
range
args
[
1
:
]
{
for
_
,
arg
:=
range
args
[
1
:
]
{
path
:=
arg
if
!
filepath
.
IsAbs
(
path
)
{
path
=
filepath
.
Join
(
ts
.
cd
,
arg
)
}
err
:=
os
.
Chmod
(
path
,
os
.
FileMode
(
perm
))
ts
.
check
(
err
)
}
...
...
src/cmd/go/testdata/script/mod_get_newcycle.txt
View file @
4497d7eb
...
...
@@ -11,6 +11,5 @@ go mod init m
cmp stderr stderr-expected
-- stderr-expected --
go: finding example.com/newcycle v1.0.0
go get: inconsistent versions:
example.com/newcycle/a@v1.0.0 requires example.com/newcycle/a@v1.0.1 (not example.com/newcycle/a@v1.0.0)
src/cmd/go/testdata/script/mod_getmode_vendor.txt
View file @
4497d7eb
...
...
@@ -11,7 +11,7 @@ stdout '^rsc.io/quote v1.5.1 .*vendor[\\/]rsc.io[\\/]quote$'
stdout '^golang.org/x/text v0.0.0.* .*vendor[\\/]golang.org[\\/]x[\\/]text[\\/]language$'
! go list -mod=vendor -m rsc.io/quote@latest
stderr 'go list -m: rsc.io/quote@latest:
module lookup disabled by
-mod=vendor'
stderr 'go list -m: rsc.io/quote@latest:
cannot query module due to
-mod=vendor'
! go get -mod=vendor -u
stderr 'flag provided but not defined: -mod'
...
...
src/cmd/go/testdata/script/mod_load_badchain.txt
View file @
4497d7eb
...
...
@@ -56,11 +56,13 @@ import (
func Test(t *testing.T) {}
-- update-main-expected --
go: example.com/badchain/c upgrade => v1.1.0
go get: example.com/badchain/c@v1.0.0 updating to
example.com/badchain/c@v1.1.0: parsing go.mod:
module declares its path as: badchain.example.com/c
but was required as: example.com/badchain/c
-- update-a-expected --
go: example.com/badchain/a upgrade => v1.1.0
go get: example.com/badchain/a@v1.1.0 requires
example.com/badchain/b@v1.1.0 requires
example.com/badchain/c@v1.1.0: parsing go.mod:
...
...
@@ -73,11 +75,13 @@ go: example.com/badchain/a@v1.1.0 requires
module declares its path as: badchain.example.com/c
but was required as: example.com/badchain/c
-- list-missing-expected --
go: found example.com/badchain/c in example.com/badchain/c v1.1.0
go: m/use imports
example.com/badchain/c: example.com/badchain/c@v1.1.0: parsing go.mod:
module declares its path as: badchain.example.com/c
but was required as: example.com/badchain/c
-- list-missing-test-expected --
go: found example.com/badchain/c in example.com/badchain/c v1.1.0
go: m/testuse tested by
m/testuse.test imports
example.com/badchain/c: example.com/badchain/c@v1.1.0: parsing go.mod:
...
...
src/cmd/go/testdata/script/mod_readonly.txt
View file @
4497d7eb
...
...
@@ -12,6 +12,14 @@ cp go.mod go.mod.empty
stderr 'import lookup disabled by -mod=readonly'
cmp go.mod go.mod.empty
# -mod=readonly should be set implicitly if the go.mod file is read-only
chmod 0400 go.mod
env GOFLAGS=
! go list all
chmod 0600 go.mod
env GOFLAGS=-mod=readonly
# update go.mod - go get allowed
go get rsc.io/quote
grep rsc.io/quote go.mod
...
...
@@ -21,11 +29,11 @@ cp go.mod.empty go.mod
go mod tidy
# -mod=readonly must succeed once go.mod is up-to-date...
go list
go list
all
# ... even if it needs downloads
go clean -modcache
go list
go list
all
# -mod=readonly should reject inconsistent go.mod files
# (ones that would be rewritten).
...
...
src/cmd/go/testdata/script/mod_vendor_auto.txt
View file @
4497d7eb
...
...
@@ -48,7 +48,6 @@ go list -f {{.Dir}} -tags tools all
stdout '^'$WORK'[/\\]auto$'
stdout '^'$GOPATH'[/\\]pkg[/\\]mod[/\\]example.com[/\\]printversion@v1.0.0$'
stdout '^'$WORK'[/\\]auto[/\\]replacement-version$'
stderr '^go: not defaulting to -mod=vendor because go.mod .go. version is 1.13$'
go list -m -f '{{.Dir}}' all
stdout '^'$WORK'[/\\]auto$'
...
...
@@ -146,7 +145,6 @@ go list -mod=vendor -f {{.Dir}} -tags tools all
stdout '^'$WORK'[/\\]auto$'
stdout '^'$WORK'[/\\]auto[/\\]vendor[/\\]example.com[/\\]printversion$'
stdout '^'$WORK'[/\\]auto[/\\]vendor[/\\]example.com[/\\]version$'
! stderr 'not defaulting to -mod=vendor'
# ...but a version mismatch for an explicit dependency should be noticed.
cp $WORK/modules-bad-1.13.txt vendor/modules.txt
...
...
src/crypto/dsa/dsa.go
View file @
4497d7eb
...
...
@@ -202,7 +202,7 @@ func Sign(rand io.Reader, priv *PrivateKey, hash []byte) (r, s *big.Int, err err
// FIPS 186-3, section 4.6
n
:=
priv
.
Q
.
BitLen
()
if
priv
.
Q
.
Sign
()
<=
0
||
priv
.
P
.
Sign
()
<=
0
||
priv
.
G
.
Sign
()
<=
0
||
priv
.
X
.
Sign
()
<=
0
||
n
&
7
!=
0
{
if
priv
.
Q
.
Sign
()
<=
0
||
priv
.
P
.
Sign
()
<=
0
||
priv
.
G
.
Sign
()
<=
0
||
priv
.
X
.
Sign
()
<=
0
||
n
%
8
!=
0
{
err
=
ErrInvalidPublicKey
return
}
...
...
@@ -281,7 +281,7 @@ func Verify(pub *PublicKey, hash []byte, r, s *big.Int) bool {
w
:=
new
(
big
.
Int
)
.
ModInverse
(
s
,
pub
.
Q
)
n
:=
pub
.
Q
.
BitLen
()
if
n
&
7
!=
0
{
if
n
%
8
!=
0
{
return
false
}
z
:=
new
(
big
.
Int
)
.
SetBytes
(
hash
)
...
...
src/encoding/binary/binary.go
View file @
4497d7eb
...
...
@@ -26,6 +26,7 @@ import (
"io"
"math"
"reflect"
"sync"
)
// A ByteOrder specifies how to convert byte sequences into
...
...
@@ -363,18 +364,32 @@ func Size(v interface{}) int {
return
dataSize
(
reflect
.
Indirect
(
reflect
.
ValueOf
(
v
)))
}
var
structSize
sync
.
Map
// map[reflect.Type]int
// dataSize returns the number of bytes the actual data represented by v occupies in memory.
// For compound structures, it sums the sizes of the elements. Thus, for instance, for a slice
// it returns the length of the slice times the element size and does not count the memory
// occupied by the header. If the type of v is not acceptable, dataSize returns -1.
func
dataSize
(
v
reflect
.
Value
)
int
{
if
v
.
Kind
()
==
reflect
.
Slice
{
switch
v
.
Kind
()
{
case
reflect
.
Slice
:
if
s
:=
sizeof
(
v
.
Type
()
.
Elem
());
s
>=
0
{
return
s
*
v
.
Len
()
}
return
-
1
case
reflect
.
Struct
:
t
:=
v
.
Type
()
if
size
,
ok
:=
structSize
.
Load
(
t
);
ok
{
return
size
.
(
int
)
}
size
:=
sizeof
(
t
)
structSize
.
Store
(
t
,
size
)
return
size
default
:
return
sizeof
(
v
.
Type
())
}
}
// sizeof returns the size >= 0 of variables for the given type or -1 if the type is not acceptable.
...
...
src/encoding/binary/binary_test.go
View file @
4497d7eb
...
...
@@ -7,9 +7,11 @@ package binary
import
(
"bytes"
"io"
"io/ioutil"
"math"
"reflect"
"strings"
"sync"
"testing"
)
...
...
@@ -296,6 +298,58 @@ func TestBlankFields(t *testing.T) {
}
}
func
TestSizeStructCache
(
t
*
testing
.
T
)
{
// Reset the cache, otherwise multiple test runs fail.
structSize
=
sync
.
Map
{}
count
:=
func
()
int
{
var
i
int
structSize
.
Range
(
func
(
_
,
_
interface
{})
bool
{
i
++
return
true
})
return
i
}
var
total
int
added
:=
func
()
int
{
delta
:=
count
()
-
total
total
+=
delta
return
delta
}
type
foo
struct
{
A
uint32
}
type
bar
struct
{
A
Struct
B
foo
C
Struct
}
testcases
:=
[]
struct
{
val
interface
{}
want
int
}{
{
new
(
foo
),
1
},
{
new
(
bar
),
1
},
{
new
(
bar
),
0
},
{
new
(
struct
{
A
Struct
}),
1
},
{
new
(
struct
{
A
Struct
}),
0
},
}
for
_
,
tc
:=
range
testcases
{
if
Size
(
tc
.
val
)
==
-
1
{
t
.
Fatalf
(
"Can't get the size of %T"
,
tc
.
val
)
}
if
n
:=
added
();
n
!=
tc
.
want
{
t
.
Errorf
(
"Sizing %T added %d entries to the cache, want %d"
,
tc
.
val
,
n
,
tc
.
want
)
}
}
}
// An attempt to read into a struct with an unexported field will
// panic. This is probably not the best choice, but at this point
// anything else would be an API change.
...
...
@@ -436,6 +490,14 @@ func BenchmarkReadStruct(b *testing.B) {
}
}
func
BenchmarkWriteStruct
(
b
*
testing
.
B
)
{
b
.
SetBytes
(
int64
(
Size
(
&
s
)))
b
.
ResetTimer
()
for
i
:=
0
;
i
<
b
.
N
;
i
++
{
Write
(
ioutil
.
Discard
,
BigEndian
,
&
s
)
}
}
func
BenchmarkReadInts
(
b
*
testing
.
B
)
{
var
ls
Struct
bsr
:=
&
byteSliceReader
{}
...
...
src/go/build/deps_test.go
View file @
4497d7eb
...
...
@@ -86,7 +86,6 @@ var pkgDeps = map[string][]string{
// L2 adds Unicode and strings processing.
"bufio"
:
{
"L0"
,
"unicode/utf8"
,
"bytes"
},
"bytes"
:
{
"L0"
,
"unicode"
,
"unicode/utf8"
},
"bytes/hash"
:
{
"L0"
},
"path"
:
{
"L0"
,
"unicode/utf8"
,
"strings"
},
"strings"
:
{
"L0"
,
"unicode"
,
"unicode/utf8"
},
"unicode"
:
{},
...
...
@@ -95,7 +94,6 @@ var pkgDeps = map[string][]string{
"L1"
,
"bufio"
,
"bytes"
,
"bytes/hash"
,
"path"
,
"strings"
,
"unicode"
,
...
...
@@ -116,6 +114,7 @@ var pkgDeps = map[string][]string{
"hash/crc32"
:
{
"L2"
,
"hash"
},
"hash/crc64"
:
{
"L2"
,
"hash"
},
"hash/fnv"
:
{
"L2"
,
"hash"
},
"hash/maphash"
:
{
"L2"
,
"hash"
},
"image"
:
{
"L2"
,
"image/color"
},
// interfaces
"image/color"
:
{
"L2"
},
// interfaces
"image/color/palette"
:
{
"L2"
,
"image/color"
},
...
...
src/
bytes/hash/
hash.go
→
src/
hash/maphash/map
hash.go
View file @
4497d7eb
...
...
@@ -2,7 +2,7 @@
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
// Package
bytes/
hash provides hash functions on byte sequences. These
// Package
hash/map
hash provides hash functions on byte sequences. These
// hash functions are intended to be used to implement hash tables or
// other data structures that need to map arbitrary strings or byte
// sequences to a uniform distribution of integers. The hash functions
...
...
@@ -29,7 +29,7 @@
// All bits of the Hash result are close to uniformly and
// independently distributed, so can be safely restricted to a range
// using bit masking, shifting, or modular arithmetic.
package
hash
package
map
hash
import
(
"unsafe"
...
...
@@ -161,7 +161,7 @@ func rthash(b []byte, seed uint64) uint64 {
//go:linkname runtime_memhash runtime.memhash
func
runtime_memhash
(
p
unsafe
.
Pointer
,
seed
,
s
uintptr
)
uintptr
// Wrapper functions so that a
bytes/
hash.Hash implements
// Wrapper functions so that a
hash/map
hash.Hash implements
// the hash.Hash and hash.Hash64 interfaces.
func
(
h
*
Hash
)
Write
(
b
[]
byte
)
(
int
,
error
)
{
...
...
src/
bytes/hash/
hash_test.go
→
src/
hash/maphash/map
hash_test.go
View file @
4497d7eb
...
...
@@ -2,18 +2,18 @@
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package
hash_test
package
map
hash_test
import
(
"
bytes/
hash"
basehash
"
hash"
"hash"
"hash/map
hash"
"testing"
)
func
TestUnseededHash
(
t
*
testing
.
T
)
{
m
:=
map
[
uint64
]
struct
{}{}
for
i
:=
0
;
i
<
1000
;
i
++
{
h
:=
hash
.
New
()
h
:=
map
hash
.
New
()
m
[
h
.
Hash
()]
=
struct
{}{}
}
if
len
(
m
)
<
900
{
...
...
@@ -22,10 +22,10 @@ func TestUnseededHash(t *testing.T) {
}
func
TestSeededHash
(
t
*
testing
.
T
)
{
s
:=
hash
.
MakeSeed
(
1234
)
s
:=
map
hash
.
MakeSeed
(
1234
)
m
:=
map
[
uint64
]
struct
{}{}
for
i
:=
0
;
i
<
1000
;
i
++
{
h
:=
hash
.
New
()
h
:=
map
hash
.
New
()
h
.
SetSeed
(
s
)
m
[
h
.
Hash
()]
=
struct
{}{}
}
...
...
@@ -36,8 +36,8 @@ func TestSeededHash(t *testing.T) {
func
TestHashGrouping
(
t
*
testing
.
T
)
{
b
:=
[]
byte
(
"foo"
)
h1
:=
hash
.
New
()
h2
:=
hash
.
New
()
h1
:=
map
hash
.
New
()
h2
:=
map
hash
.
New
()
h2
.
SetSeed
(
h1
.
Seed
())
h1
.
AddBytes
(
b
)
for
_
,
x
:=
range
b
{
...
...
@@ -51,8 +51,8 @@ func TestHashGrouping(t *testing.T) {
func
TestHashBytesVsString
(
t
*
testing
.
T
)
{
s
:=
"foo"
b
:=
[]
byte
(
s
)
h1
:=
hash
.
New
()
h2
:=
hash
.
New
()
h1
:=
map
hash
.
New
()
h2
:=
map
hash
.
New
()
h2
.
SetSeed
(
h1
.
Seed
())
h1
.
AddString
(
s
)
h2
.
AddBytes
(
b
)
...
...
@@ -66,7 +66,7 @@ func TestHashHighBytes(t *testing.T) {
const
N
=
10
m
:=
map
[
uint64
]
struct
{}{}
for
i
:=
0
;
i
<
N
;
i
++
{
h
:=
hash
.
New
()
h
:=
map
hash
.
New
()
h
.
AddString
(
"foo"
)
m
[
h
.
Hash
()
>>
32
]
=
struct
{}{}
}
...
...
@@ -76,5 +76,5 @@ func TestHashHighBytes(t *testing.T) {
}
// Make sure a Hash implements the hash.Hash and hash.Hash64 interfaces.
var
_
basehash
.
Hash
=
&
hash
.
Hash
{}
var
_
basehash
.
Hash64
=
&
hash
.
Hash
{}
var
_
hash
.
Hash
=
&
map
hash
.
Hash
{}
var
_
hash
.
Hash64
=
&
map
hash
.
Hash
{}
src/
bytes/
hash/smhasher_test.go
→
src/
hash/map
hash/smhasher_test.go
View file @
4497d7eb
...
...
@@ -2,11 +2,11 @@
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package
hash_test
package
map
hash_test
import
(
"bytes/hash"
"fmt"
"hash/maphash"
"math"
"math/rand"
"runtime"
...
...
@@ -45,14 +45,14 @@ func TestSmhasherSanity(t *testing.T) {
}
func
bytesHash
(
b
[]
byte
,
seed
uint64
)
uint64
{
h
:=
hash
.
New
()
h
.
SetSeed
(
hash
.
MakeSeed
(
seed
))
h
:=
map
hash
.
New
()
h
.
SetSeed
(
map
hash
.
MakeSeed
(
seed
))
h
.
AddBytes
(
b
)
return
h
.
Hash
()
}
func
stringHash
(
s
string
,
seed
uint64
)
uint64
{
h
:=
hash
.
New
()
h
.
SetSeed
(
hash
.
MakeSeed
(
seed
))
h
:=
map
hash
.
New
()
h
.
SetSeed
(
map
hash
.
MakeSeed
(
seed
))
h
.
AddString
(
s
)
return
h
.
Hash
()
}
...
...
src/make.bash
View file @
4497d7eb
...
...
@@ -162,7 +162,8 @@ IFS=$'\n'; for go_exe in $(type -ap go); do
fi
fi
done
;
unset
IFS
echo
"Building Go cmd/dist using
$GOROOT_BOOTSTRAP
."
GOROOT_BOOTSTRAP_VERSION
=
$(
$GOROOT_BOOTSTRAP
/bin/go version |
sed
's/go version //'
)
echo
"Building Go cmd/dist using
$GOROOT_BOOTSTRAP
. (
$GOROOT_BOOTSTRAP_VERSION
)"
if
$verbose
;
then
echo
cmd/dist
fi
...
...
src/net/http/header.go
View file @
4497d7eb
...
...
@@ -178,6 +178,7 @@ func (h Header) sortedKeyValues(exclude map[string]bool) (kvs []keyValues, hs *h
// WriteSubset writes a header in wire format.
// If exclude is not nil, keys where exclude[key] == true are not written.
// Keys are not canonicalized before checking the exclude map.
func
(
h
Header
)
WriteSubset
(
w
io
.
Writer
,
exclude
map
[
string
]
bool
)
error
{
return
h
.
writeSubset
(
w
,
exclude
,
nil
)
}
...
...
src/net/http/main_test.go
View file @
4497d7eb
...
...
@@ -122,7 +122,7 @@ func afterTest(t testing.TB) {
").noteClientGone("
:
"a closenotifier sender"
,
}
var
stacks
string
for
i
:=
0
;
i
<
4
;
i
++
{
for
i
:=
0
;
i
<
10
;
i
++
{
bad
=
""
stacks
=
strings
.
Join
(
interestingGoroutines
(),
"
\n\n
"
)
for
substr
,
what
:=
range
badSubstring
{
...
...
src/net/http/transport_test.go
View file @
4497d7eb
...
...
@@ -22,7 +22,6 @@ import (
"fmt"
"go/token"
"internal/nettrace"
"internal/testenv"
"io"
"io/ioutil"
"log"
...
...
@@ -2355,9 +2354,6 @@ func TestCancelRequestWithChannel(t *testing.T) {
}
func
TestCancelRequestWithChannelBeforeDo_Cancel
(
t
*
testing
.
T
)
{
if
os
.
Getenv
(
"GO_BUILDER_NAME"
)
==
"windows-amd64-longtest"
{
testenv
.
SkipFlaky
(
t
,
35122
)
}
testCancelRequestWithChannelBeforeDo
(
t
,
false
)
}
func
TestCancelRequestWithChannelBeforeDo_Context
(
t
*
testing
.
T
)
{
...
...
src/runtime/mgcscavenge.go
View file @
4497d7eb
...
...
@@ -136,9 +136,13 @@ func gcPaceScavenger() {
// physical page.
retainedNow
:=
heapRetained
()
// If we're already below our goal, publish the goal in case it changed
// then disable the background scavenger.
if
retainedNow
<=
retainedGoal
{
// If we're already below our goal or there's less the one physical page
// worth of work to do, publish the goal in case it changed then disable
// the background scavenger. We disable the background scavenger if there's
// less than one physical page of work to do to avoid a potential divide-by-zero
// in the calculations below (totalTime will be zero), and it's not worth
// turning on the scavenger for less than one page of work.
if
retainedNow
<=
retainedGoal
||
retainedNow
-
retainedGoal
<
uint64
(
physPageSize
)
{
mheap_
.
scavengeRetainedGoal
=
retainedGoal
mheap_
.
scavengeBytesPerNS
=
0
return
...
...
src/runtime/netpoll_solaris.go
View file @
4497d7eb
...
...
@@ -229,13 +229,21 @@ func netpoll(delay int64) gList {
var
events
[
128
]
portevent
retry
:
var
n
uint32
=
1
if
port_getn
(
portfd
,
&
events
[
0
],
uint32
(
len
(
events
)),
&
n
,
wait
)
<
0
{
if
e
:=
errno
();
e
!=
_EINTR
&&
e
!=
_ETIME
{
r
:=
port_getn
(
portfd
,
&
events
[
0
],
uint32
(
len
(
events
)),
&
n
,
wait
)
e
:=
errno
()
if
r
<
0
&&
e
==
_ETIME
&&
n
>
0
{
// As per port_getn(3C), an ETIME failure does not preclude the
// delivery of some number of events. Treat a timeout failure
// with delivered events as a success.
r
=
0
}
if
r
<
0
{
if
e
!=
_EINTR
&&
e
!=
_ETIME
{
print
(
"runtime: port_getn on fd "
,
portfd
,
" failed (errno="
,
e
,
")
\n
"
)
throw
(
"runtime: netpoll failed"
)
}
// If a timed sleep was interrupted
, just return to
// recalculate how long we should sleep now.
// If a timed sleep was interrupted
and there are no events,
//
just return to
recalculate how long we should sleep now.
if
delay
>
0
{
return
gList
{}
}
...
...
src/runtime/proc.go
View file @
4497d7eb
...
...
@@ -1625,6 +1625,7 @@ func dropm() {
// Return mp.curg to dead state.
casgstatus
(
mp
.
curg
,
_Gsyscall
,
_Gdead
)
mp
.
curg
.
preemptStop
=
false
atomic
.
Xadd
(
&
sched
.
ngsys
,
+
1
)
// Block signals before unminit.
...
...
@@ -4359,6 +4360,7 @@ func checkdead() {
}
unlock
(
&
allglock
)
if
grunning
==
0
{
// possible if main goroutine calls runtime·Goexit()
unlock
(
&
sched
.
lock
)
// unlock so that GODEBUG=scheddetail=1 doesn't hang
throw
(
"no goroutines (main called runtime.Goexit) - deadlock!"
)
}
...
...
@@ -4411,6 +4413,7 @@ func checkdead() {
}
getg
()
.
m
.
throwing
=
-
1
// do not dump full stacks
unlock
(
&
sched
.
lock
)
// unlock so that GODEBUG=scheddetail=1 doesn't hang
throw
(
"all goroutines are asleep - deadlock!"
)
}
...
...
src/runtime/time.go
View file @
4497d7eb
...
...
@@ -585,9 +585,10 @@ loop:
case
timerNoStatus
,
timerRemoved
:
// Timer was already run and t is no longer in a heap.
// Act like addtimer.
if
atomic
.
Cas
(
&
t
.
status
,
status
,
timerWaiting
)
{
wasRemoved
=
true
atomic
.
Store
(
&
t
.
status
,
timerWaiting
)
break
loop
}
case
timerRunning
,
timerRemoving
,
timerMoving
:
// The timer is being run or moved, by a different P.
// Wait for it to complete.
...
...
@@ -687,10 +688,11 @@ func resettimer(t *timer, when int64) {
for
{
switch
s
:=
atomic
.
Load
(
&
t
.
status
);
s
{
case
timerNoStatus
,
timerRemoved
:
atomic
.
Store
(
&
t
.
status
,
timerWaiting
)
if
atomic
.
Cas
(
&
t
.
status
,
s
,
timerWaiting
)
{
t
.
when
=
when
addInitializedTimer
(
t
)
return
}
case
timerDeleted
:
if
atomic
.
Cas
(
&
t
.
status
,
s
,
timerModifying
)
{
t
.
nextwhen
=
when
...
...
src/syscall/asm_linux_riscv64.s
0 → 100644
View file @
4497d7eb
//
Copyright
2019
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
.
#include "textflag.h"
//
//
System
calls
for
riscv64
,
Linux
//
//
func
Syscall
(
trap
int64
,
a1
,
a2
,
a3
int64
)
(
r1
,
r2
,
err
int64
)
TEXT
·
Syscall
(
SB
),
NOSPLIT
,$0-56
CALL
runtime
·
entersyscall
(
SB
)
MOV
a1
+
8
(
FP
),
A0
MOV
a2
+
16
(
FP
),
A1
MOV
a3
+
24
(
FP
),
A2
MOV
trap
+
0
(
FP
),
A7
//
syscall
entry
ECALL
MOV
$
-
4096
,
T0
BLTU
T0
,
A0
,
err
MOV
A0
,
r1
+
32
(
FP
)
//
r1
MOV
A1
,
r2
+
40
(
FP
)
//
r2
MOV
$
0
,
err
+
48
(
FP
)
//
errno
CALL
runtime
·
exitsyscall
(
SB
)
RET
err
:
MOV
$
-
1
,
T0
MOV
T0
,
r1
+
32
(
FP
)
//
r1
MOV
$
0
,
r2
+
40
(
FP
)
//
r2
SUB
A0
,
$
0
,
A0
MOV
A0
,
err
+
48
(
FP
)
//
errno
CALL
runtime
·
exitsyscall
(
SB
)
RET
//
func
Syscall6
(
trap
,
a1
,
a2
,
a3
,
a4
,
a5
,
a6
uintptr
)
(
r1
,
r2
,
err
uintptr
)
TEXT
·
Syscall6
(
SB
),
NOSPLIT
,$0-80
CALL
runtime
·
entersyscall
(
SB
)
MOV
a1
+
8
(
FP
),
A0
MOV
a2
+
16
(
FP
),
A1
MOV
a3
+
24
(
FP
),
A2
MOV
a4
+
32
(
FP
),
A3
MOV
a5
+
40
(
FP
),
A4
MOV
a6
+
48
(
FP
),
A5
MOV
trap
+
0
(
FP
),
A7
//
syscall
entry
ECALL
MOV
$
-
4096
,
T0
BLTU
T0
,
A0
,
err
MOV
A0
,
r1
+
56
(
FP
)
//
r1
MOV
A1
,
r2
+
64
(
FP
)
//
r2
MOV
$
0
,
err
+
72
(
FP
)
//
errno
CALL
runtime
·
exitsyscall
(
SB
)
RET
err
:
MOV
$
-
1
,
T0
MOV
T0
,
r1
+
56
(
FP
)
//
r1
MOV
$
0
,
r2
+
64
(
FP
)
//
r2
SUB
A0
,
$
0
,
A0
MOV
A0
,
err
+
72
(
FP
)
//
errno
CALL
runtime
·
exitsyscall
(
SB
)
RET
//
func
RawSyscall
(
trap
,
a1
,
a2
,
a3
uintptr
)
(
r1
,
r2
,
err
uintptr
)
TEXT
·
RawSyscall
(
SB
),
NOSPLIT
,$0-56
MOV
a1
+
8
(
FP
),
A0
MOV
a2
+
16
(
FP
),
A1
MOV
a3
+
24
(
FP
),
A2
MOV
trap
+
0
(
FP
),
A7
//
syscall
entry
ECALL
MOV
$
-
4096
,
T0
BLTU
T0
,
A0
,
err
MOV
A0
,
r1
+
32
(
FP
)
//
r1
MOV
A1
,
r2
+
40
(
FP
)
//
r2
MOV
$
0
,
err
+
48
(
FP
)
//
errno
RET
err
:
MOV
$
-
1
,
T0
MOV
T0
,
r1
+
32
(
FP
)
//
r1
MOV
$
0
,
r2
+
40
(
FP
)
//
r2
SUB
A0
,
$
0
,
A0
MOV
A0
,
err
+
48
(
FP
)
//
errno
RET
//
func
RawSyscall6
(
trap
,
a1
,
a2
,
a3
,
a4
,
a5
,
a6
uintptr
)
(
r1
,
r2
,
err
uintptr
)
TEXT
·
RawSyscall6
(
SB
),
NOSPLIT
,$0-80
MOV
a1
+
8
(
FP
),
A0
MOV
a2
+
16
(
FP
),
A1
MOV
a3
+
24
(
FP
),
A2
MOV
a4
+
32
(
FP
),
A3
MOV
a5
+
40
(
FP
),
A4
MOV
a6
+
48
(
FP
),
A5
MOV
trap
+
0
(
FP
),
A7
//
syscall
entry
ECALL
MOV
$
-
4096
,
T0
BLTU
T0
,
A0
,
err
MOV
A0
,
r1
+
56
(
FP
)
//
r1
MOV
A1
,
r2
+
64
(
FP
)
//
r2
MOV
$
0
,
err
+
72
(
FP
)
//
errno
RET
err
:
MOV
$
-
1
,
T0
MOV
T0
,
r1
+
56
(
FP
)
//
r1
MOV
$
0
,
r2
+
64
(
FP
)
//
r2
SUB
A0
,
$
0
,
A0
MOV
A0
,
err
+
72
(
FP
)
//
errno
RET
TEXT
·
rawSyscallNoError
(
SB
),
NOSPLIT
,$0-48
MOV
a1
+
8
(
FP
),
A0
MOV
a2
+
16
(
FP
),
A1
MOV
a3
+
24
(
FP
),
A2
MOV
trap
+
0
(
FP
),
A7
//
syscall
entry
ECALL
MOV
A0
,
r1
+
32
(
FP
)
MOV
A1
,
r2
+
40
(
FP
)
RET
src/syscall/endian_little.go
View file @
4497d7eb
...
...
@@ -2,7 +2,7 @@
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
//
// +build 386 amd64 arm arm64 ppc64le mips64le mipsle wasm
// +build 386 amd64 arm arm64 ppc64le mips64le mipsle
riscv64
wasm
package
syscall
...
...
src/syscall/mkall.sh
View file @
4497d7eb
...
...
@@ -258,6 +258,15 @@ linux_ppc64le)
mksysnum
=
"./mksysnum_linux.pl
$unistd_h
"
mktypes
=
"GOARCH=
$GOARCH
go tool cgo -godefs"
;;
linux_riscv64
)
unistd_h
=
$(
ls
-1
/usr/include/asm/unistd.h /usr/include/asm-generic/unistd.h 2>/dev/null |
head
-1
)
if
[
"
$unistd_h
"
=
""
]
;
then
echo
>
&2 cannot find unistd_64.h
exit
1
fi
mksysnum
=
"./mksysnum_linux.pl
$unistd_h
"
mktypes
=
"GOARCH=
$GOARCH
go tool cgo -godefs"
;;
linux_s390x
)
GOOSARCH_in
=
syscall_linux_s390x.go
unistd_h
=
/usr/include/asm/unistd.h
...
...
src/syscall/syscall_linux_riscv64.go
0 → 100644
View file @
4497d7eb
// Copyright 2019 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.
package
syscall
import
"unsafe"
const
(
_SYS_dup
=
SYS_DUP3
_SYS_setgroups
=
SYS_SETGROUPS
)
func
EpollCreate
(
size
int
)
(
fd
int
,
err
error
)
{
if
size
<=
0
{
return
-
1
,
EINVAL
}
return
EpollCreate1
(
0
)
}
//sys EpollWait(epfd int, events []EpollEvent, msec int) (n int, err error) = SYS_EPOLL_PWAIT
//sys Fchown(fd int, uid int, gid int) (err error)
//sys Fstat(fd int, stat *Stat_t) (err error)
//sys Fstatat(fd int, path string, stat *Stat_t, flags int) (err error)
//sys fstatat(dirfd int, path string, stat *Stat_t, flags int) (err error)
//sys Fstatfs(fd int, buf *Statfs_t) (err error)
//sys Ftruncate(fd int, length int64) (err error)
//sysnb Getegid() (egid int)
//sysnb Geteuid() (euid int)
//sysnb Getgid() (gid int)
//sysnb Getrlimit(resource int, rlim *Rlimit) (err error)
//sysnb Getuid() (uid int)
//sys Listen(s int, n int) (err error)
//sys Pread(fd int, p []byte, offset int64) (n int, err error) = SYS_PREAD64
//sys Pwrite(fd int, p []byte, offset int64) (n int, err error) = SYS_PWRITE64
//sys Renameat(olddirfd int, oldpath string, newdirfd int, newpath string) (err error)
//sys Seek(fd int, offset int64, whence int) (off int64, err error) = SYS_LSEEK
//sys sendfile(outfd int, infd int, offset *int64, count int) (written int, err error)
//sys Setfsgid(gid int) (err error)
//sys Setfsuid(uid int) (err error)
//sysnb Setregid(rgid int, egid int) (err error)
//sysnb Setresgid(rgid int, egid int, sgid int) (err error)
//sysnb Setresuid(ruid int, euid int, suid int) (err error)
//sysnb Setrlimit(resource int, rlim *Rlimit) (err error)
//sysnb Setreuid(ruid int, euid int) (err error)
//sys Shutdown(fd int, how int) (err error)
//sys Splice(rfd int, roff *int64, wfd int, woff *int64, len int, flags int) (n int64, err error)
func
Stat
(
path
string
,
stat
*
Stat_t
)
(
err
error
)
{
return
Fstatat
(
_AT_FDCWD
,
path
,
stat
,
0
)
}
func
Lchown
(
path
string
,
uid
int
,
gid
int
)
(
err
error
)
{
return
Fchownat
(
_AT_FDCWD
,
path
,
uid
,
gid
,
_AT_SYMLINK_NOFOLLOW
)
}
func
Lstat
(
path
string
,
stat
*
Stat_t
)
(
err
error
)
{
return
Fstatat
(
_AT_FDCWD
,
path
,
stat
,
_AT_SYMLINK_NOFOLLOW
)
}
//sys Statfs(path string, buf *Statfs_t) (err error)
//sys SyncFileRange(fd int, off int64, n int64, flags int) (err error)
//sys Truncate(path string, length int64) (err error)
//sys accept(s int, rsa *RawSockaddrAny, addrlen *_Socklen) (fd int, err error)
//sys accept4(s int, rsa *RawSockaddrAny, addrlen *_Socklen, flags int) (fd int, err error)
//sys bind(s int, addr unsafe.Pointer, addrlen _Socklen) (err error)
//sys connect(s int, addr unsafe.Pointer, addrlen _Socklen) (err error)
//sysnb getgroups(n int, list *_Gid_t) (nn int, err error)
//sysnb setgroups(n int, list *_Gid_t) (err error)
//sys getsockopt(s int, level int, name int, val unsafe.Pointer, vallen *_Socklen) (err error)
//sys setsockopt(s int, level int, name int, val unsafe.Pointer, vallen uintptr) (err error)
//sysnb socket(domain int, typ int, proto int) (fd int, err error)
//sysnb socketpair(domain int, typ int, proto int, fd *[2]int32) (err error)
//sysnb getpeername(fd int, rsa *RawSockaddrAny, addrlen *_Socklen) (err error)
//sysnb getsockname(fd int, rsa *RawSockaddrAny, addrlen *_Socklen) (err error)
//sys recvfrom(fd int, p []byte, flags int, from *RawSockaddrAny, fromlen *_Socklen) (n int, err error)
//sys sendto(s int, buf []byte, flags int, to unsafe.Pointer, addrlen _Socklen) (err error)
//sys recvmsg(s int, msg *Msghdr, flags int) (n int, err error)
//sys sendmsg(s int, msg *Msghdr, flags int) (n int, err error)
//sys mmap(addr uintptr, length uintptr, prot int, flags int, fd int, offset int64) (xaddr uintptr, err error)
type
sigset_t
struct
{
X__val
[
16
]
uint64
}
//sys pselect(nfd int, r *FdSet, w *FdSet, e *FdSet, timeout *Timespec, sigmask *sigset_t) (n int, err error) = SYS_PSELECT6
func
Select
(
nfd
int
,
r
*
FdSet
,
w
*
FdSet
,
e
*
FdSet
,
timeout
*
Timeval
)
(
n
int
,
err
error
)
{
var
ts
*
Timespec
if
timeout
!=
nil
{
ts
=
&
Timespec
{
Sec
:
timeout
.
Sec
,
Nsec
:
timeout
.
Usec
*
1000
}
}
return
pselect
(
nfd
,
r
,
w
,
e
,
ts
,
nil
)
}
//sysnb Gettimeofday(tv *Timeval) (err error)
func
setTimespec
(
sec
,
nsec
int64
)
Timespec
{
return
Timespec
{
Sec
:
sec
,
Nsec
:
nsec
}
}
func
setTimeval
(
sec
,
usec
int64
)
Timeval
{
return
Timeval
{
Sec
:
sec
,
Usec
:
usec
}
}
func
futimesat
(
dirfd
int
,
path
string
,
tv
*
[
2
]
Timeval
)
(
err
error
)
{
if
tv
==
nil
{
return
utimensat
(
dirfd
,
path
,
nil
,
0
)
}
ts
:=
[]
Timespec
{
NsecToTimespec
(
TimevalToNsec
(
tv
[
0
])),
NsecToTimespec
(
TimevalToNsec
(
tv
[
1
])),
}
return
utimensat
(
dirfd
,
path
,
(
*
[
2
]
Timespec
)(
unsafe
.
Pointer
(
&
ts
[
0
])),
0
)
}
func
Time
(
t
*
Time_t
)
(
Time_t
,
error
)
{
var
tv
Timeval
err
:=
Gettimeofday
(
&
tv
)
if
err
!=
nil
{
return
0
,
err
}
if
t
!=
nil
{
*
t
=
Time_t
(
tv
.
Sec
)
}
return
Time_t
(
tv
.
Sec
),
nil
}
func
Utime
(
path
string
,
buf
*
Utimbuf
)
error
{
tv
:=
[]
Timeval
{
{
Sec
:
buf
.
Actime
},
{
Sec
:
buf
.
Modtime
},
}
return
Utimes
(
path
,
tv
)
}
func
utimes
(
path
string
,
tv
*
[
2
]
Timeval
)
(
err
error
)
{
if
tv
==
nil
{
return
utimensat
(
_AT_FDCWD
,
path
,
nil
,
0
)
}
ts
:=
[]
Timespec
{
NsecToTimespec
(
TimevalToNsec
(
tv
[
0
])),
NsecToTimespec
(
TimevalToNsec
(
tv
[
1
])),
}
return
utimensat
(
_AT_FDCWD
,
path
,
(
*
[
2
]
Timespec
)(
unsafe
.
Pointer
(
&
ts
[
0
])),
0
)
}
func
Pipe
(
p
[]
int
)
(
err
error
)
{
if
len
(
p
)
!=
2
{
return
EINVAL
}
var
pp
[
2
]
_C_int
err
=
pipe2
(
&
pp
,
0
)
p
[
0
]
=
int
(
pp
[
0
])
p
[
1
]
=
int
(
pp
[
1
])
return
}
//sysnb pipe2(p *[2]_C_int, flags int) (err error)
func
Pipe2
(
p
[]
int
,
flags
int
)
(
err
error
)
{
if
len
(
p
)
!=
2
{
return
EINVAL
}
var
pp
[
2
]
_C_int
err
=
pipe2
(
&
pp
,
flags
)
p
[
0
]
=
int
(
pp
[
0
])
p
[
1
]
=
int
(
pp
[
1
])
return
}
func
(
r
*
PtraceRegs
)
PC
()
uint64
{
return
r
.
Pc
}
func
(
r
*
PtraceRegs
)
SetPC
(
pc
uint64
)
{
r
.
Pc
=
pc
}
func
(
iov
*
Iovec
)
SetLen
(
length
int
)
{
iov
.
Len
=
uint64
(
length
)
}
func
(
msghdr
*
Msghdr
)
SetControllen
(
length
int
)
{
msghdr
.
Controllen
=
uint64
(
length
)
}
func
(
cmsg
*
Cmsghdr
)
SetLen
(
length
int
)
{
cmsg
.
Len
=
uint64
(
length
)
}
func
InotifyInit
()
(
fd
int
,
err
error
)
{
return
InotifyInit1
(
0
)
}
//sys ppoll(fds *pollFd, nfds int, timeout *Timespec, sigmask *sigset_t) (n int, err error)
func
Pause
()
error
{
_
,
err
:=
ppoll
(
nil
,
0
,
nil
,
nil
)
return
err
}
func
rawVforkSyscall
(
trap
,
a1
uintptr
)
(
r1
uintptr
,
err
Errno
)
{
panic
(
"not implemented"
)
}
src/syscall/types_linux.go
View file @
4497d7eb
...
...
@@ -76,8 +76,8 @@ struct sockaddr_any {
// copied from /usr/include/linux/un.h
struct my_sockaddr_un {
sa_family_t sun_family;
#if defined(__ARM_EABI__) || defined(__powerpc64__) || defined(__s390x__)
// on ARM, PPC and s390x char is by default unsigned
#if defined(__ARM_EABI__) || defined(__powerpc64__) || defined(__
riscv__) || defined(__
s390x__)
// on ARM, PPC
, RISC-V,
and s390x char is by default unsigned
signed char sun_path[108];
#else
char sun_path[108];
...
...
@@ -116,7 +116,7 @@ struct my_epoll_event {
// alignment requirements of EABI
int32_t padFd;
#endif
#if defined(__powerpc64__) || defined(__s390x__)
#if defined(__powerpc64__) || defined(__s390x__)
|| (defined(__riscv_xlen) && __riscv_xlen == 64)
int32_t _padFd;
#endif
int32_t fd;
...
...
src/syscall/zerrors_linux_riscv64.go
0 → 100644
View file @
4497d7eb
// mkerrors.sh
// MACHINE GENERATED BY THE COMMAND ABOVE; DO NOT EDIT
// Created by cgo -godefs - DO NOT EDIT
// cgo -godefs -- _const.go
package
syscall
const
(
AF_ALG
=
0x26
AF_APPLETALK
=
0x5
AF_ASH
=
0x12
AF_ATMPVC
=
0x8
AF_ATMSVC
=
0x14
AF_AX25
=
0x3
AF_BLUETOOTH
=
0x1f
AF_BRIDGE
=
0x7
AF_CAIF
=
0x25
AF_CAN
=
0x1d
AF_DECnet
=
0xc
AF_ECONET
=
0x13
AF_FILE
=
0x1
AF_IB
=
0x1b
AF_IEEE802154
=
0x24
AF_INET
=
0x2
AF_INET6
=
0xa
AF_IPX
=
0x4
AF_IRDA
=
0x17
AF_ISDN
=
0x22
AF_IUCV
=
0x20
AF_KCM
=
0x29
AF_KEY
=
0xf
AF_LLC
=
0x1a
AF_LOCAL
=
0x1
AF_MAX
=
0x2a
AF_MPLS
=
0x1c
AF_NETBEUI
=
0xd
AF_NETLINK
=
0x10
AF_NETROM
=
0x6
AF_NFC
=
0x27
AF_PACKET
=
0x11
AF_PHONET
=
0x23
AF_PPPOX
=
0x18
AF_RDS
=
0x15
AF_ROSE
=
0xb
AF_ROUTE
=
0x10
AF_RXRPC
=
0x21
AF_SECURITY
=
0xe
AF_SNA
=
0x16
AF_TIPC
=
0x1e
AF_UNIX
=
0x1
AF_UNSPEC
=
0x0
AF_VSOCK
=
0x28
AF_WANPIPE
=
0x19
AF_X25
=
0x9
ARPHRD_6LOWPAN
=
0x339
ARPHRD_ADAPT
=
0x108
ARPHRD_APPLETLK
=
0x8
ARPHRD_ARCNET
=
0x7
ARPHRD_ASH
=
0x30d
ARPHRD_ATM
=
0x13
ARPHRD_AX25
=
0x3
ARPHRD_BIF
=
0x307
ARPHRD_CAIF
=
0x336
ARPHRD_CAN
=
0x118
ARPHRD_CHAOS
=
0x5
ARPHRD_CISCO
=
0x201
ARPHRD_CSLIP
=
0x101
ARPHRD_CSLIP6
=
0x103
ARPHRD_DDCMP
=
0x205
ARPHRD_DLCI
=
0xf
ARPHRD_ECONET
=
0x30e
ARPHRD_EETHER
=
0x2
ARPHRD_ETHER
=
0x1
ARPHRD_EUI64
=
0x1b
ARPHRD_FCAL
=
0x311
ARPHRD_FCFABRIC
=
0x313
ARPHRD_FCPL
=
0x312
ARPHRD_FCPP
=
0x310
ARPHRD_FDDI
=
0x306
ARPHRD_FRAD
=
0x302
ARPHRD_HDLC
=
0x201
ARPHRD_HIPPI
=
0x30c
ARPHRD_HWX25
=
0x110
ARPHRD_IEEE1394
=
0x18
ARPHRD_IEEE802
=
0x6
ARPHRD_IEEE80211
=
0x321
ARPHRD_IEEE80211_PRISM
=
0x322
ARPHRD_IEEE80211_RADIOTAP
=
0x323
ARPHRD_IEEE802154
=
0x324
ARPHRD_IEEE802154_MONITOR
=
0x325
ARPHRD_IEEE802_TR
=
0x320
ARPHRD_INFINIBAND
=
0x20
ARPHRD_IP6GRE
=
0x337
ARPHRD_IPDDP
=
0x309
ARPHRD_IPGRE
=
0x30a
ARPHRD_IRDA
=
0x30f
ARPHRD_LAPB
=
0x204
ARPHRD_LOCALTLK
=
0x305
ARPHRD_LOOPBACK
=
0x304
ARPHRD_METRICOM
=
0x17
ARPHRD_NETLINK
=
0x338
ARPHRD_NETROM
=
0x0
ARPHRD_NONE
=
0xfffe
ARPHRD_PHONET
=
0x334
ARPHRD_PHONET_PIPE
=
0x335
ARPHRD_PIMREG
=
0x30b
ARPHRD_PPP
=
0x200
ARPHRD_PRONET
=
0x4
ARPHRD_RAWHDLC
=
0x206
ARPHRD_ROSE
=
0x10e
ARPHRD_RSRVD
=
0x104
ARPHRD_SIT
=
0x308
ARPHRD_SKIP
=
0x303
ARPHRD_SLIP
=
0x100
ARPHRD_SLIP6
=
0x102
ARPHRD_TUNNEL
=
0x300
ARPHRD_TUNNEL6
=
0x301
ARPHRD_VOID
=
0xffff
ARPHRD_X25
=
0x10f
B0
=
0x0
B1000000
=
0x1008
B110
=
0x3
B115200
=
0x1002
B1152000
=
0x1009
B1200
=
0x9
B134
=
0x4
B150
=
0x5
B1500000
=
0x100a
B1800
=
0xa
B19200
=
0xe
B200
=
0x6
B2000000
=
0x100b
B230400
=
0x1003
B2400
=
0xb
B2500000
=
0x100c
B300
=
0x7
B3000000
=
0x100d
B3500000
=
0x100e
B38400
=
0xf
B4000000
=
0x100f
B460800
=
0x1004
B4800
=
0xc
B50
=
0x1
B500000
=
0x1005
B57600
=
0x1001
B576000
=
0x1006
B600
=
0x8
B75
=
0x2
B921600
=
0x1007
B9600
=
0xd
BPF_A
=
0x10
BPF_ABS
=
0x20
BPF_ADD
=
0x0
BPF_ALU
=
0x4
BPF_AND
=
0x50
BPF_B
=
0x10
BPF_DIV
=
0x30
BPF_H
=
0x8
BPF_IMM
=
0x0
BPF_IND
=
0x40
BPF_JA
=
0x0
BPF_JEQ
=
0x10
BPF_JGE
=
0x30
BPF_JGT
=
0x20
BPF_JMP
=
0x5
BPF_JSET
=
0x40
BPF_K
=
0x0
BPF_LD
=
0x0
BPF_LDX
=
0x1
BPF_LEN
=
0x80
BPF_LL_OFF
=
-
0x200000
BPF_LSH
=
0x60
BPF_MAJOR_VERSION
=
0x1
BPF_MAXINSNS
=
0x1000
BPF_MEM
=
0x60
BPF_MEMWORDS
=
0x10
BPF_MINOR_VERSION
=
0x1
BPF_MISC
=
0x7
BPF_MOD
=
0x90
BPF_MSH
=
0xa0
BPF_MUL
=
0x20
BPF_NEG
=
0x80
BPF_NET_OFF
=
-
0x100000
BPF_OR
=
0x40
BPF_RET
=
0x6
BPF_RSH
=
0x70
BPF_ST
=
0x2
BPF_STX
=
0x3
BPF_SUB
=
0x10
BPF_TAX
=
0x0
BPF_TXA
=
0x80
BPF_W
=
0x0
BPF_X
=
0x8
BPF_XOR
=
0xa0
BRKINT
=
0x2
CFLUSH
=
0xf
CLOCAL
=
0x800
CLONE_CHILD_CLEARTID
=
0x200000
CLONE_CHILD_SETTID
=
0x1000000
CLONE_DETACHED
=
0x400000
CLONE_FILES
=
0x400
CLONE_FS
=
0x200
CLONE_IO
=
0x80000000
CLONE_NEWIPC
=
0x8000000
CLONE_NEWNET
=
0x40000000
CLONE_NEWNS
=
0x20000
CLONE_NEWPID
=
0x20000000
CLONE_NEWUSER
=
0x10000000
CLONE_NEWUTS
=
0x4000000
CLONE_PARENT
=
0x8000
CLONE_PARENT_SETTID
=
0x100000
CLONE_PTRACE
=
0x2000
CLONE_SETTLS
=
0x80000
CLONE_SIGHAND
=
0x800
CLONE_SYSVSEM
=
0x40000
CLONE_THREAD
=
0x10000
CLONE_UNTRACED
=
0x800000
CLONE_VFORK
=
0x4000
CLONE_VM
=
0x100
CREAD
=
0x80
CS5
=
0x0
CS6
=
0x10
CS7
=
0x20
CS8
=
0x30
CSIGNAL
=
0xff
CSIZE
=
0x30
CSTART
=
0x11
CSTATUS
=
0x0
CSTOP
=
0x13
CSTOPB
=
0x40
CSUSP
=
0x1a
DT_BLK
=
0x6
DT_CHR
=
0x2
DT_DIR
=
0x4
DT_FIFO
=
0x1
DT_LNK
=
0xa
DT_REG
=
0x8
DT_SOCK
=
0xc
DT_UNKNOWN
=
0x0
DT_WHT
=
0xe
ECHO
=
0x8
ECHOCTL
=
0x200
ECHOE
=
0x10
ECHOK
=
0x20
ECHOKE
=
0x800
ECHONL
=
0x40
ECHOPRT
=
0x400
ENCODING_DEFAULT
=
0x0
ENCODING_FM_MARK
=
0x3
ENCODING_FM_SPACE
=
0x4
ENCODING_MANCHESTER
=
0x5
ENCODING_NRZ
=
0x1
ENCODING_NRZI
=
0x2
EPOLLERR
=
0x8
EPOLLET
=
0x80000000
EPOLLEXCLUSIVE
=
0x10000000
EPOLLHUP
=
0x10
EPOLLIN
=
0x1
EPOLLMSG
=
0x400
EPOLLONESHOT
=
0x40000000
EPOLLOUT
=
0x4
EPOLLPRI
=
0x2
EPOLLRDBAND
=
0x80
EPOLLRDHUP
=
0x2000
EPOLLRDNORM
=
0x40
EPOLLWAKEUP
=
0x20000000
EPOLLWRBAND
=
0x200
EPOLLWRNORM
=
0x100
EPOLL_CLOEXEC
=
0x80000
EPOLL_CTL_ADD
=
0x1
EPOLL_CTL_DEL
=
0x2
EPOLL_CTL_MOD
=
0x3
ETH_P_1588
=
0x88f7
ETH_P_8021AD
=
0x88a8
ETH_P_8021AH
=
0x88e7
ETH_P_8021Q
=
0x8100
ETH_P_80221
=
0x8917
ETH_P_802_2
=
0x4
ETH_P_802_3
=
0x1
ETH_P_802_3_MIN
=
0x600
ETH_P_802_EX1
=
0x88b5
ETH_P_AARP
=
0x80f3
ETH_P_AF_IUCV
=
0xfbfb
ETH_P_ALL
=
0x3
ETH_P_AOE
=
0x88a2
ETH_P_ARCNET
=
0x1a
ETH_P_ARP
=
0x806
ETH_P_ATALK
=
0x809b
ETH_P_ATMFATE
=
0x8884
ETH_P_ATMMPOA
=
0x884c
ETH_P_AX25
=
0x2
ETH_P_BATMAN
=
0x4305
ETH_P_BPQ
=
0x8ff
ETH_P_CAIF
=
0xf7
ETH_P_CAN
=
0xc
ETH_P_CANFD
=
0xd
ETH_P_CONTROL
=
0x16
ETH_P_CUST
=
0x6006
ETH_P_DDCMP
=
0x6
ETH_P_DEC
=
0x6000
ETH_P_DIAG
=
0x6005
ETH_P_DNA_DL
=
0x6001
ETH_P_DNA_RC
=
0x6002
ETH_P_DNA_RT
=
0x6003
ETH_P_DSA
=
0x1b
ETH_P_ECONET
=
0x18
ETH_P_EDSA
=
0xdada
ETH_P_FCOE
=
0x8906
ETH_P_FIP
=
0x8914
ETH_P_HDLC
=
0x19
ETH_P_IEEE802154
=
0xf6
ETH_P_IEEEPUP
=
0xa00
ETH_P_IEEEPUPAT
=
0xa01
ETH_P_IP
=
0x800
ETH_P_IPV6
=
0x86dd
ETH_P_IPX
=
0x8137
ETH_P_IRDA
=
0x17
ETH_P_LAT
=
0x6004
ETH_P_LINK_CTL
=
0x886c
ETH_P_LOCALTALK
=
0x9
ETH_P_LOOP
=
0x60
ETH_P_LOOPBACK
=
0x9000
ETH_P_MOBITEX
=
0x15
ETH_P_MPLS_MC
=
0x8848
ETH_P_MPLS_UC
=
0x8847
ETH_P_MVRP
=
0x88f5
ETH_P_PAE
=
0x888e
ETH_P_PAUSE
=
0x8808
ETH_P_PHONET
=
0xf5
ETH_P_PPPTALK
=
0x10
ETH_P_PPP_DISC
=
0x8863
ETH_P_PPP_MP
=
0x8
ETH_P_PPP_SES
=
0x8864
ETH_P_PRP
=
0x88fb
ETH_P_PUP
=
0x200
ETH_P_PUPAT
=
0x201
ETH_P_QINQ1
=
0x9100
ETH_P_QINQ2
=
0x9200
ETH_P_QINQ3
=
0x9300
ETH_P_RARP
=
0x8035
ETH_P_SCA
=
0x6007
ETH_P_SLOW
=
0x8809
ETH_P_SNAP
=
0x5
ETH_P_TDLS
=
0x890d
ETH_P_TEB
=
0x6558
ETH_P_TIPC
=
0x88ca
ETH_P_TRAILER
=
0x1c
ETH_P_TR_802_2
=
0x11
ETH_P_WAN_PPP
=
0x7
ETH_P_WCCP
=
0x883e
ETH_P_X25
=
0x805
ETH_P_XDSA
=
0xf8
EXTA
=
0xe
EXTB
=
0xf
EXTPROC
=
0x10000
FD_CLOEXEC
=
0x1
FD_SETSIZE
=
0x400
FLUSHO
=
0x1000
F_DUPFD
=
0x0
F_DUPFD_CLOEXEC
=
0x406
F_EXLCK
=
0x4
F_GETFD
=
0x1
F_GETFL
=
0x3
F_GETLEASE
=
0x401
F_GETLK
=
0x5
F_GETLK64
=
0x5
F_GETOWN
=
0x9
F_GETOWN_EX
=
0x10
F_GETPIPE_SZ
=
0x408
F_GETSIG
=
0xb
F_LOCK
=
0x1
F_NOTIFY
=
0x402
F_OFD_GETLK
=
0x24
F_OFD_SETLK
=
0x25
F_OFD_SETLKW
=
0x26
F_OK
=
0x0
F_RDLCK
=
0x0
F_SETFD
=
0x2
F_SETFL
=
0x4
F_SETLEASE
=
0x400
F_SETLK
=
0x6
F_SETLK64
=
0x6
F_SETLKW
=
0x7
F_SETLKW64
=
0x7
F_SETOWN
=
0x8
F_SETOWN_EX
=
0xf
F_SETPIPE_SZ
=
0x407
F_SETSIG
=
0xa
F_SHLCK
=
0x8
F_TEST
=
0x3
F_TLOCK
=
0x2
F_ULOCK
=
0x0
F_UNLCK
=
0x2
F_WRLCK
=
0x1
HUPCL
=
0x400
ICANON
=
0x2
ICMPV6_FILTER
=
0x1
ICRNL
=
0x100
IEXTEN
=
0x8000
IFA_F_DADFAILED
=
0x8
IFA_F_DEPRECATED
=
0x20
IFA_F_HOMEADDRESS
=
0x10
IFA_F_MANAGETEMPADDR
=
0x100
IFA_F_MCAUTOJOIN
=
0x400
IFA_F_NODAD
=
0x2
IFA_F_NOPREFIXROUTE
=
0x200
IFA_F_OPTIMISTIC
=
0x4
IFA_F_PERMANENT
=
0x80
IFA_F_SECONDARY
=
0x1
IFA_F_STABLE_PRIVACY
=
0x800
IFA_F_TEMPORARY
=
0x1
IFA_F_TENTATIVE
=
0x40
IFA_MAX
=
0x8
IFF_ALLMULTI
=
0x200
IFF_ATTACH_QUEUE
=
0x200
IFF_AUTOMEDIA
=
0x4000
IFF_BROADCAST
=
0x2
IFF_DEBUG
=
0x4
IFF_DETACH_QUEUE
=
0x400
IFF_DORMANT
=
0x20000
IFF_DYNAMIC
=
0x8000
IFF_ECHO
=
0x40000
IFF_LOOPBACK
=
0x8
IFF_LOWER_UP
=
0x10000
IFF_MASTER
=
0x400
IFF_MULTICAST
=
0x1000
IFF_MULTI_QUEUE
=
0x100
IFF_NOARP
=
0x80
IFF_NOFILTER
=
0x1000
IFF_NOTRAILERS
=
0x20
IFF_NO_PI
=
0x1000
IFF_ONE_QUEUE
=
0x2000
IFF_PERSIST
=
0x800
IFF_POINTOPOINT
=
0x10
IFF_PORTSEL
=
0x2000
IFF_PROMISC
=
0x100
IFF_RUNNING
=
0x40
IFF_SLAVE
=
0x800
IFF_TAP
=
0x2
IFF_TUN
=
0x1
IFF_TUN_EXCL
=
0x8000
IFF_UP
=
0x1
IFF_VNET_HDR
=
0x4000
IFF_VOLATILE
=
0x70c5a
IFNAMSIZ
=
0x10
IGNBRK
=
0x1
IGNCR
=
0x80
IGNPAR
=
0x4
IMAXBEL
=
0x2000
INLCR
=
0x40
INPCK
=
0x10
IN_ACCESS
=
0x1
IN_ALL_EVENTS
=
0xfff
IN_ATTRIB
=
0x4
IN_CLASSA_HOST
=
0xffffff
IN_CLASSA_MAX
=
0x80
IN_CLASSA_NET
=
0xff000000
IN_CLASSA_NSHIFT
=
0x18
IN_CLASSB_HOST
=
0xffff
IN_CLASSB_MAX
=
0x10000
IN_CLASSB_NET
=
0xffff0000
IN_CLASSB_NSHIFT
=
0x10
IN_CLASSC_HOST
=
0xff
IN_CLASSC_NET
=
0xffffff00
IN_CLASSC_NSHIFT
=
0x8
IN_CLOEXEC
=
0x80000
IN_CLOSE
=
0x18
IN_CLOSE_NOWRITE
=
0x10
IN_CLOSE_WRITE
=
0x8
IN_CREATE
=
0x100
IN_DELETE
=
0x200
IN_DELETE_SELF
=
0x400
IN_DONT_FOLLOW
=
0x2000000
IN_EXCL_UNLINK
=
0x4000000
IN_IGNORED
=
0x8000
IN_ISDIR
=
0x40000000
IN_LOOPBACKNET
=
0x7f
IN_MASK_ADD
=
0x20000000
IN_MODIFY
=
0x2
IN_MOVE
=
0xc0
IN_MOVED_FROM
=
0x40
IN_MOVED_TO
=
0x80
IN_MOVE_SELF
=
0x800
IN_NONBLOCK
=
0x800
IN_ONESHOT
=
0x80000000
IN_ONLYDIR
=
0x1000000
IN_OPEN
=
0x20
IN_Q_OVERFLOW
=
0x4000
IN_UNMOUNT
=
0x2000
IPPROTO_AH
=
0x33
IPPROTO_BEETPH
=
0x5e
IPPROTO_COMP
=
0x6c
IPPROTO_DCCP
=
0x21
IPPROTO_DSTOPTS
=
0x3c
IPPROTO_EGP
=
0x8
IPPROTO_ENCAP
=
0x62
IPPROTO_ESP
=
0x32
IPPROTO_FRAGMENT
=
0x2c
IPPROTO_GRE
=
0x2f
IPPROTO_HOPOPTS
=
0x0
IPPROTO_ICMP
=
0x1
IPPROTO_ICMPV6
=
0x3a
IPPROTO_IDP
=
0x16
IPPROTO_IGMP
=
0x2
IPPROTO_IP
=
0x0
IPPROTO_IPIP
=
0x4
IPPROTO_IPV6
=
0x29
IPPROTO_MH
=
0x87
IPPROTO_MPLS
=
0x89
IPPROTO_MTP
=
0x5c
IPPROTO_NONE
=
0x3b
IPPROTO_PIM
=
0x67
IPPROTO_PUP
=
0xc
IPPROTO_RAW
=
0xff
IPPROTO_ROUTING
=
0x2b
IPPROTO_RSVP
=
0x2e
IPPROTO_SCTP
=
0x84
IPPROTO_TCP
=
0x6
IPPROTO_TP
=
0x1d
IPPROTO_UDP
=
0x11
IPPROTO_UDPLITE
=
0x88
IPV6_2292DSTOPTS
=
0x4
IPV6_2292HOPLIMIT
=
0x8
IPV6_2292HOPOPTS
=
0x3
IPV6_2292PKTINFO
=
0x2
IPV6_2292PKTOPTIONS
=
0x6
IPV6_2292RTHDR
=
0x5
IPV6_ADDRFORM
=
0x1
IPV6_ADD_MEMBERSHIP
=
0x14
IPV6_AUTHHDR
=
0xa
IPV6_CHECKSUM
=
0x7
IPV6_DONTFRAG
=
0x3e
IPV6_DROP_MEMBERSHIP
=
0x15
IPV6_DSTOPTS
=
0x3b
IPV6_HDRINCL
=
0x24
IPV6_HOPLIMIT
=
0x34
IPV6_HOPOPTS
=
0x36
IPV6_IPSEC_POLICY
=
0x22
IPV6_JOIN_ANYCAST
=
0x1b
IPV6_JOIN_GROUP
=
0x14
IPV6_LEAVE_ANYCAST
=
0x1c
IPV6_LEAVE_GROUP
=
0x15
IPV6_MTU
=
0x18
IPV6_MTU_DISCOVER
=
0x17
IPV6_MULTICAST_HOPS
=
0x12
IPV6_MULTICAST_IF
=
0x11
IPV6_MULTICAST_LOOP
=
0x13
IPV6_NEXTHOP
=
0x9
IPV6_PATHMTU
=
0x3d
IPV6_PKTINFO
=
0x32
IPV6_PMTUDISC_DO
=
0x2
IPV6_PMTUDISC_DONT
=
0x0
IPV6_PMTUDISC_INTERFACE
=
0x4
IPV6_PMTUDISC_OMIT
=
0x5
IPV6_PMTUDISC_PROBE
=
0x3
IPV6_PMTUDISC_WANT
=
0x1
IPV6_RECVDSTOPTS
=
0x3a
IPV6_RECVERR
=
0x19
IPV6_RECVHOPLIMIT
=
0x33
IPV6_RECVHOPOPTS
=
0x35
IPV6_RECVPATHMTU
=
0x3c
IPV6_RECVPKTINFO
=
0x31
IPV6_RECVRTHDR
=
0x38
IPV6_RECVTCLASS
=
0x42
IPV6_ROUTER_ALERT
=
0x16
IPV6_RTHDR
=
0x39
IPV6_RTHDRDSTOPTS
=
0x37
IPV6_RTHDR_LOOSE
=
0x0
IPV6_RTHDR_STRICT
=
0x1
IPV6_RTHDR_TYPE_0
=
0x0
IPV6_RXDSTOPTS
=
0x3b
IPV6_RXHOPOPTS
=
0x36
IPV6_TCLASS
=
0x43
IPV6_UNICAST_HOPS
=
0x10
IPV6_V6ONLY
=
0x1a
IPV6_XFRM_POLICY
=
0x23
IP_ADD_MEMBERSHIP
=
0x23
IP_ADD_SOURCE_MEMBERSHIP
=
0x27
IP_BIND_ADDRESS_NO_PORT
=
0x18
IP_BLOCK_SOURCE
=
0x26
IP_CHECKSUM
=
0x17
IP_DEFAULT_MULTICAST_LOOP
=
0x1
IP_DEFAULT_MULTICAST_TTL
=
0x1
IP_DF
=
0x4000
IP_DROP_MEMBERSHIP
=
0x24
IP_DROP_SOURCE_MEMBERSHIP
=
0x28
IP_FREEBIND
=
0xf
IP_HDRINCL
=
0x3
IP_IPSEC_POLICY
=
0x10
IP_MAXPACKET
=
0xffff
IP_MAX_MEMBERSHIPS
=
0x14
IP_MF
=
0x2000
IP_MINTTL
=
0x15
IP_MSFILTER
=
0x29
IP_MSS
=
0x240
IP_MTU
=
0xe
IP_MTU_DISCOVER
=
0xa
IP_MULTICAST_ALL
=
0x31
IP_MULTICAST_IF
=
0x20
IP_MULTICAST_LOOP
=
0x22
IP_MULTICAST_TTL
=
0x21
IP_NODEFRAG
=
0x16
IP_OFFMASK
=
0x1fff
IP_OPTIONS
=
0x4
IP_ORIGDSTADDR
=
0x14
IP_PASSSEC
=
0x12
IP_PKTINFO
=
0x8
IP_PKTOPTIONS
=
0x9
IP_PMTUDISC
=
0xa
IP_PMTUDISC_DO
=
0x2
IP_PMTUDISC_DONT
=
0x0
IP_PMTUDISC_INTERFACE
=
0x4
IP_PMTUDISC_OMIT
=
0x5
IP_PMTUDISC_PROBE
=
0x3
IP_PMTUDISC_WANT
=
0x1
IP_RECVERR
=
0xb
IP_RECVOPTS
=
0x6
IP_RECVORIGDSTADDR
=
0x14
IP_RECVRETOPTS
=
0x7
IP_RECVTOS
=
0xd
IP_RECVTTL
=
0xc
IP_RETOPTS
=
0x7
IP_RF
=
0x8000
IP_ROUTER_ALERT
=
0x5
IP_TOS
=
0x1
IP_TRANSPARENT
=
0x13
IP_TTL
=
0x2
IP_UNBLOCK_SOURCE
=
0x25
IP_UNICAST_IF
=
0x32
IP_XFRM_POLICY
=
0x11
ISIG
=
0x1
ISTRIP
=
0x20
IUTF8
=
0x4000
IXANY
=
0x800
IXOFF
=
0x1000
IXON
=
0x400
LINUX_REBOOT_CMD_CAD_OFF
=
0x0
LINUX_REBOOT_CMD_CAD_ON
=
0x89abcdef
LINUX_REBOOT_CMD_HALT
=
0xcdef0123
LINUX_REBOOT_CMD_KEXEC
=
0x45584543
LINUX_REBOOT_CMD_POWER_OFF
=
0x4321fedc
LINUX_REBOOT_CMD_RESTART
=
0x1234567
LINUX_REBOOT_CMD_RESTART2
=
0xa1b2c3d4
LINUX_REBOOT_CMD_SW_SUSPEND
=
0xd000fce2
LINUX_REBOOT_MAGIC1
=
0xfee1dead
LINUX_REBOOT_MAGIC2
=
0x28121969
LOCK_EX
=
0x2
LOCK_NB
=
0x4
LOCK_SH
=
0x1
LOCK_UN
=
0x8
MADV_DODUMP
=
0x11
MADV_DOFORK
=
0xb
MADV_DONTDUMP
=
0x10
MADV_DONTFORK
=
0xa
MADV_DONTNEED
=
0x4
MADV_FREE
=
0x8
MADV_HUGEPAGE
=
0xe
MADV_HWPOISON
=
0x64
MADV_MERGEABLE
=
0xc
MADV_NOHUGEPAGE
=
0xf
MADV_NORMAL
=
0x0
MADV_RANDOM
=
0x1
MADV_REMOVE
=
0x9
MADV_SEQUENTIAL
=
0x2
MADV_UNMERGEABLE
=
0xd
MADV_WILLNEED
=
0x3
MAP_ANON
=
0x20
MAP_ANONYMOUS
=
0x20
MAP_DENYWRITE
=
0x800
MAP_EXECUTABLE
=
0x1000
MAP_FILE
=
0x0
MAP_FIXED
=
0x10
MAP_GROWSDOWN
=
0x100
MAP_HUGETLB
=
0x40000
MAP_HUGE_MASK
=
0x3f
MAP_HUGE_SHIFT
=
0x1a
MAP_LOCKED
=
0x2000
MAP_NONBLOCK
=
0x10000
MAP_NORESERVE
=
0x4000
MAP_POPULATE
=
0x8000
MAP_PRIVATE
=
0x2
MAP_SHARED
=
0x1
MAP_STACK
=
0x20000
MAP_TYPE
=
0xf
MCL_CURRENT
=
0x1
MCL_FUTURE
=
0x2
MCL_ONFAULT
=
0x4
MNT_DETACH
=
0x2
MNT_EXPIRE
=
0x4
MNT_FORCE
=
0x1
MSG_BATCH
=
0x40000
MSG_CMSG_CLOEXEC
=
0x40000000
MSG_CONFIRM
=
0x800
MSG_CTRUNC
=
0x8
MSG_DONTROUTE
=
0x4
MSG_DONTWAIT
=
0x40
MSG_EOR
=
0x80
MSG_ERRQUEUE
=
0x2000
MSG_FASTOPEN
=
0x20000000
MSG_FIN
=
0x200
MSG_MORE
=
0x8000
MSG_NOSIGNAL
=
0x4000
MSG_OOB
=
0x1
MSG_PEEK
=
0x2
MSG_PROXY
=
0x10
MSG_RST
=
0x1000
MSG_SYN
=
0x400
MSG_TRUNC
=
0x20
MSG_TRYHARD
=
0x4
MSG_WAITALL
=
0x100
MSG_WAITFORONE
=
0x10000
MS_ACTIVE
=
0x40000000
MS_ASYNC
=
0x1
MS_BIND
=
0x1000
MS_DIRSYNC
=
0x80
MS_INVALIDATE
=
0x2
MS_I_VERSION
=
0x800000
MS_KERNMOUNT
=
0x400000
MS_LAZYTIME
=
0x2000000
MS_MANDLOCK
=
0x40
MS_MGC_MSK
=
0xffff0000
MS_MGC_VAL
=
0xc0ed0000
MS_MOVE
=
0x2000
MS_NOATIME
=
0x400
MS_NODEV
=
0x4
MS_NODIRATIME
=
0x800
MS_NOEXEC
=
0x8
MS_NOSUID
=
0x2
MS_NOUSER
=
-
0x80000000
MS_POSIXACL
=
0x10000
MS_PRIVATE
=
0x40000
MS_RDONLY
=
0x1
MS_REC
=
0x4000
MS_RELATIME
=
0x200000
MS_REMOUNT
=
0x20
MS_RMT_MASK
=
0x2800051
MS_SHARED
=
0x100000
MS_SILENT
=
0x8000
MS_SLAVE
=
0x80000
MS_STRICTATIME
=
0x1000000
MS_SYNC
=
0x4
MS_SYNCHRONOUS
=
0x10
MS_UNBINDABLE
=
0x20000
NAME_MAX
=
0xff
NETLINK_ADD_MEMBERSHIP
=
0x1
NETLINK_AUDIT
=
0x9
NETLINK_BROADCAST_ERROR
=
0x4
NETLINK_CONNECTOR
=
0xb
NETLINK_CRYPTO
=
0x15
NETLINK_DNRTMSG
=
0xe
NETLINK_DROP_MEMBERSHIP
=
0x2
NETLINK_ECRYPTFS
=
0x13
NETLINK_FIB_LOOKUP
=
0xa
NETLINK_FIREWALL
=
0x3
NETLINK_GENERIC
=
0x10
NETLINK_INET_DIAG
=
0x4
NETLINK_IP6_FW
=
0xd
NETLINK_ISCSI
=
0x8
NETLINK_KOBJECT_UEVENT
=
0xf
NETLINK_NETFILTER
=
0xc
NETLINK_NFLOG
=
0x5
NETLINK_NO_ENOBUFS
=
0x5
NETLINK_PKTINFO
=
0x3
NETLINK_RDMA
=
0x14
NETLINK_ROUTE
=
0x0
NETLINK_RX_RING
=
0x6
NETLINK_SCSITRANSPORT
=
0x12
NETLINK_SELINUX
=
0x7
NETLINK_SOCK_DIAG
=
0x4
NETLINK_TX_RING
=
0x7
NETLINK_UNUSED
=
0x1
NETLINK_USERSOCK
=
0x2
NETLINK_XFRM
=
0x6
NLA_ALIGNTO
=
0x4
NLA_F_NESTED
=
0x8000
NLA_F_NET_BYTEORDER
=
0x4000
NLA_HDRLEN
=
0x4
NLMSG_ALIGNTO
=
0x4
NLMSG_DONE
=
0x3
NLMSG_ERROR
=
0x2
NLMSG_HDRLEN
=
0x10
NLMSG_MIN_TYPE
=
0x10
NLMSG_NOOP
=
0x1
NLMSG_OVERRUN
=
0x4
NLM_F_ACK
=
0x4
NLM_F_APPEND
=
0x800
NLM_F_ATOMIC
=
0x400
NLM_F_CREATE
=
0x400
NLM_F_DUMP
=
0x300
NLM_F_DUMP_INTR
=
0x10
NLM_F_ECHO
=
0x8
NLM_F_EXCL
=
0x200
NLM_F_MATCH
=
0x200
NLM_F_MULTI
=
0x2
NLM_F_REPLACE
=
0x100
NLM_F_REQUEST
=
0x1
NLM_F_ROOT
=
0x100
NOFLSH
=
0x80
OCRNL
=
0x8
OFDEL
=
0x80
OFILL
=
0x40
ONLCR
=
0x4
ONLRET
=
0x20
ONOCR
=
0x10
OPOST
=
0x1
O_ACCMODE
=
0x3
O_APPEND
=
0x400
O_ASYNC
=
0x2000
O_CLOEXEC
=
0x80000
O_CREAT
=
0x40
O_DIRECT
=
0x4000
O_DIRECTORY
=
0x10000
O_DSYNC
=
0x1000
O_EXCL
=
0x80
O_FSYNC
=
0x101000
O_LARGEFILE
=
0x0
O_NDELAY
=
0x800
O_NOATIME
=
0x40000
O_NOCTTY
=
0x100
O_NOFOLLOW
=
0x20000
O_NONBLOCK
=
0x800
O_PATH
=
0x200000
O_RDONLY
=
0x0
O_RDWR
=
0x2
O_RSYNC
=
0x101000
O_SYNC
=
0x101000
O_TMPFILE
=
0x410000
O_TRUNC
=
0x200
O_WRONLY
=
0x1
PACKET_ADD_MEMBERSHIP
=
0x1
PACKET_AUXDATA
=
0x8
PACKET_BROADCAST
=
0x1
PACKET_COPY_THRESH
=
0x7
PACKET_DROP_MEMBERSHIP
=
0x2
PACKET_FANOUT
=
0x12
PACKET_FANOUT_CPU
=
0x2
PACKET_FANOUT_FLAG_DEFRAG
=
0x8000
PACKET_FANOUT_FLAG_ROLLOVER
=
0x1000
PACKET_FANOUT_HASH
=
0x0
PACKET_FANOUT_LB
=
0x1
PACKET_FANOUT_QM
=
0x5
PACKET_FANOUT_RND
=
0x4
PACKET_FANOUT_ROLLOVER
=
0x3
PACKET_FASTROUTE
=
0x6
PACKET_HDRLEN
=
0xb
PACKET_HOST
=
0x0
PACKET_KERNEL
=
0x7
PACKET_LOOPBACK
=
0x5
PACKET_LOSS
=
0xe
PACKET_MR_ALLMULTI
=
0x2
PACKET_MR_MULTICAST
=
0x0
PACKET_MR_PROMISC
=
0x1
PACKET_MR_UNICAST
=
0x3
PACKET_MULTICAST
=
0x2
PACKET_ORIGDEV
=
0x9
PACKET_OTHERHOST
=
0x3
PACKET_OUTGOING
=
0x4
PACKET_QDISC_BYPASS
=
0x14
PACKET_RECV_OUTPUT
=
0x3
PACKET_RESERVE
=
0xc
PACKET_RX_RING
=
0x5
PACKET_STATISTICS
=
0x6
PACKET_TIMESTAMP
=
0x11
PACKET_TX_HAS_OFF
=
0x13
PACKET_TX_RING
=
0xd
PACKET_TX_TIMESTAMP
=
0x10
PACKET_USER
=
0x6
PACKET_VERSION
=
0xa
PACKET_VNET_HDR
=
0xf
PARENB
=
0x100
PARITY_CRC16_PR0
=
0x2
PARITY_CRC16_PR0_CCITT
=
0x4
PARITY_CRC16_PR1
=
0x3
PARITY_CRC16_PR1_CCITT
=
0x5
PARITY_CRC32_PR0_CCITT
=
0x6
PARITY_CRC32_PR1_CCITT
=
0x7
PARITY_DEFAULT
=
0x0
PARITY_NONE
=
0x1
PARMRK
=
0x8
PARODD
=
0x200
PENDIN
=
0x4000
PRIO_PGRP
=
0x1
PRIO_PROCESS
=
0x0
PRIO_USER
=
0x2
PROT_EXEC
=
0x4
PROT_GROWSDOWN
=
0x1000000
PROT_GROWSUP
=
0x2000000
PROT_NONE
=
0x0
PROT_READ
=
0x1
PROT_WRITE
=
0x2
PR_CAPBSET_DROP
=
0x18
PR_CAPBSET_READ
=
0x17
PR_ENDIAN_BIG
=
0x0
PR_ENDIAN_LITTLE
=
0x1
PR_ENDIAN_PPC_LITTLE
=
0x2
PR_FPEMU_NOPRINT
=
0x1
PR_FPEMU_SIGFPE
=
0x2
PR_FP_EXC_ASYNC
=
0x2
PR_FP_EXC_DISABLED
=
0x0
PR_FP_EXC_DIV
=
0x10000
PR_FP_EXC_INV
=
0x100000
PR_FP_EXC_NONRECOV
=
0x1
PR_FP_EXC_OVF
=
0x20000
PR_FP_EXC_PRECISE
=
0x3
PR_FP_EXC_RES
=
0x80000
PR_FP_EXC_SW_ENABLE
=
0x80
PR_FP_EXC_UND
=
0x40000
PR_FP_MODE_FR
=
0x1
PR_FP_MODE_FRE
=
0x2
PR_GET_CHILD_SUBREAPER
=
0x25
PR_GET_DUMPABLE
=
0x3
PR_GET_ENDIAN
=
0x13
PR_GET_FPEMU
=
0x9
PR_GET_FPEXC
=
0xb
PR_GET_FP_MODE
=
0x2e
PR_GET_KEEPCAPS
=
0x7
PR_GET_NAME
=
0x10
PR_GET_NO_NEW_PRIVS
=
0x27
PR_GET_PDEATHSIG
=
0x2
PR_GET_SECCOMP
=
0x15
PR_GET_SECUREBITS
=
0x1b
PR_GET_THP_DISABLE
=
0x2a
PR_GET_TID_ADDRESS
=
0x28
PR_GET_TIMERSLACK
=
0x1e
PR_GET_TIMING
=
0xd
PR_GET_TSC
=
0x19
PR_GET_UNALIGN
=
0x5
PR_MCE_KILL
=
0x21
PR_MCE_KILL_CLEAR
=
0x0
PR_MCE_KILL_DEFAULT
=
0x2
PR_MCE_KILL_EARLY
=
0x1
PR_MCE_KILL_GET
=
0x22
PR_MCE_KILL_LATE
=
0x0
PR_MCE_KILL_SET
=
0x1
PR_MPX_DISABLE_MANAGEMENT
=
0x2c
PR_MPX_ENABLE_MANAGEMENT
=
0x2b
PR_SET_CHILD_SUBREAPER
=
0x24
PR_SET_DUMPABLE
=
0x4
PR_SET_ENDIAN
=
0x14
PR_SET_FPEMU
=
0xa
PR_SET_FPEXC
=
0xc
PR_SET_FP_MODE
=
0x2d
PR_SET_KEEPCAPS
=
0x8
PR_SET_MM
=
0x23
PR_SET_MM_ARG_END
=
0x9
PR_SET_MM_ARG_START
=
0x8
PR_SET_MM_AUXV
=
0xc
PR_SET_MM_BRK
=
0x7
PR_SET_MM_END_CODE
=
0x2
PR_SET_MM_END_DATA
=
0x4
PR_SET_MM_ENV_END
=
0xb
PR_SET_MM_ENV_START
=
0xa
PR_SET_MM_EXE_FILE
=
0xd
PR_SET_MM_MAP
=
0xe
PR_SET_MM_MAP_SIZE
=
0xf
PR_SET_MM_START_BRK
=
0x6
PR_SET_MM_START_CODE
=
0x1
PR_SET_MM_START_DATA
=
0x3
PR_SET_MM_START_STACK
=
0x5
PR_SET_NAME
=
0xf
PR_SET_NO_NEW_PRIVS
=
0x26
PR_SET_PDEATHSIG
=
0x1
PR_SET_PTRACER
=
0x59616d61
PR_SET_PTRACER_ANY
=
-
0x1
PR_SET_SECCOMP
=
0x16
PR_SET_SECUREBITS
=
0x1c
PR_SET_THP_DISABLE
=
0x29
PR_SET_TIMERSLACK
=
0x1d
PR_SET_TIMING
=
0xe
PR_SET_TSC
=
0x1a
PR_SET_UNALIGN
=
0x6
PR_TASK_PERF_EVENTS_DISABLE
=
0x1f
PR_TASK_PERF_EVENTS_ENABLE
=
0x20
PR_TIMING_STATISTICAL
=
0x0
PR_TIMING_TIMESTAMP
=
0x1
PR_TSC_ENABLE
=
0x1
PR_TSC_SIGSEGV
=
0x2
PR_UNALIGN_NOPRINT
=
0x1
PR_UNALIGN_SIGBUS
=
0x2
PTRACE_ATTACH
=
0x10
PTRACE_CONT
=
0x7
PTRACE_DETACH
=
0x11
PTRACE_EVENT_CLONE
=
0x3
PTRACE_EVENT_EXEC
=
0x4
PTRACE_EVENT_EXIT
=
0x6
PTRACE_EVENT_FORK
=
0x1
PTRACE_EVENT_SECCOMP
=
0x7
PTRACE_EVENT_STOP
=
0x80
PTRACE_EVENT_VFORK
=
0x2
PTRACE_EVENT_VFORK_DONE
=
0x5
PTRACE_GETEVENTMSG
=
0x4201
PTRACE_GETREGS
=
0xc
PTRACE_GETREGSET
=
0x4204
PTRACE_GETSIGINFO
=
0x4202
PTRACE_GETSIGMASK
=
0x420a
PTRACE_INTERRUPT
=
0x4207
PTRACE_KILL
=
0x8
PTRACE_LISTEN
=
0x4208
PTRACE_O_EXITKILL
=
0x100000
PTRACE_O_MASK
=
0x1000ff
PTRACE_O_TRACECLONE
=
0x8
PTRACE_O_TRACEEXEC
=
0x10
PTRACE_O_TRACEEXIT
=
0x40
PTRACE_O_TRACEFORK
=
0x2
PTRACE_O_TRACESECCOMP
=
0x80
PTRACE_O_TRACESYSGOOD
=
0x1
PTRACE_O_TRACEVFORK
=
0x4
PTRACE_O_TRACEVFORKDONE
=
0x20
PTRACE_PEEKDATA
=
0x2
PTRACE_PEEKSIGINFO
=
0x4209
PTRACE_PEEKSIGINFO_SHARED
=
0x1
PTRACE_PEEKTEXT
=
0x1
PTRACE_PEEKUSR
=
0x3
PTRACE_POKEDATA
=
0x5
PTRACE_POKETEXT
=
0x4
PTRACE_POKEUSR
=
0x6
PTRACE_SEIZE
=
0x4206
PTRACE_SETOPTIONS
=
0x4200
PTRACE_SETREGS
=
0xd
PTRACE_SETREGSET
=
0x4205
PTRACE_SETSIGINFO
=
0x4203
PTRACE_SETSIGMASK
=
0x420b
PTRACE_SINGLESTEP
=
0x9
PTRACE_SYSCALL
=
0x18
PTRACE_TRACEME
=
0x0
RLIMIT_AS
=
0x9
RLIMIT_CORE
=
0x4
RLIMIT_CPU
=
0x0
RLIMIT_DATA
=
0x2
RLIMIT_FSIZE
=
0x1
RLIMIT_NOFILE
=
0x7
RLIMIT_STACK
=
0x3
RLIM_INFINITY
=
-
0x1
RTAX_ADVMSS
=
0x8
RTAX_CC_ALGO
=
0x10
RTAX_CWND
=
0x7
RTAX_FEATURES
=
0xc
RTAX_FEATURE_ALLFRAG
=
0x8
RTAX_FEATURE_ECN
=
0x1
RTAX_FEATURE_SACK
=
0x2
RTAX_FEATURE_TIMESTAMP
=
0x4
RTAX_HOPLIMIT
=
0xa
RTAX_INITCWND
=
0xb
RTAX_INITRWND
=
0xe
RTAX_LOCK
=
0x1
RTAX_MAX
=
0x10
RTAX_MTU
=
0x2
RTAX_QUICKACK
=
0xf
RTAX_REORDERING
=
0x9
RTAX_RTO_MIN
=
0xd
RTAX_RTT
=
0x4
RTAX_RTTVAR
=
0x5
RTAX_SSTHRESH
=
0x6
RTAX_UNSPEC
=
0x0
RTAX_WINDOW
=
0x3
RTA_ALIGNTO
=
0x4
RTA_MAX
=
0x14
RTCF_DIRECTSRC
=
0x4000000
RTCF_DOREDIRECT
=
0x1000000
RTCF_LOG
=
0x2000000
RTCF_MASQ
=
0x400000
RTCF_NAT
=
0x800000
RTCF_VALVE
=
0x200000
RTF_ADDRCLASSMASK
=
0xf8000000
RTF_ADDRCONF
=
0x40000
RTF_ALLONLINK
=
0x20000
RTF_BROADCAST
=
0x10000000
RTF_CACHE
=
0x1000000
RTF_DEFAULT
=
0x10000
RTF_DYNAMIC
=
0x10
RTF_FLOW
=
0x2000000
RTF_GATEWAY
=
0x2
RTF_HOST
=
0x4
RTF_INTERFACE
=
0x40000000
RTF_IRTT
=
0x100
RTF_LINKRT
=
0x100000
RTF_LOCAL
=
0x80000000
RTF_MODIFIED
=
0x20
RTF_MSS
=
0x40
RTF_MTU
=
0x40
RTF_MULTICAST
=
0x20000000
RTF_NAT
=
0x8000000
RTF_NOFORWARD
=
0x1000
RTF_NONEXTHOP
=
0x200000
RTF_NOPMTUDISC
=
0x4000
RTF_POLICY
=
0x4000000
RTF_REINSTATE
=
0x8
RTF_REJECT
=
0x200
RTF_STATIC
=
0x400
RTF_THROW
=
0x2000
RTF_UP
=
0x1
RTF_WINDOW
=
0x80
RTF_XRESOLVE
=
0x800
RTM_BASE
=
0x10
RTM_DELACTION
=
0x31
RTM_DELADDR
=
0x15
RTM_DELADDRLABEL
=
0x49
RTM_DELLINK
=
0x11
RTM_DELMDB
=
0x55
RTM_DELNEIGH
=
0x1d
RTM_DELNSID
=
0x59
RTM_DELQDISC
=
0x25
RTM_DELROUTE
=
0x19
RTM_DELRULE
=
0x21
RTM_DELTCLASS
=
0x29
RTM_DELTFILTER
=
0x2d
RTM_F_CLONED
=
0x200
RTM_F_EQUALIZE
=
0x400
RTM_F_NOTIFY
=
0x100
RTM_F_PREFIX
=
0x800
RTM_GETACTION
=
0x32
RTM_GETADDR
=
0x16
RTM_GETADDRLABEL
=
0x4a
RTM_GETANYCAST
=
0x3e
RTM_GETDCB
=
0x4e
RTM_GETLINK
=
0x12
RTM_GETMDB
=
0x56
RTM_GETMULTICAST
=
0x3a
RTM_GETNEIGH
=
0x1e
RTM_GETNEIGHTBL
=
0x42
RTM_GETNETCONF
=
0x52
RTM_GETNSID
=
0x5a
RTM_GETQDISC
=
0x26
RTM_GETROUTE
=
0x1a
RTM_GETRULE
=
0x22
RTM_GETTCLASS
=
0x2a
RTM_GETTFILTER
=
0x2e
RTM_MAX
=
0x5b
RTM_NEWACTION
=
0x30
RTM_NEWADDR
=
0x14
RTM_NEWADDRLABEL
=
0x48
RTM_NEWLINK
=
0x10
RTM_NEWMDB
=
0x54
RTM_NEWNDUSEROPT
=
0x44
RTM_NEWNEIGH
=
0x1c
RTM_NEWNEIGHTBL
=
0x40
RTM_NEWNETCONF
=
0x50
RTM_NEWNSID
=
0x58
RTM_NEWPREFIX
=
0x34
RTM_NEWQDISC
=
0x24
RTM_NEWROUTE
=
0x18
RTM_NEWRULE
=
0x20
RTM_NEWTCLASS
=
0x28
RTM_NEWTFILTER
=
0x2c
RTM_NR_FAMILIES
=
0x13
RTM_NR_MSGTYPES
=
0x4c
RTM_SETDCB
=
0x4f
RTM_SETLINK
=
0x13
RTM_SETNEIGHTBL
=
0x43
RTNH_ALIGNTO
=
0x4
RTNH_F_DEAD
=
0x1
RTNH_F_OFFLOAD
=
0x8
RTNH_F_ONLINK
=
0x4
RTNH_F_PERVASIVE
=
0x2
RTN_MAX
=
0xb
RTPROT_BABEL
=
0x2a
RTPROT_BIRD
=
0xc
RTPROT_BOOT
=
0x3
RTPROT_DHCP
=
0x10
RTPROT_DNROUTED
=
0xd
RTPROT_GATED
=
0x8
RTPROT_KERNEL
=
0x2
RTPROT_MROUTED
=
0x11
RTPROT_MRT
=
0xa
RTPROT_NTK
=
0xf
RTPROT_RA
=
0x9
RTPROT_REDIRECT
=
0x1
RTPROT_STATIC
=
0x4
RTPROT_UNSPEC
=
0x0
RTPROT_XORP
=
0xe
RTPROT_ZEBRA
=
0xb
RT_CLASS_DEFAULT
=
0xfd
RT_CLASS_LOCAL
=
0xff
RT_CLASS_MAIN
=
0xfe
RT_CLASS_MAX
=
0xff
RT_CLASS_UNSPEC
=
0x0
RUSAGE_CHILDREN
=
-
0x1
RUSAGE_SELF
=
0x0
RUSAGE_THREAD
=
0x1
SCM_CREDENTIALS
=
0x2
SCM_RIGHTS
=
0x1
SCM_TIMESTAMP
=
0x1d
SCM_TIMESTAMPING
=
0x25
SCM_TIMESTAMPNS
=
0x23
SCM_WIFI_STATUS
=
0x29
SHUT_RD
=
0x0
SHUT_RDWR
=
0x2
SHUT_WR
=
0x1
SIOCADDDLCI
=
0x8980
SIOCADDMULTI
=
0x8931
SIOCADDRT
=
0x890b
SIOCATMARK
=
0x8905
SIOCDARP
=
0x8953
SIOCDELDLCI
=
0x8981
SIOCDELMULTI
=
0x8932
SIOCDELRT
=
0x890c
SIOCDEVPRIVATE
=
0x89f0
SIOCDIFADDR
=
0x8936
SIOCDRARP
=
0x8960
SIOCGARP
=
0x8954
SIOCGIFADDR
=
0x8915
SIOCGIFBR
=
0x8940
SIOCGIFBRDADDR
=
0x8919
SIOCGIFCONF
=
0x8912
SIOCGIFCOUNT
=
0x8938
SIOCGIFDSTADDR
=
0x8917
SIOCGIFENCAP
=
0x8925
SIOCGIFFLAGS
=
0x8913
SIOCGIFHWADDR
=
0x8927
SIOCGIFINDEX
=
0x8933
SIOCGIFMAP
=
0x8970
SIOCGIFMEM
=
0x891f
SIOCGIFMETRIC
=
0x891d
SIOCGIFMTU
=
0x8921
SIOCGIFNAME
=
0x8910
SIOCGIFNETMASK
=
0x891b
SIOCGIFPFLAGS
=
0x8935
SIOCGIFSLAVE
=
0x8929
SIOCGIFTXQLEN
=
0x8942
SIOCGPGRP
=
0x8904
SIOCGRARP
=
0x8961
SIOCGSTAMP
=
0x8906
SIOCGSTAMPNS
=
0x8907
SIOCPROTOPRIVATE
=
0x89e0
SIOCRTMSG
=
0x890d
SIOCSARP
=
0x8955
SIOCSIFADDR
=
0x8916
SIOCSIFBR
=
0x8941
SIOCSIFBRDADDR
=
0x891a
SIOCSIFDSTADDR
=
0x8918
SIOCSIFENCAP
=
0x8926
SIOCSIFFLAGS
=
0x8914
SIOCSIFHWADDR
=
0x8924
SIOCSIFHWBROADCAST
=
0x8937
SIOCSIFLINK
=
0x8911
SIOCSIFMAP
=
0x8971
SIOCSIFMEM
=
0x8920
SIOCSIFMETRIC
=
0x891e
SIOCSIFMTU
=
0x8922
SIOCSIFNAME
=
0x8923
SIOCSIFNETMASK
=
0x891c
SIOCSIFPFLAGS
=
0x8934
SIOCSIFSLAVE
=
0x8930
SIOCSIFTXQLEN
=
0x8943
SIOCSPGRP
=
0x8902
SIOCSRARP
=
0x8962
SOCK_CLOEXEC
=
0x80000
SOCK_DCCP
=
0x6
SOCK_DGRAM
=
0x2
SOCK_NONBLOCK
=
0x800
SOCK_PACKET
=
0xa
SOCK_RAW
=
0x3
SOCK_RDM
=
0x4
SOCK_SEQPACKET
=
0x5
SOCK_STREAM
=
0x1
SOL_AAL
=
0x109
SOL_ALG
=
0x117
SOL_ATM
=
0x108
SOL_BLUETOOTH
=
0x112
SOL_CAIF
=
0x116
SOL_DCCP
=
0x10d
SOL_DECNET
=
0x105
SOL_ICMPV6
=
0x3a
SOL_IP
=
0x0
SOL_IPV6
=
0x29
SOL_IRDA
=
0x10a
SOL_IUCV
=
0x115
SOL_KCM
=
0x119
SOL_LLC
=
0x10c
SOL_NETBEUI
=
0x10b
SOL_NETLINK
=
0x10e
SOL_NFC
=
0x118
SOL_PACKET
=
0x107
SOL_PNPIPE
=
0x113
SOL_PPPOL2TP
=
0x111
SOL_RAW
=
0xff
SOL_RDS
=
0x114
SOL_RXRPC
=
0x110
SOL_SOCKET
=
0x1
SOL_TCP
=
0x6
SOL_TIPC
=
0x10f
SOL_X25
=
0x106
SOMAXCONN
=
0x80
SO_ACCEPTCONN
=
0x1e
SO_ATTACH_BPF
=
0x32
SO_ATTACH_FILTER
=
0x1a
SO_BINDTODEVICE
=
0x19
SO_BPF_EXTENSIONS
=
0x30
SO_BROADCAST
=
0x6
SO_BSDCOMPAT
=
0xe
SO_BUSY_POLL
=
0x2e
SO_DEBUG
=
0x1
SO_DETACH_BPF
=
0x1b
SO_DETACH_FILTER
=
0x1b
SO_DOMAIN
=
0x27
SO_DONTROUTE
=
0x5
SO_ERROR
=
0x4
SO_GET_FILTER
=
0x1a
SO_INCOMING_CPU
=
0x31
SO_KEEPALIVE
=
0x9
SO_LINGER
=
0xd
SO_LOCK_FILTER
=
0x2c
SO_MARK
=
0x24
SO_MAX_PACING_RATE
=
0x2f
SO_NOFCS
=
0x2b
SO_NO_CHECK
=
0xb
SO_OOBINLINE
=
0xa
SO_PASSCRED
=
0x10
SO_PASSSEC
=
0x22
SO_PEEK_OFF
=
0x2a
SO_PEERCRED
=
0x11
SO_PEERNAME
=
0x1c
SO_PEERSEC
=
0x1f
SO_PRIORITY
=
0xc
SO_PROTOCOL
=
0x26
SO_RCVBUF
=
0x8
SO_RCVBUFFORCE
=
0x21
SO_RCVLOWAT
=
0x12
SO_RCVTIMEO
=
0x14
SO_REUSEADDR
=
0x2
SO_REUSEPORT
=
0xf
SO_RXQ_OVFL
=
0x28
SO_SECURITY_AUTHENTICATION
=
0x16
SO_SECURITY_ENCRYPTION_NETWORK
=
0x18
SO_SECURITY_ENCRYPTION_TRANSPORT
=
0x17
SO_SELECT_ERR_QUEUE
=
0x2d
SO_SNDBUF
=
0x7
SO_SNDBUFFORCE
=
0x20
SO_SNDLOWAT
=
0x13
SO_SNDTIMEO
=
0x15
SO_TIMESTAMP
=
0x1d
SO_TIMESTAMPING
=
0x25
SO_TIMESTAMPNS
=
0x23
SO_TYPE
=
0x3
SO_WIFI_STATUS
=
0x29
S_BLKSIZE
=
0x200
S_IEXEC
=
0x40
S_IFBLK
=
0x6000
S_IFCHR
=
0x2000
S_IFDIR
=
0x4000
S_IFIFO
=
0x1000
S_IFLNK
=
0xa000
S_IFMT
=
0xf000
S_IFREG
=
0x8000
S_IFSOCK
=
0xc000
S_IREAD
=
0x100
S_IRGRP
=
0x20
S_IROTH
=
0x4
S_IRUSR
=
0x100
S_IRWXG
=
0x38
S_IRWXO
=
0x7
S_IRWXU
=
0x1c0
S_ISGID
=
0x400
S_ISUID
=
0x800
S_ISVTX
=
0x200
S_IWGRP
=
0x10
S_IWOTH
=
0x2
S_IWRITE
=
0x80
S_IWUSR
=
0x80
S_IXGRP
=
0x8
S_IXOTH
=
0x1
S_IXUSR
=
0x40
TCFLSH
=
0x540b
TCIFLUSH
=
0x0
TCIOFLUSH
=
0x2
TCOFLUSH
=
0x1
TCP_CC_INFO
=
0x1a
TCP_CONGESTION
=
0xd
TCP_COOKIE_IN_ALWAYS
=
0x1
TCP_COOKIE_MAX
=
0x10
TCP_COOKIE_MIN
=
0x8
TCP_COOKIE_OUT_NEVER
=
0x2
TCP_COOKIE_PAIR_SIZE
=
0x20
TCP_COOKIE_TRANSACTIONS
=
0xf
TCP_CORK
=
0x3
TCP_DEFER_ACCEPT
=
0x9
TCP_FASTOPEN
=
0x17
TCP_INFO
=
0xb
TCP_KEEPCNT
=
0x6
TCP_KEEPIDLE
=
0x4
TCP_KEEPINTVL
=
0x5
TCP_LINGER2
=
0x8
TCP_MAXSEG
=
0x2
TCP_MAXWIN
=
0xffff
TCP_MAX_WINSHIFT
=
0xe
TCP_MD5SIG
=
0xe
TCP_MD5SIG_MAXKEYLEN
=
0x50
TCP_MSS
=
0x200
TCP_MSS_DEFAULT
=
0x218
TCP_MSS_DESIRED
=
0x4c4
TCP_NODELAY
=
0x1
TCP_NOTSENT_LOWAT
=
0x19
TCP_QUEUE_SEQ
=
0x15
TCP_QUICKACK
=
0xc
TCP_REPAIR
=
0x13
TCP_REPAIR_OPTIONS
=
0x16
TCP_REPAIR_QUEUE
=
0x14
TCP_SAVED_SYN
=
0x1c
TCP_SAVE_SYN
=
0x1b
TCP_SYNCNT
=
0x7
TCP_S_DATA_IN
=
0x4
TCP_S_DATA_OUT
=
0x8
TCP_THIN_DUPACK
=
0x11
TCP_THIN_LINEAR_TIMEOUTS
=
0x10
TCP_TIMESTAMP
=
0x18
TCP_USER_TIMEOUT
=
0x12
TCP_WINDOW_CLAMP
=
0xa
TCSAFLUSH
=
0x2
TIOCCBRK
=
0x5428
TIOCCONS
=
0x541d
TIOCEXCL
=
0x540c
TIOCGDEV
=
0x80045432
TIOCGETD
=
0x5424
TIOCGEXCL
=
0x80045440
TIOCGICOUNT
=
0x545d
TIOCGLCKTRMIOS
=
0x5456
TIOCGPGRP
=
0x540f
TIOCGPKT
=
0x80045438
TIOCGPTLCK
=
0x80045439
TIOCGPTN
=
0x80045430
TIOCGRS485
=
0x542e
TIOCGSERIAL
=
0x541e
TIOCGSID
=
0x5429
TIOCGSOFTCAR
=
0x5419
TIOCGWINSZ
=
0x5413
TIOCINQ
=
0x541b
TIOCLINUX
=
0x541c
TIOCMBIC
=
0x5417
TIOCMBIS
=
0x5416
TIOCMGET
=
0x5415
TIOCMIWAIT
=
0x545c
TIOCMSET
=
0x5418
TIOCM_CAR
=
0x40
TIOCM_CD
=
0x40
TIOCM_CTS
=
0x20
TIOCM_DSR
=
0x100
TIOCM_DTR
=
0x2
TIOCM_LE
=
0x1
TIOCM_RI
=
0x80
TIOCM_RNG
=
0x80
TIOCM_RTS
=
0x4
TIOCM_SR
=
0x10
TIOCM_ST
=
0x8
TIOCNOTTY
=
0x5422
TIOCNXCL
=
0x540d
TIOCOUTQ
=
0x5411
TIOCPKT
=
0x5420
TIOCPKT_DATA
=
0x0
TIOCPKT_DOSTOP
=
0x20
TIOCPKT_FLUSHREAD
=
0x1
TIOCPKT_FLUSHWRITE
=
0x2
TIOCPKT_IOCTL
=
0x40
TIOCPKT_NOSTOP
=
0x10
TIOCPKT_START
=
0x8
TIOCPKT_STOP
=
0x4
TIOCSBRK
=
0x5427
TIOCSCTTY
=
0x540e
TIOCSERCONFIG
=
0x5453
TIOCSERGETLSR
=
0x5459
TIOCSERGETMULTI
=
0x545a
TIOCSERGSTRUCT
=
0x5458
TIOCSERGWILD
=
0x5454
TIOCSERSETMULTI
=
0x545b
TIOCSERSWILD
=
0x5455
TIOCSER_TEMT
=
0x1
TIOCSETD
=
0x5423
TIOCSIG
=
0x40045436
TIOCSLCKTRMIOS
=
0x5457
TIOCSPGRP
=
0x5410
TIOCSPTLCK
=
0x40045431
TIOCSRS485
=
0x542f
TIOCSSERIAL
=
0x541f
TIOCSSOFTCAR
=
0x541a
TIOCSTI
=
0x5412
TIOCSWINSZ
=
0x5414
TIOCVHANGUP
=
0x5437
TOSTOP
=
0x100
TUNATTACHFILTER
=
0x401054d5
TUNDETACHFILTER
=
0x401054d6
TUNGETFEATURES
=
0x800454cf
TUNGETFILTER
=
0x801054db
TUNGETIFF
=
0x800454d2
TUNGETSNDBUF
=
0x800454d3
TUNGETVNETHDRSZ
=
0x800454d7
TUNGETVNETLE
=
0x800454dd
TUNSETDEBUG
=
0x400454c9
TUNSETGROUP
=
0x400454ce
TUNSETIFF
=
0x400454ca
TUNSETIFINDEX
=
0x400454da
TUNSETLINK
=
0x400454cd
TUNSETNOCSUM
=
0x400454c8
TUNSETOFFLOAD
=
0x400454d0
TUNSETOWNER
=
0x400454cc
TUNSETPERSIST
=
0x400454cb
TUNSETQUEUE
=
0x400454d9
TUNSETSNDBUF
=
0x400454d4
TUNSETTXFILTER
=
0x400454d1
TUNSETVNETHDRSZ
=
0x400454d8
TUNSETVNETLE
=
0x400454dc
VDISCARD
=
0xd
VEOF
=
0x4
VEOL
=
0xb
VEOL2
=
0x10
VERASE
=
0x2
VINTR
=
0x0
VKILL
=
0x3
VLNEXT
=
0xf
VMIN
=
0x6
VQUIT
=
0x1
VREPRINT
=
0xc
VSTART
=
0x8
VSTOP
=
0x9
VSUSP
=
0xa
VSWTC
=
0x7
VT0
=
0x0
VT1
=
0x4000
VTDLY
=
0x4000
VTIME
=
0x5
VWERASE
=
0xe
WALL
=
0x40000000
WCLONE
=
0x80000000
WCONTINUED
=
0x8
WEXITED
=
0x4
WNOHANG
=
0x1
WNOTHREAD
=
0x20000000
WNOWAIT
=
0x1000000
WORDSIZE
=
0x40
WSTOPPED
=
0x2
WUNTRACED
=
0x2
)
// Errors
const
(
E2BIG
=
Errno
(
0x7
)
EACCES
=
Errno
(
0xd
)
EADDRINUSE
=
Errno
(
0x62
)
EADDRNOTAVAIL
=
Errno
(
0x63
)
EADV
=
Errno
(
0x44
)
EAFNOSUPPORT
=
Errno
(
0x61
)
EAGAIN
=
Errno
(
0xb
)
EALREADY
=
Errno
(
0x72
)
EBADE
=
Errno
(
0x34
)
EBADF
=
Errno
(
0x9
)
EBADFD
=
Errno
(
0x4d
)
EBADMSG
=
Errno
(
0x4a
)
EBADR
=
Errno
(
0x35
)
EBADRQC
=
Errno
(
0x38
)
EBADSLT
=
Errno
(
0x39
)
EBFONT
=
Errno
(
0x3b
)
EBUSY
=
Errno
(
0x10
)
ECANCELED
=
Errno
(
0x7d
)
ECHILD
=
Errno
(
0xa
)
ECHRNG
=
Errno
(
0x2c
)
ECOMM
=
Errno
(
0x46
)
ECONNABORTED
=
Errno
(
0x67
)
ECONNREFUSED
=
Errno
(
0x6f
)
ECONNRESET
=
Errno
(
0x68
)
EDEADLK
=
Errno
(
0x23
)
EDEADLOCK
=
Errno
(
0x23
)
EDESTADDRREQ
=
Errno
(
0x59
)
EDOM
=
Errno
(
0x21
)
EDOTDOT
=
Errno
(
0x49
)
EDQUOT
=
Errno
(
0x7a
)
EEXIST
=
Errno
(
0x11
)
EFAULT
=
Errno
(
0xe
)
EFBIG
=
Errno
(
0x1b
)
EHOSTDOWN
=
Errno
(
0x70
)
EHOSTUNREACH
=
Errno
(
0x71
)
EHWPOISON
=
Errno
(
0x85
)
EIDRM
=
Errno
(
0x2b
)
EILSEQ
=
Errno
(
0x54
)
EINPROGRESS
=
Errno
(
0x73
)
EINTR
=
Errno
(
0x4
)
EINVAL
=
Errno
(
0x16
)
EIO
=
Errno
(
0x5
)
EISCONN
=
Errno
(
0x6a
)
EISDIR
=
Errno
(
0x15
)
EISNAM
=
Errno
(
0x78
)
EKEYEXPIRED
=
Errno
(
0x7f
)
EKEYREJECTED
=
Errno
(
0x81
)
EKEYREVOKED
=
Errno
(
0x80
)
EL2HLT
=
Errno
(
0x33
)
EL2NSYNC
=
Errno
(
0x2d
)
EL3HLT
=
Errno
(
0x2e
)
EL3RST
=
Errno
(
0x2f
)
ELIBACC
=
Errno
(
0x4f
)
ELIBBAD
=
Errno
(
0x50
)
ELIBEXEC
=
Errno
(
0x53
)
ELIBMAX
=
Errno
(
0x52
)
ELIBSCN
=
Errno
(
0x51
)
ELNRNG
=
Errno
(
0x30
)
ELOOP
=
Errno
(
0x28
)
EMEDIUMTYPE
=
Errno
(
0x7c
)
EMFILE
=
Errno
(
0x18
)
EMLINK
=
Errno
(
0x1f
)
EMSGSIZE
=
Errno
(
0x5a
)
EMULTIHOP
=
Errno
(
0x48
)
ENAMETOOLONG
=
Errno
(
0x24
)
ENAVAIL
=
Errno
(
0x77
)
ENETDOWN
=
Errno
(
0x64
)
ENETRESET
=
Errno
(
0x66
)
ENETUNREACH
=
Errno
(
0x65
)
ENFILE
=
Errno
(
0x17
)
ENOANO
=
Errno
(
0x37
)
ENOBUFS
=
Errno
(
0x69
)
ENOCSI
=
Errno
(
0x32
)
ENODATA
=
Errno
(
0x3d
)
ENODEV
=
Errno
(
0x13
)
ENOENT
=
Errno
(
0x2
)
ENOEXEC
=
Errno
(
0x8
)
ENOKEY
=
Errno
(
0x7e
)
ENOLCK
=
Errno
(
0x25
)
ENOLINK
=
Errno
(
0x43
)
ENOMEDIUM
=
Errno
(
0x7b
)
ENOMEM
=
Errno
(
0xc
)
ENOMSG
=
Errno
(
0x2a
)
ENONET
=
Errno
(
0x40
)
ENOPKG
=
Errno
(
0x41
)
ENOPROTOOPT
=
Errno
(
0x5c
)
ENOSPC
=
Errno
(
0x1c
)
ENOSR
=
Errno
(
0x3f
)
ENOSTR
=
Errno
(
0x3c
)
ENOSYS
=
Errno
(
0x26
)
ENOTBLK
=
Errno
(
0xf
)
ENOTCONN
=
Errno
(
0x6b
)
ENOTDIR
=
Errno
(
0x14
)
ENOTEMPTY
=
Errno
(
0x27
)
ENOTNAM
=
Errno
(
0x76
)
ENOTRECOVERABLE
=
Errno
(
0x83
)
ENOTSOCK
=
Errno
(
0x58
)
ENOTSUP
=
Errno
(
0x5f
)
ENOTTY
=
Errno
(
0x19
)
ENOTUNIQ
=
Errno
(
0x4c
)
ENXIO
=
Errno
(
0x6
)
EOPNOTSUPP
=
Errno
(
0x5f
)
EOVERFLOW
=
Errno
(
0x4b
)
EOWNERDEAD
=
Errno
(
0x82
)
EPERM
=
Errno
(
0x1
)
EPFNOSUPPORT
=
Errno
(
0x60
)
EPIPE
=
Errno
(
0x20
)
EPROTO
=
Errno
(
0x47
)
EPROTONOSUPPORT
=
Errno
(
0x5d
)
EPROTOTYPE
=
Errno
(
0x5b
)
ERANGE
=
Errno
(
0x22
)
EREMCHG
=
Errno
(
0x4e
)
EREMOTE
=
Errno
(
0x42
)
EREMOTEIO
=
Errno
(
0x79
)
ERESTART
=
Errno
(
0x55
)
ERFKILL
=
Errno
(
0x84
)
EROFS
=
Errno
(
0x1e
)
ESHUTDOWN
=
Errno
(
0x6c
)
ESOCKTNOSUPPORT
=
Errno
(
0x5e
)
ESPIPE
=
Errno
(
0x1d
)
ESRCH
=
Errno
(
0x3
)
ESRMNT
=
Errno
(
0x45
)
ESTALE
=
Errno
(
0x74
)
ESTRPIPE
=
Errno
(
0x56
)
ETIME
=
Errno
(
0x3e
)
ETIMEDOUT
=
Errno
(
0x6e
)
ETOOMANYREFS
=
Errno
(
0x6d
)
ETXTBSY
=
Errno
(
0x1a
)
EUCLEAN
=
Errno
(
0x75
)
EUNATCH
=
Errno
(
0x31
)
EUSERS
=
Errno
(
0x57
)
EWOULDBLOCK
=
Errno
(
0xb
)
EXDEV
=
Errno
(
0x12
)
EXFULL
=
Errno
(
0x36
)
)
// Signals
const
(
SIGABRT
=
Signal
(
0x6
)
SIGALRM
=
Signal
(
0xe
)
SIGBUS
=
Signal
(
0x7
)
SIGCHLD
=
Signal
(
0x11
)
SIGCLD
=
Signal
(
0x11
)
SIGCONT
=
Signal
(
0x12
)
SIGFPE
=
Signal
(
0x8
)
SIGHUP
=
Signal
(
0x1
)
SIGILL
=
Signal
(
0x4
)
SIGINT
=
Signal
(
0x2
)
SIGIO
=
Signal
(
0x1d
)
SIGIOT
=
Signal
(
0x6
)
SIGKILL
=
Signal
(
0x9
)
SIGPIPE
=
Signal
(
0xd
)
SIGPOLL
=
Signal
(
0x1d
)
SIGPROF
=
Signal
(
0x1b
)
SIGPWR
=
Signal
(
0x1e
)
SIGQUIT
=
Signal
(
0x3
)
SIGSEGV
=
Signal
(
0xb
)
SIGSTKFLT
=
Signal
(
0x10
)
SIGSTOP
=
Signal
(
0x13
)
SIGSYS
=
Signal
(
0x1f
)
SIGTERM
=
Signal
(
0xf
)
SIGTRAP
=
Signal
(
0x5
)
SIGTSTP
=
Signal
(
0x14
)
SIGTTIN
=
Signal
(
0x15
)
SIGTTOU
=
Signal
(
0x16
)
SIGUNUSED
=
Signal
(
0x1f
)
SIGURG
=
Signal
(
0x17
)
SIGUSR1
=
Signal
(
0xa
)
SIGUSR2
=
Signal
(
0xc
)
SIGVTALRM
=
Signal
(
0x1a
)
SIGWINCH
=
Signal
(
0x1c
)
SIGXCPU
=
Signal
(
0x18
)
SIGXFSZ
=
Signal
(
0x19
)
)
// Error table
var
errors
=
[
...
]
string
{
1
:
"operation not permitted"
,
2
:
"no such file or directory"
,
3
:
"no such process"
,
4
:
"interrupted system call"
,
5
:
"input/output error"
,
6
:
"no such device or address"
,
7
:
"argument list too long"
,
8
:
"exec format error"
,
9
:
"bad file descriptor"
,
10
:
"no child processes"
,
11
:
"resource temporarily unavailable"
,
12
:
"cannot allocate memory"
,
13
:
"permission denied"
,
14
:
"bad address"
,
15
:
"block device required"
,
16
:
"device or resource busy"
,
17
:
"file exists"
,
18
:
"invalid cross-device link"
,
19
:
"no such device"
,
20
:
"not a directory"
,
21
:
"is a directory"
,
22
:
"invalid argument"
,
23
:
"too many open files in system"
,
24
:
"too many open files"
,
25
:
"inappropriate ioctl for device"
,
26
:
"text file busy"
,
27
:
"file too large"
,
28
:
"no space left on device"
,
29
:
"illegal seek"
,
30
:
"read-only file system"
,
31
:
"too many links"
,
32
:
"broken pipe"
,
33
:
"numerical argument out of domain"
,
34
:
"numerical result out of range"
,
35
:
"resource deadlock avoided"
,
36
:
"file name too long"
,
37
:
"no locks available"
,
38
:
"function not implemented"
,
39
:
"directory not empty"
,
40
:
"too many levels of symbolic links"
,
42
:
"no message of desired type"
,
43
:
"identifier removed"
,
44
:
"channel number out of range"
,
45
:
"level 2 not synchronized"
,
46
:
"level 3 halted"
,
47
:
"level 3 reset"
,
48
:
"link number out of range"
,
49
:
"protocol driver not attached"
,
50
:
"no CSI structure available"
,
51
:
"level 2 halted"
,
52
:
"invalid exchange"
,
53
:
"invalid request descriptor"
,
54
:
"exchange full"
,
55
:
"no anode"
,
56
:
"invalid request code"
,
57
:
"invalid slot"
,
59
:
"bad font file format"
,
60
:
"device not a stream"
,
61
:
"no data available"
,
62
:
"timer expired"
,
63
:
"out of streams resources"
,
64
:
"machine is not on the network"
,
65
:
"package not installed"
,
66
:
"object is remote"
,
67
:
"link has been severed"
,
68
:
"advertise error"
,
69
:
"srmount error"
,
70
:
"communication error on send"
,
71
:
"protocol error"
,
72
:
"multihop attempted"
,
73
:
"RFS specific error"
,
74
:
"bad message"
,
75
:
"value too large for defined data type"
,
76
:
"name not unique on network"
,
77
:
"file descriptor in bad state"
,
78
:
"remote address changed"
,
79
:
"can not access a needed shared library"
,
80
:
"accessing a corrupted shared library"
,
81
:
".lib section in a.out corrupted"
,
82
:
"attempting to link in too many shared libraries"
,
83
:
"cannot exec a shared library directly"
,
84
:
"invalid or incomplete multibyte or wide character"
,
85
:
"interrupted system call should be restarted"
,
86
:
"streams pipe error"
,
87
:
"too many users"
,
88
:
"socket operation on non-socket"
,
89
:
"destination address required"
,
90
:
"message too long"
,
91
:
"protocol wrong type for socket"
,
92
:
"protocol not available"
,
93
:
"protocol not supported"
,
94
:
"socket type not supported"
,
95
:
"operation not supported"
,
96
:
"protocol family not supported"
,
97
:
"address family not supported by protocol"
,
98
:
"address already in use"
,
99
:
"cannot assign requested address"
,
100
:
"network is down"
,
101
:
"network is unreachable"
,
102
:
"network dropped connection on reset"
,
103
:
"software caused connection abort"
,
104
:
"connection reset by peer"
,
105
:
"no buffer space available"
,
106
:
"transport endpoint is already connected"
,
107
:
"transport endpoint is not connected"
,
108
:
"cannot send after transport endpoint shutdown"
,
109
:
"too many references: cannot splice"
,
110
:
"connection timed out"
,
111
:
"connection refused"
,
112
:
"host is down"
,
113
:
"no route to host"
,
114
:
"operation already in progress"
,
115
:
"operation now in progress"
,
116
:
"stale file handle"
,
117
:
"structure needs cleaning"
,
118
:
"not a XENIX named type file"
,
119
:
"no XENIX semaphores available"
,
120
:
"is a named type file"
,
121
:
"remote I/O error"
,
122
:
"disk quota exceeded"
,
123
:
"no medium found"
,
124
:
"wrong medium type"
,
125
:
"operation canceled"
,
126
:
"required key not available"
,
127
:
"key has expired"
,
128
:
"key has been revoked"
,
129
:
"key was rejected by service"
,
130
:
"owner died"
,
131
:
"state not recoverable"
,
132
:
"operation not possible due to RF-kill"
,
133
:
"memory page has hardware error"
,
}
// Signal table
var
signals
=
[
...
]
string
{
1
:
"hangup"
,
2
:
"interrupt"
,
3
:
"quit"
,
4
:
"illegal instruction"
,
5
:
"trace/breakpoint trap"
,
6
:
"aborted"
,
7
:
"bus error"
,
8
:
"floating point exception"
,
9
:
"killed"
,
10
:
"user defined signal 1"
,
11
:
"segmentation fault"
,
12
:
"user defined signal 2"
,
13
:
"broken pipe"
,
14
:
"alarm clock"
,
15
:
"terminated"
,
16
:
"stack fault"
,
17
:
"child exited"
,
18
:
"continued"
,
19
:
"stopped (signal)"
,
20
:
"stopped"
,
21
:
"stopped (tty input)"
,
22
:
"stopped (tty output)"
,
23
:
"urgent I/O condition"
,
24
:
"CPU time limit exceeded"
,
25
:
"file size limit exceeded"
,
26
:
"virtual timer expired"
,
27
:
"profiling timer expired"
,
28
:
"window changed"
,
29
:
"I/O possible"
,
30
:
"power failure"
,
31
:
"bad system call"
,
}
src/syscall/zsyscall_linux_riscv64.go
0 → 100644
View file @
4497d7eb
// mksyscall.pl -tags linux,riscv64 syscall_linux.go syscall_linux_riscv64.go
// Code generated by the command above; DO NOT EDIT.
// +build linux,riscv64
package
syscall
import
"unsafe"
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
faccessat
(
dirfd
int
,
path
string
,
mode
uint32
)
(
err
error
)
{
var
_p0
*
byte
_p0
,
err
=
BytePtrFromString
(
path
)
if
err
!=
nil
{
return
}
_
,
_
,
e1
:=
Syscall
(
SYS_FACCESSAT
,
uintptr
(
dirfd
),
uintptr
(
unsafe
.
Pointer
(
_p0
)),
uintptr
(
mode
))
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
fchmodat
(
dirfd
int
,
path
string
,
mode
uint32
)
(
err
error
)
{
var
_p0
*
byte
_p0
,
err
=
BytePtrFromString
(
path
)
if
err
!=
nil
{
return
}
_
,
_
,
e1
:=
Syscall
(
SYS_FCHMODAT
,
uintptr
(
dirfd
),
uintptr
(
unsafe
.
Pointer
(
_p0
)),
uintptr
(
mode
))
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
linkat
(
olddirfd
int
,
oldpath
string
,
newdirfd
int
,
newpath
string
,
flags
int
)
(
err
error
)
{
var
_p0
*
byte
_p0
,
err
=
BytePtrFromString
(
oldpath
)
if
err
!=
nil
{
return
}
var
_p1
*
byte
_p1
,
err
=
BytePtrFromString
(
newpath
)
if
err
!=
nil
{
return
}
_
,
_
,
e1
:=
Syscall6
(
SYS_LINKAT
,
uintptr
(
olddirfd
),
uintptr
(
unsafe
.
Pointer
(
_p0
)),
uintptr
(
newdirfd
),
uintptr
(
unsafe
.
Pointer
(
_p1
)),
uintptr
(
flags
),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
openat
(
dirfd
int
,
path
string
,
flags
int
,
mode
uint32
)
(
fd
int
,
err
error
)
{
var
_p0
*
byte
_p0
,
err
=
BytePtrFromString
(
path
)
if
err
!=
nil
{
return
}
r0
,
_
,
e1
:=
Syscall6
(
SYS_OPENAT
,
uintptr
(
dirfd
),
uintptr
(
unsafe
.
Pointer
(
_p0
)),
uintptr
(
flags
),
uintptr
(
mode
),
0
,
0
)
fd
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
readlinkat
(
dirfd
int
,
path
string
,
buf
[]
byte
)
(
n
int
,
err
error
)
{
var
_p0
*
byte
_p0
,
err
=
BytePtrFromString
(
path
)
if
err
!=
nil
{
return
}
var
_p1
unsafe
.
Pointer
if
len
(
buf
)
>
0
{
_p1
=
unsafe
.
Pointer
(
&
buf
[
0
])
}
else
{
_p1
=
unsafe
.
Pointer
(
&
_zero
)
}
r0
,
_
,
e1
:=
Syscall6
(
SYS_READLINKAT
,
uintptr
(
dirfd
),
uintptr
(
unsafe
.
Pointer
(
_p0
)),
uintptr
(
_p1
),
uintptr
(
len
(
buf
)),
0
,
0
)
n
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
symlinkat
(
oldpath
string
,
newdirfd
int
,
newpath
string
)
(
err
error
)
{
var
_p0
*
byte
_p0
,
err
=
BytePtrFromString
(
oldpath
)
if
err
!=
nil
{
return
}
var
_p1
*
byte
_p1
,
err
=
BytePtrFromString
(
newpath
)
if
err
!=
nil
{
return
}
_
,
_
,
e1
:=
Syscall
(
SYS_SYMLINKAT
,
uintptr
(
unsafe
.
Pointer
(
_p0
)),
uintptr
(
newdirfd
),
uintptr
(
unsafe
.
Pointer
(
_p1
)))
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
unlinkat
(
dirfd
int
,
path
string
,
flags
int
)
(
err
error
)
{
var
_p0
*
byte
_p0
,
err
=
BytePtrFromString
(
path
)
if
err
!=
nil
{
return
}
_
,
_
,
e1
:=
Syscall
(
SYS_UNLINKAT
,
uintptr
(
dirfd
),
uintptr
(
unsafe
.
Pointer
(
_p0
)),
uintptr
(
flags
))
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
utimensat
(
dirfd
int
,
path
string
,
times
*
[
2
]
Timespec
,
flag
int
)
(
err
error
)
{
var
_p0
*
byte
_p0
,
err
=
BytePtrFromString
(
path
)
if
err
!=
nil
{
return
}
_
,
_
,
e1
:=
Syscall6
(
SYS_UTIMENSAT
,
uintptr
(
dirfd
),
uintptr
(
unsafe
.
Pointer
(
_p0
)),
uintptr
(
unsafe
.
Pointer
(
times
)),
uintptr
(
flag
),
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Getcwd
(
buf
[]
byte
)
(
n
int
,
err
error
)
{
var
_p0
unsafe
.
Pointer
if
len
(
buf
)
>
0
{
_p0
=
unsafe
.
Pointer
(
&
buf
[
0
])
}
else
{
_p0
=
unsafe
.
Pointer
(
&
_zero
)
}
r0
,
_
,
e1
:=
Syscall
(
SYS_GETCWD
,
uintptr
(
_p0
),
uintptr
(
len
(
buf
)),
0
)
n
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
wait4
(
pid
int
,
wstatus
*
_C_int
,
options
int
,
rusage
*
Rusage
)
(
wpid
int
,
err
error
)
{
r0
,
_
,
e1
:=
Syscall6
(
SYS_WAIT4
,
uintptr
(
pid
),
uintptr
(
unsafe
.
Pointer
(
wstatus
)),
uintptr
(
options
),
uintptr
(
unsafe
.
Pointer
(
rusage
)),
0
,
0
)
wpid
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
ptrace
(
request
int
,
pid
int
,
addr
uintptr
,
data
uintptr
)
(
err
error
)
{
_
,
_
,
e1
:=
Syscall6
(
SYS_PTRACE
,
uintptr
(
request
),
uintptr
(
pid
),
uintptr
(
addr
),
uintptr
(
data
),
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
reboot
(
magic1
uint
,
magic2
uint
,
cmd
int
,
arg
string
)
(
err
error
)
{
var
_p0
*
byte
_p0
,
err
=
BytePtrFromString
(
arg
)
if
err
!=
nil
{
return
}
_
,
_
,
e1
:=
Syscall6
(
SYS_REBOOT
,
uintptr
(
magic1
),
uintptr
(
magic2
),
uintptr
(
cmd
),
uintptr
(
unsafe
.
Pointer
(
_p0
)),
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
mount
(
source
string
,
target
string
,
fstype
string
,
flags
uintptr
,
data
*
byte
)
(
err
error
)
{
var
_p0
*
byte
_p0
,
err
=
BytePtrFromString
(
source
)
if
err
!=
nil
{
return
}
var
_p1
*
byte
_p1
,
err
=
BytePtrFromString
(
target
)
if
err
!=
nil
{
return
}
var
_p2
*
byte
_p2
,
err
=
BytePtrFromString
(
fstype
)
if
err
!=
nil
{
return
}
_
,
_
,
e1
:=
Syscall6
(
SYS_MOUNT
,
uintptr
(
unsafe
.
Pointer
(
_p0
)),
uintptr
(
unsafe
.
Pointer
(
_p1
)),
uintptr
(
unsafe
.
Pointer
(
_p2
)),
uintptr
(
flags
),
uintptr
(
unsafe
.
Pointer
(
data
)),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Acct
(
path
string
)
(
err
error
)
{
var
_p0
*
byte
_p0
,
err
=
BytePtrFromString
(
path
)
if
err
!=
nil
{
return
}
_
,
_
,
e1
:=
Syscall
(
SYS_ACCT
,
uintptr
(
unsafe
.
Pointer
(
_p0
)),
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Adjtimex
(
buf
*
Timex
)
(
state
int
,
err
error
)
{
r0
,
_
,
e1
:=
Syscall
(
SYS_ADJTIMEX
,
uintptr
(
unsafe
.
Pointer
(
buf
)),
0
,
0
)
state
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Chdir
(
path
string
)
(
err
error
)
{
var
_p0
*
byte
_p0
,
err
=
BytePtrFromString
(
path
)
if
err
!=
nil
{
return
}
_
,
_
,
e1
:=
Syscall
(
SYS_CHDIR
,
uintptr
(
unsafe
.
Pointer
(
_p0
)),
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Chroot
(
path
string
)
(
err
error
)
{
var
_p0
*
byte
_p0
,
err
=
BytePtrFromString
(
path
)
if
err
!=
nil
{
return
}
_
,
_
,
e1
:=
Syscall
(
SYS_CHROOT
,
uintptr
(
unsafe
.
Pointer
(
_p0
)),
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Close
(
fd
int
)
(
err
error
)
{
_
,
_
,
e1
:=
Syscall
(
SYS_CLOSE
,
uintptr
(
fd
),
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Dup
(
oldfd
int
)
(
fd
int
,
err
error
)
{
r0
,
_
,
e1
:=
Syscall
(
SYS_DUP
,
uintptr
(
oldfd
),
0
,
0
)
fd
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Dup3
(
oldfd
int
,
newfd
int
,
flags
int
)
(
err
error
)
{
_
,
_
,
e1
:=
Syscall
(
SYS_DUP3
,
uintptr
(
oldfd
),
uintptr
(
newfd
),
uintptr
(
flags
))
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
EpollCreate1
(
flag
int
)
(
fd
int
,
err
error
)
{
r0
,
_
,
e1
:=
RawSyscall
(
SYS_EPOLL_CREATE1
,
uintptr
(
flag
),
0
,
0
)
fd
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
EpollCtl
(
epfd
int
,
op
int
,
fd
int
,
event
*
EpollEvent
)
(
err
error
)
{
_
,
_
,
e1
:=
RawSyscall6
(
SYS_EPOLL_CTL
,
uintptr
(
epfd
),
uintptr
(
op
),
uintptr
(
fd
),
uintptr
(
unsafe
.
Pointer
(
event
)),
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Fallocate
(
fd
int
,
mode
uint32
,
off
int64
,
len
int64
)
(
err
error
)
{
_
,
_
,
e1
:=
Syscall6
(
SYS_FALLOCATE
,
uintptr
(
fd
),
uintptr
(
mode
),
uintptr
(
off
),
uintptr
(
len
),
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Fchdir
(
fd
int
)
(
err
error
)
{
_
,
_
,
e1
:=
Syscall
(
SYS_FCHDIR
,
uintptr
(
fd
),
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Fchmod
(
fd
int
,
mode
uint32
)
(
err
error
)
{
_
,
_
,
e1
:=
Syscall
(
SYS_FCHMOD
,
uintptr
(
fd
),
uintptr
(
mode
),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Fchownat
(
dirfd
int
,
path
string
,
uid
int
,
gid
int
,
flags
int
)
(
err
error
)
{
var
_p0
*
byte
_p0
,
err
=
BytePtrFromString
(
path
)
if
err
!=
nil
{
return
}
_
,
_
,
e1
:=
Syscall6
(
SYS_FCHOWNAT
,
uintptr
(
dirfd
),
uintptr
(
unsafe
.
Pointer
(
_p0
)),
uintptr
(
uid
),
uintptr
(
gid
),
uintptr
(
flags
),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
fcntl
(
fd
int
,
cmd
int
,
arg
int
)
(
val
int
,
err
error
)
{
r0
,
_
,
e1
:=
Syscall
(
SYS_FCNTL
,
uintptr
(
fd
),
uintptr
(
cmd
),
uintptr
(
arg
))
val
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Fdatasync
(
fd
int
)
(
err
error
)
{
_
,
_
,
e1
:=
Syscall
(
SYS_FDATASYNC
,
uintptr
(
fd
),
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Flock
(
fd
int
,
how
int
)
(
err
error
)
{
_
,
_
,
e1
:=
Syscall
(
SYS_FLOCK
,
uintptr
(
fd
),
uintptr
(
how
),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Fsync
(
fd
int
)
(
err
error
)
{
_
,
_
,
e1
:=
Syscall
(
SYS_FSYNC
,
uintptr
(
fd
),
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Getdents
(
fd
int
,
buf
[]
byte
)
(
n
int
,
err
error
)
{
var
_p0
unsafe
.
Pointer
if
len
(
buf
)
>
0
{
_p0
=
unsafe
.
Pointer
(
&
buf
[
0
])
}
else
{
_p0
=
unsafe
.
Pointer
(
&
_zero
)
}
r0
,
_
,
e1
:=
Syscall
(
SYS_GETDENTS64
,
uintptr
(
fd
),
uintptr
(
_p0
),
uintptr
(
len
(
buf
)))
n
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Getpgid
(
pid
int
)
(
pgid
int
,
err
error
)
{
r0
,
_
,
e1
:=
RawSyscall
(
SYS_GETPGID
,
uintptr
(
pid
),
0
,
0
)
pgid
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Getpid
()
(
pid
int
)
{
r0
,
_
:=
rawSyscallNoError
(
SYS_GETPID
,
0
,
0
,
0
)
pid
=
int
(
r0
)
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Getppid
()
(
ppid
int
)
{
r0
,
_
:=
rawSyscallNoError
(
SYS_GETPPID
,
0
,
0
,
0
)
ppid
=
int
(
r0
)
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Getpriority
(
which
int
,
who
int
)
(
prio
int
,
err
error
)
{
r0
,
_
,
e1
:=
Syscall
(
SYS_GETPRIORITY
,
uintptr
(
which
),
uintptr
(
who
),
0
)
prio
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Getrusage
(
who
int
,
rusage
*
Rusage
)
(
err
error
)
{
_
,
_
,
e1
:=
RawSyscall
(
SYS_GETRUSAGE
,
uintptr
(
who
),
uintptr
(
unsafe
.
Pointer
(
rusage
)),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Gettid
()
(
tid
int
)
{
r0
,
_
:=
rawSyscallNoError
(
SYS_GETTID
,
0
,
0
,
0
)
tid
=
int
(
r0
)
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Getxattr
(
path
string
,
attr
string
,
dest
[]
byte
)
(
sz
int
,
err
error
)
{
var
_p0
*
byte
_p0
,
err
=
BytePtrFromString
(
path
)
if
err
!=
nil
{
return
}
var
_p1
*
byte
_p1
,
err
=
BytePtrFromString
(
attr
)
if
err
!=
nil
{
return
}
var
_p2
unsafe
.
Pointer
if
len
(
dest
)
>
0
{
_p2
=
unsafe
.
Pointer
(
&
dest
[
0
])
}
else
{
_p2
=
unsafe
.
Pointer
(
&
_zero
)
}
r0
,
_
,
e1
:=
Syscall6
(
SYS_GETXATTR
,
uintptr
(
unsafe
.
Pointer
(
_p0
)),
uintptr
(
unsafe
.
Pointer
(
_p1
)),
uintptr
(
_p2
),
uintptr
(
len
(
dest
)),
0
,
0
)
sz
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
InotifyAddWatch
(
fd
int
,
pathname
string
,
mask
uint32
)
(
watchdesc
int
,
err
error
)
{
var
_p0
*
byte
_p0
,
err
=
BytePtrFromString
(
pathname
)
if
err
!=
nil
{
return
}
r0
,
_
,
e1
:=
Syscall
(
SYS_INOTIFY_ADD_WATCH
,
uintptr
(
fd
),
uintptr
(
unsafe
.
Pointer
(
_p0
)),
uintptr
(
mask
))
watchdesc
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
InotifyInit1
(
flags
int
)
(
fd
int
,
err
error
)
{
r0
,
_
,
e1
:=
RawSyscall
(
SYS_INOTIFY_INIT1
,
uintptr
(
flags
),
0
,
0
)
fd
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
InotifyRmWatch
(
fd
int
,
watchdesc
uint32
)
(
success
int
,
err
error
)
{
r0
,
_
,
e1
:=
RawSyscall
(
SYS_INOTIFY_RM_WATCH
,
uintptr
(
fd
),
uintptr
(
watchdesc
),
0
)
success
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Kill
(
pid
int
,
sig
Signal
)
(
err
error
)
{
_
,
_
,
e1
:=
RawSyscall
(
SYS_KILL
,
uintptr
(
pid
),
uintptr
(
sig
),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Klogctl
(
typ
int
,
buf
[]
byte
)
(
n
int
,
err
error
)
{
var
_p0
unsafe
.
Pointer
if
len
(
buf
)
>
0
{
_p0
=
unsafe
.
Pointer
(
&
buf
[
0
])
}
else
{
_p0
=
unsafe
.
Pointer
(
&
_zero
)
}
r0
,
_
,
e1
:=
Syscall
(
SYS_SYSLOG
,
uintptr
(
typ
),
uintptr
(
_p0
),
uintptr
(
len
(
buf
)))
n
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Listxattr
(
path
string
,
dest
[]
byte
)
(
sz
int
,
err
error
)
{
var
_p0
*
byte
_p0
,
err
=
BytePtrFromString
(
path
)
if
err
!=
nil
{
return
}
var
_p1
unsafe
.
Pointer
if
len
(
dest
)
>
0
{
_p1
=
unsafe
.
Pointer
(
&
dest
[
0
])
}
else
{
_p1
=
unsafe
.
Pointer
(
&
_zero
)
}
r0
,
_
,
e1
:=
Syscall
(
SYS_LISTXATTR
,
uintptr
(
unsafe
.
Pointer
(
_p0
)),
uintptr
(
_p1
),
uintptr
(
len
(
dest
)))
sz
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Mkdirat
(
dirfd
int
,
path
string
,
mode
uint32
)
(
err
error
)
{
var
_p0
*
byte
_p0
,
err
=
BytePtrFromString
(
path
)
if
err
!=
nil
{
return
}
_
,
_
,
e1
:=
Syscall
(
SYS_MKDIRAT
,
uintptr
(
dirfd
),
uintptr
(
unsafe
.
Pointer
(
_p0
)),
uintptr
(
mode
))
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Mknodat
(
dirfd
int
,
path
string
,
mode
uint32
,
dev
int
)
(
err
error
)
{
var
_p0
*
byte
_p0
,
err
=
BytePtrFromString
(
path
)
if
err
!=
nil
{
return
}
_
,
_
,
e1
:=
Syscall6
(
SYS_MKNODAT
,
uintptr
(
dirfd
),
uintptr
(
unsafe
.
Pointer
(
_p0
)),
uintptr
(
mode
),
uintptr
(
dev
),
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Nanosleep
(
time
*
Timespec
,
leftover
*
Timespec
)
(
err
error
)
{
_
,
_
,
e1
:=
Syscall
(
SYS_NANOSLEEP
,
uintptr
(
unsafe
.
Pointer
(
time
)),
uintptr
(
unsafe
.
Pointer
(
leftover
)),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
PivotRoot
(
newroot
string
,
putold
string
)
(
err
error
)
{
var
_p0
*
byte
_p0
,
err
=
BytePtrFromString
(
newroot
)
if
err
!=
nil
{
return
}
var
_p1
*
byte
_p1
,
err
=
BytePtrFromString
(
putold
)
if
err
!=
nil
{
return
}
_
,
_
,
e1
:=
Syscall
(
SYS_PIVOT_ROOT
,
uintptr
(
unsafe
.
Pointer
(
_p0
)),
uintptr
(
unsafe
.
Pointer
(
_p1
)),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
prlimit
(
pid
int
,
resource
int
,
newlimit
*
Rlimit
,
old
*
Rlimit
)
(
err
error
)
{
_
,
_
,
e1
:=
RawSyscall6
(
SYS_PRLIMIT64
,
uintptr
(
pid
),
uintptr
(
resource
),
uintptr
(
unsafe
.
Pointer
(
newlimit
)),
uintptr
(
unsafe
.
Pointer
(
old
)),
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
read
(
fd
int
,
p
[]
byte
)
(
n
int
,
err
error
)
{
var
_p0
unsafe
.
Pointer
if
len
(
p
)
>
0
{
_p0
=
unsafe
.
Pointer
(
&
p
[
0
])
}
else
{
_p0
=
unsafe
.
Pointer
(
&
_zero
)
}
r0
,
_
,
e1
:=
Syscall
(
SYS_READ
,
uintptr
(
fd
),
uintptr
(
_p0
),
uintptr
(
len
(
p
)))
n
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Removexattr
(
path
string
,
attr
string
)
(
err
error
)
{
var
_p0
*
byte
_p0
,
err
=
BytePtrFromString
(
path
)
if
err
!=
nil
{
return
}
var
_p1
*
byte
_p1
,
err
=
BytePtrFromString
(
attr
)
if
err
!=
nil
{
return
}
_
,
_
,
e1
:=
Syscall
(
SYS_REMOVEXATTR
,
uintptr
(
unsafe
.
Pointer
(
_p0
)),
uintptr
(
unsafe
.
Pointer
(
_p1
)),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Setdomainname
(
p
[]
byte
)
(
err
error
)
{
var
_p0
unsafe
.
Pointer
if
len
(
p
)
>
0
{
_p0
=
unsafe
.
Pointer
(
&
p
[
0
])
}
else
{
_p0
=
unsafe
.
Pointer
(
&
_zero
)
}
_
,
_
,
e1
:=
Syscall
(
SYS_SETDOMAINNAME
,
uintptr
(
_p0
),
uintptr
(
len
(
p
)),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Sethostname
(
p
[]
byte
)
(
err
error
)
{
var
_p0
unsafe
.
Pointer
if
len
(
p
)
>
0
{
_p0
=
unsafe
.
Pointer
(
&
p
[
0
])
}
else
{
_p0
=
unsafe
.
Pointer
(
&
_zero
)
}
_
,
_
,
e1
:=
Syscall
(
SYS_SETHOSTNAME
,
uintptr
(
_p0
),
uintptr
(
len
(
p
)),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Setpgid
(
pid
int
,
pgid
int
)
(
err
error
)
{
_
,
_
,
e1
:=
RawSyscall
(
SYS_SETPGID
,
uintptr
(
pid
),
uintptr
(
pgid
),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Setsid
()
(
pid
int
,
err
error
)
{
r0
,
_
,
e1
:=
RawSyscall
(
SYS_SETSID
,
0
,
0
,
0
)
pid
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Settimeofday
(
tv
*
Timeval
)
(
err
error
)
{
_
,
_
,
e1
:=
RawSyscall
(
SYS_SETTIMEOFDAY
,
uintptr
(
unsafe
.
Pointer
(
tv
)),
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Setpriority
(
which
int
,
who
int
,
prio
int
)
(
err
error
)
{
_
,
_
,
e1
:=
Syscall
(
SYS_SETPRIORITY
,
uintptr
(
which
),
uintptr
(
who
),
uintptr
(
prio
))
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Setxattr
(
path
string
,
attr
string
,
data
[]
byte
,
flags
int
)
(
err
error
)
{
var
_p0
*
byte
_p0
,
err
=
BytePtrFromString
(
path
)
if
err
!=
nil
{
return
}
var
_p1
*
byte
_p1
,
err
=
BytePtrFromString
(
attr
)
if
err
!=
nil
{
return
}
var
_p2
unsafe
.
Pointer
if
len
(
data
)
>
0
{
_p2
=
unsafe
.
Pointer
(
&
data
[
0
])
}
else
{
_p2
=
unsafe
.
Pointer
(
&
_zero
)
}
_
,
_
,
e1
:=
Syscall6
(
SYS_SETXATTR
,
uintptr
(
unsafe
.
Pointer
(
_p0
)),
uintptr
(
unsafe
.
Pointer
(
_p1
)),
uintptr
(
_p2
),
uintptr
(
len
(
data
)),
uintptr
(
flags
),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Sync
()
{
Syscall
(
SYS_SYNC
,
0
,
0
,
0
)
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Sysinfo
(
info
*
Sysinfo_t
)
(
err
error
)
{
_
,
_
,
e1
:=
RawSyscall
(
SYS_SYSINFO
,
uintptr
(
unsafe
.
Pointer
(
info
)),
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Tee
(
rfd
int
,
wfd
int
,
len
int
,
flags
int
)
(
n
int64
,
err
error
)
{
r0
,
_
,
e1
:=
Syscall6
(
SYS_TEE
,
uintptr
(
rfd
),
uintptr
(
wfd
),
uintptr
(
len
),
uintptr
(
flags
),
0
,
0
)
n
=
int64
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Tgkill
(
tgid
int
,
tid
int
,
sig
Signal
)
(
err
error
)
{
_
,
_
,
e1
:=
RawSyscall
(
SYS_TGKILL
,
uintptr
(
tgid
),
uintptr
(
tid
),
uintptr
(
sig
))
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Times
(
tms
*
Tms
)
(
ticks
uintptr
,
err
error
)
{
r0
,
_
,
e1
:=
RawSyscall
(
SYS_TIMES
,
uintptr
(
unsafe
.
Pointer
(
tms
)),
0
,
0
)
ticks
=
uintptr
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Umask
(
mask
int
)
(
oldmask
int
)
{
r0
,
_
:=
rawSyscallNoError
(
SYS_UMASK
,
uintptr
(
mask
),
0
,
0
)
oldmask
=
int
(
r0
)
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Uname
(
buf
*
Utsname
)
(
err
error
)
{
_
,
_
,
e1
:=
RawSyscall
(
SYS_UNAME
,
uintptr
(
unsafe
.
Pointer
(
buf
)),
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Unmount
(
target
string
,
flags
int
)
(
err
error
)
{
var
_p0
*
byte
_p0
,
err
=
BytePtrFromString
(
target
)
if
err
!=
nil
{
return
}
_
,
_
,
e1
:=
Syscall
(
SYS_UMOUNT2
,
uintptr
(
unsafe
.
Pointer
(
_p0
)),
uintptr
(
flags
),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Unshare
(
flags
int
)
(
err
error
)
{
_
,
_
,
e1
:=
Syscall
(
SYS_UNSHARE
,
uintptr
(
flags
),
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
write
(
fd
int
,
p
[]
byte
)
(
n
int
,
err
error
)
{
var
_p0
unsafe
.
Pointer
if
len
(
p
)
>
0
{
_p0
=
unsafe
.
Pointer
(
&
p
[
0
])
}
else
{
_p0
=
unsafe
.
Pointer
(
&
_zero
)
}
r0
,
_
,
e1
:=
Syscall
(
SYS_WRITE
,
uintptr
(
fd
),
uintptr
(
_p0
),
uintptr
(
len
(
p
)))
n
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
exitThread
(
code
int
)
(
err
error
)
{
_
,
_
,
e1
:=
Syscall
(
SYS_EXIT
,
uintptr
(
code
),
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
readlen
(
fd
int
,
p
*
byte
,
np
int
)
(
n
int
,
err
error
)
{
r0
,
_
,
e1
:=
Syscall
(
SYS_READ
,
uintptr
(
fd
),
uintptr
(
unsafe
.
Pointer
(
p
)),
uintptr
(
np
))
n
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
writelen
(
fd
int
,
p
*
byte
,
np
int
)
(
n
int
,
err
error
)
{
r0
,
_
,
e1
:=
Syscall
(
SYS_WRITE
,
uintptr
(
fd
),
uintptr
(
unsafe
.
Pointer
(
p
)),
uintptr
(
np
))
n
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
munmap
(
addr
uintptr
,
length
uintptr
)
(
err
error
)
{
_
,
_
,
e1
:=
Syscall
(
SYS_MUNMAP
,
uintptr
(
addr
),
uintptr
(
length
),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Madvise
(
b
[]
byte
,
advice
int
)
(
err
error
)
{
var
_p0
unsafe
.
Pointer
if
len
(
b
)
>
0
{
_p0
=
unsafe
.
Pointer
(
&
b
[
0
])
}
else
{
_p0
=
unsafe
.
Pointer
(
&
_zero
)
}
_
,
_
,
e1
:=
Syscall
(
SYS_MADVISE
,
uintptr
(
_p0
),
uintptr
(
len
(
b
)),
uintptr
(
advice
))
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Mprotect
(
b
[]
byte
,
prot
int
)
(
err
error
)
{
var
_p0
unsafe
.
Pointer
if
len
(
b
)
>
0
{
_p0
=
unsafe
.
Pointer
(
&
b
[
0
])
}
else
{
_p0
=
unsafe
.
Pointer
(
&
_zero
)
}
_
,
_
,
e1
:=
Syscall
(
SYS_MPROTECT
,
uintptr
(
_p0
),
uintptr
(
len
(
b
)),
uintptr
(
prot
))
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Mlock
(
b
[]
byte
)
(
err
error
)
{
var
_p0
unsafe
.
Pointer
if
len
(
b
)
>
0
{
_p0
=
unsafe
.
Pointer
(
&
b
[
0
])
}
else
{
_p0
=
unsafe
.
Pointer
(
&
_zero
)
}
_
,
_
,
e1
:=
Syscall
(
SYS_MLOCK
,
uintptr
(
_p0
),
uintptr
(
len
(
b
)),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Munlock
(
b
[]
byte
)
(
err
error
)
{
var
_p0
unsafe
.
Pointer
if
len
(
b
)
>
0
{
_p0
=
unsafe
.
Pointer
(
&
b
[
0
])
}
else
{
_p0
=
unsafe
.
Pointer
(
&
_zero
)
}
_
,
_
,
e1
:=
Syscall
(
SYS_MUNLOCK
,
uintptr
(
_p0
),
uintptr
(
len
(
b
)),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Mlockall
(
flags
int
)
(
err
error
)
{
_
,
_
,
e1
:=
Syscall
(
SYS_MLOCKALL
,
uintptr
(
flags
),
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Munlockall
()
(
err
error
)
{
_
,
_
,
e1
:=
Syscall
(
SYS_MUNLOCKALL
,
0
,
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
EpollWait
(
epfd
int
,
events
[]
EpollEvent
,
msec
int
)
(
n
int
,
err
error
)
{
var
_p0
unsafe
.
Pointer
if
len
(
events
)
>
0
{
_p0
=
unsafe
.
Pointer
(
&
events
[
0
])
}
else
{
_p0
=
unsafe
.
Pointer
(
&
_zero
)
}
r0
,
_
,
e1
:=
Syscall6
(
SYS_EPOLL_PWAIT
,
uintptr
(
epfd
),
uintptr
(
_p0
),
uintptr
(
len
(
events
)),
uintptr
(
msec
),
0
,
0
)
n
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Fchown
(
fd
int
,
uid
int
,
gid
int
)
(
err
error
)
{
_
,
_
,
e1
:=
Syscall
(
SYS_FCHOWN
,
uintptr
(
fd
),
uintptr
(
uid
),
uintptr
(
gid
))
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Fstat
(
fd
int
,
stat
*
Stat_t
)
(
err
error
)
{
_
,
_
,
e1
:=
Syscall
(
SYS_FSTAT
,
uintptr
(
fd
),
uintptr
(
unsafe
.
Pointer
(
stat
)),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Fstatat
(
fd
int
,
path
string
,
stat
*
Stat_t
,
flags
int
)
(
err
error
)
{
var
_p0
*
byte
_p0
,
err
=
BytePtrFromString
(
path
)
if
err
!=
nil
{
return
}
_
,
_
,
e1
:=
Syscall6
(
SYS_FSTATAT
,
uintptr
(
fd
),
uintptr
(
unsafe
.
Pointer
(
_p0
)),
uintptr
(
unsafe
.
Pointer
(
stat
)),
uintptr
(
flags
),
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
fstatat
(
dirfd
int
,
path
string
,
stat
*
Stat_t
,
flags
int
)
(
err
error
)
{
var
_p0
*
byte
_p0
,
err
=
BytePtrFromString
(
path
)
if
err
!=
nil
{
return
}
_
,
_
,
e1
:=
Syscall6
(
SYS_FSTATAT
,
uintptr
(
dirfd
),
uintptr
(
unsafe
.
Pointer
(
_p0
)),
uintptr
(
unsafe
.
Pointer
(
stat
)),
uintptr
(
flags
),
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Fstatfs
(
fd
int
,
buf
*
Statfs_t
)
(
err
error
)
{
_
,
_
,
e1
:=
Syscall
(
SYS_FSTATFS
,
uintptr
(
fd
),
uintptr
(
unsafe
.
Pointer
(
buf
)),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Ftruncate
(
fd
int
,
length
int64
)
(
err
error
)
{
_
,
_
,
e1
:=
Syscall
(
SYS_FTRUNCATE
,
uintptr
(
fd
),
uintptr
(
length
),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Getegid
()
(
egid
int
)
{
r0
,
_
:=
rawSyscallNoError
(
SYS_GETEGID
,
0
,
0
,
0
)
egid
=
int
(
r0
)
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Geteuid
()
(
euid
int
)
{
r0
,
_
:=
rawSyscallNoError
(
SYS_GETEUID
,
0
,
0
,
0
)
euid
=
int
(
r0
)
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Getgid
()
(
gid
int
)
{
r0
,
_
:=
rawSyscallNoError
(
SYS_GETGID
,
0
,
0
,
0
)
gid
=
int
(
r0
)
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Getrlimit
(
resource
int
,
rlim
*
Rlimit
)
(
err
error
)
{
_
,
_
,
e1
:=
RawSyscall
(
SYS_GETRLIMIT
,
uintptr
(
resource
),
uintptr
(
unsafe
.
Pointer
(
rlim
)),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Getuid
()
(
uid
int
)
{
r0
,
_
:=
rawSyscallNoError
(
SYS_GETUID
,
0
,
0
,
0
)
uid
=
int
(
r0
)
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Listen
(
s
int
,
n
int
)
(
err
error
)
{
_
,
_
,
e1
:=
Syscall
(
SYS_LISTEN
,
uintptr
(
s
),
uintptr
(
n
),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Pread
(
fd
int
,
p
[]
byte
,
offset
int64
)
(
n
int
,
err
error
)
{
var
_p0
unsafe
.
Pointer
if
len
(
p
)
>
0
{
_p0
=
unsafe
.
Pointer
(
&
p
[
0
])
}
else
{
_p0
=
unsafe
.
Pointer
(
&
_zero
)
}
r0
,
_
,
e1
:=
Syscall6
(
SYS_PREAD64
,
uintptr
(
fd
),
uintptr
(
_p0
),
uintptr
(
len
(
p
)),
uintptr
(
offset
),
0
,
0
)
n
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Pwrite
(
fd
int
,
p
[]
byte
,
offset
int64
)
(
n
int
,
err
error
)
{
var
_p0
unsafe
.
Pointer
if
len
(
p
)
>
0
{
_p0
=
unsafe
.
Pointer
(
&
p
[
0
])
}
else
{
_p0
=
unsafe
.
Pointer
(
&
_zero
)
}
r0
,
_
,
e1
:=
Syscall6
(
SYS_PWRITE64
,
uintptr
(
fd
),
uintptr
(
_p0
),
uintptr
(
len
(
p
)),
uintptr
(
offset
),
0
,
0
)
n
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Renameat
(
olddirfd
int
,
oldpath
string
,
newdirfd
int
,
newpath
string
)
(
err
error
)
{
var
_p0
*
byte
_p0
,
err
=
BytePtrFromString
(
oldpath
)
if
err
!=
nil
{
return
}
var
_p1
*
byte
_p1
,
err
=
BytePtrFromString
(
newpath
)
if
err
!=
nil
{
return
}
_
,
_
,
e1
:=
Syscall6
(
SYS_RENAMEAT
,
uintptr
(
olddirfd
),
uintptr
(
unsafe
.
Pointer
(
_p0
)),
uintptr
(
newdirfd
),
uintptr
(
unsafe
.
Pointer
(
_p1
)),
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Seek
(
fd
int
,
offset
int64
,
whence
int
)
(
off
int64
,
err
error
)
{
r0
,
_
,
e1
:=
Syscall
(
SYS_LSEEK
,
uintptr
(
fd
),
uintptr
(
offset
),
uintptr
(
whence
))
off
=
int64
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
sendfile
(
outfd
int
,
infd
int
,
offset
*
int64
,
count
int
)
(
written
int
,
err
error
)
{
r0
,
_
,
e1
:=
Syscall6
(
SYS_SENDFILE
,
uintptr
(
outfd
),
uintptr
(
infd
),
uintptr
(
unsafe
.
Pointer
(
offset
)),
uintptr
(
count
),
0
,
0
)
written
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Setfsgid
(
gid
int
)
(
err
error
)
{
_
,
_
,
e1
:=
Syscall
(
SYS_SETFSGID
,
uintptr
(
gid
),
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Setfsuid
(
uid
int
)
(
err
error
)
{
_
,
_
,
e1
:=
Syscall
(
SYS_SETFSUID
,
uintptr
(
uid
),
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Setregid
(
rgid
int
,
egid
int
)
(
err
error
)
{
_
,
_
,
e1
:=
RawSyscall
(
SYS_SETREGID
,
uintptr
(
rgid
),
uintptr
(
egid
),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Setresgid
(
rgid
int
,
egid
int
,
sgid
int
)
(
err
error
)
{
_
,
_
,
e1
:=
RawSyscall
(
SYS_SETRESGID
,
uintptr
(
rgid
),
uintptr
(
egid
),
uintptr
(
sgid
))
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Setresuid
(
ruid
int
,
euid
int
,
suid
int
)
(
err
error
)
{
_
,
_
,
e1
:=
RawSyscall
(
SYS_SETRESUID
,
uintptr
(
ruid
),
uintptr
(
euid
),
uintptr
(
suid
))
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Setrlimit
(
resource
int
,
rlim
*
Rlimit
)
(
err
error
)
{
_
,
_
,
e1
:=
RawSyscall
(
SYS_SETRLIMIT
,
uintptr
(
resource
),
uintptr
(
unsafe
.
Pointer
(
rlim
)),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Setreuid
(
ruid
int
,
euid
int
)
(
err
error
)
{
_
,
_
,
e1
:=
RawSyscall
(
SYS_SETREUID
,
uintptr
(
ruid
),
uintptr
(
euid
),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Shutdown
(
fd
int
,
how
int
)
(
err
error
)
{
_
,
_
,
e1
:=
Syscall
(
SYS_SHUTDOWN
,
uintptr
(
fd
),
uintptr
(
how
),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Splice
(
rfd
int
,
roff
*
int64
,
wfd
int
,
woff
*
int64
,
len
int
,
flags
int
)
(
n
int64
,
err
error
)
{
r0
,
_
,
e1
:=
Syscall6
(
SYS_SPLICE
,
uintptr
(
rfd
),
uintptr
(
unsafe
.
Pointer
(
roff
)),
uintptr
(
wfd
),
uintptr
(
unsafe
.
Pointer
(
woff
)),
uintptr
(
len
),
uintptr
(
flags
))
n
=
int64
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Statfs
(
path
string
,
buf
*
Statfs_t
)
(
err
error
)
{
var
_p0
*
byte
_p0
,
err
=
BytePtrFromString
(
path
)
if
err
!=
nil
{
return
}
_
,
_
,
e1
:=
Syscall
(
SYS_STATFS
,
uintptr
(
unsafe
.
Pointer
(
_p0
)),
uintptr
(
unsafe
.
Pointer
(
buf
)),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
SyncFileRange
(
fd
int
,
off
int64
,
n
int64
,
flags
int
)
(
err
error
)
{
_
,
_
,
e1
:=
Syscall6
(
SYS_SYNC_FILE_RANGE
,
uintptr
(
fd
),
uintptr
(
off
),
uintptr
(
n
),
uintptr
(
flags
),
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Truncate
(
path
string
,
length
int64
)
(
err
error
)
{
var
_p0
*
byte
_p0
,
err
=
BytePtrFromString
(
path
)
if
err
!=
nil
{
return
}
_
,
_
,
e1
:=
Syscall
(
SYS_TRUNCATE
,
uintptr
(
unsafe
.
Pointer
(
_p0
)),
uintptr
(
length
),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
accept
(
s
int
,
rsa
*
RawSockaddrAny
,
addrlen
*
_Socklen
)
(
fd
int
,
err
error
)
{
r0
,
_
,
e1
:=
Syscall
(
SYS_ACCEPT
,
uintptr
(
s
),
uintptr
(
unsafe
.
Pointer
(
rsa
)),
uintptr
(
unsafe
.
Pointer
(
addrlen
)))
fd
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
accept4
(
s
int
,
rsa
*
RawSockaddrAny
,
addrlen
*
_Socklen
,
flags
int
)
(
fd
int
,
err
error
)
{
r0
,
_
,
e1
:=
Syscall6
(
SYS_ACCEPT4
,
uintptr
(
s
),
uintptr
(
unsafe
.
Pointer
(
rsa
)),
uintptr
(
unsafe
.
Pointer
(
addrlen
)),
uintptr
(
flags
),
0
,
0
)
fd
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
bind
(
s
int
,
addr
unsafe
.
Pointer
,
addrlen
_Socklen
)
(
err
error
)
{
_
,
_
,
e1
:=
Syscall
(
SYS_BIND
,
uintptr
(
s
),
uintptr
(
addr
),
uintptr
(
addrlen
))
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
connect
(
s
int
,
addr
unsafe
.
Pointer
,
addrlen
_Socklen
)
(
err
error
)
{
_
,
_
,
e1
:=
Syscall
(
SYS_CONNECT
,
uintptr
(
s
),
uintptr
(
addr
),
uintptr
(
addrlen
))
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
getgroups
(
n
int
,
list
*
_Gid_t
)
(
nn
int
,
err
error
)
{
r0
,
_
,
e1
:=
RawSyscall
(
SYS_GETGROUPS
,
uintptr
(
n
),
uintptr
(
unsafe
.
Pointer
(
list
)),
0
)
nn
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
setgroups
(
n
int
,
list
*
_Gid_t
)
(
err
error
)
{
_
,
_
,
e1
:=
RawSyscall
(
SYS_SETGROUPS
,
uintptr
(
n
),
uintptr
(
unsafe
.
Pointer
(
list
)),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
getsockopt
(
s
int
,
level
int
,
name
int
,
val
unsafe
.
Pointer
,
vallen
*
_Socklen
)
(
err
error
)
{
_
,
_
,
e1
:=
Syscall6
(
SYS_GETSOCKOPT
,
uintptr
(
s
),
uintptr
(
level
),
uintptr
(
name
),
uintptr
(
val
),
uintptr
(
unsafe
.
Pointer
(
vallen
)),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
setsockopt
(
s
int
,
level
int
,
name
int
,
val
unsafe
.
Pointer
,
vallen
uintptr
)
(
err
error
)
{
_
,
_
,
e1
:=
Syscall6
(
SYS_SETSOCKOPT
,
uintptr
(
s
),
uintptr
(
level
),
uintptr
(
name
),
uintptr
(
val
),
uintptr
(
vallen
),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
socket
(
domain
int
,
typ
int
,
proto
int
)
(
fd
int
,
err
error
)
{
r0
,
_
,
e1
:=
RawSyscall
(
SYS_SOCKET
,
uintptr
(
domain
),
uintptr
(
typ
),
uintptr
(
proto
))
fd
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
socketpair
(
domain
int
,
typ
int
,
proto
int
,
fd
*
[
2
]
int32
)
(
err
error
)
{
_
,
_
,
e1
:=
RawSyscall6
(
SYS_SOCKETPAIR
,
uintptr
(
domain
),
uintptr
(
typ
),
uintptr
(
proto
),
uintptr
(
unsafe
.
Pointer
(
fd
)),
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
getpeername
(
fd
int
,
rsa
*
RawSockaddrAny
,
addrlen
*
_Socklen
)
(
err
error
)
{
_
,
_
,
e1
:=
RawSyscall
(
SYS_GETPEERNAME
,
uintptr
(
fd
),
uintptr
(
unsafe
.
Pointer
(
rsa
)),
uintptr
(
unsafe
.
Pointer
(
addrlen
)))
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
getsockname
(
fd
int
,
rsa
*
RawSockaddrAny
,
addrlen
*
_Socklen
)
(
err
error
)
{
_
,
_
,
e1
:=
RawSyscall
(
SYS_GETSOCKNAME
,
uintptr
(
fd
),
uintptr
(
unsafe
.
Pointer
(
rsa
)),
uintptr
(
unsafe
.
Pointer
(
addrlen
)))
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
recvfrom
(
fd
int
,
p
[]
byte
,
flags
int
,
from
*
RawSockaddrAny
,
fromlen
*
_Socklen
)
(
n
int
,
err
error
)
{
var
_p0
unsafe
.
Pointer
if
len
(
p
)
>
0
{
_p0
=
unsafe
.
Pointer
(
&
p
[
0
])
}
else
{
_p0
=
unsafe
.
Pointer
(
&
_zero
)
}
r0
,
_
,
e1
:=
Syscall6
(
SYS_RECVFROM
,
uintptr
(
fd
),
uintptr
(
_p0
),
uintptr
(
len
(
p
)),
uintptr
(
flags
),
uintptr
(
unsafe
.
Pointer
(
from
)),
uintptr
(
unsafe
.
Pointer
(
fromlen
)))
n
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
sendto
(
s
int
,
buf
[]
byte
,
flags
int
,
to
unsafe
.
Pointer
,
addrlen
_Socklen
)
(
err
error
)
{
var
_p0
unsafe
.
Pointer
if
len
(
buf
)
>
0
{
_p0
=
unsafe
.
Pointer
(
&
buf
[
0
])
}
else
{
_p0
=
unsafe
.
Pointer
(
&
_zero
)
}
_
,
_
,
e1
:=
Syscall6
(
SYS_SENDTO
,
uintptr
(
s
),
uintptr
(
_p0
),
uintptr
(
len
(
buf
)),
uintptr
(
flags
),
uintptr
(
to
),
uintptr
(
addrlen
))
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
recvmsg
(
s
int
,
msg
*
Msghdr
,
flags
int
)
(
n
int
,
err
error
)
{
r0
,
_
,
e1
:=
Syscall
(
SYS_RECVMSG
,
uintptr
(
s
),
uintptr
(
unsafe
.
Pointer
(
msg
)),
uintptr
(
flags
))
n
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
sendmsg
(
s
int
,
msg
*
Msghdr
,
flags
int
)
(
n
int
,
err
error
)
{
r0
,
_
,
e1
:=
Syscall
(
SYS_SENDMSG
,
uintptr
(
s
),
uintptr
(
unsafe
.
Pointer
(
msg
)),
uintptr
(
flags
))
n
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
mmap
(
addr
uintptr
,
length
uintptr
,
prot
int
,
flags
int
,
fd
int
,
offset
int64
)
(
xaddr
uintptr
,
err
error
)
{
r0
,
_
,
e1
:=
Syscall6
(
SYS_MMAP
,
uintptr
(
addr
),
uintptr
(
length
),
uintptr
(
prot
),
uintptr
(
flags
),
uintptr
(
fd
),
uintptr
(
offset
))
xaddr
=
uintptr
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
pselect
(
nfd
int
,
r
*
FdSet
,
w
*
FdSet
,
e
*
FdSet
,
timeout
*
Timespec
,
sigmask
*
sigset_t
)
(
n
int
,
err
error
)
{
r0
,
_
,
e1
:=
Syscall6
(
SYS_PSELECT6
,
uintptr
(
nfd
),
uintptr
(
unsafe
.
Pointer
(
r
)),
uintptr
(
unsafe
.
Pointer
(
w
)),
uintptr
(
unsafe
.
Pointer
(
e
)),
uintptr
(
unsafe
.
Pointer
(
timeout
)),
uintptr
(
unsafe
.
Pointer
(
sigmask
)))
n
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
Gettimeofday
(
tv
*
Timeval
)
(
err
error
)
{
_
,
_
,
e1
:=
RawSyscall
(
SYS_GETTIMEOFDAY
,
uintptr
(
unsafe
.
Pointer
(
tv
)),
0
,
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
pipe2
(
p
*
[
2
]
_C_int
,
flags
int
)
(
err
error
)
{
_
,
_
,
e1
:=
RawSyscall
(
SYS_PIPE2
,
uintptr
(
unsafe
.
Pointer
(
p
)),
uintptr
(
flags
),
0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
// THIS FILE IS GENERATED BY THE COMMAND AT THE TOP; DO NOT EDIT
func
ppoll
(
fds
*
pollFd
,
nfds
int
,
timeout
*
Timespec
,
sigmask
*
sigset_t
)
(
n
int
,
err
error
)
{
r0
,
_
,
e1
:=
Syscall6
(
SYS_PPOLL
,
uintptr
(
unsafe
.
Pointer
(
fds
)),
uintptr
(
nfds
),
uintptr
(
unsafe
.
Pointer
(
timeout
)),
uintptr
(
unsafe
.
Pointer
(
sigmask
)),
0
,
0
)
n
=
int
(
r0
)
if
e1
!=
0
{
err
=
errnoErr
(
e1
)
}
return
}
src/syscall/zsysnum_linux_riscv64.go
0 → 100644
View file @
4497d7eb
// mksysnum_linux.pl /usr/include/asm/unistd.h
// MACHINE GENERATED BY THE ABOVE COMMAND; DO NOT EDIT
package
syscall
const
(
SYS_IO_SETUP
=
0
SYS_IO_DESTROY
=
1
SYS_IO_SUBMIT
=
2
SYS_IO_CANCEL
=
3
SYS_IO_GETEVENTS
=
4
SYS_SETXATTR
=
5
SYS_LSETXATTR
=
6
SYS_FSETXATTR
=
7
SYS_GETXATTR
=
8
SYS_LGETXATTR
=
9
SYS_FGETXATTR
=
10
SYS_LISTXATTR
=
11
SYS_LLISTXATTR
=
12
SYS_FLISTXATTR
=
13
SYS_REMOVEXATTR
=
14
SYS_LREMOVEXATTR
=
15
SYS_FREMOVEXATTR
=
16
SYS_GETCWD
=
17
SYS_LOOKUP_DCOOKIE
=
18
SYS_EVENTFD2
=
19
SYS_EPOLL_CREATE1
=
20
SYS_EPOLL_CTL
=
21
SYS_EPOLL_PWAIT
=
22
SYS_DUP
=
23
SYS_DUP3
=
24
SYS_FCNTL
=
25
SYS_INOTIFY_INIT1
=
26
SYS_INOTIFY_ADD_WATCH
=
27
SYS_INOTIFY_RM_WATCH
=
28
SYS_IOCTL
=
29
SYS_IOPRIO_SET
=
30
SYS_IOPRIO_GET
=
31
SYS_FLOCK
=
32
SYS_MKNODAT
=
33
SYS_MKDIRAT
=
34
SYS_UNLINKAT
=
35
SYS_SYMLINKAT
=
36
SYS_LINKAT
=
37
SYS_UMOUNT2
=
39
SYS_MOUNT
=
40
SYS_PIVOT_ROOT
=
41
SYS_NFSSERVCTL
=
42
SYS_STATFS
=
43
SYS_FSTATFS
=
44
SYS_TRUNCATE
=
45
SYS_FTRUNCATE
=
46
SYS_FALLOCATE
=
47
SYS_FACCESSAT
=
48
SYS_CHDIR
=
49
SYS_FCHDIR
=
50
SYS_CHROOT
=
51
SYS_FCHMOD
=
52
SYS_FCHMODAT
=
53
SYS_FCHOWNAT
=
54
SYS_FCHOWN
=
55
SYS_OPENAT
=
56
SYS_CLOSE
=
57
SYS_VHANGUP
=
58
SYS_PIPE2
=
59
SYS_QUOTACTL
=
60
SYS_GETDENTS64
=
61
SYS_LSEEK
=
62
SYS_READ
=
63
SYS_WRITE
=
64
SYS_READV
=
65
SYS_WRITEV
=
66
SYS_PREAD64
=
67
SYS_PWRITE64
=
68
SYS_PREADV
=
69
SYS_PWRITEV
=
70
SYS_SENDFILE
=
71
SYS_PSELECT6
=
72
SYS_PPOLL
=
73
SYS_SIGNALFD4
=
74
SYS_VMSPLICE
=
75
SYS_SPLICE
=
76
SYS_TEE
=
77
SYS_READLINKAT
=
78
SYS_FSTATAT
=
79
SYS_FSTAT
=
80
SYS_SYNC
=
81
SYS_FSYNC
=
82
SYS_FDATASYNC
=
83
SYS_SYNC_FILE_RANGE
=
84
SYS_TIMERFD_CREATE
=
85
SYS_TIMERFD_SETTIME
=
86
SYS_TIMERFD_GETTIME
=
87
SYS_UTIMENSAT
=
88
SYS_ACCT
=
89
SYS_CAPGET
=
90
SYS_CAPSET
=
91
SYS_PERSONALITY
=
92
SYS_EXIT
=
93
SYS_EXIT_GROUP
=
94
SYS_WAITID
=
95
SYS_SET_TID_ADDRESS
=
96
SYS_UNSHARE
=
97
SYS_FUTEX
=
98
SYS_SET_ROBUST_LIST
=
99
SYS_GET_ROBUST_LIST
=
100
SYS_NANOSLEEP
=
101
SYS_GETITIMER
=
102
SYS_SETITIMER
=
103
SYS_KEXEC_LOAD
=
104
SYS_INIT_MODULE
=
105
SYS_DELETE_MODULE
=
106
SYS_TIMER_CREATE
=
107
SYS_TIMER_GETTIME
=
108
SYS_TIMER_GETOVERRUN
=
109
SYS_TIMER_SETTIME
=
110
SYS_TIMER_DELETE
=
111
SYS_CLOCK_SETTIME
=
112
SYS_CLOCK_GETTIME
=
113
SYS_CLOCK_GETRES
=
114
SYS_CLOCK_NANOSLEEP
=
115
SYS_SYSLOG
=
116
SYS_PTRACE
=
117
SYS_SCHED_SETPARAM
=
118
SYS_SCHED_SETSCHEDULER
=
119
SYS_SCHED_GETSCHEDULER
=
120
SYS_SCHED_GETPARAM
=
121
SYS_SCHED_SETAFFINITY
=
122
SYS_SCHED_GETAFFINITY
=
123
SYS_SCHED_YIELD
=
124
SYS_SCHED_GET_PRIORITY_MAX
=
125
SYS_SCHED_GET_PRIORITY_MIN
=
126
SYS_SCHED_RR_GET_INTERVAL
=
127
SYS_RESTART_SYSCALL
=
128
SYS_KILL
=
129
SYS_TKILL
=
130
SYS_TGKILL
=
131
SYS_SIGALTSTACK
=
132
SYS_RT_SIGSUSPEND
=
133
SYS_RT_SIGACTION
=
134
SYS_RT_SIGPROCMASK
=
135
SYS_RT_SIGPENDING
=
136
SYS_RT_SIGTIMEDWAIT
=
137
SYS_RT_SIGQUEUEINFO
=
138
SYS_RT_SIGRETURN
=
139
SYS_SETPRIORITY
=
140
SYS_GETPRIORITY
=
141
SYS_REBOOT
=
142
SYS_SETREGID
=
143
SYS_SETGID
=
144
SYS_SETREUID
=
145
SYS_SETUID
=
146
SYS_SETRESUID
=
147
SYS_GETRESUID
=
148
SYS_SETRESGID
=
149
SYS_GETRESGID
=
150
SYS_SETFSUID
=
151
SYS_SETFSGID
=
152
SYS_TIMES
=
153
SYS_SETPGID
=
154
SYS_GETPGID
=
155
SYS_GETSID
=
156
SYS_SETSID
=
157
SYS_GETGROUPS
=
158
SYS_SETGROUPS
=
159
SYS_UNAME
=
160
SYS_SETHOSTNAME
=
161
SYS_SETDOMAINNAME
=
162
SYS_GETRLIMIT
=
163
SYS_SETRLIMIT
=
164
SYS_GETRUSAGE
=
165
SYS_UMASK
=
166
SYS_PRCTL
=
167
SYS_GETCPU
=
168
SYS_GETTIMEOFDAY
=
169
SYS_SETTIMEOFDAY
=
170
SYS_ADJTIMEX
=
171
SYS_GETPID
=
172
SYS_GETPPID
=
173
SYS_GETUID
=
174
SYS_GETEUID
=
175
SYS_GETGID
=
176
SYS_GETEGID
=
177
SYS_GETTID
=
178
SYS_SYSINFO
=
179
SYS_MQ_OPEN
=
180
SYS_MQ_UNLINK
=
181
SYS_MQ_TIMEDSEND
=
182
SYS_MQ_TIMEDRECEIVE
=
183
SYS_MQ_NOTIFY
=
184
SYS_MQ_GETSETATTR
=
185
SYS_MSGGET
=
186
SYS_MSGCTL
=
187
SYS_MSGRCV
=
188
SYS_MSGSND
=
189
SYS_SEMGET
=
190
SYS_SEMCTL
=
191
SYS_SEMTIMEDOP
=
192
SYS_SEMOP
=
193
SYS_SHMGET
=
194
SYS_SHMCTL
=
195
SYS_SHMAT
=
196
SYS_SHMDT
=
197
SYS_SOCKET
=
198
SYS_SOCKETPAIR
=
199
SYS_BIND
=
200
SYS_LISTEN
=
201
SYS_ACCEPT
=
202
SYS_CONNECT
=
203
SYS_GETSOCKNAME
=
204
SYS_GETPEERNAME
=
205
SYS_SENDTO
=
206
SYS_RECVFROM
=
207
SYS_SETSOCKOPT
=
208
SYS_GETSOCKOPT
=
209
SYS_SHUTDOWN
=
210
SYS_SENDMSG
=
211
SYS_RECVMSG
=
212
SYS_READAHEAD
=
213
SYS_BRK
=
214
SYS_MUNMAP
=
215
SYS_MREMAP
=
216
SYS_ADD_KEY
=
217
SYS_REQUEST_KEY
=
218
SYS_KEYCTL
=
219
SYS_CLONE
=
220
SYS_EXECVE
=
221
SYS_MMAP
=
222
SYS_FADVISE64
=
223
SYS_SWAPON
=
224
SYS_SWAPOFF
=
225
SYS_MPROTECT
=
226
SYS_MSYNC
=
227
SYS_MLOCK
=
228
SYS_MUNLOCK
=
229
SYS_MLOCKALL
=
230
SYS_MUNLOCKALL
=
231
SYS_MINCORE
=
232
SYS_MADVISE
=
233
SYS_REMAP_FILE_PAGES
=
234
SYS_MBIND
=
235
SYS_GET_MEMPOLICY
=
236
SYS_SET_MEMPOLICY
=
237
SYS_MIGRATE_PAGES
=
238
SYS_MOVE_PAGES
=
239
SYS_RT_TGSIGQUEUEINFO
=
240
SYS_PERF_EVENT_OPEN
=
241
SYS_ACCEPT4
=
242
SYS_RECVMMSG
=
243
SYS_ARCH_SPECIFIC_SYSCALL
=
244
SYS_WAIT4
=
260
SYS_PRLIMIT64
=
261
SYS_FANOTIFY_INIT
=
262
SYS_FANOTIFY_MARK
=
263
SYS_NAME_TO_HANDLE_AT
=
264
SYS_OPEN_BY_HANDLE_AT
=
265
SYS_CLOCK_ADJTIME
=
266
SYS_SYNCFS
=
267
SYS_SETNS
=
268
SYS_SENDMMSG
=
269
SYS_PROCESS_VM_READV
=
270
SYS_PROCESS_VM_WRITEV
=
271
SYS_KCMP
=
272
SYS_FINIT_MODULE
=
273
SYS_SCHED_SETATTR
=
274
SYS_SCHED_GETATTR
=
275
SYS_RENAMEAT2
=
276
SYS_SECCOMP
=
277
SYS_GETRANDOM
=
278
SYS_MEMFD_CREATE
=
279
SYS_BPF
=
280
SYS_EXECVEAT
=
281
)
src/syscall/ztypes_linux_riscv64.go
0 → 100644
View file @
4497d7eb
// Created by cgo -godefs - DO NOT EDIT
// cgo -godefs types_linux.go
package
syscall
const
(
sizeofPtr
=
0x8
sizeofShort
=
0x2
sizeofInt
=
0x4
sizeofLong
=
0x8
sizeofLongLong
=
0x8
PathMax
=
0x1000
)
type
(
_C_short
int16
_C_int
int32
_C_long
int64
_C_long_long
int64
)
type
Timespec
struct
{
Sec
int64
Nsec
int64
}
type
Timeval
struct
{
Sec
int64
Usec
int64
}
type
Timex
struct
{
Modes
uint32
Pad_cgo_0
[
4
]
byte
Offset
int64
Freq
int64
Maxerror
int64
Esterror
int64
Status
int32
Pad_cgo_1
[
4
]
byte
Constant
int64
Precision
int64
Tolerance
int64
Time
Timeval
Tick
int64
Ppsfreq
int64
Jitter
int64
Shift
int32
Pad_cgo_2
[
4
]
byte
Stabil
int64
Jitcnt
int64
Calcnt
int64
Errcnt
int64
Stbcnt
int64
Tai
int32
Pad_cgo_3
[
44
]
byte
}
type
Time_t
int64
type
Tms
struct
{
Utime
int64
Stime
int64
Cutime
int64
Cstime
int64
}
type
Utimbuf
struct
{
Actime
int64
Modtime
int64
}
type
Rusage
struct
{
Utime
Timeval
Stime
Timeval
Maxrss
int64
Ixrss
int64
Idrss
int64
Isrss
int64
Minflt
int64
Majflt
int64
Nswap
int64
Inblock
int64
Oublock
int64
Msgsnd
int64
Msgrcv
int64
Nsignals
int64
Nvcsw
int64
Nivcsw
int64
}
type
Rlimit
struct
{
Cur
uint64
Max
uint64
}
type
_Gid_t
uint32
type
Stat_t
struct
{
Dev
uint64
Ino
uint64
Mode
uint32
Nlink
uint32
Uid
uint32
Gid
uint32
Rdev
uint64
X__pad1
uint64
Size
int64
Blksize
int32
X__pad2
int32
Blocks
int64
Atim
Timespec
Mtim
Timespec
Ctim
Timespec
X__glibc_reserved
[
2
]
int32
}
type
Statfs_t
struct
{
Type
int64
Bsize
int64
Blocks
uint64
Bfree
uint64
Bavail
uint64
Files
uint64
Ffree
uint64
Fsid
Fsid
Namelen
int64
Frsize
int64
Flags
int64
Spare
[
4
]
int64
}
type
Dirent
struct
{
Ino
uint64
Off
int64
Reclen
uint16
Type
uint8
Name
[
256
]
uint8
Pad_cgo_0
[
5
]
byte
}
type
Fsid
struct
{
X__val
[
2
]
int32
}
type
Flock_t
struct
{
Type
int16
Whence
int16
Pad_cgo_0
[
4
]
byte
Start
int64
Len
int64
Pid
int32
Pad_cgo_1
[
4
]
byte
}
type
RawSockaddrInet4
struct
{
Family
uint16
Port
uint16
Addr
[
4
]
byte
/* in_addr */
Zero
[
8
]
uint8
}
type
RawSockaddrInet6
struct
{
Family
uint16
Port
uint16
Flowinfo
uint32
Addr
[
16
]
byte
/* in6_addr */
Scope_id
uint32
}
type
RawSockaddrUnix
struct
{
Family
uint16
Path
[
108
]
int8
}
type
RawSockaddrLinklayer
struct
{
Family
uint16
Protocol
uint16
Ifindex
int32
Hatype
uint16
Pkttype
uint8
Halen
uint8
Addr
[
8
]
uint8
}
type
RawSockaddrNetlink
struct
{
Family
uint16
Pad
uint16
Pid
uint32
Groups
uint32
}
type
RawSockaddr
struct
{
Family
uint16
Data
[
14
]
uint8
}
type
RawSockaddrAny
struct
{
Addr
RawSockaddr
Pad
[
96
]
uint8
}
type
_Socklen
uint32
type
Linger
struct
{
Onoff
int32
Linger
int32
}
type
Iovec
struct
{
Base
*
byte
Len
uint64
}
type
IPMreq
struct
{
Multiaddr
[
4
]
byte
/* in_addr */
Interface
[
4
]
byte
/* in_addr */
}
type
IPMreqn
struct
{
Multiaddr
[
4
]
byte
/* in_addr */
Address
[
4
]
byte
/* in_addr */
Ifindex
int32
}
type
IPv6Mreq
struct
{
Multiaddr
[
16
]
byte
/* in6_addr */
Interface
uint32
}
type
Msghdr
struct
{
Name
*
byte
Namelen
uint32
Pad_cgo_0
[
4
]
byte
Iov
*
Iovec
Iovlen
uint64
Control
*
byte
Controllen
uint64
Flags
int32
Pad_cgo_1
[
4
]
byte
}
type
Cmsghdr
struct
{
Len
uint64
Level
int32
Type
int32
}
type
Inet4Pktinfo
struct
{
Ifindex
int32
Spec_dst
[
4
]
byte
/* in_addr */
Addr
[
4
]
byte
/* in_addr */
}
type
Inet6Pktinfo
struct
{
Addr
[
16
]
byte
/* in6_addr */
Ifindex
uint32
}
type
IPv6MTUInfo
struct
{
Addr
RawSockaddrInet6
Mtu
uint32
}
type
ICMPv6Filter
struct
{
Data
[
8
]
uint32
}
type
Ucred
struct
{
Pid
int32
Uid
uint32
Gid
uint32
}
type
TCPInfo
struct
{
State
uint8
Ca_state
uint8
Retransmits
uint8
Probes
uint8
Backoff
uint8
Options
uint8
Pad_cgo_0
[
2
]
byte
Rto
uint32
Ato
uint32
Snd_mss
uint32
Rcv_mss
uint32
Unacked
uint32
Sacked
uint32
Lost
uint32
Retrans
uint32
Fackets
uint32
Last_data_sent
uint32
Last_ack_sent
uint32
Last_data_recv
uint32
Last_ack_recv
uint32
Pmtu
uint32
Rcv_ssthresh
uint32
Rtt
uint32
Rttvar
uint32
Snd_ssthresh
uint32
Snd_cwnd
uint32
Advmss
uint32
Reordering
uint32
Rcv_rtt
uint32
Rcv_space
uint32
Total_retrans
uint32
}
const
(
SizeofSockaddrInet4
=
0x10
SizeofSockaddrInet6
=
0x1c
SizeofSockaddrAny
=
0x70
SizeofSockaddrUnix
=
0x6e
SizeofSockaddrLinklayer
=
0x14
SizeofSockaddrNetlink
=
0xc
SizeofLinger
=
0x8
SizeofIPMreq
=
0x8
SizeofIPMreqn
=
0xc
SizeofIPv6Mreq
=
0x14
SizeofMsghdr
=
0x38
SizeofCmsghdr
=
0x10
SizeofInet4Pktinfo
=
0xc
SizeofInet6Pktinfo
=
0x14
SizeofIPv6MTUInfo
=
0x20
SizeofICMPv6Filter
=
0x20
SizeofUcred
=
0xc
SizeofTCPInfo
=
0x68
)
const
(
IFA_UNSPEC
=
0x0
IFA_ADDRESS
=
0x1
IFA_LOCAL
=
0x2
IFA_LABEL
=
0x3
IFA_BROADCAST
=
0x4
IFA_ANYCAST
=
0x5
IFA_CACHEINFO
=
0x6
IFA_MULTICAST
=
0x7
IFLA_UNSPEC
=
0x0
IFLA_ADDRESS
=
0x1
IFLA_BROADCAST
=
0x2
IFLA_IFNAME
=
0x3
IFLA_MTU
=
0x4
IFLA_LINK
=
0x5
IFLA_QDISC
=
0x6
IFLA_STATS
=
0x7
IFLA_COST
=
0x8
IFLA_PRIORITY
=
0x9
IFLA_MASTER
=
0xa
IFLA_WIRELESS
=
0xb
IFLA_PROTINFO
=
0xc
IFLA_TXQLEN
=
0xd
IFLA_MAP
=
0xe
IFLA_WEIGHT
=
0xf
IFLA_OPERSTATE
=
0x10
IFLA_LINKMODE
=
0x11
IFLA_LINKINFO
=
0x12
IFLA_NET_NS_PID
=
0x13
IFLA_IFALIAS
=
0x14
IFLA_MAX
=
0x26
RT_SCOPE_UNIVERSE
=
0x0
RT_SCOPE_SITE
=
0xc8
RT_SCOPE_LINK
=
0xfd
RT_SCOPE_HOST
=
0xfe
RT_SCOPE_NOWHERE
=
0xff
RT_TABLE_UNSPEC
=
0x0
RT_TABLE_COMPAT
=
0xfc
RT_TABLE_DEFAULT
=
0xfd
RT_TABLE_MAIN
=
0xfe
RT_TABLE_LOCAL
=
0xff
RT_TABLE_MAX
=
0xffffffff
RTA_UNSPEC
=
0x0
RTA_DST
=
0x1
RTA_SRC
=
0x2
RTA_IIF
=
0x3
RTA_OIF
=
0x4
RTA_GATEWAY
=
0x5
RTA_PRIORITY
=
0x6
RTA_PREFSRC
=
0x7
RTA_METRICS
=
0x8
RTA_MULTIPATH
=
0x9
RTA_FLOW
=
0xb
RTA_CACHEINFO
=
0xc
RTA_TABLE
=
0xf
RTN_UNSPEC
=
0x0
RTN_UNICAST
=
0x1
RTN_LOCAL
=
0x2
RTN_BROADCAST
=
0x3
RTN_ANYCAST
=
0x4
RTN_MULTICAST
=
0x5
RTN_BLACKHOLE
=
0x6
RTN_UNREACHABLE
=
0x7
RTN_PROHIBIT
=
0x8
RTN_THROW
=
0x9
RTN_NAT
=
0xa
RTN_XRESOLVE
=
0xb
RTNLGRP_NONE
=
0x0
RTNLGRP_LINK
=
0x1
RTNLGRP_NOTIFY
=
0x2
RTNLGRP_NEIGH
=
0x3
RTNLGRP_TC
=
0x4
RTNLGRP_IPV4_IFADDR
=
0x5
RTNLGRP_IPV4_MROUTE
=
0x6
RTNLGRP_IPV4_ROUTE
=
0x7
RTNLGRP_IPV4_RULE
=
0x8
RTNLGRP_IPV6_IFADDR
=
0x9
RTNLGRP_IPV6_MROUTE
=
0xa
RTNLGRP_IPV6_ROUTE
=
0xb
RTNLGRP_IPV6_IFINFO
=
0xc
RTNLGRP_IPV6_PREFIX
=
0x12
RTNLGRP_IPV6_RULE
=
0x13
RTNLGRP_ND_USEROPT
=
0x14
SizeofNlMsghdr
=
0x10
SizeofNlMsgerr
=
0x14
SizeofRtGenmsg
=
0x1
SizeofNlAttr
=
0x4
SizeofRtAttr
=
0x4
SizeofIfInfomsg
=
0x10
SizeofIfAddrmsg
=
0x8
SizeofRtMsg
=
0xc
SizeofRtNexthop
=
0x8
)
type
NlMsghdr
struct
{
Len
uint32
Type
uint16
Flags
uint16
Seq
uint32
Pid
uint32
}
type
NlMsgerr
struct
{
Error
int32
Msg
NlMsghdr
}
type
RtGenmsg
struct
{
Family
uint8
}
type
NlAttr
struct
{
Len
uint16
Type
uint16
}
type
RtAttr
struct
{
Len
uint16
Type
uint16
}
type
IfInfomsg
struct
{
Family
uint8
X__ifi_pad
uint8
Type
uint16
Index
int32
Flags
uint32
Change
uint32
}
type
IfAddrmsg
struct
{
Family
uint8
Prefixlen
uint8
Flags
uint8
Scope
uint8
Index
uint32
}
type
RtMsg
struct
{
Family
uint8
Dst_len
uint8
Src_len
uint8
Tos
uint8
Table
uint8
Protocol
uint8
Scope
uint8
Type
uint8
Flags
uint32
}
type
RtNexthop
struct
{
Len
uint16
Flags
uint8
Hops
uint8
Ifindex
int32
}
const
(
SizeofSockFilter
=
0x8
SizeofSockFprog
=
0x10
)
type
SockFilter
struct
{
Code
uint16
Jt
uint8
Jf
uint8
K
uint32
}
type
SockFprog
struct
{
Len
uint16
Pad_cgo_0
[
6
]
byte
Filter
*
SockFilter
}
type
InotifyEvent
struct
{
Wd
int32
Mask
uint32
Cookie
uint32
Len
uint32
}
const
SizeofInotifyEvent
=
0x10
type
PtraceRegs
struct
{
Pc
uint64
Ra
uint64
Sp
uint64
Gp
uint64
Tp
uint64
T0
uint64
T1
uint64
T2
uint64
S0
uint64
S1
uint64
A0
uint64
A1
uint64
A2
uint64
A3
uint64
A4
uint64
A5
uint64
A6
uint64
A7
uint64
S2
uint64
S3
uint64
S4
uint64
S5
uint64
S6
uint64
S7
uint64
S8
uint64
S9
uint64
S10
uint64
S11
uint64
T3
uint64
T4
uint64
T5
uint64
T6
uint64
}
type
ptracePsw
struct
{
}
type
ptraceFpregs
struct
{
}
type
ptracePer
struct
{
}
type
FdSet
struct
{
Bits
[
16
]
int64
}
type
Sysinfo_t
struct
{
Uptime
int64
Loads
[
3
]
uint64
Totalram
uint64
Freeram
uint64
Sharedram
uint64
Bufferram
uint64
Totalswap
uint64
Freeswap
uint64
Procs
uint16
Pad
uint16
Pad_cgo_0
[
4
]
byte
Totalhigh
uint64
Freehigh
uint64
Unit
uint32
X_f
[
0
]
uint8
Pad_cgo_1
[
4
]
byte
}
type
Utsname
struct
{
Sysname
[
65
]
uint8
Nodename
[
65
]
uint8
Release
[
65
]
uint8
Version
[
65
]
uint8
Machine
[
65
]
uint8
Domainname
[
65
]
uint8
}
type
Ustat_t
struct
{
Tfree
int32
Pad_cgo_0
[
4
]
byte
Tinode
uint64
Fname
[
6
]
uint8
Fpack
[
6
]
uint8
Pad_cgo_1
[
4
]
byte
}
type
EpollEvent
struct
{
Events
uint32
_
int32
Fd
int32
Pad
int32
}
const
(
_AT_FDCWD
=
-
0x64
_AT_REMOVEDIR
=
0x200
_AT_SYMLINK_NOFOLLOW
=
0x100
_AT_EACCESS
=
0x200
)
type
Termios
struct
{
Iflag
uint32
Oflag
uint32
Cflag
uint32
Lflag
uint32
Line
uint8
Cc
[
32
]
uint8
Pad_cgo_0
[
3
]
byte
Ispeed
uint32
Ospeed
uint32
}
const
(
IUCLC
=
0x200
OLCUC
=
0x2
TCGETS
=
0x5401
TCSETS
=
0x5402
XCASE
=
0x4
)
src/time/zoneinfo.go
View file @
4497d7eb
...
...
@@ -65,6 +65,11 @@ var UTC *Location = &utcLoc
var
utcLoc
=
Location
{
name
:
"UTC"
}
// Local represents the system's local time zone.
// On Unix systems, Local consults the TZ environment
// variable to find the time zone to use. No TZ means
// use the system default /etc/localtime.
// TZ="" means use UTC.
// TZ="foo" means use file foo in the system timezone directory.
var
Local
*
Location
=
&
localLoc
// localLoc is separate so that initLocal can initialize
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment