提交 e94f7856 编写于 作者: C Chris Wilson

drm/i915/gem: Promote 'remain' to unsigned long

Tidy the code by casting remain to unsigned long once for the duration
of eb_relocate_vma()
Signed-off-by: NChris Wilson <chris@chris-wilson.co.uk>
Reviewed-by: NMika Kuoppala <mika.kuoppala@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20200407085930.19421-1-chris@chris-wilson.co.uk
上级 e6829625
...@@ -1501,13 +1501,12 @@ static int eb_relocate_vma(struct i915_execbuffer *eb, struct eb_vma *ev) ...@@ -1501,13 +1501,12 @@ static int eb_relocate_vma(struct i915_execbuffer *eb, struct eb_vma *ev)
{ {
#define N_RELOC(x) ((x) / sizeof(struct drm_i915_gem_relocation_entry)) #define N_RELOC(x) ((x) / sizeof(struct drm_i915_gem_relocation_entry))
struct drm_i915_gem_relocation_entry stack[N_RELOC(512)]; struct drm_i915_gem_relocation_entry stack[N_RELOC(512)];
struct drm_i915_gem_relocation_entry __user *urelocs;
const struct drm_i915_gem_exec_object2 *entry = ev->exec; const struct drm_i915_gem_exec_object2 *entry = ev->exec;
unsigned int remain; struct drm_i915_gem_relocation_entry __user *urelocs =
u64_to_user_ptr(entry->relocs_ptr);
unsigned long remain = entry->relocation_count;
urelocs = u64_to_user_ptr(entry->relocs_ptr); if (unlikely(remain > N_RELOC(ULONG_MAX)))
remain = entry->relocation_count;
if (unlikely((unsigned long)remain > N_RELOC(ULONG_MAX)))
return -EINVAL; return -EINVAL;
/* /*
...@@ -1515,13 +1514,13 @@ static int eb_relocate_vma(struct i915_execbuffer *eb, struct eb_vma *ev) ...@@ -1515,13 +1514,13 @@ static int eb_relocate_vma(struct i915_execbuffer *eb, struct eb_vma *ev)
* to read. However, if the array is not writable the user loses * to read. However, if the array is not writable the user loses
* the updated relocation values. * the updated relocation values.
*/ */
if (unlikely(!access_ok(urelocs, remain*sizeof(*urelocs)))) if (unlikely(!access_ok(urelocs, remain * sizeof(*urelocs))))
return -EFAULT; return -EFAULT;
do { do {
struct drm_i915_gem_relocation_entry *r = stack; struct drm_i915_gem_relocation_entry *r = stack;
unsigned int count = unsigned int count =
min_t(unsigned int, remain, ARRAY_SIZE(stack)); min_t(unsigned long, remain, ARRAY_SIZE(stack));
unsigned int copied; unsigned int copied;
/* /*
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册