Commit 3e1b3357 authored by Samuel Pitoiset's avatar Samuel Pitoiset Committed by Ben Skeggs

drm/nouveau/pm: allow to query signals by domain

This will allow to configure performance counters with hardware signal
indexes instead of user-readable names in an upcoming patch.
Signed-off-by: default avatarSamuel Pitoiset <samuel.pitoiset@gmail.com>
Signed-off-by: default avatarBen Skeggs <bskeggs@redhat.com>
parent 45f0f94d
...@@ -264,7 +264,8 @@ struct nvif_perfmon_query_domain_v0 { ...@@ -264,7 +264,8 @@ struct nvif_perfmon_query_domain_v0 {
struct nvif_perfmon_query_signal_v0 { struct nvif_perfmon_query_signal_v0 {
__u8 version; __u8 version;
__u8 pad01[3]; __u8 domain;
__u8 pad02[2];
__u32 iter; __u32 iter;
char name[64]; char name[64];
}; };
......
...@@ -174,29 +174,22 @@ nvkm_perfmon_mthd_query_signal(struct nvkm_object *object, void *data, u32 size) ...@@ -174,29 +174,22 @@ nvkm_perfmon_mthd_query_signal(struct nvkm_object *object, void *data, u32 size)
} *args = data; } *args = data;
struct nvkm_device *device = nv_device(object); struct nvkm_device *device = nv_device(object);
struct nvkm_pm *ppm = (void *)object->engine; struct nvkm_pm *ppm = (void *)object->engine;
struct nvkm_perfdom *dom = NULL, *chk; struct nvkm_perfdom *dom;
const bool all = nvkm_boolopt(device->cfgopt, "NvPmShowAll", false); const bool all = nvkm_boolopt(device->cfgopt, "NvPmShowAll", false);
const bool raw = nvkm_boolopt(device->cfgopt, "NvPmUnnamed", all); const bool raw = nvkm_boolopt(device->cfgopt, "NvPmUnnamed", all);
const char *name; const char *name;
int tmp = 0, di, si; int ret, si;
int ret;
nv_ioctl(object, "perfmon query signal size %d\n", size); nv_ioctl(object, "perfmon query signal size %d\n", size);
if (nvif_unpack(args->v0, 0, 0, false)) { if (nvif_unpack(args->v0, 0, 0, false)) {
nv_ioctl(object, "perfmon query signal vers %d iter %08x\n", nv_ioctl(object,
args->v0.version, args->v0.iter); "perfmon query signal vers %d dom %d iter %08x\n",
di = (args->v0.iter & 0xff000000) >> 24; args->v0.version, args->v0.domain, args->v0.iter);
si = (args->v0.iter & 0x00ffffff) - 1; si = (args->v0.iter & 0xffffffff) - 1;
} else } else
return ret; return ret;
list_for_each_entry(chk, &ppm->domains, head) { dom = nvkm_perfdom_find(ppm, args->v0.domain);
if (tmp++ == di) {
dom = chk;
break;
}
}
if (dom == NULL || si >= (int)dom->signal_nr) if (dom == NULL || si >= (int)dom->signal_nr)
return -EINVAL; return -EINVAL;
...@@ -209,17 +202,12 @@ nvkm_perfmon_mthd_query_signal(struct nvkm_object *object, void *data, u32 size) ...@@ -209,17 +202,12 @@ nvkm_perfmon_mthd_query_signal(struct nvkm_object *object, void *data, u32 size)
} }
} }
do {
while (++si < dom->signal_nr) { while (++si < dom->signal_nr) {
if (all || dom->signal[si].name) { if (all || dom->signal[si].name) {
args->v0.iter = (di << 24) | ++si; args->v0.iter = ++si;
return 0; return 0;
} }
} }
si = -1;
di = di + 1;
dom = list_entry(dom->head.next, typeof(*dom), head);
} while (&dom->head != &ppm->domains);
args->v0.iter = 0xffffffff; args->v0.iter = 0xffffffff;
return 0; return 0;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment