From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932517AbbFITLz (ORCPT ); Tue, 9 Jun 2015 15:11:55 -0400 Received: from mail-la0-f51.google.com ([209.85.215.51]:33285 "EHLO mail-la0-f51.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752131AbbFITLr (ORCPT ); Tue, 9 Jun 2015 15:11:47 -0400 MIME-Version: 1.0 In-Reply-To: <5577389F.4090301@redhat.com> References: <1433876051-26604-1-git-send-email-dvlasenk@redhat.com> <1433876051-26604-4-git-send-email-dvlasenk@redhat.com> <5577389F.4090301@redhat.com> From: Andy Lutomirski Date: Tue, 9 Jun 2015 12:11:25 -0700 Message-ID: Subject: Re: [PATCH 4/5] x86/asm/entry/32: Replace RESTORE_RSI_RDI[_RDX] with open-coded 32-bit reads To: Denys Vlasenko Cc: Ingo Molnar , Linus Torvalds , Steven Rostedt , Borislav Petkov , "H. Peter Anvin" , Oleg Nesterov , Frederic Weisbecker , Alexei Starovoitov , Will Drewry , Kees Cook , X86 ML , "linux-kernel@vger.kernel.org" Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Jun 9, 2015 at 12:03 PM, Denys Vlasenko wrote: > On 06/09/2015 09:01 PM, Andy Lutomirski wrote: >> On Tue, Jun 9, 2015 at 11:54 AM, Denys Vlasenko wrote: >>> This doesn't change much, but this uses shorter 32-bit insns: >>> >>> -48 8b 74 24 68 mov 0x68(%rsp),%rsi >>> -48 8b 7c 24 70 mov 0x70(%rsp),%rdi >>> -48 8b 54 24 60 mov 0x60(%rsp),%rdx >>> +8b 74 24 68 mov 0x68(%rsp),%esi >>> +8b 7c 24 70 mov 0x70(%rsp),%edi >>> +8b 54 24 60 mov 0x60(%rsp),%edx >>> >>> Since these are the only uses of RESTORE_RSI_RDI[_RDX], drop these macros. >>> >> >> It probably doesn't matter for these fast paths, but, for the full >> slow path return, we really do need to restore the full pt_regs. >> After all, the syscall we're returning from might be sigreturn. > > This is compat 32-bit syscall handling code. > IIUC we do not restore high half of any registers for 32-bit tasks. > > Am I missing something? Yes -- 64-bit tasks can call 32-bit compat syscalls. In fact, we should really excise the entire concept of "64-bit tasks" and "32-bit tasks" from the kernel. The things that have bitness are the current syscall (TS_COMPAT), CS, the mm, and the signal context. The task should be agnostic. --Andy