summaryrefslogtreecommitdiff
path: root/drivers
diff options
context:
space:
mode:
authorBen Skeggs <bskeggs@redhat.com>2013-11-26 04:31:18 (GMT)
committerBen Skeggs <bskeggs@redhat.com>2014-01-23 03:38:46 (GMT)
commit2daaf5b0e4fbed1fa9524881272c9a956a0aaf78 (patch)
treecfd0519a83f2092c4e1f702b99526bdd0d571ce9 /drivers
parentcb1567c2861432e83210f01ddb0560c4ae64f9ed (diff)
downloadlinux-2daaf5b0e4fbed1fa9524881272c9a956a0aaf78.tar.xz
drm/nve0/fb/gddr5: fix behaviour of lp3 setting
Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/gpu/drm/nouveau/core/subdev/fb/gddr5.c3
-rw-r--r--drivers/gpu/drm/nouveau/core/subdev/fb/ramnve0.c4
2 files changed, 5 insertions, 2 deletions
diff --git a/drivers/gpu/drm/nouveau/core/subdev/fb/gddr5.c b/drivers/gpu/drm/nouveau/core/subdev/fb/gddr5.c
index 34f9605..012c1ea 100644
--- a/drivers/gpu/drm/nouveau/core/subdev/fb/gddr5.c
+++ b/drivers/gpu/drm/nouveau/core/subdev/fb/gddr5.c
@@ -78,6 +78,9 @@ nouveau_gddr5_calc(struct nouveau_ram *ram)
ram->mr[3] &= ~0x020;
ram->mr[3] |= (rq & 0x01) << 5;
+ /*XXX: LP3, where's the bit? Let's hardcode to off for now */
+ ram->mr[5] &= ~0x004;
+
if (!vo)
vo = (ram->mr[6] & 0xff0) >> 4;
if (ram->mr[6] & 0x001)
diff --git a/drivers/gpu/drm/nouveau/core/subdev/fb/ramnve0.c b/drivers/gpu/drm/nouveau/core/subdev/fb/ramnve0.c
index bc86cfd..0fa983f 100644
--- a/drivers/gpu/drm/nouveau/core/subdev/fb/ramnve0.c
+++ b/drivers/gpu/drm/nouveau/core/subdev/fb/ramnve0.c
@@ -528,7 +528,7 @@ nve0_ram_calc_gddr5(struct nouveau_fb *pfb, u32 freq)
ram_mask(fuc, mr[8], 0xfff, ram->base.mr[8]);
ram_nsec(fuc, 1000);
ram_mask(fuc, mr[1], 0xfff, ram->base.mr[1]);
- ram_mask(fuc, mr[5], 0xfff, ram->base.mr[5]);
+ ram_mask(fuc, mr[5], 0xfff, ram->base.mr[5] & ~0x004); /* LP3 later */
ram_mask(fuc, mr[6], 0xfff, ram->base.mr[6]);
ram_mask(fuc, mr[7], 0xfff, ram->base.mr[7]);
@@ -582,7 +582,7 @@ nve0_ram_calc_gddr5(struct nouveau_fb *pfb, u32 freq)
/* MR5: (re)enable LP3 if necessary
* XXX: need to find the switch, keeping off for now
*/
- ram_mask(fuc, mr[5], 0x00000004, 0x00000000);
+ ram_mask(fuc, mr[5], 0xfff, ram->base.mr[5]);
if (ram->mode != 2) {
ram_mask(fuc, 0x10f830, 0x01000000, 0x01000000);