Commit 9a2b8131 authored by Ben Skeggs's avatar Ben Skeggs

drm/nouveau/disp/nv50-: fix lookup of udisp table under certain circumstances

Some VBIOS have separate tables for each link of a given output path,
which means we have to specify the specific link we're using instead
of all possible links.
Signed-off-by: default avatarBen Skeggs <bskeggs@redhat.com>
parent 86b40432
...@@ -76,12 +76,10 @@ exec_lookup(struct nv50_disp *disp, int head, int or, u32 ctrl, ...@@ -76,12 +76,10 @@ exec_lookup(struct nv50_disp *disp, int head, int or, u32 ctrl,
mask |= 0x0001 << or; mask |= 0x0001 << or;
mask |= 0x0100 << head; mask |= 0x0100 << head;
list_for_each_entry(outp, &disp->base.outp, head) { list_for_each_entry(outp, &disp->base.outp, head) {
if ((outp->info.hasht & 0xff) == type && if ((outp->info.hasht & 0xff) == type &&
(outp->info.hashm & mask) == mask) { (outp->info.hashm & mask) == mask) {
*data = nvbios_outp_match(bios, outp->info.hasht, *data = nvbios_outp_match(bios, outp->info.hasht, mask,
outp->info.hashm,
ver, hdr, cnt, len, info); ver, hdr, cnt, len, info);
if (!*data) if (!*data)
return NULL; return NULL;
......
...@@ -269,8 +269,7 @@ exec_lookup(struct nv50_disp *disp, int head, int or, u32 ctrl, ...@@ -269,8 +269,7 @@ exec_lookup(struct nv50_disp *disp, int head, int or, u32 ctrl,
list_for_each_entry(outp, &disp->base.outp, head) { list_for_each_entry(outp, &disp->base.outp, head) {
if ((outp->info.hasht & 0xff) == type && if ((outp->info.hasht & 0xff) == type &&
(outp->info.hashm & mask) == mask) { (outp->info.hashm & mask) == mask) {
*data = nvbios_outp_match(bios, outp->info.hasht, *data = nvbios_outp_match(bios, outp->info.hasht, mask,
outp->info.hashm,
ver, hdr, cnt, len, info); ver, hdr, cnt, len, info);
if (!*data) if (!*data)
return NULL; return NULL;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment