Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 96d1fcf8 authored by Ben Skeggs's avatar Ben Skeggs
Browse files

drm/nouveau/pm: translate ramcfg strap through ram restrict table



Hopefully this is how we're supposed to correctly handle when the RAMCFG
strap is above the number of entries in timing-related tables.

It's rather difficult to confirm without finding a configuration where
the ram restrict table doesn't map 8-15 back onto 0-7 anyway.  There's
not a single vbios in the repo which is configured differently..

In any case, this is probably still better than potentially reading
outside of the bounds of various tables..

Signed-off-by: default avatarBen Skeggs <bskeggs@redhat.com>
parent bfb61f43
Loading
Loading
Loading
Loading
+4 −2
Original line number Original line Diff line number Diff line
@@ -116,8 +116,10 @@ nouveau_perf_timing(struct drm_device *dev, struct bit_entry *P,
		entries   = tmap[4];
		entries   = tmap[4];
	}
	}


	ramcfg = nv_rd32(dev, NV_PEXTDEV_BOOT_0) & 0x0000003c;
	ramcfg = (nv_rd32(dev, NV_PEXTDEV_BOOT_0) & 0x0000003c) >> 2;
	ramcfg >>= 2;
	if (bios->ram_restrict_tbl_ptr)
		ramcfg = bios->data[bios->ram_restrict_tbl_ptr + ramcfg];

	if (ramcfg >= entries) {
	if (ramcfg >= entries) {
		NV_WARN(dev, "ramcfg strap out of bounds!\n");
		NV_WARN(dev, "ramcfg strap out of bounds!\n");
		return NULL;
		return NULL;