Commit 8c40397f authored by Thomas Gleixner's avatar Thomas Gleixner

x86/ptrace: Prevent truncation of bitmap size

The active() callback of the IO bitmap regset divides the IO bitmap size by
the word size (32/64 bit). As the I/O bitmap size is in bytes the active
check fails for bitmap sizes of 1-3 bytes on 32bit and 1-7 bytes on 64bit.

Use DIV_ROUND_UP() instead.
Signed-off-by: default avatarThomas Gleixner <tglx@linutronix.de>
Reviewed-by: default avatarIngo Molnar <mingo@kernel.org>
Reviewed-by: default avatarAndy Lutomirski <luto@kernel.org>
parent 31f4f5b4
...@@ -697,7 +697,7 @@ static int ptrace_set_debugreg(struct task_struct *tsk, int n, ...@@ -697,7 +697,7 @@ static int ptrace_set_debugreg(struct task_struct *tsk, int n,
static int ioperm_active(struct task_struct *target, static int ioperm_active(struct task_struct *target,
const struct user_regset *regset) const struct user_regset *regset)
{ {
return target->thread.io_bitmap_max / regset->size; return DIV_ROUND_UP(target->thread.io_bitmap_max, regset->size);
} }
static int ioperm_get(struct task_struct *target, static int ioperm_get(struct task_struct *target,
......
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