
This is to check if runc 1.0.0 (to be released shortly) works with k8s. The commands used were (roughly): hack/pin-dependency.sh github.com/opencontainers/runc v1.0.0 hack/lint-dependencies.sh # Follow its recommendations. hack/pin-dependency.sh github.com/cilium/ebpf v0.6.1 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 [v2: rebased, updated runc 3a0234e1fe2e82 -> 2f8e8e9d977500] [v3: testing master + runc pr 3019] [v4: updated to 93a01cd4d0b7a0f08a] [v5: updated to f093cca13d3cf8a484] [v6: rebased] [v7: updated to runc v1.0.0] [v8: rebased] 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])
|
|
}
|