421
421
if (ASIC_IS_DCE5(rdev)) {
422
422
args.v3.usSpreadSpectrumAmountFrac = cpu_to_le16(0);
423
args.v3.ucSpreadSpectrumType = ss->type;
423
args.v3.ucSpreadSpectrumType = ss->type & ATOM_SS_CENTRE_SPREAD_MODE_MASK;
424
424
switch (pll_id) {
426
426
args.v3.ucSpreadSpectrumType |= ATOM_PPLL_SS_TYPE_V3_P1PLL;
440
440
case ATOM_PPLL_INVALID:
443
args.v2.ucEnable = enable;
443
args.v3.ucEnable = enable;
444
if ((ss->percentage == 0) || (ss->type & ATOM_EXTERNAL_SS_MASK))
445
args.v3.ucEnable = ATOM_DISABLE;
444
446
} else if (ASIC_IS_DCE4(rdev)) {
445
447
args.v2.usSpreadSpectrumPercentage = cpu_to_le16(ss->percentage);
446
args.v2.ucSpreadSpectrumType = ss->type;
448
args.v2.ucSpreadSpectrumType = ss->type & ATOM_SS_CENTRE_SPREAD_MODE_MASK;
447
449
switch (pll_id) {
449
451
args.v2.ucSpreadSpectrumType |= ATOM_PPLL_SS_TYPE_V2_P1PLL;
466
468
args.v2.ucEnable = enable;
469
if ((ss->percentage == 0) || (ss->type & ATOM_EXTERNAL_SS_MASK))
470
args.v2.ucEnable = ATOM_DISABLE;
467
471
} else if (ASIC_IS_DCE3(rdev)) {
468
472
args.v1.usSpreadSpectrumPercentage = cpu_to_le16(ss->percentage);
469
args.v1.ucSpreadSpectrumType = ss->type;
473
args.v1.ucSpreadSpectrumType = ss->type & ATOM_SS_CENTRE_SPREAD_MODE_MASK;
470
474
args.v1.ucSpreadSpectrumStep = ss->step;
471
475
args.v1.ucSpreadSpectrumDelay = ss->delay;
472
476
args.v1.ucSpreadSpectrumRange = ss->range;
473
477
args.v1.ucPpll = pll_id;
474
478
args.v1.ucEnable = enable;
475
479
} else if (ASIC_IS_AVIVO(rdev)) {
476
if (enable == ATOM_DISABLE) {
480
if ((enable == ATOM_DISABLE) || (ss->percentage == 0) ||
481
(ss->type & ATOM_EXTERNAL_SS_MASK)) {
477
482
atombios_disable_ss(crtc);
480
485
args.lvds_ss_2.usSpreadSpectrumPercentage = cpu_to_le16(ss->percentage);
481
args.lvds_ss_2.ucSpreadSpectrumType = ss->type;
486
args.lvds_ss_2.ucSpreadSpectrumType = ss->type & ATOM_SS_CENTRE_SPREAD_MODE_MASK;
482
487
args.lvds_ss_2.ucSpreadSpectrumStep = ss->step;
483
488
args.lvds_ss_2.ucSpreadSpectrumDelay = ss->delay;
484
489
args.lvds_ss_2.ucSpreadSpectrumRange = ss->range;
485
490
args.lvds_ss_2.ucEnable = enable;
487
if (enable == ATOM_DISABLE) {
492
if ((enable == ATOM_DISABLE) || (ss->percentage == 0) ||
493
(ss->type & ATOM_EXTERNAL_SS_MASK)) {
488
494
atombios_disable_ss(crtc);
491
497
args.lvds_ss.usSpreadSpectrumPercentage = cpu_to_le16(ss->percentage);
492
args.lvds_ss.ucSpreadSpectrumType = ss->type;
498
args.lvds_ss.ucSpreadSpectrumType = ss->type & ATOM_SS_CENTRE_SPREAD_MODE_MASK;
493
499
args.lvds_ss.ucSpreadSpectrumStepSize_Delay = (ss->step & 3) << 2;
494
500
args.lvds_ss.ucSpreadSpectrumStepSize_Delay |= (ss->delay & 7) << 4;
495
501
args.lvds_ss.ucEnable = enable;
512
518
struct radeon_device *rdev = dev->dev_private;
513
519
struct drm_encoder *encoder = NULL;
514
520
struct radeon_encoder *radeon_encoder = NULL;
521
struct drm_connector *connector = NULL;
515
522
u32 adjusted_clock = mode->clock;
516
523
int encoder_mode = 0;
517
524
u32 dp_clock = mode->clock;
546
553
list_for_each_entry(encoder, &dev->mode_config.encoder_list, head) {
547
554
if (encoder->crtc == crtc) {
548
555
radeon_encoder = to_radeon_encoder(encoder);
556
connector = radeon_get_connector_for_encoder(encoder);
558
bpc = connector->display_info.bpc;
549
559
encoder_mode = atombios_get_encoder_mode(encoder);
550
if (radeon_encoder->devices & (ATOM_DEVICE_LCD_SUPPORT | ATOM_DEVICE_DFP_SUPPORT)) {
551
struct drm_connector *connector = radeon_get_connector_for_encoder(encoder);
560
if ((radeon_encoder->devices & (ATOM_DEVICE_LCD_SUPPORT | ATOM_DEVICE_DFP_SUPPORT)) ||
561
radeon_encoder_is_dp_bridge(encoder)) {
553
563
struct radeon_connector *radeon_connector = to_radeon_connector(connector);
554
564
struct radeon_connector_atom_dig *dig_connector =
612
622
args.v1.usPixelClock = cpu_to_le16(mode->clock / 10);
613
623
args.v1.ucTransmitterID = radeon_encoder->encoder_id;
614
624
args.v1.ucEncodeMode = encoder_mode;
625
if (ss_enabled && ss->percentage)
616
626
args.v1.ucConfig |=
617
627
ADJUST_DISPLAY_CONFIG_SS_ENABLE;
625
635
args.v3.sInput.ucTransmitterID = radeon_encoder->encoder_id;
626
636
args.v3.sInput.ucEncodeMode = encoder_mode;
627
637
args.v3.sInput.ucDispPllConfig = 0;
638
if (ss_enabled && ss->percentage)
629
639
args.v3.sInput.ucDispPllConfig |=
630
640
DISPPLL_CONFIG_SS_ENABLE;
631
if (radeon_encoder->devices & (ATOM_DEVICE_DFP_SUPPORT)) {
641
if (radeon_encoder->devices & (ATOM_DEVICE_DFP_SUPPORT) ||
642
radeon_encoder_is_dp_bridge(encoder)) {
632
643
struct radeon_encoder_atom_dig *dig = radeon_encoder->enc_priv;
633
644
if (encoder_mode == ATOM_ENCODER_MODE_DP) {
634
645
args.v3.sInput.ucDispPllConfig |=
660
671
DISPPLL_CONFIG_DUAL_LINK;
674
if (radeon_encoder_is_dp_bridge(encoder)) {
675
struct drm_encoder *ext_encoder = radeon_atom_get_external_encoder(encoder);
676
struct radeon_encoder *ext_radeon_encoder = to_radeon_encoder(ext_encoder);
677
args.v3.sInput.ucExtTransmitterID = ext_radeon_encoder->encoder_id;
679
args.v3.sInput.ucExtTransmitterID = 0;
663
681
atom_execute_table(rdev->mode_info.atom_context,
664
682
index, (uint32_t *)&args);
665
683
adjusted_clock = le32_to_cpu(args.v3.sOutput.ulDispPllFreq) * 10;
801
822
args.v3.ucPostDiv = post_div;
802
823
args.v3.ucPpll = pll_id;
803
824
args.v3.ucMiscInfo = (pll_id << 2);
825
if (ss_enabled && (ss->type & ATOM_EXTERNAL_SS_MASK))
826
args.v3.ucMiscInfo |= PIXEL_CLOCK_MISC_REF_DIV_SRC;
804
827
args.v3.ucTransmitterId = encoder_id;
805
828
args.v3.ucEncoderMode = encoder_mode;
812
835
args.v5.ulFbDivDecFrac = cpu_to_le32(frac_fb_div * 100000);
813
836
args.v5.ucPostDiv = post_div;
814
837
args.v5.ucMiscInfo = 0; /* HDMI depth, etc. */
838
if (ss_enabled && (ss->type & ATOM_EXTERNAL_SS_MASK))
839
args.v5.ucMiscInfo |= PIXEL_CLOCK_V5_MISC_REF_DIV_SRC;
843
args.v5.ucMiscInfo |= PIXEL_CLOCK_V5_MISC_HDMI_24BPP;
846
args.v5.ucMiscInfo |= PIXEL_CLOCK_V5_MISC_HDMI_30BPP;
815
849
args.v5.ucTransmitterID = encoder_id;
816
850
args.v5.ucEncoderMode = encoder_mode;
817
851
args.v5.ucPpll = pll_id;
824
858
args.v6.ulFbDivDecFrac = cpu_to_le32(frac_fb_div * 100000);
825
859
args.v6.ucPostDiv = post_div;
826
860
args.v6.ucMiscInfo = 0; /* HDMI depth, etc. */
861
if (ss_enabled && (ss->type & ATOM_EXTERNAL_SS_MASK))
862
args.v6.ucMiscInfo |= PIXEL_CLOCK_V6_MISC_REF_DIV_SRC;
866
args.v6.ucMiscInfo |= PIXEL_CLOCK_V6_MISC_HDMI_24BPP;
869
args.v6.ucMiscInfo |= PIXEL_CLOCK_V6_MISC_HDMI_30BPP;
872
args.v6.ucMiscInfo |= PIXEL_CLOCK_V6_MISC_HDMI_36BPP;
875
args.v6.ucMiscInfo |= PIXEL_CLOCK_V6_MISC_HDMI_48BPP;
827
878
args.v6.ucTransmitterID = encoder_id;
828
879
args.v6.ucEncoderMode = encoder_mode;
829
880
args.v6.ucPpll = pll_id;
891
943
struct radeon_connector_atom_dig *dig_connector =
892
944
radeon_connector->con_priv;
946
bpc = connector->display_info.bpc;
895
948
switch (encoder_mode) {
896
949
case ATOM_ENCODER_MODE_DP:
898
951
dp_clock = dig_connector->dp_clock / 10;
899
if (radeon_encoder->active_device & (ATOM_DEVICE_LCD_SUPPORT)) {
900
if (ASIC_IS_DCE4(rdev))
902
radeon_atombios_get_asic_ss_info(rdev, &ss,
952
if (ASIC_IS_DCE4(rdev))
954
radeon_atombios_get_asic_ss_info(rdev, &ss,
955
ASIC_INTERNAL_SS_ON_DP,
958
if (dp_clock == 16200) {
907
960
radeon_atombios_get_ppll_ss_info(rdev, &ss,
910
if (ASIC_IS_DCE4(rdev))
912
radeon_atombios_get_asic_ss_info(rdev, &ss,
913
ASIC_INTERNAL_SS_ON_DP,
916
if (dp_clock == 16200) {
918
radeon_atombios_get_ppll_ss_info(rdev, &ss,
922
radeon_atombios_get_ppll_ss_info(rdev, &ss,
926
964
radeon_atombios_get_ppll_ss_info(rdev, &ss,
968
radeon_atombios_get_ppll_ss_info(rdev, &ss,
931
972
case ATOM_ENCODER_MODE_LVDS:
975
1016
atombios_crtc_program_pll(crtc, radeon_crtc->crtc_id, radeon_crtc->pll_id,
976
1017
encoder_mode, radeon_encoder->encoder_id, mode->clock,
977
ref_div, fb_div, frac_fb_div, post_div);
1018
ref_div, fb_div, frac_fb_div, post_div, bpc, ss_enabled, &ss);
979
1020
if (ss_enabled) {
980
1021
/* calculate ss amount and step size */
983
1024
u32 amount = (((fb_div * 10) + frac_fb_div) * ss.percentage) / 10000;
984
1025
ss.amount = (amount / 10) & ATOM_PPLL_SS_AMOUNT_V2_FBDIV_MASK;
985
ss.amount |= ((amount - (ss.amount * 10)) << ATOM_PPLL_SS_AMOUNT_V2_NFRAC_SHIFT) &
1026
ss.amount |= ((amount - (amount / 10)) << ATOM_PPLL_SS_AMOUNT_V2_NFRAC_SHIFT) &
986
1027
ATOM_PPLL_SS_AMOUNT_V2_NFRAC_MASK;
987
1028
if (ss.type & ATOM_PPLL_SS_TYPE_V2_CENTRE_SPREAD)
988
1029
step_size = (4 * amount * ref_div * (ss.rate * 2048)) /
1011
1052
uint64_t fb_location;
1012
1053
uint32_t fb_format, fb_pitch_pixels, tiling_flags;
1013
1054
u32 fb_swap = EVERGREEN_GRPH_ENDIAN_SWAP(EVERGREEN_GRPH_ENDIAN_NONE);
1055
u32 tmp, viewport_w, viewport_h;
1017
1058
/* no fb bound */
1138
1179
WREG32(EVERGREEN_VIEWPORT_START + radeon_crtc->crtc_offset,
1139
1180
(x << 16) | y);
1181
viewport_w = crtc->mode.hdisplay;
1182
viewport_h = (crtc->mode.vdisplay + 1) & ~1;
1140
1183
WREG32(EVERGREEN_VIEWPORT_SIZE + radeon_crtc->crtc_offset,
1141
(crtc->mode.hdisplay << 16) | crtc->mode.vdisplay);
1184
(viewport_w << 16) | viewport_h);
1143
1186
/* pageflip setup */
1144
1187
/* make sure flip is at vb rather than hb */
1179
1222
uint64_t fb_location;
1180
1223
uint32_t fb_format, fb_pitch_pixels, tiling_flags;
1181
1224
u32 fb_swap = R600_D1GRPH_SWAP_ENDIAN_NONE;
1225
u32 tmp, viewport_w, viewport_h;
1185
1228
/* no fb bound */
1305
1348
WREG32(AVIVO_D1MODE_VIEWPORT_START + radeon_crtc->crtc_offset,
1306
1349
(x << 16) | y);
1350
viewport_w = crtc->mode.hdisplay;
1351
viewport_h = (crtc->mode.vdisplay + 1) & ~1;
1307
1352
WREG32(AVIVO_D1MODE_VIEWPORT_SIZE + radeon_crtc->crtc_offset,
1308
(crtc->mode.hdisplay << 16) | crtc->mode.vdisplay);
1353
(viewport_w << 16) | viewport_h);
1310
1355
/* pageflip setup */
1311
1356
/* make sure flip is at vb rather than hb */
1395
1440
uint32_t pll_in_use = 0;
1397
1442
if (ASIC_IS_DCE4(rdev)) {
1398
/* if crtc is driving DP and we have an ext clock, use that */
1399
1443
list_for_each_entry(test_encoder, &dev->mode_config.encoder_list, head) {
1400
1444
if (test_encoder->crtc && (test_encoder->crtc == crtc)) {
1445
/* in DP mode, the DP ref clock can come from PPLL, DCPLL, or ext clock,
1446
* depending on the asic:
1447
* DCE4: PPLL or ext clock
1448
* DCE5: DCPLL or ext clock
1450
* Setting ATOM_PPLL_INVALID will cause SetPixelClock to skip
1451
* PPLL/DCPLL programming and only program the DP DTO for the
1452
* crtc virtual pixel clock.
1401
1454
if (atombios_get_encoder_mode(test_encoder) == ATOM_ENCODER_MODE_DP) {
1402
if (rdev->clock.dp_extclk)
1455
if (ASIC_IS_DCE5(rdev) || rdev->clock.dp_extclk)
1403
1456
return ATOM_PPLL_INVALID;
1515
1568
static void atombios_crtc_disable(struct drm_crtc *crtc)
1517
1570
struct radeon_crtc *radeon_crtc = to_radeon_crtc(crtc);
1571
struct radeon_atom_ss ss;
1518
1573
atombios_crtc_dpms(crtc, DRM_MODE_DPMS_OFF);
1520
1575
switch (radeon_crtc->pll_id) {
1522
1577
case ATOM_PPLL2:
1523
1578
/* disable the ppll */
1524
1579
atombios_crtc_program_pll(crtc, radeon_crtc->crtc_id, radeon_crtc->pll_id,
1525
0, 0, ATOM_DISABLE, 0, 0, 0, 0);
1580
0, 0, ATOM_DISABLE, 0, 0, 0, 0, 0, false, &ss);