drm/nouveau/mc: implement support for PTOP interrupt routing
Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
This commit is contained in:
parent
583f8e4ea2
commit
921be10d85
|
@ -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);
|
||||||
|
|
Loading…
Reference in New Issue