2019-05-13 23:38:53 +08:00
|
|
|
// Copyright 2019 The Go Authors. All rights reserved.
|
|
|
|
// Use of this source code is governed by a BSD-style
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
2020-06-18 07:29:38 +08:00
|
|
|
// +build aix
|
2019-05-13 23:38:53 +08:00
|
|
|
|
|
|
|
package cpu
|
|
|
|
|
|
|
|
const cacheLineSize = 128
|
|
|
|
|
|
|
|
const (
|
|
|
|
// getsystemcfg constants
|
|
|
|
_SC_IMPL = 2
|
|
|
|
_IMPL_POWER8 = 0x10000
|
|
|
|
_IMPL_POWER9 = 0x20000
|
|
|
|
)
|
|
|
|
|
|
|
|
func init() {
|
2019-06-19 10:14:15 +08:00
|
|
|
impl := getsystemcfg(_SC_IMPL)
|
2019-05-13 23:38:53 +08:00
|
|
|
if impl&_IMPL_POWER8 != 0 {
|
|
|
|
PPC64.IsPOWER8 = true
|
|
|
|
}
|
|
|
|
if impl&_IMPL_POWER9 != 0 {
|
|
|
|
PPC64.IsPOWER9 = true
|
|
|
|
}
|
|
|
|
|
|
|
|
Initialized = true
|
|
|
|
}
|
2019-06-19 10:14:15 +08:00
|
|
|
|
|
|
|
func getsystemcfg(label int) (n uint64) {
|
|
|
|
r0, _ := callgetsystemcfg(label)
|
|
|
|
n = uint64(r0)
|
|
|
|
return
|
|
|
|
}
|