|
@@ -7,9 +7,7 @@
|
|
|
package cpu
|
|
package cpu
|
|
|
|
|
|
|
|
import (
|
|
import (
|
|
|
- "encoding/binary"
|
|
|
|
|
"io/ioutil"
|
|
"io/ioutil"
|
|
|
- "runtime"
|
|
|
|
|
)
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
const (
|
|
@@ -18,7 +16,7 @@ const (
|
|
|
|
|
|
|
|
procAuxv = "/proc/self/auxv"
|
|
procAuxv = "/proc/self/auxv"
|
|
|
|
|
|
|
|
- uintSize uint = 32 << (^uint(0) >> 63)
|
|
|
|
|
|
|
+ uintSize = int(32 << (^uint(0) >> 63))
|
|
|
)
|
|
)
|
|
|
|
|
|
|
|
// For those platforms don't have a 'cpuid' equivalent we use HWCAP/HWCAP2
|
|
// For those platforms don't have a 'cpuid' equivalent we use HWCAP/HWCAP2
|
|
@@ -33,22 +31,18 @@ func init() {
|
|
|
panic("read proc auxv failed: " + err.Error())
|
|
panic("read proc auxv failed: " + err.Error())
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- pb := int(uintSize / 8)
|
|
|
|
|
-
|
|
|
|
|
- for i := 0; i < len(buf)-pb*2; i += pb * 2 {
|
|
|
|
|
|
|
+ bo := hostByteOrder()
|
|
|
|
|
+ for len(buf) >= 2*(uintSize/8) {
|
|
|
var tag, val uint
|
|
var tag, val uint
|
|
|
switch uintSize {
|
|
switch uintSize {
|
|
|
case 32:
|
|
case 32:
|
|
|
- tag = uint(binary.LittleEndian.Uint32(buf[i:]))
|
|
|
|
|
- val = uint(binary.LittleEndian.Uint32(buf[i+pb:]))
|
|
|
|
|
|
|
+ tag = uint(bo.Uint32(buf[0:]))
|
|
|
|
|
+ val = uint(bo.Uint32(buf[4:]))
|
|
|
|
|
+ buf = buf[8:]
|
|
|
case 64:
|
|
case 64:
|
|
|
- if runtime.GOARCH == "ppc64" {
|
|
|
|
|
- tag = uint(binary.BigEndian.Uint64(buf[i:]))
|
|
|
|
|
- val = uint(binary.BigEndian.Uint64(buf[i+pb:]))
|
|
|
|
|
- } else {
|
|
|
|
|
- tag = uint(binary.LittleEndian.Uint64(buf[i:]))
|
|
|
|
|
- val = uint(binary.LittleEndian.Uint64(buf[i+pb:]))
|
|
|
|
|
- }
|
|
|
|
|
|
|
+ tag = uint(bo.Uint64(buf[0:]))
|
|
|
|
|
+ val = uint(bo.Uint64(buf[8:]))
|
|
|
|
|
+ buf = buf[16:]
|
|
|
}
|
|
}
|
|
|
switch tag {
|
|
switch tag {
|
|
|
case _AT_HWCAP:
|
|
case _AT_HWCAP:
|