aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu
diff options
context:
space:
mode:
authorMichel Dänzer <daenzer@vmware.com>2011-08-31 03:42:47 -0400
committerDave Airlie <airlied@redhat.com>2011-09-01 04:37:27 -0400
commitf01b7ba0eba63fc758ea1e0d4100c5ea0482e43e (patch)
tree9eb8050542ef5a9cabbac16aee0adf121f195bad /drivers/gpu
parent654a4ef07a53c6b20e5411718e3aebe04c6a985f (diff)
vmwgfx: Add support for depth 8
Signed-off-by: Michel Dänzer <daenzer@vmware.com> Signed-off-by: Thomas Hellstrom <thellstrom@vmware.com> Signed-off-by: Dave Airlie <airlied@redhat.com>
Diffstat (limited to 'drivers/gpu')
-rw-r--r--drivers/gpu/drm/vmwgfx/vmwgfx_kms.c3
-rw-r--r--drivers/gpu/drm/vmwgfx/vmwgfx_ldu.c11
2 files changed, 14 insertions, 0 deletions
diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_kms.c b/drivers/gpu/drm/vmwgfx/vmwgfx_kms.c
index dfe32e62bd90..7539b569207a 100644
--- a/drivers/gpu/drm/vmwgfx/vmwgfx_kms.c
+++ b/drivers/gpu/drm/vmwgfx/vmwgfx_kms.c
@@ -567,6 +567,9 @@ static int vmw_kms_new_framebuffer_surface(struct vmw_private *dev_priv,
567 case 15: 567 case 15:
568 format = SVGA3D_A1R5G5B5; 568 format = SVGA3D_A1R5G5B5;
569 break; 569 break;
570 case 8:
571 format = SVGA3D_LUMINANCE8;
572 break;
570 default: 573 default:
571 DRM_ERROR("Invalid color depth: %d\n", mode_cmd->depth); 574 DRM_ERROR("Invalid color depth: %d\n", mode_cmd->depth);
572 return -EINVAL; 575 return -EINVAL;
diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_ldu.c b/drivers/gpu/drm/vmwgfx/vmwgfx_ldu.c
index 7b8115aab54d..c6d09a618353 100644
--- a/drivers/gpu/drm/vmwgfx/vmwgfx_ldu.c
+++ b/drivers/gpu/drm/vmwgfx/vmwgfx_ldu.c
@@ -83,6 +83,15 @@ static void vmw_ldu_crtc_gamma_set(struct drm_crtc *crtc,
83 u16 *r, u16 *g, u16 *b, 83 u16 *r, u16 *g, u16 *b,
84 uint32_t start, uint32_t size) 84 uint32_t start, uint32_t size)
85{ 85{
86 struct vmw_private *dev_priv = vmw_priv(crtc->dev);
87 int i;
88
89 for (i = 0; i < size; i++) {
90 DRM_DEBUG("%d r/g/b = 0x%04x / 0x%04x / 0x%04x\n", i, r[i], g[i], b[i]);
91 vmw_write(dev_priv, SVGA_PALETTE_BASE + i * 3 + 0, r[i] >> 8);
92 vmw_write(dev_priv, SVGA_PALETTE_BASE + i * 3 + 1, g[i] >> 8);
93 vmw_write(dev_priv, SVGA_PALETTE_BASE + i * 3 + 2, b[i] >> 8);
94 }
86} 95}
87 96
88static void vmw_ldu_crtc_destroy(struct drm_crtc *crtc) 97static void vmw_ldu_crtc_destroy(struct drm_crtc *crtc)
@@ -547,6 +556,8 @@ static int vmw_ldu_init(struct vmw_private *dev_priv, unsigned unit)
547 556
548 drm_crtc_init(dev, crtc, &vmw_legacy_crtc_funcs); 557 drm_crtc_init(dev, crtc, &vmw_legacy_crtc_funcs);
549 558
559 drm_mode_crtc_set_gamma_size(crtc, 256);
560
550 drm_connector_attach_property(connector, 561 drm_connector_attach_property(connector,
551 dev->mode_config.dirty_info_property, 562 dev->mode_config.dirty_info_property,
552 1); 563 1);