This source file includes following definitions.
- hwloc_nvml_get_device_cpuset
- hwloc_nvml_get_device_osdev_by_index
- hwloc_nvml_get_device_osdev
1
2
3
4
5
6
7
8
9
10
11
12
13 #ifndef HWLOC_NVML_H
14 #define HWLOC_NVML_H
15
16 #include <hwloc.h>
17 #include <hwloc/autogen/config.h>
18 #include <hwloc/helper.h>
19 #ifdef HWLOC_LINUX_SYS
20 #include <hwloc/linux.h>
21 #endif
22
23 #include <nvml.h>
24
25
26 #ifdef __cplusplus
27 extern "C" {
28 #endif
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55 static __hwloc_inline int
56 hwloc_nvml_get_device_cpuset(hwloc_topology_t topology __hwloc_attribute_unused,
57 nvmlDevice_t device, hwloc_cpuset_t set)
58 {
59 #ifdef HWLOC_LINUX_SYS
60
61 #define HWLOC_NVML_DEVICE_SYSFS_PATH_MAX 128
62 char path[HWLOC_NVML_DEVICE_SYSFS_PATH_MAX];
63 nvmlReturn_t nvres;
64 nvmlPciInfo_t pci;
65
66 if (!hwloc_topology_is_thissystem(topology)) {
67 errno = EINVAL;
68 return -1;
69 }
70
71 nvres = nvmlDeviceGetPciInfo(device, &pci);
72 if (NVML_SUCCESS != nvres) {
73 errno = EINVAL;
74 return -1;
75 }
76
77 sprintf(path, "/sys/bus/pci/devices/%04x:%02x:%02x.0/local_cpus", pci.domain, pci.bus, pci.device);
78 if (hwloc_linux_read_path_as_cpumask(path, set) < 0
79 || hwloc_bitmap_iszero(set))
80 hwloc_bitmap_copy(set, hwloc_topology_get_complete_cpuset(topology));
81 #else
82
83 hwloc_bitmap_copy(set, hwloc_topology_get_complete_cpuset(topology));
84 #endif
85 return 0;
86 }
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101 static __hwloc_inline hwloc_obj_t
102 hwloc_nvml_get_device_osdev_by_index(hwloc_topology_t topology, unsigned idx)
103 {
104 hwloc_obj_t osdev = NULL;
105 while ((osdev = hwloc_get_next_osdev(topology, osdev)) != NULL) {
106 if (HWLOC_OBJ_OSDEV_GPU == osdev->attr->osdev.type
107 && osdev->name
108 && !strncmp("nvml", osdev->name, 4)
109 && atoi(osdev->name + 4) == (int) idx)
110 return osdev;
111 }
112 return NULL;
113 }
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128 static __hwloc_inline hwloc_obj_t
129 hwloc_nvml_get_device_osdev(hwloc_topology_t topology, nvmlDevice_t device)
130 {
131 hwloc_obj_t osdev;
132 nvmlReturn_t nvres;
133 nvmlPciInfo_t pci;
134 char uuid[64];
135
136 if (!hwloc_topology_is_thissystem(topology)) {
137 errno = EINVAL;
138 return NULL;
139 }
140
141 nvres = nvmlDeviceGetPciInfo(device, &pci);
142 if (NVML_SUCCESS != nvres)
143 return NULL;
144
145 nvres = nvmlDeviceGetUUID(device, uuid, sizeof(uuid));
146 if (NVML_SUCCESS != nvres)
147 uuid[0] = '\0';
148
149 osdev = NULL;
150 while ((osdev = hwloc_get_next_osdev(topology, osdev)) != NULL) {
151 hwloc_obj_t pcidev = osdev->parent;
152 const char *info;
153
154 if (strncmp(osdev->name, "nvml", 4))
155 continue;
156
157 if (pcidev
158 && pcidev->type == HWLOC_OBJ_PCI_DEVICE
159 && pcidev->attr->pcidev.domain == pci.domain
160 && pcidev->attr->pcidev.bus == pci.bus
161 && pcidev->attr->pcidev.dev == pci.device
162 && pcidev->attr->pcidev.func == 0)
163 return osdev;
164
165 info = hwloc_obj_get_info_by_name(osdev, "NVIDIAUUID");
166 if (info && !strcmp(info, uuid))
167 return osdev;
168 }
169
170 return NULL;
171 }
172
173
174
175
176 #ifdef __cplusplus
177 }
178 #endif
179
180
181 #endif