Commit 4a6eccbc authored by Xiong Zhang's avatar Xiong Zhang Committed by Zhenyu Wang

drm/i915/gvt: Change fb_info->size from pages to bytes

fb_info->size is in pages, but some function need bytes when it
is as a parameter. Such as:
a. intel_gvt_ggtt_validate_range(), according to function definition
b. vifio_device_gfx_plane_info->size, according to the comment of
   its definition

So change fb_info->size into bytes.

v2: Keep fb_info->size in real size instead of assinging casted page
    size(zhenyu)
v3: obj->size should be page aligned and delete redundant check(zhenyu)
Signed-off-by: default avatarXiong Zhang <xiong.y.zhang@intel.com>
Reviewed-by: default avatarZhenyu Wang <zhenyuw@linux.intel.com>
Signed-off-by: default avatarZhenyu Wang <zhenyuw@linux.intel.com>
parent 447811a6
...@@ -45,6 +45,7 @@ static int vgpu_gem_get_pages( ...@@ -45,6 +45,7 @@ static int vgpu_gem_get_pages(
int i, ret; int i, ret;
gen8_pte_t __iomem *gtt_entries; gen8_pte_t __iomem *gtt_entries;
struct intel_vgpu_fb_info *fb_info; struct intel_vgpu_fb_info *fb_info;
u32 page_num;
fb_info = (struct intel_vgpu_fb_info *)obj->gvt_info; fb_info = (struct intel_vgpu_fb_info *)obj->gvt_info;
if (WARN_ON(!fb_info)) if (WARN_ON(!fb_info))
...@@ -54,14 +55,15 @@ static int vgpu_gem_get_pages( ...@@ -54,14 +55,15 @@ static int vgpu_gem_get_pages(
if (unlikely(!st)) if (unlikely(!st))
return -ENOMEM; return -ENOMEM;
ret = sg_alloc_table(st, fb_info->size, GFP_KERNEL); page_num = obj->base.size >> PAGE_SHIFT;
ret = sg_alloc_table(st, page_num, GFP_KERNEL);
if (ret) { if (ret) {
kfree(st); kfree(st);
return ret; return ret;
} }
gtt_entries = (gen8_pte_t __iomem *)dev_priv->ggtt.gsm + gtt_entries = (gen8_pte_t __iomem *)dev_priv->ggtt.gsm +
(fb_info->start >> PAGE_SHIFT); (fb_info->start >> PAGE_SHIFT);
for_each_sg(st->sgl, sg, fb_info->size, i) { for_each_sg(st->sgl, sg, page_num, i) {
sg->offset = 0; sg->offset = 0;
sg->length = PAGE_SIZE; sg->length = PAGE_SIZE;
sg_dma_address(sg) = sg_dma_address(sg) =
...@@ -158,7 +160,7 @@ static struct drm_i915_gem_object *vgpu_create_gem(struct drm_device *dev, ...@@ -158,7 +160,7 @@ static struct drm_i915_gem_object *vgpu_create_gem(struct drm_device *dev,
return NULL; return NULL;
drm_gem_private_object_init(dev, &obj->base, drm_gem_private_object_init(dev, &obj->base,
info->size << PAGE_SHIFT); roundup(info->size, PAGE_SIZE));
i915_gem_object_init(obj, &intel_vgpu_gem_ops); i915_gem_object_init(obj, &intel_vgpu_gem_ops);
obj->read_domains = I915_GEM_DOMAIN_GTT; obj->read_domains = I915_GEM_DOMAIN_GTT;
...@@ -206,7 +208,6 @@ static int vgpu_get_plane_info(struct drm_device *dev, ...@@ -206,7 +208,6 @@ static int vgpu_get_plane_info(struct drm_device *dev,
struct intel_vgpu_fb_info *info, struct intel_vgpu_fb_info *info,
int plane_id) int plane_id)
{ {
struct drm_i915_private *dev_priv = to_i915(dev);
struct intel_vgpu_primary_plane_format p; struct intel_vgpu_primary_plane_format p;
struct intel_vgpu_cursor_plane_format c; struct intel_vgpu_cursor_plane_format c;
int ret, tile_height = 1; int ret, tile_height = 1;
...@@ -267,8 +268,7 @@ static int vgpu_get_plane_info(struct drm_device *dev, ...@@ -267,8 +268,7 @@ static int vgpu_get_plane_info(struct drm_device *dev,
return -EINVAL; return -EINVAL;
} }
info->size = (info->stride * roundup(info->height, tile_height) info->size = info->stride * roundup(info->height, tile_height);
+ PAGE_SIZE - 1) >> PAGE_SHIFT;
if (info->size == 0) { if (info->size == 0) {
gvt_vgpu_err("fb size is zero\n"); gvt_vgpu_err("fb size is zero\n");
return -EINVAL; return -EINVAL;
...@@ -278,11 +278,6 @@ static int vgpu_get_plane_info(struct drm_device *dev, ...@@ -278,11 +278,6 @@ static int vgpu_get_plane_info(struct drm_device *dev,
gvt_vgpu_err("Not aligned fb address:0x%llx\n", info->start); gvt_vgpu_err("Not aligned fb address:0x%llx\n", info->start);
return -EFAULT; return -EFAULT;
} }
if (((info->start >> PAGE_SHIFT) + info->size) >
ggtt_total_entries(&dev_priv->ggtt)) {
gvt_vgpu_err("Invalid GTT offset or size\n");
return -EFAULT;
}
if (!intel_gvt_ggtt_validate_range(vgpu, info->start, info->size)) { if (!intel_gvt_ggtt_validate_range(vgpu, info->start, info->size)) {
gvt_vgpu_err("invalid gma addr\n"); gvt_vgpu_err("invalid gma addr\n");
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment