aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlex Deucher <alexdeucher@gmail.com>2009-10-14 02:00:42 -0400
committerDave Airlie <airlied@redhat.com>2009-10-14 20:30:23 -0400
commit8c2a6d730400e14bf28ccfa11b9bbf453db775ec (patch)
treee62b5d600ae2bee724568d63ad3c27c8e072db6c
parentfb06ca8f8c61dfd7cbfa2092756577ff78a26dcd (diff)
drm/radeon/kms: move active_device setup into encoder fixup()
radeon_encoder->active_device defines the active routing between the encoder and connector. The encoder fixup and dpms functions need to know the active_device to function properly. Setting active_device in the prepare hook was too late in some cases. Signed-off-by: Alex Deucher <alexdeucher@gmail.com> Signed-off-by: Dave Airlie <airlied@redhat.com>
-rw-r--r--drivers/gpu/drm/radeon/radeon_encoders.c19
-rw-r--r--drivers/gpu/drm/radeon/radeon_legacy_encoders.c17
2 files changed, 14 insertions, 22 deletions
diff --git a/drivers/gpu/drm/radeon/radeon_encoders.c b/drivers/gpu/drm/radeon/radeon_encoders.c
index 10845f39124a..6cdef27be99d 100644
--- a/drivers/gpu/drm/radeon/radeon_encoders.c
+++ b/drivers/gpu/drm/radeon/radeon_encoders.c
@@ -194,6 +194,8 @@ static bool radeon_atom_mode_fixup(struct drm_encoder *encoder,
194 struct drm_device *dev = encoder->dev; 194 struct drm_device *dev = encoder->dev;
195 struct radeon_device *rdev = dev->dev_private; 195 struct radeon_device *rdev = dev->dev_private;
196 196
197 /* set the active encoder to connector routing */
198 radeon_encoder_set_active_device(encoder);
197 drm_mode_set_crtcinfo(adjusted_mode, 0); 199 drm_mode_set_crtcinfo(adjusted_mode, 0);
198 200
199 if (radeon_encoder->rmx_type != RMX_OFF) 201 if (radeon_encoder->rmx_type != RMX_OFF)
@@ -860,16 +862,9 @@ radeon_atom_encoder_dpms(struct drm_encoder *encoder, int mode)
860 DISPLAY_DEVICE_OUTPUT_CONTROL_PS_ALLOCATION args; 862 DISPLAY_DEVICE_OUTPUT_CONTROL_PS_ALLOCATION args;
861 int index = 0; 863 int index = 0;
862 bool is_dig = false; 864 bool is_dig = false;
863 int devices;
864 865
865 memset(&args, 0, sizeof(args)); 866 memset(&args, 0, sizeof(args));
866 867
867 /* on DPMS off we have no idea if active device is meaningful */
868 if (mode != DRM_MODE_DPMS_ON && !radeon_encoder->active_device)
869 devices = radeon_encoder->devices;
870 else
871 devices = radeon_encoder->active_device;
872
873 DRM_DEBUG("encoder dpms %d to mode %d, devices %08x, active_devices %08x\n", 868 DRM_DEBUG("encoder dpms %d to mode %d, devices %08x, active_devices %08x\n",
874 radeon_encoder->encoder_id, mode, radeon_encoder->devices, 869 radeon_encoder->encoder_id, mode, radeon_encoder->devices,
875 radeon_encoder->active_device); 870 radeon_encoder->active_device);
@@ -900,18 +895,18 @@ radeon_atom_encoder_dpms(struct drm_encoder *encoder, int mode)
900 break; 895 break;
901 case ENCODER_OBJECT_ID_INTERNAL_DAC1: 896 case ENCODER_OBJECT_ID_INTERNAL_DAC1:
902 case ENCODER_OBJECT_ID_INTERNAL_KLDSCP_DAC1: 897 case ENCODER_OBJECT_ID_INTERNAL_KLDSCP_DAC1:
903 if (devices & (ATOM_DEVICE_TV_SUPPORT)) 898 if (radeon_encoder->active_device & (ATOM_DEVICE_TV_SUPPORT))
904 index = GetIndexIntoMasterTable(COMMAND, TV1OutputControl); 899 index = GetIndexIntoMasterTable(COMMAND, TV1OutputControl);
905 else if (devices & (ATOM_DEVICE_CV_SUPPORT)) 900 else if (radeon_encoder->active_device & (ATOM_DEVICE_CV_SUPPORT))
906 index = GetIndexIntoMasterTable(COMMAND, CV1OutputControl); 901 index = GetIndexIntoMasterTable(COMMAND, CV1OutputControl);
907 else 902 else
908 index = GetIndexIntoMasterTable(COMMAND, DAC1OutputControl); 903 index = GetIndexIntoMasterTable(COMMAND, DAC1OutputControl);
909 break; 904 break;
910 case ENCODER_OBJECT_ID_INTERNAL_DAC2: 905 case ENCODER_OBJECT_ID_INTERNAL_DAC2:
911 case ENCODER_OBJECT_ID_INTERNAL_KLDSCP_DAC2: 906 case ENCODER_OBJECT_ID_INTERNAL_KLDSCP_DAC2:
912 if (devices & (ATOM_DEVICE_TV_SUPPORT)) 907 if (radeon_encoder->active_device & (ATOM_DEVICE_TV_SUPPORT))
913 index = GetIndexIntoMasterTable(COMMAND, TV1OutputControl); 908 index = GetIndexIntoMasterTable(COMMAND, TV1OutputControl);
914 else if (devices & (ATOM_DEVICE_CV_SUPPORT)) 909 else if (radeon_encoder->active_device & (ATOM_DEVICE_CV_SUPPORT))
915 index = GetIndexIntoMasterTable(COMMAND, CV1OutputControl); 910 index = GetIndexIntoMasterTable(COMMAND, CV1OutputControl);
916 else 911 else
917 index = GetIndexIntoMasterTable(COMMAND, DAC2OutputControl); 912 index = GetIndexIntoMasterTable(COMMAND, DAC2OutputControl);
@@ -1254,8 +1249,6 @@ static void radeon_atom_encoder_prepare(struct drm_encoder *encoder)
1254{ 1249{
1255 radeon_atom_output_lock(encoder, true); 1250 radeon_atom_output_lock(encoder, true);
1256 radeon_atom_encoder_dpms(encoder, DRM_MODE_DPMS_OFF); 1251 radeon_atom_encoder_dpms(encoder, DRM_MODE_DPMS_OFF);
1257
1258 radeon_encoder_set_active_device(encoder);
1259} 1252}
1260 1253
1261static void radeon_atom_encoder_commit(struct drm_encoder *encoder) 1254static void radeon_atom_encoder_commit(struct drm_encoder *encoder)
diff --git a/drivers/gpu/drm/radeon/radeon_legacy_encoders.c b/drivers/gpu/drm/radeon/radeon_legacy_encoders.c
index 6ceb958fd194..3a75b5b6009b 100644
--- a/drivers/gpu/drm/radeon/radeon_legacy_encoders.c
+++ b/drivers/gpu/drm/radeon/radeon_legacy_encoders.c
@@ -107,8 +107,6 @@ static void radeon_legacy_lvds_prepare(struct drm_encoder *encoder)
107 else 107 else
108 radeon_combios_output_lock(encoder, true); 108 radeon_combios_output_lock(encoder, true);
109 radeon_legacy_lvds_dpms(encoder, DRM_MODE_DPMS_OFF); 109 radeon_legacy_lvds_dpms(encoder, DRM_MODE_DPMS_OFF);
110
111 radeon_encoder_set_active_device(encoder);
112} 110}
113 111
114static void radeon_legacy_lvds_commit(struct drm_encoder *encoder) 112static void radeon_legacy_lvds_commit(struct drm_encoder *encoder)
@@ -192,6 +190,8 @@ static bool radeon_legacy_lvds_mode_fixup(struct drm_encoder *encoder,
192{ 190{
193 struct radeon_encoder *radeon_encoder = to_radeon_encoder(encoder); 191 struct radeon_encoder *radeon_encoder = to_radeon_encoder(encoder);
194 192
193 /* set the active encoder to connector routing */
194 radeon_encoder_set_active_device(encoder);
195 drm_mode_set_crtcinfo(adjusted_mode, 0); 195 drm_mode_set_crtcinfo(adjusted_mode, 0);
196 196
197 if (radeon_encoder->rmx_type != RMX_OFF) 197 if (radeon_encoder->rmx_type != RMX_OFF)
@@ -218,7 +218,8 @@ static bool radeon_legacy_primary_dac_mode_fixup(struct drm_encoder *encoder,
218 struct drm_display_mode *mode, 218 struct drm_display_mode *mode,
219 struct drm_display_mode *adjusted_mode) 219 struct drm_display_mode *adjusted_mode)
220{ 220{
221 221 /* set the active encoder to connector routing */
222 radeon_encoder_set_active_device(encoder);
222 drm_mode_set_crtcinfo(adjusted_mode, 0); 223 drm_mode_set_crtcinfo(adjusted_mode, 0);
223 224
224 return true; 225 return true;
@@ -272,7 +273,6 @@ static void radeon_legacy_primary_dac_prepare(struct drm_encoder *encoder)
272 else 273 else
273 radeon_combios_output_lock(encoder, true); 274 radeon_combios_output_lock(encoder, true);
274 radeon_legacy_primary_dac_dpms(encoder, DRM_MODE_DPMS_OFF); 275 radeon_legacy_primary_dac_dpms(encoder, DRM_MODE_DPMS_OFF);
275 radeon_encoder_set_active_device(encoder);
276} 276}
277 277
278static void radeon_legacy_primary_dac_commit(struct drm_encoder *encoder) 278static void radeon_legacy_primary_dac_commit(struct drm_encoder *encoder)
@@ -468,7 +468,6 @@ static void radeon_legacy_tmds_int_prepare(struct drm_encoder *encoder)
468 else 468 else
469 radeon_combios_output_lock(encoder, true); 469 radeon_combios_output_lock(encoder, true);
470 radeon_legacy_tmds_int_dpms(encoder, DRM_MODE_DPMS_OFF); 470 radeon_legacy_tmds_int_dpms(encoder, DRM_MODE_DPMS_OFF);
471 radeon_encoder_set_active_device(encoder);
472} 471}
473 472
474static void radeon_legacy_tmds_int_commit(struct drm_encoder *encoder) 473static void radeon_legacy_tmds_int_commit(struct drm_encoder *encoder)
@@ -593,7 +592,8 @@ static bool radeon_legacy_tmds_ext_mode_fixup(struct drm_encoder *encoder,
593 struct drm_display_mode *mode, 592 struct drm_display_mode *mode,
594 struct drm_display_mode *adjusted_mode) 593 struct drm_display_mode *adjusted_mode)
595{ 594{
596 595 /* set the active encoder to connector routing */
596 radeon_encoder_set_active_device(encoder);
597 drm_mode_set_crtcinfo(adjusted_mode, 0); 597 drm_mode_set_crtcinfo(adjusted_mode, 0);
598 598
599 return true; 599 return true;
@@ -636,7 +636,6 @@ static void radeon_legacy_tmds_ext_prepare(struct drm_encoder *encoder)
636 else 636 else
637 radeon_combios_output_lock(encoder, true); 637 radeon_combios_output_lock(encoder, true);
638 radeon_legacy_tmds_ext_dpms(encoder, DRM_MODE_DPMS_OFF); 638 radeon_legacy_tmds_ext_dpms(encoder, DRM_MODE_DPMS_OFF);
639 radeon_encoder_set_active_device(encoder);
640} 639}
641 640
642static void radeon_legacy_tmds_ext_commit(struct drm_encoder *encoder) 641static void radeon_legacy_tmds_ext_commit(struct drm_encoder *encoder)
@@ -735,7 +734,8 @@ static bool radeon_legacy_tv_dac_mode_fixup(struct drm_encoder *encoder,
735 struct drm_display_mode *mode, 734 struct drm_display_mode *mode,
736 struct drm_display_mode *adjusted_mode) 735 struct drm_display_mode *adjusted_mode)
737{ 736{
738 737 /* set the active encoder to connector routing */
738 radeon_encoder_set_active_device(encoder);
739 drm_mode_set_crtcinfo(adjusted_mode, 0); 739 drm_mode_set_crtcinfo(adjusted_mode, 0);
740 740
741 return true; 741 return true;
@@ -839,7 +839,6 @@ static void radeon_legacy_tv_dac_prepare(struct drm_encoder *encoder)
839 else 839 else
840 radeon_combios_output_lock(encoder, true); 840 radeon_combios_output_lock(encoder, true);
841 radeon_legacy_tv_dac_dpms(encoder, DRM_MODE_DPMS_OFF); 841 radeon_legacy_tv_dac_dpms(encoder, DRM_MODE_DPMS_OFF);
842 radeon_encoder_set_active_device(encoder);
843} 842}
844 843
845static void radeon_legacy_tv_dac_commit(struct drm_encoder *encoder) 844static void radeon_legacy_tv_dac_commit(struct drm_encoder *encoder)