diff options
author | Deepak Rawat <drawat@vmware.com> | 2018-06-20 17:25:07 -0400 |
---|---|---|
committer | Thomas Hellstrom <thellstrom@vmware.com> | 2018-07-06 14:16:08 -0400 |
commit | 397a11175f830e1ceb82b608a1c7adbacfbe39b0 (patch) | |
tree | 541c0c7b35aba5eb25ef95b23c3d3f6501ec4cf8 /drivers/gpu/drm | |
parent | cdff8e73006c05ee342dd588b5ba90b5def56184 (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.h | 4 | ||||
-rw-r--r-- | drivers/gpu/drm/vmwgfx/vmwgfx_surface.c | 21 |
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 | ||
167 | struct vmw_surface { | 167 | struct 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); |
1081 | int vmw_surface_gb_priv_define(struct drm_device *dev, | 1081 | int 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 | */ |
1496 | int vmw_surface_gb_priv_define(struct drm_device *dev, | 1503 | int 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, |