提交 a752d719 编写于 作者: C Chuck Ebbert 提交者: Andi Kleen

[PATCH] fix is_at_popf() for compat tasks

When testing for the REX instruction prefix, first check
for 32-bit mode because in compat mode the REX prefix is an
increment instruction.
Signed-off-by: NChuck Ebbert <76306.1226@compuserve.com>
Signed-off-by: NAndi Kleen <ak@suse.de>
上级 8578bdf8
...@@ -141,8 +141,11 @@ static int is_at_popf(struct task_struct *child, struct pt_regs *regs) ...@@ -141,8 +141,11 @@ static int is_at_popf(struct task_struct *child, struct pt_regs *regs)
case 0xf0: case 0xf2: case 0xf3: case 0xf0: case 0xf2: case 0xf3:
continue; continue;
/* REX prefixes */
case 0x40 ... 0x4f: case 0x40 ... 0x4f:
if (regs->cs != __USER_CS)
/* 32-bit mode: register increment */
return 0;
/* 64-bit mode: REX prefix */
continue; continue;
/* CHECKME: f0, f2, f3 */ /* CHECKME: f0, f2, f3 */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册