numa_linux_test.go 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. // Copyright © 2021 Jeffrey H. Johnson <trnsz@pobox.com>.
  2. // Copyright © 2021 Gridfinity, LLC.
  3. // Copyright © 2019 Neal.
  4. // Copyright © 2018 lrita@163.com.
  5. //
  6. // Use of this source code is governed by the MIT
  7. // license that can be found in the LICENSE file.
  8. //go:build linux
  9. // +build linux
  10. package gonuma_test
  11. import (
  12. "runtime"
  13. "sync"
  14. "testing"
  15. gonuma "github.com/johnsonjh/gonuma"
  16. "github.com/stretchr/testify/require"
  17. )
  18. func TestGetNodeAndCPU2(t *testing.T) {
  19. if !gonuma.NUMAavailable() || !gonuma.NUMAfastway {
  20. t.Skip("not available or fastwway")
  21. }
  22. var (
  23. nodem = gonuma.NewBitmask(gonuma.NodePossibleCount())
  24. mu sync.Mutex
  25. wg sync.WaitGroup
  26. assert = require.New(t)
  27. )
  28. gonuma.NUMAfastway = false
  29. defer func() { gonuma.NUMAfastway = true }()
  30. cpum := make([]gonuma.Bitmask, gonuma.NodePossibleCount())
  31. for i := 0; i < len(cpum); i++ {
  32. cpum[i] = gonuma.NewBitmask(gonuma.CPUPossibleCount())
  33. }
  34. for i := 0; i < gonuma.CPUCount(); i++ {
  35. wg.Add(1)
  36. go func() {
  37. defer wg.Done()
  38. for i := 0; i < 100; i++ {
  39. cpu, node := gonuma.GetCPUAndNode()
  40. mu.Lock()
  41. cpum[node].Set(cpu, true)
  42. nodem.Set(node, true)
  43. mu.Unlock()
  44. runtime.Gosched()
  45. }
  46. }()
  47. }
  48. wg.Wait()
  49. for i := 0; i < (2 * gonuma.CPUCount()); i++ {
  50. wg.Add(1)
  51. go func() {
  52. defer wg.Done()
  53. cpu, node := gonuma.GetCPUAndNode()
  54. t.Logf("TestGetNodeAndCPU2 cpu %v node %v", cpu, node)
  55. }()
  56. }
  57. wg.Wait()
  58. nmask := gonuma.NodeMask()
  59. for i := 0; i < nodem.Len(); i++ {
  60. if !nodem.Get(i) {
  61. continue
  62. }
  63. assert.True(nmask.Get(i), "node %d", i)
  64. cpumask, err := gonuma.NodeToCPUMask(i)
  65. assert.NoError(err)
  66. cmask := cpum[i]
  67. for j := 0; j < cmask.Len(); j++ {
  68. if !cmask.Get(j) {
  69. continue
  70. }
  71. assert.True(cpumask.Get(j), "cpu %d @ node %d", j, i)
  72. }
  73. }
  74. }