aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/radeon/atombios_encoders.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/gpu/drm/radeon/atombios_encoders.c')
-rw-r--r--drivers/gpu/drm/radeon/atombios_encoders.c211
1 files changed, 127 insertions, 84 deletions
diff --git a/drivers/gpu/drm/radeon/atombios_encoders.c b/drivers/gpu/drm/radeon/atombios_encoders.c
index 7d91d3ca9c69..e0285c419875 100644
--- a/drivers/gpu/drm/radeon/atombios_encoders.c
+++ b/drivers/gpu/drm/radeon/atombios_encoders.c
@@ -585,97 +585,140 @@ atombios_dig_encoder_setup(struct drm_encoder *encoder, int action, int panel_mo
585 if (!atom_parse_cmd_header(rdev->mode_info.atom_context, index, &frev, &crev)) 585 if (!atom_parse_cmd_header(rdev->mode_info.atom_context, index, &frev, &crev))
586 return; 586 return;
587 587
588 args.v1.ucAction = action; 588 switch (frev) {
589 args.v1.usPixelClock = cpu_to_le16(radeon_encoder->pixel_clock / 10); 589 case 1:
590 if (action == ATOM_ENCODER_CMD_SETUP_PANEL_MODE) 590 switch (crev) {
591 args.v3.ucPanelMode = panel_mode; 591 case 1:
592 else 592 args.v1.ucAction = action;
593 args.v1.ucEncoderMode = atombios_get_encoder_mode(encoder); 593 args.v1.usPixelClock = cpu_to_le16(radeon_encoder->pixel_clock / 10);
594 if (action == ATOM_ENCODER_CMD_SETUP_PANEL_MODE)
595 args.v3.ucPanelMode = panel_mode;
596 else
597 args.v1.ucEncoderMode = atombios_get_encoder_mode(encoder);
594 598
595 if (ENCODER_MODE_IS_DP(args.v1.ucEncoderMode)) 599 if (ENCODER_MODE_IS_DP(args.v1.ucEncoderMode))
596 args.v1.ucLaneNum = dp_lane_count; 600 args.v1.ucLaneNum = dp_lane_count;
597 else if (radeon_encoder->pixel_clock > 165000) 601 else if (radeon_encoder->pixel_clock > 165000)
598 args.v1.ucLaneNum = 8; 602 args.v1.ucLaneNum = 8;
599 else 603 else
600 args.v1.ucLaneNum = 4; 604 args.v1.ucLaneNum = 4;
601 605
602 if (ASIC_IS_DCE5(rdev)) { 606 if (ENCODER_MODE_IS_DP(args.v1.ucEncoderMode) && (dp_clock == 270000))
603 if (ENCODER_MODE_IS_DP(args.v1.ucEncoderMode)) { 607 args.v1.ucConfig |= ATOM_ENCODER_CONFIG_DPLINKRATE_2_70GHZ;
604 if (dp_clock == 270000) 608 switch (radeon_encoder->encoder_id) {
605 args.v1.ucConfig |= ATOM_ENCODER_CONFIG_V4_DPLINKRATE_2_70GHZ; 609 case ENCODER_OBJECT_ID_INTERNAL_UNIPHY:
606 else if (dp_clock == 540000) 610 args.v1.ucConfig = ATOM_ENCODER_CONFIG_V2_TRANSMITTER1;
607 args.v1.ucConfig |= ATOM_ENCODER_CONFIG_V4_DPLINKRATE_5_40GHZ; 611 break;
608 } 612 case ENCODER_OBJECT_ID_INTERNAL_UNIPHY1:
609 args.v4.acConfig.ucDigSel = dig->dig_encoder; 613 case ENCODER_OBJECT_ID_INTERNAL_KLDSCP_LVTMA:
610 switch (bpc) { 614 args.v1.ucConfig = ATOM_ENCODER_CONFIG_V2_TRANSMITTER2;
611 case 0: 615 break;
612 args.v4.ucBitPerColor = PANEL_BPC_UNDEFINE; 616 case ENCODER_OBJECT_ID_INTERNAL_UNIPHY2:
613 break; 617 args.v1.ucConfig = ATOM_ENCODER_CONFIG_V2_TRANSMITTER3;
614 case 6: 618 break;
615 args.v4.ucBitPerColor = PANEL_6BIT_PER_COLOR; 619 }
616 break; 620 if (dig->linkb)
617 case 8: 621 args.v1.ucConfig |= ATOM_ENCODER_CONFIG_LINKB;
618 default: 622 else
619 args.v4.ucBitPerColor = PANEL_8BIT_PER_COLOR; 623 args.v1.ucConfig |= ATOM_ENCODER_CONFIG_LINKA;
620 break;
621 case 10:
622 args.v4.ucBitPerColor = PANEL_10BIT_PER_COLOR;
623 break;
624 case 12:
625 args.v4.ucBitPerColor = PANEL_12BIT_PER_COLOR;
626 break;
627 case 16:
628 args.v4.ucBitPerColor = PANEL_16BIT_PER_COLOR;
629 break; 624 break;
630 } 625 case 2:
631 if (hpd_id == RADEON_HPD_NONE) 626 case 3:
632 args.v4.ucHPD_ID = 0; 627 args.v3.ucAction = action;
633 else 628 args.v3.usPixelClock = cpu_to_le16(radeon_encoder->pixel_clock / 10);
634 args.v4.ucHPD_ID = hpd_id + 1; 629 if (action == ATOM_ENCODER_CMD_SETUP_PANEL_MODE)
635 } else if (ASIC_IS_DCE4(rdev)) { 630 args.v3.ucPanelMode = panel_mode;
636 if (ENCODER_MODE_IS_DP(args.v1.ucEncoderMode) && (dp_clock == 270000)) 631 else
637 args.v1.ucConfig |= ATOM_ENCODER_CONFIG_V3_DPLINKRATE_2_70GHZ; 632 args.v3.ucEncoderMode = atombios_get_encoder_mode(encoder);
638 args.v3.acConfig.ucDigSel = dig->dig_encoder; 633
639 switch (bpc) { 634 if (ENCODER_MODE_IS_DP(args.v1.ucEncoderMode))
640 case 0: 635 args.v3.ucLaneNum = dp_lane_count;
641 args.v3.ucBitPerColor = PANEL_BPC_UNDEFINE; 636 else if (radeon_encoder->pixel_clock > 165000)
637 args.v3.ucLaneNum = 8;
638 else
639 args.v3.ucLaneNum = 4;
640
641 if (ENCODER_MODE_IS_DP(args.v1.ucEncoderMode) && (dp_clock == 270000))
642 args.v1.ucConfig |= ATOM_ENCODER_CONFIG_V3_DPLINKRATE_2_70GHZ;
643 args.v3.acConfig.ucDigSel = dig->dig_encoder;
644 switch (bpc) {
645 case 0:
646 args.v3.ucBitPerColor = PANEL_BPC_UNDEFINE;
647 break;
648 case 6:
649 args.v3.ucBitPerColor = PANEL_6BIT_PER_COLOR;
650 break;
651 case 8:
652 default:
653 args.v3.ucBitPerColor = PANEL_8BIT_PER_COLOR;
654 break;
655 case 10:
656 args.v3.ucBitPerColor = PANEL_10BIT_PER_COLOR;
657 break;
658 case 12:
659 args.v3.ucBitPerColor = PANEL_12BIT_PER_COLOR;
660 break;
661 case 16:
662 args.v3.ucBitPerColor = PANEL_16BIT_PER_COLOR;
663 break;
664 }
642 break; 665 break;
643 case 6: 666 case 4:
644 args.v3.ucBitPerColor = PANEL_6BIT_PER_COLOR; 667 args.v4.ucAction = action;
668 args.v4.usPixelClock = cpu_to_le16(radeon_encoder->pixel_clock / 10);
669 if (action == ATOM_ENCODER_CMD_SETUP_PANEL_MODE)
670 args.v4.ucPanelMode = panel_mode;
671 else
672 args.v4.ucEncoderMode = atombios_get_encoder_mode(encoder);
673
674 if (ENCODER_MODE_IS_DP(args.v1.ucEncoderMode))
675 args.v4.ucLaneNum = dp_lane_count;
676 else if (radeon_encoder->pixel_clock > 165000)
677 args.v4.ucLaneNum = 8;
678 else
679 args.v4.ucLaneNum = 4;
680
681 if (ENCODER_MODE_IS_DP(args.v1.ucEncoderMode)) {
682 if (dp_clock == 270000)
683 args.v1.ucConfig |= ATOM_ENCODER_CONFIG_V4_DPLINKRATE_2_70GHZ;
684 else if (dp_clock == 540000)
685 args.v1.ucConfig |= ATOM_ENCODER_CONFIG_V4_DPLINKRATE_5_40GHZ;
686 }
687 args.v4.acConfig.ucDigSel = dig->dig_encoder;
688 switch (bpc) {
689 case 0:
690 args.v4.ucBitPerColor = PANEL_BPC_UNDEFINE;
691 break;
692 case 6:
693 args.v4.ucBitPerColor = PANEL_6BIT_PER_COLOR;
694 break;
695 case 8:
696 default:
697 args.v4.ucBitPerColor = PANEL_8BIT_PER_COLOR;
698 break;
699 case 10:
700 args.v4.ucBitPerColor = PANEL_10BIT_PER_COLOR;
701 break;
702 case 12:
703 args.v4.ucBitPerColor = PANEL_12BIT_PER_COLOR;
704 break;
705 case 16:
706 args.v4.ucBitPerColor = PANEL_16BIT_PER_COLOR;
707 break;
708 }
709 if (hpd_id == RADEON_HPD_NONE)
710 args.v4.ucHPD_ID = 0;
711 else
712 args.v4.ucHPD_ID = hpd_id + 1;
645 break; 713 break;
646 case 8:
647 default: 714 default:
648 args.v3.ucBitPerColor = PANEL_8BIT_PER_COLOR; 715 DRM_ERROR("Unknown table version %d, %d\n", frev, crev);
649 break;
650 case 10:
651 args.v3.ucBitPerColor = PANEL_10BIT_PER_COLOR;
652 break;
653 case 12:
654 args.v3.ucBitPerColor = PANEL_12BIT_PER_COLOR;
655 break;
656 case 16:
657 args.v3.ucBitPerColor = PANEL_16BIT_PER_COLOR;
658 break;
659 }
660 } else {
661 if (ENCODER_MODE_IS_DP(args.v1.ucEncoderMode) && (dp_clock == 270000))
662 args.v1.ucConfig |= ATOM_ENCODER_CONFIG_DPLINKRATE_2_70GHZ;
663 switch (radeon_encoder->encoder_id) {
664 case ENCODER_OBJECT_ID_INTERNAL_UNIPHY:
665 args.v1.ucConfig = ATOM_ENCODER_CONFIG_V2_TRANSMITTER1;
666 break;
667 case ENCODER_OBJECT_ID_INTERNAL_UNIPHY1:
668 case ENCODER_OBJECT_ID_INTERNAL_KLDSCP_LVTMA:
669 args.v1.ucConfig = ATOM_ENCODER_CONFIG_V2_TRANSMITTER2;
670 break;
671 case ENCODER_OBJECT_ID_INTERNAL_UNIPHY2:
672 args.v1.ucConfig = ATOM_ENCODER_CONFIG_V2_TRANSMITTER3;
673 break; 716 break;
674 } 717 }
675 if (dig->linkb) 718 break;
676 args.v1.ucConfig |= ATOM_ENCODER_CONFIG_LINKB; 719 default:
677 else 720 DRM_ERROR("Unknown table version %d, %d\n", frev, crev);
678 args.v1.ucConfig |= ATOM_ENCODER_CONFIG_LINKA; 721 break;
679 } 722 }
680 723
681 atom_execute_table(rdev->mode_info.atom_context, index, (uint32_t *)&args); 724 atom_execute_table(rdev->mode_info.atom_context, index, (uint32_t *)&args);