Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753106AbbGMT6a (ORCPT ); Mon, 13 Jul 2015 15:58:30 -0400 Received: from mail-am1on0059.outbound.protection.outlook.com ([157.56.112.59]:60850 "EHLO emea01-am1-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1753055AbbGMT60 (ORCPT ); Mon, 13 Jul 2015 15:58:26 -0400 Authentication-Results: spf=fail (sender IP is 12.216.194.146) smtp.mailfrom=ezchip.com; ezchip.com; dkim=none (message not signed) header.d=none; From: Chris Metcalf To: Gilad Ben Yossef , Steven Rostedt , Ingo Molnar , Peter Zijlstra , Andrew Morton , Rik van Riel , Tejun Heo , Frederic Weisbecker , Thomas Gleixner , "Paul E. McKenney" , Christoph Lameter , Viresh Kumar , , , CC: Chris Metcalf Subject: [PATCH v4 3/5] nohz: cpu_isolated strict mode configurable signal Date: Mon, 13 Jul 2015 15:57:59 -0400 Message-ID: <1436817481-8732-4-git-send-email-cmetcalf@ezchip.com> X-Mailer: git-send-email 2.1.2 In-Reply-To: <1436817481-8732-1-git-send-email-cmetcalf@ezchip.com> References: <1436817481-8732-1-git-send-email-cmetcalf@ezchip.com> X-EOPAttributedMessage: 0 X-Microsoft-Exchange-Diagnostics: 1;DB3FFO11FD041;1:WfgyNzFbBD3Sz844slknKr7O3DZVJImPk/5Ey3MvtOsd9PVvaZzItqeR+58DB5ZiQrI2kirKk4JAix/aBTJj2IMVlMEY7HIe+exQ+VC/gCK69E/09kaF8c94Ul24AIFMS3HFMJLwXt2NczAXMmuhLSm2X8B4wCizqtU46PjURTy8B2k8uzftUiT1oMrwXCsvzHh1KXDiMaaE41NNhbZ95lWaVFK30SwADaNZzgDWL3X9IhLOPhAnuZ0VuzGdVc1u5pGQKxDqblS3vyOyQWZ77Izg6u5+wHBwqmwiuWvl0ANggkzM8taOzyWmTU/j6roriRmaQXG5AOVrZg4dZgGMi0fa5atEqs6bn41vY2vIyZGy+CuYkE6K9Jwr1YQSTUHREwZBCcGW6xECK1f6ChshSQ== X-Forefront-Antispam-Report: CIP:12.216.194.146;CTRY:US;IPV:NLI;EFV:NLI;SFV:NSPM;SFS:(10009020)(6009001)(2980300002)(339900001)(199003)(189002)(86362001)(104016003)(2950100001)(2201001)(47776003)(76176999)(85426001)(36756003)(50226001)(50986999)(42186005)(46102003)(229853001)(33646002)(105606002)(92566002)(77156002)(19580405001)(106466001)(19580395003)(6806004)(87936001)(48376002)(5003940100001)(5001770100001)(50466002)(5001960100002)(107886002)(189998001)(62966003)(921003)(4001430100001)(1121003);DIR:OUT;SFP:1101;SCL:1;SRVR:AM2PR02MB0769;H:ld-1.internal.tilera.com;FPR:;SPF:Fail;MLV:sfv;A:1;MX:1;LANG:en; MIME-Version: 1.0 Content-Type: text/plain X-Microsoft-Exchange-Diagnostics: 1;AM2PR02MB0769;2:S0QBuQiwPP5zxwOcbKNkueQBRS1W0MbA5TMYWNwncJoCZoKm+SvAef/ZlG/Y1T5w;3:j3+1U8WgwRSC9EJn4W8VjZ/H5ChamegkCKM+wKrwWVSEqVB5DY5daXOveV4yohnXXODVLI0ncI7fZg6qFCWIBx2Wfaerg3LZLy1d4Vlqb7EAbCHt9ySbxuU3JSUq5Qf9VQ2dbQmMpyY99SrvqwUErIx4Xadz7z0bg26STlP3V5WmKPxkGt43l2WAVjQyG43baUyJ8+uw7u9s087IlvxW/qkdLkbMGXkgkzrWxVuyKmIZDVwK6QHXGww82xH7EaRX;25:EQLfWE2/mrdwGKg44dDtwh/CkoZeRVD+I3tNOGqzOMxo5G3vkGD0w/flbrKJlvDqu7i7bNJWrPGsUiWveJoxeslF94JoLAQtZuSp1jjXIsSKB9gzKctaqrhqW1bNPPXNSIy/lEDKXUXSiiOJA8qztpWLRemMOqtZfvzk21RWAP31PZtEBK+jtcSfUjk0uRCnWVqrA+qk9GPOQRc9lQ8NDXIIEjipObYtOxGpMMgn+yePBnz5f6aZkn0czbJkiiWdvcvLaGNl2Mipz6NEJJnvXg==;20:aD3jIWKH2+y/GVSXfwjls/0cBIcGzHw2W8U0e6l0Gh+vqeH+0dtDMO2lX0mB4QhnrQ0I0RLw3Y3qYILJB8ysyIvYkLfviJjzCcBfX5raR1zD7CuJD3w4PZNZYH7O0+BVACKt9+p2lJqhxzHLaVOPAw0CIH+7sHN8bu9nBtLiAEY= X-Microsoft-Antispam: UriScan:;BCL:0;PCL:0;RULEID:;SRVR:AM2PR02MB0769; AM2PR02MB0769: X-MS-Exchange-Organization-RulesExecuted X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:; X-Exchange-Antispam-Report-CFA-Test: BCL:0;PCL:0;RULEID:(601004)(5005006)(3002001);SRVR:AM2PR02MB0769;BCL:0;PCL:0;RULEID:;SRVR:AM2PR02MB0769; X-Microsoft-Exchange-Diagnostics: 1;AM2PR02MB0769;4:BhlFEZz4qpYfsbLnb6the1g6XNHrhzMIq24/P4iE6N77/zVmHf5m8FuhJNBzz3yQpw10e1vmH3aYFtgsILrb82vhTxssXzYyNYyZTGKfMRq9QJ6bD80ffaEXxctgnxJ1HYvV4Ij+xNHXpcu6WYoqCAWlb2pk3vFI2BdBZbeA4fmNt3z8M4KudTtXt5VnZB/UOFERr8knNklzNF+sk+lzZ0FwK69O32AZ5O/rj2xUPKFXT+GV3CthfLsfwHNhBxtR7TOLbxEbuXSM1hOlWTLLc09aQWrPHsLaYIpLIxcFfV8= X-Forefront-PRVS: 0636271852 X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1;AM2PR02MB0769;23:Rq4WAjJlu5BCxt+D8WAxQ8l01ShpqJylIYf86hRWz?= =?us-ascii?Q?Dv6hi5MAzGfJR6IN+3zjx0wCi6AAsPp8wJ1Q2c3ZpYpJa/U3QOD0QRqEKaDN?= =?us-ascii?Q?jj9mMl/LMrkJNRDWl7y2SyKi2HWI2/kjUKyadEIiXRmolMcW4do54XkZXmSV?= =?us-ascii?Q?HQ17tdvCDFRJLcbOTkU60narNZHLVigLP650EcF+5zjK/6v/ABxHUIFJBIob?= =?us-ascii?Q?nOe7I5yc0ztt5/QBSt+LvbLDu9dhj10bDMClZASrByGhnxwEBPTCC80H6nnc?= =?us-ascii?Q?2yaW9FzJhZ9SzZisp1guw3bJHxNJq49R0gn9tmJqlbV5y4CpK/9idfaOiRqD?= =?us-ascii?Q?0lV8wvXQMJX8uxge+KvwqihMjlavvFDhZtv+5R0h5WVJBf8iTGWxxckHaS3Y?= =?us-ascii?Q?0dSFCoYtMc1iGa2F6IPf3//7vwW2YE7sGUC+MhtG2HvZjocO7pWWcAKO6mEd?= =?us-ascii?Q?Hvdx+fmduReN2QKgcIzjhw4Fc/nY6cwUKIfR6z1v6iIWs9fEUdOARYJH4Lq8?= =?us-ascii?Q?IqI+2IbcaN3TJzciWtitnpP9b3jcxOa4DhOiv12B8DAWW4rNCJoInhD4ShQj?= =?us-ascii?Q?h9rVlkqRgLu3kdD7xXUROaZ7RQvyVh4SXoHqn94GuPMbvAZXb2VOfNIlMGsa?= =?us-ascii?Q?iPpKbrUzXhKWOfSJpkFt8OZqIl5nxg7dAiMO7CiLy3AldaoQ4xjNg5FiKOsM?= =?us-ascii?Q?lwyzO4KEAdEbj3tYXUqmM6VeiDjfzYcMU0HIDE7cn3EVpJDyMv3NMsdTCH7V?= =?us-ascii?Q?6kuoFcneCtX92184cDV4L3C4oqNWXRIw5fBC77WZa1ROPkbsPQqqIIQCiuDN?= =?us-ascii?Q?YYZLJ1jKlJDQwp0fqlDKChEgxIC0p5hWRMAfMjHCgYTklToCX+a3mCggON3z?= =?us-ascii?Q?8omBbMXc97PpDFFB8IMFY1197+WD1A4dUt7IEDRJz116jCClvkel/+DxLXja?= =?us-ascii?Q?S4Vbvm4XXSTMmLqjOxaAdtpbH7f3xGC7V8h7LgW9nuPtHHYZsblK2GN06j/6?= =?us-ascii?Q?tFidIbsR27qFrFqLPj4cK+/?= X-Microsoft-Exchange-Diagnostics: 1;AM2PR02MB0769;5:JBp6Er0xXaWNSP9kBx6nvcK+rropLmVSS3W4TUEelY7sjqE8CBhmDHD6J/EShvsuy30UYDQqsD4GM8HlXP7Npg5JNTbGGDFouhOs4f9YBl3hmzw9NgL7B9w5AEsmwH2QJXIv5+5ftHpIdVyim0CU/g==;24:OvstVgIRAKAJvs0kJwlKmEhKEum+gMGM4g06sJnzkM5txwdygMNF1zxmoEy5Ttuckb6fO1vz5htiSJPrbYZlgcLE99LddA71EJAM84GvuSU=;20:XODJ1hU/n+RkRjILIr2hi1R3r/XsgzBQMZ2092GmOgIyccxfeSPu/iB+v46vvOtq691oXy4LZLFZwVVtOuWNNA== SpamDiagnosticOutput: 1:23 SpamDiagnosticMetadata: NSPM X-OriginatorOrg: ezchip.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 13 Jul 2015 19:58:22.3877 (UTC) X-MS-Exchange-CrossTenant-Id: 0fc16e0a-3cd3-4092-8b2f-0a42cff122c3 X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=0fc16e0a-3cd3-4092-8b2f-0a42cff122c3;Ip=[12.216.194.146];Helo=[ld-1.internal.tilera.com] X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: AM2PR02MB0769 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2433 Lines: 77 Allow userspace to override the default SIGKILL delivered when a cpu_isolated process in STRICT mode does a syscall or otherwise synchronously enters the kernel. In addition to being able to set the signal, we now also pass whether or not the interruption was from a syscall in the si_code field of the siginfo. Signed-off-by: Chris Metcalf --- include/uapi/linux/prctl.h | 2 ++ kernel/time/tick-sched.c | 15 +++++++++++---- 2 files changed, 13 insertions(+), 4 deletions(-) diff --git a/include/uapi/linux/prctl.h b/include/uapi/linux/prctl.h index 0c11238a84fb..ab45bd3d5799 100644 --- a/include/uapi/linux/prctl.h +++ b/include/uapi/linux/prctl.h @@ -195,5 +195,7 @@ struct prctl_mm_map { #define PR_GET_CPU_ISOLATED 48 # define PR_CPU_ISOLATED_ENABLE (1 << 0) # define PR_CPU_ISOLATED_STRICT (1 << 1) +# define PR_CPU_ISOLATED_SET_SIG(sig) (((sig) & 0x7f) << 8) +# define PR_CPU_ISOLATED_GET_SIG(bits) (((bits) >> 8) & 0x7f) #endif /* _LINUX_PRCTL_H */ diff --git a/kernel/time/tick-sched.c b/kernel/time/tick-sched.c index 9f495c7c7dc2..c5eca9c99fad 100644 --- a/kernel/time/tick-sched.c +++ b/kernel/time/tick-sched.c @@ -447,11 +447,18 @@ void tick_nohz_cpu_isolated_enter(void) } } -static void kill_cpu_isolated_strict_task(void) +static void kill_cpu_isolated_strict_task(int is_syscall) { + siginfo_t info = {}; + int sig; + dump_stack(); current->cpu_isolated_flags &= ~PR_CPU_ISOLATED_ENABLE; - send_sig(SIGKILL, current, 1); + + sig = PR_CPU_ISOLATED_GET_SIG(current->cpu_isolated_flags) ?: SIGKILL; + info.si_signo = sig; + info.si_code = is_syscall; + send_sig_info(sig, &info, current); } /* @@ -470,7 +477,7 @@ void tick_nohz_cpu_isolated_syscall(int syscall) pr_warn("%s/%d: cpu_isolated strict mode violated by syscall %d\n", current->comm, current->pid, syscall); - kill_cpu_isolated_strict_task(); + kill_cpu_isolated_strict_task(1); } /* @@ -481,7 +488,7 @@ void tick_nohz_cpu_isolated_exception(void) { pr_warn("%s/%d: cpu_isolated strict mode violated by exception\n", current->comm, current->pid); - kill_cpu_isolated_strict_task(); + kill_cpu_isolated_strict_task(0); } #endif -- 2.1.2 -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/