container/init: close setup pipe early
All checks were successful
Test / Create distribution (push) Successful in 34s
Test / Sandbox (push) Successful in 2m32s
Test / Sandbox (race detector) (push) Successful in 4m30s
Test / Hpkg (push) Successful in 4m48s
Test / Hakurei (race detector) (push) Successful in 6m17s
Test / Hakurei (push) Successful in 3m17s
Test / Flake checks (push) Successful in 1m21s

This prevents leaking the setup pipe.

Signed-off-by: Ophestra <cat@gensokyo.uk>
This commit is contained in:
2025-11-11 07:18:43 +09:00
parent 2f74adc8bd
commit 9dec9dbc4b
4 changed files with 51 additions and 12 deletions

View File

@@ -67,6 +67,39 @@ func main() {
case "hash": // this eases the pain of passing the hash to python
fmt.Print(flagBpfHash)
case "fd":
if len(args) != 2 {
log.Fatal("invalid argument")
}
prefix := fmt.Sprintf("/proc/%s/fd/", args[1])
var fail bool
if entries, err := os.ReadDir(prefix); err != nil {
log.Fatal(err.Error())
} else {
for _, ent := range entries {
var fd int
if fd, err = strconv.Atoi(ent.Name()); err != nil {
log.Fatal(err.Error())
}
// skip standard streams
if fd <= 2 {
continue
}
fail = true
var d string
if d, err = os.Readlink(prefix + ent.Name()); err != nil {
log.Fatal(err.Error())
}
log.Printf("[FAIL] extra fd %d -> %s", fd, d)
}
}
if fail {
log.Fatal("[FAIL] file descriptors leaked")
}
default:
log.Fatal("invalid argument")
}