lvmstat.go 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. // +build aix
  2. package perfstat
  3. /*
  4. #cgo LDFLAGS: -lperfstat
  5. #include <libperfstat.h>
  6. #include <string.h>
  7. #include <stdlib.h>
  8. #include "c_helpers.h"
  9. */
  10. import "C"
  11. import (
  12. "fmt"
  13. "unsafe"
  14. )
  15. func LogicalVolumeStat() ([]LogicalVolume, error) {
  16. var lv *C.perfstat_logicalvolume_t
  17. var lvname C.perfstat_id_t
  18. numlvs := C.perfstat_logicalvolume(nil, nil, C.sizeof_perfstat_logicalvolume_t, 0)
  19. if numlvs <= 0 {
  20. return nil, fmt.Errorf("perfstat_logicalvolume() error")
  21. }
  22. lv_len := C.sizeof_perfstat_logicalvolume_t * C.ulong(numlvs)
  23. lv = (*C.perfstat_logicalvolume_t)(C.malloc(lv_len))
  24. defer C.free(unsafe.Pointer(lv))
  25. C.strcpy(&lvname.name[0], C.CString(""))
  26. r := C.perfstat_logicalvolume(&lvname, lv, C.sizeof_perfstat_logicalvolume_t, numlvs)
  27. if r < 0 {
  28. return nil, fmt.Errorf("perfstat_logicalvolume() error")
  29. }
  30. lvs := make([]LogicalVolume, r)
  31. for i := 0; i < int(r); i++ {
  32. l := C.get_logicalvolume_stat(lv, C.int(i))
  33. if l != nil {
  34. lvs[i] = perfstatlogicalvolume2logicalvolume(l)
  35. }
  36. }
  37. return lvs, nil
  38. }
  39. func VolumeGroupStat() ([]VolumeGroup, error) {
  40. var vg *C.perfstat_volumegroup_t
  41. var vgname C.perfstat_id_t
  42. numvgs := C.perfstat_volumegroup(nil, nil, C.sizeof_perfstat_volumegroup_t, 0)
  43. if numvgs <= 0 {
  44. return nil, fmt.Errorf("perfstat_volumegroup() error")
  45. }
  46. vg_len := C.sizeof_perfstat_volumegroup_t * C.ulong(numvgs)
  47. vg = (*C.perfstat_volumegroup_t)(C.malloc(vg_len))
  48. defer C.free(unsafe.Pointer(vg))
  49. C.strcpy(&vgname.name[0], C.CString(""))
  50. r := C.perfstat_volumegroup(&vgname, vg, C.sizeof_perfstat_volumegroup_t, numvgs)
  51. if r < 0 {
  52. return nil, fmt.Errorf("perfstat_volumegroup() error")
  53. }
  54. vgs := make([]VolumeGroup, r)
  55. for i := 0; i < int(r); i++ {
  56. v := C.get_volumegroup_stat(vg, C.int(i))
  57. if v != nil {
  58. vgs[i] = perfstatvolumegroup2volumegroup(v)
  59. }
  60. }
  61. return vgs, nil
  62. }