Skip to content

Commit

Permalink
Merge pull request shirou#1036 from tklauser/drop-getconf
Browse files Browse the repository at this point in the history
cpu, v3/cpu: use sysconf package instead of exec'ing getconf
  • Loading branch information
shirou authored Feb 20, 2021
2 parents 3585d27 + ee12f66 commit a346c31
Show file tree
Hide file tree
Showing 16 changed files with 76 additions and 131 deletions.
17 changes: 17 additions & 0 deletions Gopkg.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

4 changes: 4 additions & 0 deletions Gopkg.toml
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,10 @@
name = "github.com/stretchr/testify"
version = "1.2.2"

[[constraint]]
name = "github.com/tklauser/go-sysconf"
version = "0.3.4"

[[constraint]]
branch = "master"
name = "golang.org/x/sys"
Expand Down
13 changes: 3 additions & 10 deletions cpu/cpu_darwin.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,10 +4,10 @@ package cpu

import (
"context"
"os/exec"
"strconv"
"strings"

"github.com/tklauser/go-sysconf"
"golang.org/x/sys/unix"
)

Expand All @@ -25,17 +25,10 @@ const (
var ClocksPerSec = float64(128)

func init() {
getconf, err := exec.LookPath("getconf")
if err != nil {
return
}
out, err := invoke.Command(getconf, "CLK_TCK")
clkTck, err := sysconf.Sysconf(sysconf.SC_CLK_TCK)
// ignore errors
if err == nil {
i, err := strconv.ParseFloat(strings.TrimSpace(string(out)), 64)
if err == nil {
ClocksPerSec = float64(i)
}
ClocksPerSec = float64(clkTck)
}
}

Expand Down
13 changes: 3 additions & 10 deletions cpu/cpu_dragonfly.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@ package cpu
import (
"context"
"fmt"
"os/exec"
"reflect"
"regexp"
"runtime"
Expand All @@ -12,6 +11,7 @@ import (
"unsafe"

"github.com/shirou/gopsutil/internal/common"
"github.com/tklauser/go-sysconf"
"golang.org/x/sys/unix"
)

Expand All @@ -25,17 +25,10 @@ var cpuTimesSize int
var emptyTimes cpuTimes

func init() {
getconf, err := exec.LookPath("getconf")
if err != nil {
return
}
out, err := invoke.Command(getconf, "CLK_TCK")
clkTck, err := sysconf.Sysconf(sysconf.SC_CLK_TCK)
// ignore errors
if err == nil {
i, err := strconv.ParseFloat(strings.TrimSpace(string(out)), 64)
if err == nil {
ClocksPerSec = float64(i)
}
ClocksPerSec = float64(clkTck)
}
}

Expand Down
13 changes: 3 additions & 10 deletions cpu/cpu_freebsd.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@ package cpu
import (
"context"
"fmt"
"os/exec"
"reflect"
"regexp"
"runtime"
Expand All @@ -12,6 +11,7 @@ import (
"unsafe"

"github.com/shirou/gopsutil/internal/common"
"github.com/tklauser/go-sysconf"
"golang.org/x/sys/unix"
)

Expand All @@ -26,17 +26,10 @@ var cpuTimesSize int
var emptyTimes cpuTimes

func init() {
getconf, err := exec.LookPath("getconf")
if err != nil {
return
}
out, err := invoke.Command(getconf, "CLK_TCK")
clkTck, err := sysconf.Sysconf(sysconf.SC_CLK_TCK)
// ignore errors
if err == nil {
i, err := strconv.ParseFloat(strings.TrimSpace(string(out)), 64)
if err == nil {
ClocksPerSec = float64(i)
}
ClocksPerSec = float64(clkTck)
}
}

Expand Down
13 changes: 3 additions & 10 deletions cpu/cpu_linux.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,28 +6,21 @@ import (
"context"
"errors"
"fmt"
"os/exec"
"path/filepath"
"strconv"
"strings"

"github.com/shirou/gopsutil/internal/common"
"github.com/tklauser/go-sysconf"
)

var ClocksPerSec = float64(100)

func init() {
getconf, err := exec.LookPath("getconf")
if err != nil {
return
}
out, err := invoke.CommandWithContext(context.Background(), getconf, "CLK_TCK")
clkTck, err := sysconf.Sysconf(sysconf.SC_CLK_TCK)
// ignore errors
if err == nil {
i, err := strconv.ParseFloat(strings.TrimSpace(string(out)), 64)
if err == nil {
ClocksPerSec = i
}
ClocksPerSec = float64(clkTck)
}
}

Expand Down
22 changes: 7 additions & 15 deletions cpu/cpu_openbsd.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,13 +7,13 @@ import (
"context"
"encoding/binary"
"fmt"
"os/exec"
"runtime"
"strconv"
"strings"
"syscall"

"github.com/shirou/gopsutil/internal/common"
"github.com/tklauser/go-sysconf"
"golang.org/x/sys/unix"
)

Expand All @@ -39,20 +39,12 @@ const (
var ClocksPerSec = float64(128)

func init() {
func() {
getconf, err := exec.LookPath("getconf")
if err != nil {
return
}
out, err := invoke.Command(getconf, "CLK_TCK")
// ignore errors
if err == nil {
i, err := strconv.ParseFloat(strings.TrimSpace(string(out)), 64)
if err == nil {
ClocksPerSec = float64(i)
}
}
}()
clkTck, err := sysconf.Sysconf(sysconf.SC_CLK_TCK)
// ignore errors
if err == nil {
ClocksPerSec = float64(clkTck)
}

func() {
v, err := unix.Sysctl("kern.osrelease") // can't reuse host.PlatformInformation because of circular import
if err != nil {
Expand Down
13 changes: 4 additions & 9 deletions cpu/cpu_solaris.go
Original file line number Diff line number Diff line change
Expand Up @@ -10,22 +10,17 @@ import (
"sort"
"strconv"
"strings"

"github.com/tklauser/go-sysconf"
)

var ClocksPerSec = float64(128)

func init() {
getconf, err := exec.LookPath("getconf")
if err != nil {
return
}
out, err := invoke.Command(getconf, "CLK_TCK")
clkTck, err := sysconf.Sysconf(sysconf.SC_CLK_TCK)
// ignore errors
if err == nil {
i, err := strconv.ParseFloat(strings.TrimSpace(string(out)), 64)
if err == nil {
ClocksPerSec = float64(i)
}
ClocksPerSec = float64(clkTck)
}
}

Expand Down
13 changes: 3 additions & 10 deletions v3/cpu/cpu_darwin.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,10 +4,10 @@ package cpu

import (
"context"
"os/exec"
"strconv"
"strings"

"github.com/tklauser/go-sysconf"
"golang.org/x/sys/unix"
)

Expand All @@ -25,17 +25,10 @@ const (
var ClocksPerSec = float64(128)

func init() {
getconf, err := exec.LookPath("getconf")
if err != nil {
return
}
out, err := invoke.Command(getconf, "CLK_TCK")
clkTck, err := sysconf.Sysconf(sysconf.SC_CLK_TCK)
// ignore errors
if err == nil {
i, err := strconv.ParseFloat(strings.TrimSpace(string(out)), 64)
if err == nil {
ClocksPerSec = float64(i)
}
ClocksPerSec = float64(clkTck)
}
}

Expand Down
13 changes: 3 additions & 10 deletions v3/cpu/cpu_dragonfly.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@ package cpu
import (
"context"
"fmt"
"os/exec"
"reflect"
"regexp"
"runtime"
Expand All @@ -12,6 +11,7 @@ import (
"unsafe"

"github.com/shirou/gopsutil/v3/internal/common"
"github.com/tklauser/go-sysconf"
"golang.org/x/sys/unix"
)

Expand All @@ -25,17 +25,10 @@ var cpuTimesSize int
var emptyTimes cpuTimes

func init() {
getconf, err := exec.LookPath("getconf")
if err != nil {
return
}
out, err := invoke.Command(getconf, "CLK_TCK")
clkTck, err := sysconf.Sysconf(sysconf.SC_CLK_TCK)
// ignore errors
if err == nil {
i, err := strconv.ParseFloat(strings.TrimSpace(string(out)), 64)
if err == nil {
ClocksPerSec = float64(i)
}
ClocksPerSec = float64(clkTck)
}
}

Expand Down
13 changes: 3 additions & 10 deletions v3/cpu/cpu_freebsd.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@ package cpu
import (
"context"
"fmt"
"os/exec"
"reflect"
"regexp"
"runtime"
Expand All @@ -12,6 +11,7 @@ import (
"unsafe"

"github.com/shirou/gopsutil/v3/internal/common"
"github.com/tklauser/go-sysconf"
"golang.org/x/sys/unix"
)

Expand All @@ -26,17 +26,10 @@ var cpuTimesSize int
var emptyTimes cpuTimes

func init() {
getconf, err := exec.LookPath("getconf")
if err != nil {
return
}
out, err := invoke.Command(getconf, "CLK_TCK")
clkTck, err := sysconf.Sysconf(sysconf.SC_CLK_TCK)
// ignore errors
if err == nil {
i, err := strconv.ParseFloat(strings.TrimSpace(string(out)), 64)
if err == nil {
ClocksPerSec = float64(i)
}
ClocksPerSec = float64(clkTck)
}
}

Expand Down
13 changes: 3 additions & 10 deletions v3/cpu/cpu_linux.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,28 +6,21 @@ import (
"context"
"errors"
"fmt"
"os/exec"
"path/filepath"
"strconv"
"strings"

"github.com/shirou/gopsutil/v3/internal/common"
"github.com/tklauser/go-sysconf"
)

var ClocksPerSec = float64(100)

func init() {
getconf, err := exec.LookPath("getconf")
if err != nil {
return
}
out, err := invoke.CommandWithContext(context.Background(), getconf, "CLK_TCK")
clkTck, err := sysconf.Sysconf(sysconf.SC_CLK_TCK)
// ignore errors
if err == nil {
i, err := strconv.ParseFloat(strings.TrimSpace(string(out)), 64)
if err == nil {
ClocksPerSec = i
}
ClocksPerSec = float64(clkTck)
}
}

Expand Down
Loading

0 comments on commit a346c31

Please sign in to comment.