liuxiaolong
2022-06-28 37714b1093c04061e636e5b1d27179652e671c0a
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
// Copyright 2018 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 unix
 
import (
    "syscall"
    "unsafe"
)
 
// Unveil implements the unveil syscall.
// For more information see unveil(2).
// Note that the special case of blocking further
// unveil calls is handled by UnveilBlock.
func Unveil(path string, flags string) error {
    pathPtr, err := syscall.BytePtrFromString(path)
    if err != nil {
        return err
    }
    flagsPtr, err := syscall.BytePtrFromString(flags)
    if err != nil {
        return err
    }
    _, _, e := syscall.Syscall(SYS_UNVEIL, uintptr(unsafe.Pointer(pathPtr)), uintptr(unsafe.Pointer(flagsPtr)), 0)
    if e != 0 {
        return e
    }
    return nil
}
 
// UnveilBlock blocks future unveil calls.
// For more information see unveil(2).
func UnveilBlock() error {
    // Both pointers must be nil.
    var pathUnsafe, flagsUnsafe unsafe.Pointer
    _, _, e := syscall.Syscall(SYS_UNVEIL, uintptr(pathUnsafe), uintptr(flagsUnsafe), 0)
    if e != 0 {
        return e
    }
    return nil
}