aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm
diff options
context:
space:
mode:
authorDeepak Rawat <drawat@vmware.com>2018-06-20 17:25:07 -0400
committerThomas Hellstrom <thellstrom@vmware.com>2018-07-06 14:16:08 -0400
commit397a11175f830e1ceb82b608a1c7adbacfbe39b0 (patch)
tree541c0c7b35aba5eb25ef95b23c3d3f6501ec4cf8 /drivers/gpu/drm
parentcdff8e73006c05ee342dd588b5ba90b5def56184 (diff)
drm/vmwgfx: Support for SVGA3dSurfaceAllFlags in vmwgfx
Since svga device introduced new 64bit SVGA3dSurfaceAllFlags, vmwgfx now stores the surface flags internally as SVGA3dSurfaceAllFlags. For legacy surface define commands, only lower 32-bit is used. Signed-off-by: Deepak Rawat <drawat@vmware.com> Reviewed-by: Sinclair Yeh <syeh@vmware.com> Reviewed-by: Brian Paul <brianp@vmware.com> Reviewed-by: Thomas Hellstrom <thellstrom@vmware.com> Signed-off-by: Thomas Hellstrom <thellstrom@vmware.com>
Diffstat (limited to 'drivers/gpu/drm')
-rw-r--r--drivers/gpu/drm/vmwgfx/vmwgfx_drv.h4
-rw-r--r--drivers/gpu/drm/vmwgfx/vmwgfx_surface.c21
2 files changed, 16 insertions, 9 deletions
diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_drv.h b/drivers/gpu/drm/vmwgfx/vmwgfx_drv.h
index 06cce72b7b9e..7e5c93083036 100644
--- a/drivers/gpu/drm/vmwgfx/vmwgfx_drv.h
+++ b/drivers/gpu/drm/vmwgfx/vmwgfx_drv.h
@@ -166,7 +166,7 @@ struct vmw_surface_offset;
166 166
167struct vmw_surface { 167struct vmw_surface {
168 struct vmw_resource res; 168 struct vmw_resource res;
169 uint32_t flags; 169 SVGA3dSurfaceAllFlags flags;
170 uint32_t format; 170 uint32_t format;
171 uint32_t mip_levels[DRM_VMW_MAX_SURFACE_FACES]; 171 uint32_t mip_levels[DRM_VMW_MAX_SURFACE_FACES];
172 struct drm_vmw_size base_size; 172 struct drm_vmw_size base_size;
@@ -1080,7 +1080,7 @@ extern int vmw_surface_validate(struct vmw_private *dev_priv,
1080 struct vmw_surface *srf); 1080 struct vmw_surface *srf);
1081int vmw_surface_gb_priv_define(struct drm_device *dev, 1081int vmw_surface_gb_priv_define(struct drm_device *dev,
1082 uint32_t user_accounting_size, 1082 uint32_t user_accounting_size,
1083 uint32_t svga3d_flags, 1083 SVGA3dSurfaceAllFlags svga3d_flags,
1084 SVGA3dSurfaceFormat format, 1084 SVGA3dSurfaceFormat format,
1085 bool for_scanout, 1085 bool for_scanout,
1086 uint32_t num_mip_levels, 1086 uint32_t num_mip_levels,
diff --git a/drivers/gpu/drm/vmwgfx/vmwgfx_surface.c b/drivers/gpu/drm/vmwgfx/vmwgfx_surface.c
index 2abf9a895605..a5f93f62c7fa 100644
--- a/drivers/gpu/drm/vmwgfx/vmwgfx_surface.c
+++ b/drivers/gpu/drm/vmwgfx/vmwgfx_surface.c
@@ -224,7 +224,12 @@ static void vmw_surface_define_encode(const struct vmw_surface *srf,
224 cmd->header.id = SVGA_3D_CMD_SURFACE_DEFINE; 224 cmd->header.id = SVGA_3D_CMD_SURFACE_DEFINE;
225 cmd->header.size = cmd_len; 225 cmd->header.size = cmd_len;
226 cmd->body.sid = srf->res.id; 226 cmd->body.sid = srf->res.id;
227 cmd->body.surfaceFlags = srf->flags; 227 /*
228 * Downcast of surfaceFlags, was upcasted when received from user-space,
229 * since driver internally stores as 64 bit.
230 * For legacy surface define only 32 bit flag is supported.
231 */
232 cmd->body.surfaceFlags = (SVGA3dSurface1Flags)srf->flags;
228 cmd->body.format = srf->format; 233 cmd->body.format = srf->format;
229 for (i = 0; i < DRM_VMW_MAX_SURFACE_FACES; ++i) 234 for (i = 0; i < DRM_VMW_MAX_SURFACE_FACES; ++i)
230 cmd->body.face[i].numMipLevels = srf->mip_levels[i]; 235 cmd->body.face[i].numMipLevels = srf->mip_levels[i];
@@ -760,7 +765,8 @@ int vmw_surface_define_ioctl(struct drm_device *dev, void *data,
760 srf = &user_srf->srf; 765 srf = &user_srf->srf;
761 res = &srf->res; 766 res = &srf->res;
762 767
763 srf->flags = req->flags; 768 /* Driver internally stores as 64-bit flags */
769 srf->flags = (SVGA3dSurfaceAllFlags)req->flags;
764 srf->format = req->format; 770 srf->format = req->format;
765 srf->scanout = req->scanout; 771 srf->scanout = req->scanout;
766 772
@@ -992,7 +998,8 @@ int vmw_surface_reference_ioctl(struct drm_device *dev, void *data,
992 user_srf = container_of(base, struct vmw_user_surface, prime.base); 998 user_srf = container_of(base, struct vmw_user_surface, prime.base);
993 srf = &user_srf->srf; 999 srf = &user_srf->srf;
994 1000
995 rep->flags = srf->flags; 1001 /* Downcast of flags when sending back to user space */
1002 rep->flags = (uint32_t)srf->flags;
996 rep->format = srf->format; 1003 rep->format = srf->format;
997 memcpy(rep->mip_levels, srf->mip_levels, sizeof(srf->mip_levels)); 1004 memcpy(rep->mip_levels, srf->mip_levels, sizeof(srf->mip_levels));
998 user_sizes = (struct drm_vmw_size __user *)(unsigned long) 1005 user_sizes = (struct drm_vmw_size __user *)(unsigned long)
@@ -1082,7 +1089,7 @@ static int vmw_gb_surface_create(struct vmw_resource *res)
1082 cmd3->header.id = cmd_id; 1089 cmd3->header.id = cmd_id;
1083 cmd3->header.size = cmd_len; 1090 cmd3->header.size = cmd_len;
1084 cmd3->body.sid = srf->res.id; 1091 cmd3->body.sid = srf->res.id;
1085 cmd3->body.surfaceFlags = (SVGA3dSurfaceAllFlags)srf->flags; 1092 cmd3->body.surfaceFlags = srf->flags;
1086 cmd3->body.format = srf->format; 1093 cmd3->body.format = srf->format;
1087 cmd3->body.numMipLevels = srf->mip_levels[0]; 1094 cmd3->body.numMipLevels = srf->mip_levels[0];
1088 cmd3->body.multisampleCount = srf->multisample_count; 1095 cmd3->body.multisampleCount = srf->multisample_count;
@@ -1320,7 +1327,7 @@ int vmw_gb_surface_define_ioctl(struct drm_device *dev, void *data,
1320 /* Define a surface based on the parameters. */ 1327 /* Define a surface based on the parameters. */
1321 ret = vmw_surface_gb_priv_define(dev, 1328 ret = vmw_surface_gb_priv_define(dev,
1322 size, 1329 size,
1323 req->svga3d_flags, 1330 (SVGA3dSurfaceAllFlags)req->svga3d_flags,
1324 req->format, 1331 req->format,
1325 req->drm_surface_flags & drm_vmw_surface_flag_scanout, 1332 req->drm_surface_flags & drm_vmw_surface_flag_scanout,
1326 req->mip_levels, 1333 req->mip_levels,
@@ -1451,7 +1458,7 @@ int vmw_gb_surface_reference_ioctl(struct drm_device *dev, void *data,
1451 goto out_bad_resource; 1458 goto out_bad_resource;
1452 } 1459 }
1453 1460
1454 rep->creq.svga3d_flags = srf->flags; 1461 rep->creq.svga3d_flags = (uint32_t)srf->flags;
1455 rep->creq.format = srf->format; 1462 rep->creq.format = srf->format;
1456 rep->creq.mip_levels = srf->mip_levels[0]; 1463 rep->creq.mip_levels = srf->mip_levels[0];
1457 rep->creq.drm_surface_flags = 0; 1464 rep->creq.drm_surface_flags = 0;
@@ -1495,7 +1502,7 @@ out_bad_resource:
1495 */ 1502 */
1496int vmw_surface_gb_priv_define(struct drm_device *dev, 1503int vmw_surface_gb_priv_define(struct drm_device *dev,
1497 uint32_t user_accounting_size, 1504 uint32_t user_accounting_size,
1498 uint32_t svga3d_flags, 1505 SVGA3dSurfaceAllFlags svga3d_flags,
1499 SVGA3dSurfaceFormat format, 1506 SVGA3dSurfaceFormat format,
1500 bool for_scanout, 1507 bool for_scanout,
1501 uint32_t num_mip_levels, 1508 uint32_t num_mip_levels,