From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1161118AbcFANNX (ORCPT ); Wed, 1 Jun 2016 09:13:23 -0400 Received: from mail-am1on0116.outbound.protection.outlook.com ([157.56.112.116]:59568 "EHLO emea01-am1-obe.outbound.protection.outlook.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1758283AbcFANNS (ORCPT ); Wed, 1 Jun 2016 09:13:18 -0400 Authentication-Results: vger.kernel.org; dkim=none (message not signed) header.d=none;vger.kernel.org; dmarc=none action=none header.from=virtuozzo.com; From: Dmitry Safonov To: , CC: , , , , <0x7f454c46@gmail.com>, , , , , Dmitry Safonov Subject: [PATCH 0/6] x86: 32-bit compatible C/R on x86_64 Date: Wed, 1 Jun 2016 16:11:31 +0300 Message-ID: <1464786697-20639-1-git-send-email-dsafonov@virtuozzo.com> X-Mailer: git-send-email 2.8.2 MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [195.214.232.10] X-ClientProxiedBy: AM5PR0901CA0029.eurprd09.prod.outlook.com (10.164.186.167) To DB6PR0801MB1286.eurprd08.prod.outlook.com (10.168.11.16) X-MS-Office365-Filtering-Correlation-Id: 4e91eafe-c8d9-4b6f-470c-08d38a1e7812 X-Microsoft-Exchange-Diagnostics: 1;DB6PR0801MB1286;2:ugKVV3CsnUgn+QFUuQrBxRX6OEV6/VQ6OuwUsPKb/iAtRTnj6jGJKue9x5l45zzJweqnPUonFbIbarlsG0txWWeJD4+VL5Yqfas9WwUiyFQJrdMFL8LA6WAZJzYdSBrtCzg2EFUSM0iIibrM1ri3h9I+k7s/nDMSLHvQuy3hRiVnOlZlb9iSiJRvNYh6K3Sr;3:1DX6nvzZEDiodYpWVqG+ltNOjTC13D1K1tuglT/DiUdj4wVyaizjOCtRLSoeRzR9kVfmLzq1k5TBelEZCVelX4bzLZQVAmkLBgU4FHqHszQP8fIGLgp4nzYL7SESrVeH X-Microsoft-Antispam: UriScan:;BCL:0;PCL:0;RULEID:;SRVR:DB6PR0801MB1286; X-Microsoft-Exchange-Diagnostics: 1;DB6PR0801MB1286;25:UQe/COdiieMVRtszGIvLUvDR+/FKwGrYsFXM/NVIkhuw8+nvNS4CKY9LPrK+KXuBaGzI3ROsO57YtNpEjUOvE6H3XgrHBjizYqKx6T/7wiU4DBkVody0mH+GNDSwXlICx1x1KwuZAFZGOY2FOn8Od950t59hpqOYcwmK+Ywu1tAVX2/pF3wmefNqDUtWTaoqzvakl6gZKRetyftxbHlF2vHIAn7N4oxAlWRbDqSx42xUhdErUwiSewchp/pBsrOF6yA3SJB6ck/mpSUWGWLwjEOR3iUySJSKfbM0qTv/n4LjJUe7V4En3GVK67RqqU5zw9248S8aW0SwhD08wiqCr3OAcHon8twaxpAJEcI64/5X+9rVFjlVVlFr7LLSzLZUlV8VDfehs0WfIvZXv3aRpTctrORrc8hilyoNqPZSlKLERXhPidq21cYou0vgE6pE5l9PvvvfYXuhgQHeuijeT2v/0w2aa01PBUpZrcj+lzTCBql1PIDew3dSVZptmLw4aok+XQaseEkOzzoQ7yXqPR7CmAnzy7h+u9+HmGQO3R21RwwijfvUhGsna26s8faEjrfGguSLPAIfPaSPfLTGAXvIHaE37joRbjJJGHKBPJWkReFMNU+7PxXiDjuOZnjusok5Bsfi3sXJnUMMlTz1OTYGHczmtL/I5HKjYwYBqDUlWB0r9xziHBQyVbWtsgC3onBnmBXAjYCQ/X0Cx0L9ZFjGz1Kkxqk7TCKBQDtdaLyXiQqEg+InyZsRToYRlA13LB8DZjpCRm6oqmFvxD8v2TuykfZ4Kc+pt/PnCuwd8Oc= X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-Test: UriScan:; X-Exchange-Antispam-Report-CFA-Test: BCL:0;PCL:0;RULEID:(6040130)(601004)(2401047)(8121501046)(5005006)(10201501046)(3002001)(6041072)(6043046);SRVR:DB6PR0801MB1286;BCL:0;PCL:0;RULEID:;SRVR:DB6PR0801MB1286; X-Microsoft-Exchange-Diagnostics: 1;DB6PR0801MB1286;4:+stXlzbK5xKLvJLI/mzStaePzgNRvJsbHZnHy9UAxGPAkM6CLm2vVo+qS8CE3o/W4ZorCVDeY50kM1VR88Q60feuhaVb3i58JzD6l5tljO1wiIsFap5eqm0jJnYcT2ZzFne+jCa89+yhAD+WItu0Gu6OQEe/JJK62pStyBXL25McyA/MIFdY6p8A4eo1vTh+mrGEiyD7SDRE7yY1y/HWDOexN/2/CJmcfsXH3q8MA1gh0Opa02W+zvu+ZAjPBHi95TbA2tjxOssfjJC32Rm2wgmKUZm9wXHMDXK006H3fIXT5nzxPsDr7VgQvgzjt3Lzf1fIM52NAITFdDdxIfkSVjikls/RzTnWbqOztIm5iVC2g8usmIUZWUF+xK8+wuh/4vJvPFr6CA1Pqqu3G8vJ9+tSESdaRiyeVnMC7mpBJCM= X-Forefront-PRVS: 096029FF66 X-Forefront-Antispam-Report: SFV:NSPM;SFS:(10019020)(4630300001)(979002)(6009001)(189998001)(107886002)(5008740100001)(229853001)(19580395003)(8676002)(15975445007)(77096005)(33646002)(53416004)(5001770100001)(42186005)(5003940100001)(81166006)(586003)(50466002)(48376002)(6116002)(86362001)(66066001)(36756003)(47776003)(4001430100002)(50986999)(50226002)(92566002)(3846002)(4326007)(5004730100002)(2906002)(969003)(989001)(999001)(1009001)(1019001);DIR:OUT;SFP:1102;SCL:1;SRVR:DB6PR0801MB1286;H:dsafonov.sw.ru;FPR:;SPF:None;MLV:ovrnspm;PTR:InfoNoRecords;LANG:en; X-Microsoft-Exchange-Diagnostics: =?us-ascii?Q?1;DB6PR0801MB1286;23:qY8jj6+hy4ZqWK559XqlEI36LM551BC5iNsgYqr?= =?us-ascii?Q?KSOMlg7kA/V/G0X19xB+RZLM+MoERD7GIuXObHmn3Qb1dlwebjUs+EeIj9dZ?= =?us-ascii?Q?kY/HrBCglsMqBXqfkOcK1UhhqSi/MoqhkonlQ0ZVkRR8gybDxIVLbkprn4Fb?= =?us-ascii?Q?WuxhXFBMwdMrSYCYyhj3u91x/Kru5m/SnOkWuOpkTkTzPjQGHxL+HyamR0VH?= =?us-ascii?Q?owgFwg1nG1NJgdfBou4sA9pHlaL1MLpp8yirS09PR8nJrVfSQoNlpKhu5E2b?= =?us-ascii?Q?qDT3aW07K0Ow1fLgePGDIbdYUW+mv6jTCh1mqSOEU5rXDzANh1H5vKKOUX7W?= =?us-ascii?Q?+JzCYaV7Jh4Uo2TS1nAt1Q4Da2yxPGIDR99OBMsXdpDhhOfjWNSKhX917NIL?= =?us-ascii?Q?zg+N8finp5eV4PsTP2pOtwQGaqKu4HJdvAqKqQXvDgfMXhYneY1G5w0m3Y//?= =?us-ascii?Q?ZuEn4385e8KmKmVJsL3ii0sRst8bbK28dVDbUeLrHEdcV19OfzUxXMOH0s32?= =?us-ascii?Q?Jyjbx4lsll1VSIVgKzqk+kph7QpH3ioiRwm9kBt3ut7tjgQNroeKU0n2T1DT?= =?us-ascii?Q?HZv8pQj9hJS1XxmjATPNBNdMB1l3utvls9/4Du6moyD0u+fwJByI8NUjHL0+?= =?us-ascii?Q?NLUrFvALNbNZ8C6ZWNJFgnv6zrbD4IGh6+aesSy+rf02has1ppedhV92ewIG?= =?us-ascii?Q?SerFwt/3rrTuMxpJO11QePgSOoi1Sj5ZKlOqGCYCK4kPQt6r+GlpkI87WHrN?= =?us-ascii?Q?Micb+iN0B8aoCkr5eNUMHTRkdQHiJJLjg4b1iaLuhay/S0UUkuvIvVGjdMSE?= =?us-ascii?Q?3Bb+rUPG3H1TE/jvojzHk0n8WDmi/ykK72Ik/WGorW+oYVlWY0tIsPx6u5Ts?= =?us-ascii?Q?qr7vQbfq3OG3IdP6ryZ+LjJTykJempnqsjgAP9YoTAuoQJn4/n0QL6cwumLL?= =?us-ascii?Q?gerT4qqBizNejOZ1B6oWjJpLmsrvkXV3JWdINBeWKCRZ8dvFIrBWle8BIp7Y?= =?us-ascii?Q?mYwNmarzbQveQe367ma502zyx?= X-Microsoft-Exchange-Diagnostics: 1;DB6PR0801MB1286;5:z6Kc7cQfyWGmgMw/vPEl3kfH2IswgepACPl9ncEw5N2u6vXOZ5E7qZJIz49QJVeKX6harpsSBRrpkdFGZJYeR1miOWxGms4S/Nm/IqIyY5hwOGpL942XJYxFHBjnCt2HueiLM6TcYDhdtMNkTbp0YQ==;24:vL0JLaqELmroMYvk0UXatnfMIxi6nQxWeoQ2FNWZEaJKagiWoAiUAw3CfwvGsRfrw7rn+zRUoofkPdIFZy1kwxHrds/+9Y/xJukRRCskgDk=;7:YlKUoMlskJL51dNzJ0RTFi+KciTFrBvCV3Li60zQIeIL2ROHYe4KHkE4UKBzPwjQoJNxUC6DvEZNIklDcUqjOQiJm1PLpoT/l7h2NNFbJHyWTO8Nh23RM793UlafbPWST9hpQWnWNZWon3IcjkDOvZUyy7wRt5WJpXqi5Y2B7+YEYMNB2LoB7uscuWoYn7gT;20:lQwlBmoa8AmDGhFC1njTmT7s6OB7hEMQmpgb5Azggd3VqcD12Kqj3QezhkOaZ/QhW+bdj4qbhxKbQzV57wIkfaEn2HeOOHsw8pXMl6DBH1WJ0ZLeJpINDv82XjMiFODp2JlzNL8ALl/EyCTHcDcZqg7uUdqtA2zPTGt/g9TWvBE= SpamDiagnosticOutput: 1:23 SpamDiagnosticMetadata: NSPM X-OriginatorOrg: virtuozzo.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 01 Jun 2016 13:13:04.4674 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-Transport-CrossTenantHeadersStamped: DB6PR0801MB1286 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patches set is an attempt to add checkpoint/restore for 32-bit tasks in compatibility mode on x86_64 hosts. Restore in CRIU starts from one root restoring process, which reads info for all threads being restored from images files. This information is used further to to find out which processes share some resources. Later shared resources are restored only by one process and all other inherit them. After that it calls clone() and new threads restore their properties in parallel. Those threads inherit all parent's mappings and fetch properties from those mappings (and do clone themself, if they have children/subthreads). [1] Then starts restorer blob's play, it's PIE binary, which unmaps all unneeded for restoring VMAs, maps new VMAs and finalize restoring with sigreturn syscall. [2] To restore of 32-bit task we need three things to do in running x86_64 restorer blob: a) set code selector to __USER32_CS (to run 32-bit code); b) remap vdso blob from 64-bit to 32-bit This is primary needed because restore may happen on a different kernel, which has different vDSO image than we had on dump. c) if 32-bit vDSO differ to dumped image, move it on free place and add jump trampolines to that place. d) switch TIF_IA32 flag, so kernel would know that it deals with compatible 32-bit application. >>From all this: a) setting CS may be done from userspace, no patches needed; b) patches 1-3 add ability to map different vDSO blobs on x86 kernel; c) for remapping/moving 32-bit vDSO blob patches have been send earlier and seems to be accepted [3] d) and for swapping TIF_IA32 flag discussion with Andy ended in conclusion that it's better to remove this flag completely. Patches 4-6 deletes usage of TIF_IA32 from ptrace, signal and coredump code. This is rework/resend of RFC [4] [1] https://criu.org/Checkpoint/Restore#Restore [2] https://criu.org/Restorer_context [3] https://lkml.org/lkml/2016/5/17/243 [4] https://lkml.org/lkml/2016/4/25/650 Dmitry Safonov (6): x86/vdso: unmap vdso blob on vvar mapping failure x86/vdso: introduce do_map_vdso() and vdso_type enum x86/arch_prctl/vdso: add ARCH_MAP_VDSO_* x86/coredump: use core regs, rather that TIF_IA32 flag x86/ptrace: down with test_thread_flag(TIF_IA32) x86/signal: add SA_{X32,IA32}_ABI sa_flags arch/x86/entry/vdso/vma.c | 72 +++++++++++++++++++++----------------- arch/x86/ia32/ia32_signal.c | 2 +- arch/x86/include/asm/compat.h | 8 ++--- arch/x86/include/asm/fpu/signal.h | 6 ++++ arch/x86/include/asm/vdso.h | 4 +++ arch/x86/include/uapi/asm/prctl.h | 6 ++++ arch/x86/include/uapi/asm/signal.h | 6 +++- arch/x86/kernel/process_64.c | 10 ++++++ arch/x86/kernel/ptrace.c | 2 +- arch/x86/kernel/signal.c | 19 +++++----- arch/x86/kernel/signal_compat.c | 30 ++++++++++++++-- fs/binfmt_elf.c | 18 +++++----- kernel/signal.c | 5 +++ 13 files changed, 129 insertions(+), 59 deletions(-) -- 2.8.2