mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-07-21 10:51:29 +00:00
The commands used were (roughly): hack/pin-dependency.sh github.com/opencontainers/runc v1.0.1 hack/lint-dependencies.sh # Follow its recommendations. hack/pin-dependency.sh github.com/cilium/ebpf v0.6.2 hack/pin-dependency.sh github.com/opencontainers/selinux v1.8.2 hack/pin-dependency.sh github.com/sirupsen/logrus v1.8.1 # Recheck. hack/lint-dependencies.sh GO111MODULE=on go mod edit -dropreplace github.com/willf/bitset hack/update-vendor.sh # Recheck. hack/lint-dependencies.sh hack/update-internal-modules.sh # Recheck. hack/lint-dependencies.sh Signed-off-by: Kir Kolyshkin <kolyshkin@gmail.com>
52 lines
1.0 KiB
Go
52 lines
1.0 KiB
Go
package internal
|
|
|
|
import (
|
|
"bytes"
|
|
"errors"
|
|
"fmt"
|
|
"strings"
|
|
|
|
"github.com/cilium/ebpf/internal/unix"
|
|
)
|
|
|
|
// ErrorWithLog returns an error that includes logs from the
|
|
// kernel verifier.
|
|
//
|
|
// logErr should be the error returned by the syscall that generated
|
|
// the log. It is used to check for truncation of the output.
|
|
func ErrorWithLog(err error, log []byte, logErr error) error {
|
|
logStr := strings.Trim(CString(log), "\t\r\n ")
|
|
if errors.Is(logErr, unix.ENOSPC) {
|
|
logStr += " (truncated...)"
|
|
}
|
|
|
|
return &VerifierError{err, logStr}
|
|
}
|
|
|
|
// VerifierError includes information from the eBPF verifier.
|
|
type VerifierError struct {
|
|
cause error
|
|
log string
|
|
}
|
|
|
|
func (le *VerifierError) Unwrap() error {
|
|
return le.cause
|
|
}
|
|
|
|
func (le *VerifierError) Error() string {
|
|
if le.log == "" {
|
|
return le.cause.Error()
|
|
}
|
|
|
|
return fmt.Sprintf("%s: %s", le.cause, le.log)
|
|
}
|
|
|
|
// CString turns a NUL / zero terminated byte buffer into a string.
|
|
func CString(in []byte) string {
|
|
inLen := bytes.IndexByte(in, 0)
|
|
if inLen == -1 {
|
|
return ""
|
|
}
|
|
return string(in[:inLen])
|
|
}
|