mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-09 22:24:04 +08:00
drm/nouveau/kms/nv50-: determine MST support from DP Info Table
GV100 doesn't support MST, use the information provided in VBIOS tables to detect its presence instead. Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
This commit is contained in:
parent
261fcfa969
commit
34508f9d26
@ -52,6 +52,8 @@
|
|||||||
#include "nouveau_fence.h"
|
#include "nouveau_fence.h"
|
||||||
#include "nouveau_fbcon.h"
|
#include "nouveau_fbcon.h"
|
||||||
|
|
||||||
|
#include <subdev/bios/dp.h>
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* Atomic state
|
* Atomic state
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
@ -1383,9 +1385,12 @@ nv50_sor_create(struct drm_connector *connector, struct dcb_output *dcbe)
|
|||||||
{
|
{
|
||||||
struct nouveau_connector *nv_connector = nouveau_connector(connector);
|
struct nouveau_connector *nv_connector = nouveau_connector(connector);
|
||||||
struct nouveau_drm *drm = nouveau_drm(connector->dev);
|
struct nouveau_drm *drm = nouveau_drm(connector->dev);
|
||||||
|
struct nvkm_bios *bios = nvxx_bios(&drm->client.device);
|
||||||
struct nvkm_i2c *i2c = nvxx_i2c(&drm->client.device);
|
struct nvkm_i2c *i2c = nvxx_i2c(&drm->client.device);
|
||||||
struct nouveau_encoder *nv_encoder;
|
struct nouveau_encoder *nv_encoder;
|
||||||
struct drm_encoder *encoder;
|
struct drm_encoder *encoder;
|
||||||
|
u8 ver, hdr, cnt, len;
|
||||||
|
u32 data;
|
||||||
int type, ret;
|
int type, ret;
|
||||||
|
|
||||||
switch (dcbe->type) {
|
switch (dcbe->type) {
|
||||||
@ -1429,8 +1434,8 @@ nv50_sor_create(struct drm_connector *connector, struct dcb_output *dcbe)
|
|||||||
nv_encoder->aux = aux;
|
nv_encoder->aux = aux;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*TODO: Use DP Info Table to check for support. */
|
if ((data = nvbios_dp_table(bios, &ver, &hdr, &cnt, &len)) &&
|
||||||
if (disp->disp->object.oclass >= GF110_DISP) {
|
ver >= 0x40 && (nvbios_rd08(bios, data + 0x08) & 0x04)) {
|
||||||
ret = nv50_mstm_new(nv_encoder, &nv_connector->aux, 16,
|
ret = nv50_mstm_new(nv_encoder, &nv_connector->aux, 16,
|
||||||
nv_connector->base.base.id,
|
nv_connector->base.base.id,
|
||||||
&nv_encoder->dp.mstm);
|
&nv_encoder->dp.mstm);
|
||||||
|
@ -1,6 +1,10 @@
|
|||||||
/* SPDX-License-Identifier: GPL-2.0 */
|
/* SPDX-License-Identifier: GPL-2.0 */
|
||||||
#ifndef __NVBIOS_DP_H__
|
#ifndef __NVBIOS_DP_H__
|
||||||
#define __NVBIOS_DP_H__
|
#define __NVBIOS_DP_H__
|
||||||
|
|
||||||
|
u16
|
||||||
|
nvbios_dp_table(struct nvkm_bios *bios, u8 *ver, u8 *hdr, u8 *cnt, u8 *len);
|
||||||
|
|
||||||
struct nvbios_dpout {
|
struct nvbios_dpout {
|
||||||
u16 type;
|
u16 type;
|
||||||
u16 mask;
|
u16 mask;
|
||||||
|
@ -25,7 +25,7 @@
|
|||||||
#include <subdev/bios/bit.h>
|
#include <subdev/bios/bit.h>
|
||||||
#include <subdev/bios/dp.h>
|
#include <subdev/bios/dp.h>
|
||||||
|
|
||||||
static u16
|
u16
|
||||||
nvbios_dp_table(struct nvkm_bios *bios, u8 *ver, u8 *hdr, u8 *cnt, u8 *len)
|
nvbios_dp_table(struct nvkm_bios *bios, u8 *ver, u8 *hdr, u8 *cnt, u8 *len)
|
||||||
{
|
{
|
||||||
struct bit_entry d;
|
struct bit_entry d;
|
||||||
|
Loading…
Reference in New Issue
Block a user