Lines Matching full:dcb
913 * The TMDS table is typically found just before the DCB table, with a in parse_bit_tmds_tbl_entry()
926 * "or" from the DCB. in parse_bit_tmds_tbl_entry()
1105 * Make sure that 0x36 is blank and can't be mistaken for a DCB in parse_bmp_structure()
1254 u8 *dcb = NULL; in olddcb_table() local
1257 dcb = ROMPTR(dev, drm->vbios.data[0x36]); in olddcb_table()
1258 if (!dcb) { in olddcb_table()
1259 NV_WARN(drm, "No DCB data found in VBIOS\n"); in olddcb_table()
1263 if (dcb[0] >= 0x42) { in olddcb_table()
1264 NV_WARN(drm, "DCB version 0x%02x unknown\n", dcb[0]); in olddcb_table()
1267 if (dcb[0] >= 0x30) { in olddcb_table()
1268 if (ROM32(dcb[6]) == 0x4edcbdcb) in olddcb_table()
1269 return dcb; in olddcb_table()
1271 if (dcb[0] >= 0x20) { in olddcb_table()
1272 if (ROM32(dcb[4]) == 0x4edcbdcb) in olddcb_table()
1273 return dcb; in olddcb_table()
1275 if (dcb[0] >= 0x15) { in olddcb_table()
1276 if (!memcmp(&dcb[-7], "DEV_REC", 7)) in olddcb_table()
1277 return dcb; in olddcb_table()
1296 NV_WARN(drm, "No useful DCB data in VBIOS\n"); in olddcb_table()
1300 NV_WARN(drm, "DCB header validation failed\n"); in olddcb_table()
1307 u8 *dcb = olddcb_table(dev); in olddcb_outp() local
1308 if (dcb && dcb[0] >= 0x30) { in olddcb_outp()
1309 if (idx < dcb[2]) in olddcb_outp()
1310 return dcb + dcb[1] + (idx * dcb[3]); in olddcb_outp()
1312 if (dcb && dcb[0] >= 0x20) { in olddcb_outp()
1313 u8 *i2c = ROMPTR(dev, dcb[2]); in olddcb_outp()
1314 u8 *ent = dcb + 8 + (idx * 8); in olddcb_outp()
1318 if (dcb && dcb[0] >= 0x15) { in olddcb_outp()
1319 u8 *i2c = ROMPTR(dev, dcb[2]); in olddcb_outp()
1320 u8 *ent = dcb + 4 + (idx * 10); in olddcb_outp()
1336 break; /* seen on an NV11 with DCB v1.5 */ in olddcb_outp_foreach()
1338 break; /* seen on an NV17 with DCB v2.0 */ in olddcb_outp_foreach()
1356 u8 *dcb = olddcb_table(dev); in olddcb_conntab() local
1357 if (dcb && dcb[0] >= 0x30 && dcb[1] >= 0x16) { in olddcb_conntab()
1358 u8 *conntab = ROMPTR(dev, dcb[0x14]); in olddcb_conntab()
1374 static struct dcb_output *new_dcb_entry(struct dcb_table *dcb) in new_dcb_entry() argument
1376 struct dcb_output *entry = &dcb->entry[dcb->entries]; in new_dcb_entry()
1379 entry->index = dcb->entries++; in new_dcb_entry()
1384 static void fabricate_dcb_output(struct dcb_table *dcb, int type, int i2c, in fabricate_dcb_output() argument
1387 struct dcb_output *entry = new_dcb_entry(dcb); in fabricate_dcb_output()
1398 parse_dcb20_entry(struct drm_device *dev, struct dcb_table *dcb, in parse_dcb20_entry() argument
1418 entry->crtconf.maxfreq = (dcb->version < 0x30) ? in parse_dcb20_entry()
1427 if (dcb->version < 0x22) { in parse_dcb20_entry()
1431 * straps when it does, so assume all DCB 2.0 laptops in parse_dcb20_entry()
1455 if (dcb->version >= 0x40) in parse_dcb20_entry()
1465 if (dcb->version >= 0x30) in parse_dcb20_entry()
1506 if (dcb->version >= 0x40) { in parse_dcb20_entry()
1511 else if (dcb->version >= 0x30) in parse_dcb20_entry()
1513 else if (dcb->version >= 0x22) in parse_dcb20_entry()
1518 dcb->entries--; in parse_dcb20_entry()
1524 if (dcb->version < 0x40) { in parse_dcb20_entry()
1534 /* unsure what DCB version introduces this, 3.0? */ in parse_dcb20_entry()
1545 parse_dcb15_entry(struct drm_device *dev, struct dcb_table *dcb, in parse_dcb15_entry() argument
1568 NV_ERROR(drm, "Unknown DCB type %d\n", conn & 0x0000000f); in parse_dcb15_entry()
1599 void merge_like_dcb_entries(struct drm_device *dev, struct dcb_table *dcb) in merge_like_dcb_entries() argument
1602 * DCB v2.0 lists each output combination separately. in merge_like_dcb_entries()
1610 for (i = 0; i < dcb->entries; i++) { in merge_like_dcb_entries()
1611 struct dcb_output *ient = &dcb->entry[i]; in merge_like_dcb_entries()
1614 for (j = i + 1; j < dcb->entries; j++) { in merge_like_dcb_entries()
1615 struct dcb_output *jent = &dcb->entry[j]; in merge_like_dcb_entries()
1625 NV_INFO(drm, "Merging DCB entries %d and %d\n", in merge_like_dcb_entries()
1633 /* Compact entries merged into others out of dcb */ in merge_like_dcb_entries()
1634 for (i = 0; i < dcb->entries; i++) { in merge_like_dcb_entries()
1635 if (dcb->entry[i].type == 100) in merge_like_dcb_entries()
1639 dcb->entry[newentries] = dcb->entry[i]; in merge_like_dcb_entries()
1640 dcb->entry[newentries].index = newentries; in merge_like_dcb_entries()
1645 dcb->entries = newentries; in merge_like_dcb_entries()
1652 struct dcb_table *dcb = &drm->vbios.dcb; in apply_dcb_encoder_quirks() local
1655 * DCB entry 2: 02025312 00000010 in apply_dcb_encoder_quirks()
1656 * DCB entry 3: 02026312 00000020 in apply_dcb_encoder_quirks()
1673 * DCB reports an LVDS output that should be TMDS: in apply_dcb_encoder_quirks()
1674 * DCB entry 1: f2005014 ffffffff in apply_dcb_encoder_quirks()
1678 fabricate_dcb_output(dcb, DCB_OUTPUT_TMDS, 1, 1, 1); in apply_dcb_encoder_quirks()
1758 struct dcb_table *dcb = &bios->dcb; in fabricate_dcb_encoder_table() local
1764 fabricate_dcb_output(dcb, DCB_OUTPUT_TMDS, 0, all_heads, 1); in fabricate_dcb_encoder_table()
1765 fabricate_dcb_output(dcb, DCB_OUTPUT_ANALOG, 1, all_heads, 2); in fabricate_dcb_encoder_table()
1771 fabricate_dcb_output(dcb, DCB_OUTPUT_ANALOG, in fabricate_dcb_encoder_table()
1775 fabricate_dcb_output(dcb, DCB_OUTPUT_TV, in fabricate_dcb_encoder_table()
1781 fabricate_dcb_output(dcb, DCB_OUTPUT_TMDS, in fabricate_dcb_encoder_table()
1790 struct dcb_table *dcb = &drm->vbios.dcb; in parse_dcb_entry() local
1791 u32 conf = (dcb->version >= 0x20) ? ROM32(outp[4]) : ROM32(outp[6]); in parse_dcb_entry()
1796 struct dcb_output *entry = new_dcb_entry(dcb); in parse_dcb_entry()
1798 NV_INFO(drm, "DCB outp %02d: %08x %08x\n", idx, conn, conf); in parse_dcb_entry()
1800 if (dcb->version >= 0x20) in parse_dcb_entry()
1801 ret = parse_dcb20_entry(dev, dcb, conn, conf, entry); in parse_dcb_entry()
1803 ret = parse_dcb15_entry(dev, dcb, conn, conf, entry); in parse_dcb_entry()
1824 struct dcb_table *dcbt = &bios->dcb; in dcb_fake_connectors()
1871 struct dcb_table *dcb = &bios->dcb; in parse_dcb_table() local
1877 /* handle pre-DCB boards */ in parse_dcb_table()
1886 NV_INFO(drm, "DCB version %d.%d\n", dcbt[0] >> 4, dcbt[0] & 0xf); in parse_dcb_table()
1888 dcb->version = dcbt[0]; in parse_dcb_table()
1895 if (dcb->version < 0x21) in parse_dcb_table()
1896 merge_like_dcb_entries(dev, dcb); in parse_dcb_table()
1903 NV_INFO(drm, "DCB conn %02d: %04x\n", in parse_dcb_table()
1906 NV_INFO(drm, "DCB conn %02d: %08x\n", in parse_dcb_table()