implemented Temp.update for openbsd
This commit is contained in:
parent
a1c99bb10f
commit
175cfef2e1
76
src/widgets/temp_openbsd.go
Normal file
76
src/widgets/temp_openbsd.go
Normal file
|
@ -0,0 +1,76 @@
|
|||
package widgets
|
||||
|
||||
// #include <sys/time.h>
|
||||
// #include <sys/sysctl.h>
|
||||
// #include <sys/sensors.h>
|
||||
import "C"
|
||||
|
||||
import (
|
||||
"unsafe"
|
||||
"syscall"
|
||||
"strconv"
|
||||
|
||||
"github.com/cjbassi/gotop/src/utils"
|
||||
)
|
||||
|
||||
func gettemp(t *Temp, mib []C.int, mlen int, snsrdev *C.struct_sensordev, index int) {
|
||||
if mlen == 4 {
|
||||
k := mib[3]
|
||||
var numt C.int
|
||||
for numt = 0; numt < snsrdev.maxnumt[k]; numt += 1 {
|
||||
mib[4] = numt
|
||||
gettemp(t, mib, mlen+1, snsrdev, int(numt))
|
||||
}
|
||||
return
|
||||
}
|
||||
|
||||
if mlen == 5 {
|
||||
var snsr C.struct_sensor
|
||||
var slen C.size_t = C.sizeof_struct_sensor
|
||||
|
||||
if v, _ := C.sysctl(&mib[0], 5, unsafe.Pointer(&snsr), &slen, nil, 0); v == -1 {
|
||||
return
|
||||
}
|
||||
|
||||
if slen > 0 && (snsr.flags & C.SENSOR_FINVALID) == 0 {
|
||||
key := C.GoString(&snsrdev.xname[0]) + ".temp" + strconv.Itoa(index)
|
||||
temp := int((snsr.value - 273150000.0) / 1000000.0)
|
||||
|
||||
if t.Fahrenheit {
|
||||
t.Data[key] = utils.CelsiusToFahrenheit(temp)
|
||||
} else {
|
||||
t.Data[key] = temp
|
||||
}
|
||||
}
|
||||
|
||||
return
|
||||
}
|
||||
}
|
||||
|
||||
func (self *Temp) update() {
|
||||
mib := []C.int{0, 1, 2, 3, 4}
|
||||
|
||||
var snsrdev C.struct_sensordev
|
||||
var len C.ulong = C.sizeof_struct_sensordev
|
||||
|
||||
mib[0] = C.CTL_HW
|
||||
mib[1] = C.HW_SENSORS
|
||||
mib[3] = C.SENSOR_TEMP
|
||||
|
||||
var i C.int
|
||||
for i = 0; ; i += 1 {
|
||||
mib[2] = i
|
||||
|
||||
if v, e := C.sysctl(&mib[0], 3, unsafe.Pointer(&snsrdev), &len, nil, 0); v == -1 {
|
||||
if e == syscall.ENXIO {
|
||||
continue
|
||||
}
|
||||
|
||||
if e == syscall.ENOENT {
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
gettemp(self, mib, 4, &snsrdev, 0)
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user