Merge pull request #12231 from Loongson-Cloud-Community/main

fix: RLIM_INFINITY type is uint64 on loong64
This commit is contained in:
Julien Pivotto 2023-05-28 15:12:34 +02:00 committed by GitHub
commit 7f29458e69
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -18,16 +18,18 @@ package runtime
import (
"fmt"
"math"
"syscall"
)
// syscall.RLIM_INFINITY is a constant and its default type is int.
// It needs to be converted to an int64 variable to be compared with uint64 values.
// See https://golang.org/ref/spec#Conversions
var unlimited int64 = syscall.RLIM_INFINITY
// syscall.RLIM_INFINITY is a constant.
// Its type is int on most architectures but there are exceptions such as loong64.
// Uniform it to uint accorind to the standard.
// https://pubs.opengroup.org/onlinepubs/9699919799/basedefs/sys_resource.h.html
var unlimited uint64 = syscall.RLIM_INFINITY & math.MaxUint64
func limitToString(v uint64, unit string) string {
if v == uint64(unlimited) {
if v == unlimited {
return "unlimited"
}
return fmt.Sprintf("%d%s", v, unit)