drm/nouveau/mc: implement support for PTOP interrupt routing

Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
This commit is contained in:
Ben Skeggs 2016-04-08 17:24:40 +10:00
parent 583f8e4ea2
commit 921be10d85
1 changed files with 11 additions and 2 deletions

View File

@ -60,9 +60,18 @@ nvkm_mc_intr(struct nvkm_mc *mc, bool *handled)
struct nvkm_device *device = mc->subdev.device; struct nvkm_device *device = mc->subdev.device;
struct nvkm_subdev *subdev; struct nvkm_subdev *subdev;
const struct nvkm_mc_map *map = mc->func->intr; const struct nvkm_mc_map *map = mc->func->intr;
u32 stat, intr; u32 stat, intr = nvkm_mc_intr_mask(mc);
u64 subdevs;
stat = nvkm_top_intr(device->top, intr, &subdevs);
while (subdevs) {
enum nvkm_devidx subidx = __ffs64(subdevs);
subdev = nvkm_device_subdev(device, subidx);
if (subdev)
nvkm_subdev_intr(subdev);
subdevs &= ~BIT_ULL(subidx);
}
stat = intr = nvkm_mc_intr_mask(mc);
while (map->stat) { while (map->stat) {
if (intr & map->stat) { if (intr & map->stat) {
subdev = nvkm_device_subdev(device, map->unit); subdev = nvkm_device_subdev(device, map->unit);