diff options
author | Andi Kleen <ak@linux.intel.com> | 2009-10-03 20:20:11 -0400 |
---|---|---|
committer | Andi Kleen <ak@linux.intel.com> | 2009-10-03 21:23:17 -0400 |
commit | 1087e9b4ff708976499b4de541d9e1d57d49b60a (patch) | |
tree | a370356b3f969b6081189d850d9a56921ed341c4 /kernel | |
parent | f0a221ef47df3cdde2123fe75ce3b61bb7df656d (diff) |
HWPOISON: Clean up PR_MCE_KILL interface
While writing the manpage I noticed some shortcomings in the
current interface.
- Define symbolic names for all the different values
- Boundary check the kill mode values
- For symmetry add a get interface too. This allows library
code to get/set the current state.
- For consistency define a PR_MCE_KILL_DEFAULT value
Signed-off-by: Andi Kleen <ak@linux.intel.com>
Diffstat (limited to 'kernel')
-rw-r--r-- | kernel/sys.c | 23 |
1 files changed, 18 insertions, 5 deletions
diff --git a/kernel/sys.c b/kernel/sys.c index 255475d163e0..f6afe07d6c0b 100644 --- a/kernel/sys.c +++ b/kernel/sys.c | |||
@@ -1546,24 +1546,37 @@ SYSCALL_DEFINE5(prctl, int, option, unsigned long, arg2, unsigned long, arg3, | |||
1546 | if (arg4 | arg5) | 1546 | if (arg4 | arg5) |
1547 | return -EINVAL; | 1547 | return -EINVAL; |
1548 | switch (arg2) { | 1548 | switch (arg2) { |
1549 | case 0: | 1549 | case PR_MCE_KILL_CLEAR: |
1550 | if (arg3 != 0) | 1550 | if (arg3 != 0) |
1551 | return -EINVAL; | 1551 | return -EINVAL; |
1552 | current->flags &= ~PF_MCE_PROCESS; | 1552 | current->flags &= ~PF_MCE_PROCESS; |
1553 | break; | 1553 | break; |
1554 | case 1: | 1554 | case PR_MCE_KILL_SET: |
1555 | current->flags |= PF_MCE_PROCESS; | 1555 | current->flags |= PF_MCE_PROCESS; |
1556 | if (arg3 != 0) | 1556 | if (arg3 == PR_MCE_KILL_EARLY) |
1557 | current->flags |= PF_MCE_EARLY; | 1557 | current->flags |= PF_MCE_EARLY; |
1558 | else | 1558 | else if (arg3 == PR_MCE_KILL_LATE) |
1559 | current->flags &= ~PF_MCE_EARLY; | 1559 | current->flags &= ~PF_MCE_EARLY; |
1560 | else if (arg3 == PR_MCE_KILL_DEFAULT) | ||
1561 | current->flags &= | ||
1562 | ~(PF_MCE_EARLY|PF_MCE_PROCESS); | ||
1563 | else | ||
1564 | return -EINVAL; | ||
1560 | break; | 1565 | break; |
1561 | default: | 1566 | default: |
1562 | return -EINVAL; | 1567 | return -EINVAL; |
1563 | } | 1568 | } |
1564 | error = 0; | 1569 | error = 0; |
1565 | break; | 1570 | break; |
1566 | 1571 | case PR_MCE_KILL_GET: | |
1572 | if (arg2 | arg3 | arg4 | arg5) | ||
1573 | return -EINVAL; | ||
1574 | if (current->flags & PF_MCE_PROCESS) | ||
1575 | error = (current->flags & PF_MCE_EARLY) ? | ||
1576 | PR_MCE_KILL_EARLY : PR_MCE_KILL_LATE; | ||
1577 | else | ||
1578 | error = PR_MCE_KILL_DEFAULT; | ||
1579 | break; | ||
1567 | default: | 1580 | default: |
1568 | error = -EINVAL; | 1581 | error = -EINVAL; |
1569 | break; | 1582 | break; |