diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2013-11-15 00:19:54 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2013-11-15 00:19:54 -0500 |
commit | 049ffa8ab33a63b3bff672d1a0ee6a35ad253fe8 (patch) | |
tree | 70f4c684818b1c9871fa800088427e40d260592e /drivers/gpu/drm/radeon/rs600.c | |
parent | c681427e5ca22925fcc1be76a2e260a11e0a8498 (diff) | |
parent | 0846c728e20a0cd1e43fb75a3015f3b176a26466 (diff) |
Merge branch 'drm-next' of git://people.freedesktop.org/~airlied/linux
Pull drm updates from Dave Airlie:
"This is a combo of -next and some -fixes that came in in the
intervening time.
Highlights:
New drivers:
ARM Armada driver for Marvell Armada 510 SOCs
Intel:
Broadwell initial support under a default off switch,
Stereo/3D HDMI mode support
Valleyview improvements
Displayport improvements
Haswell fixes
initial mipi dsi panel support
CRC support for debugging
build with CONFIG_FB=n
Radeon:
enable DPM on a number of GPUs by default
secondary GPU powerdown support
enable HDMI audio by default
Hawaii support
Nouveau:
dynamic pm code infrastructure reworked, does nothing major yet
GK208 modesetting support
MSI fixes, on by default again
PMPEG improvements
pageflipping fixes
GMA500:
minnowboard SDVO support
VMware:
misc fixes
MSM:
prime, plane and rendernodes support
Tegra:
rearchitected to put the drm driver into the drm subsystem.
HDMI and gr2d support for tegra 114 SoC
QXL:
oops fix, and multi-head fixes
DRM core:
sysfs lifetime fixes
client capability ioctl
further cleanups to device midlayer
more vblank timestamp fixes"
* 'drm-next' of git://people.freedesktop.org/~airlied/linux: (789 commits)
drm/nouveau: do not map evicted vram buffers in nouveau_bo_vma_add
drm/nvc0-/gr: shift wrapping bug in nvc0_grctx_generate_r406800
drm/nouveau/pwr: fix missing mutex unlock in a failure path
drm/nv40/therm: fix slowing down fan when pstate undefined
drm/nv11-: synchronise flips to vblank, unless async flip requested
drm/nvc0-: remove nasty fifo swmthd hack for flip completion method
drm/nv10-: we no longer need to create nvsw object on user channels
drm/nouveau: always queue flips relative to kernel channel activity
drm/nouveau: there is no need to reserve/fence the new fb when flipping
drm/nouveau: when bailing out of a pushbuf ioctl, do not remove previous fence
drm/nouveau: allow nouveau_fence_ref() to be a noop
drm/nvc8/mc: msi rearm is via the nvc0 method
drm/ttm: Fix vma page_prot bit manipulation
drm/vmwgfx: Fix a couple of compile / sparse warnings and errors
drm/vmwgfx: Resource evict fixes
drm/edid: compare actual vrefresh for all modes for quirks
drm: shmob_drm: Convert to clk_prepare/unprepare
drm/nouveau: fix 32-bit build
drm/i915/opregion: fix build error on CONFIG_ACPI=n
Revert "drm/radeon/audio: don't set speaker allocation on DCE4+"
...
Diffstat (limited to 'drivers/gpu/drm/radeon/rs600.c')
-rw-r--r-- | drivers/gpu/drm/radeon/rs600.c | 64 |
1 files changed, 64 insertions, 0 deletions
diff --git a/drivers/gpu/drm/radeon/rs600.c b/drivers/gpu/drm/radeon/rs600.c index 6acba8017b9a..76cc8d3aafec 100644 --- a/drivers/gpu/drm/radeon/rs600.c +++ b/drivers/gpu/drm/radeon/rs600.c | |||
@@ -153,6 +153,70 @@ u32 rs600_page_flip(struct radeon_device *rdev, int crtc_id, u64 crtc_base) | |||
153 | return RREG32(AVIVO_D1GRPH_UPDATE + radeon_crtc->crtc_offset) & AVIVO_D1GRPH_SURFACE_UPDATE_PENDING; | 153 | return RREG32(AVIVO_D1GRPH_UPDATE + radeon_crtc->crtc_offset) & AVIVO_D1GRPH_SURFACE_UPDATE_PENDING; |
154 | } | 154 | } |
155 | 155 | ||
156 | void avivo_program_fmt(struct drm_encoder *encoder) | ||
157 | { | ||
158 | struct drm_device *dev = encoder->dev; | ||
159 | struct radeon_device *rdev = dev->dev_private; | ||
160 | struct radeon_encoder *radeon_encoder = to_radeon_encoder(encoder); | ||
161 | struct drm_connector *connector = radeon_get_connector_for_encoder(encoder); | ||
162 | int bpc = 0; | ||
163 | u32 tmp = 0; | ||
164 | enum radeon_connector_dither dither = RADEON_FMT_DITHER_DISABLE; | ||
165 | |||
166 | if (connector) { | ||
167 | struct radeon_connector *radeon_connector = to_radeon_connector(connector); | ||
168 | bpc = radeon_get_monitor_bpc(connector); | ||
169 | dither = radeon_connector->dither; | ||
170 | } | ||
171 | |||
172 | /* LVDS FMT is set up by atom */ | ||
173 | if (radeon_encoder->devices & ATOM_DEVICE_LCD_SUPPORT) | ||
174 | return; | ||
175 | |||
176 | if (bpc == 0) | ||
177 | return; | ||
178 | |||
179 | switch (bpc) { | ||
180 | case 6: | ||
181 | if (dither == RADEON_FMT_DITHER_ENABLE) | ||
182 | /* XXX sort out optimal dither settings */ | ||
183 | tmp |= AVIVO_TMDS_BIT_DEPTH_CONTROL_SPATIAL_DITHER_EN; | ||
184 | else | ||
185 | tmp |= AVIVO_TMDS_BIT_DEPTH_CONTROL_TRUNCATE_EN; | ||
186 | break; | ||
187 | case 8: | ||
188 | if (dither == RADEON_FMT_DITHER_ENABLE) | ||
189 | /* XXX sort out optimal dither settings */ | ||
190 | tmp |= (AVIVO_TMDS_BIT_DEPTH_CONTROL_SPATIAL_DITHER_EN | | ||
191 | AVIVO_TMDS_BIT_DEPTH_CONTROL_SPATIAL_DITHER_DEPTH); | ||
192 | else | ||
193 | tmp |= (AVIVO_TMDS_BIT_DEPTH_CONTROL_TRUNCATE_EN | | ||
194 | AVIVO_TMDS_BIT_DEPTH_CONTROL_TRUNCATE_DEPTH); | ||
195 | break; | ||
196 | case 10: | ||
197 | default: | ||
198 | /* not needed */ | ||
199 | break; | ||
200 | } | ||
201 | |||
202 | switch (radeon_encoder->encoder_id) { | ||
203 | case ENCODER_OBJECT_ID_INTERNAL_KLDSCP_TMDS1: | ||
204 | WREG32(AVIVO_TMDSA_BIT_DEPTH_CONTROL, tmp); | ||
205 | break; | ||
206 | case ENCODER_OBJECT_ID_INTERNAL_LVTM1: | ||
207 | WREG32(AVIVO_LVTMA_BIT_DEPTH_CONTROL, tmp); | ||
208 | break; | ||
209 | case ENCODER_OBJECT_ID_INTERNAL_KLDSCP_DVO1: | ||
210 | WREG32(AVIVO_DVOA_BIT_DEPTH_CONTROL, tmp); | ||
211 | break; | ||
212 | case ENCODER_OBJECT_ID_INTERNAL_DDI: | ||
213 | WREG32(AVIVO_DDIA_BIT_DEPTH_CONTROL, tmp); | ||
214 | break; | ||
215 | default: | ||
216 | break; | ||
217 | } | ||
218 | } | ||
219 | |||
156 | void rs600_pm_misc(struct radeon_device *rdev) | 220 | void rs600_pm_misc(struct radeon_device *rdev) |
157 | { | 221 | { |
158 | int requested_index = rdev->pm.requested_power_state_index; | 222 | int requested_index = rdev->pm.requested_power_state_index; |