diff --git a/src/cmd/go/internal/load/pkg.go b/src/cmd/go/internal/load/pkg.go index 9d8523725aa596..5524f86044637f 100644 --- a/src/cmd/go/internal/load/pkg.go +++ b/src/cmd/go/internal/load/pkg.go @@ -7,6 +7,7 @@ package load import ( "bytes" + "cmd/internal/objabi" "context" "encoding/json" "errors" @@ -3561,7 +3562,7 @@ func SelectCoverPackages(roots []*Package, match []func(*Package) bool, op strin // $GOROOT/src/internal/coverage/pkid.go dealing with // hard-coding of runtime package IDs. cmode := cfg.BuildCoverMode - if cfg.BuildRace && p.Standard && p.ImportPath == "runtime" { + if cfg.BuildRace && p.Standard && objabi.LookupPkgSpecial(p.ImportPath).Runtime { cmode = "regonly" } diff --git a/src/cmd/link/internal/ld/data.go b/src/cmd/link/internal/ld/data.go index 67ee71bab31939..ca394700cfe34f 100644 --- a/src/cmd/link/internal/ld/data.go +++ b/src/cmd/link/internal/ld/data.go @@ -55,30 +55,8 @@ import ( ) // isRuntimeDepPkg reports whether pkg is the runtime package or its dependency. -// TODO: just compute from the runtime package, and remove this hardcoded list. func isRuntimeDepPkg(pkg string) bool { - switch pkg { - case "runtime", - "sync/atomic", // runtime may call to sync/atomic, due to go:linkname // TODO: this is not true? - "internal/abi", // used by reflectcall (and maybe more) - "internal/asan", - "internal/bytealg", // for IndexByte - "internal/byteorder", - "internal/chacha8rand", // for rand - "internal/coverage/rtcov", - "internal/cpu", // for cpu features - "internal/goarch", - "internal/godebugs", - "internal/goexperiment", - "internal/goos", - "internal/msan", - "internal/profilerecord", - "internal/race", - "internal/stringslite", - "unsafe": - return true - } - return strings.HasPrefix(pkg, "internal/runtime/") && !strings.HasSuffix(pkg, "_test") + return objabi.LookupPkgSpecial(pkg).Runtime } // Estimate the max size needed to hold any new trampolines created for this function. This