提交 b830973b 编写于 作者: B Ben Skeggs

drm/nouveau/pm: fix dll off -> dll on transitions

Signed-off-by: NBen Skeggs <bskeggs@redhat.com>
Signed-off-by: NMartin Peres <martin.peres@labri.fr>
上级 a9bc247c
...@@ -1016,7 +1016,8 @@ nouveau_mem_exec(struct nouveau_mem_exec_func *exec, ...@@ -1016,7 +1016,8 @@ nouveau_mem_exec(struct nouveau_mem_exec_func *exec,
} }
if (mr[1] != info->mr[1]) { if (mr[1] != info->mr[1]) {
exec->mrs (exec, 1, info->mr[1]); /* need to keep DLL off until later, at least on GDDR3 */
exec->mrs (exec, 1, info->mr[1] | (mr[1] & mr1_dlloff));
exec->wait(exec, tMRD); exec->wait(exec, tMRD);
} }
...@@ -1028,8 +1029,12 @@ nouveau_mem_exec(struct nouveau_mem_exec_func *exec, ...@@ -1028,8 +1029,12 @@ nouveau_mem_exec(struct nouveau_mem_exec_func *exec,
/* update PFB timing registers */ /* update PFB timing registers */
exec->timing_set(exec); exec->timing_set(exec);
/* DLL reset */ /* DLL (enable + ) reset */
if (!(info->mr[1] & mr1_dlloff)) { if (!(info->mr[1] & mr1_dlloff)) {
if (mr[1] & mr1_dlloff) {
exec->mrs (exec, 1, info->mr[1]);
exec->wait(exec, tMRD);
}
exec->mrs (exec, 0, info->mr[0] | 0x00000100); exec->mrs (exec, 0, info->mr[0] | 0x00000100);
exec->wait(exec, tMRD); exec->wait(exec, tMRD);
exec->mrs (exec, 0, info->mr[0] | 0x00000000); exec->mrs (exec, 0, info->mr[0] | 0x00000000);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册