Received: by 10.192.165.148 with SMTP id m20csp359992imm; Fri, 20 Apr 2018 07:57:32 -0700 (PDT) X-Google-Smtp-Source: AIpwx488SfPxIAOPS1ZTcsNStni15YmE0dbKfXEd2FF7bN7piXIGkEMj49JIR0cB36WV70OhTTAa X-Received: by 10.98.47.2 with SMTP id v2mr6349072pfv.239.1524236252304; Fri, 20 Apr 2018 07:57:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1524236252; cv=none; d=google.com; s=arc-20160816; b=s2lyaq8tYZ0Hg5hxOQgp2IJ03B5+rMVlS2TuX7BOYKDfO6AHuA3L4zOckwUnaRU2bs 3ZaSP0egPKMNGr7oyQBzaObQ091LVjtJdCPB3tzWslBvOHRVRzFxCWSCyNdwjxUlek0W c9FjEyxbfYS0v/VuySO0kbNLFsVicPJsgkwKxJCTztPrzscvjXC6fZeA5+TZZDzxXfSp el8gfPEIrqOfI3PelMu2qOKSCuXcRjc777QwfGicHIYzp+xCyCZCvaBEvFrmthWex9ev T+oQ68RR8rmKCoEN8/6i7qMsrptWlHQnhdA3bIor5f819hmrTnGi6q+5meqd3RelfvJH Y5kg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:arc-authentication-results; bh=BPzKo00mTz2RD6O3Epl0c8YKvgWLD7Z+7M/1BdfBiVA=; b=zO5vXNJottTnVEdeUshODw9iD/Mrm5cz2hxZue9RWX2NeY6fsDDjj2PDiFjgRai4Iv 4vUbtxuUYYjQuzi0LIlBqZI3dDBW5/9DgUgpojSAeX88Egy1KFp3L8hzGerNPOhY8JTm QJ8B3qtqI49G3bhJ0OEqaPK27wLc5ECPcMb2uw8qJ6ZVddfJm3cDhU/0dbv/K1sqLQWr /FtDp4qjRIhgXXfIuHE+fcNgoCrkYRLF9AMJPUZpI37z74jR2Jz8rooUJ9Jetj9yAvwb 8WWnRe4OFKiBz7vFvlhs6WZh4Df257M55RZWe79cFWOqhjpy8VHG7ZiQO+mDKUm9UtKy cnpg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id v1si5624317pfg.222.2018.04.20.07.57.17; Fri, 20 Apr 2018 07:57:32 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755552AbeDTOzr (ORCPT + 99 others); Fri, 20 Apr 2018 10:55:47 -0400 Received: from 216-12-86-13.cv.mvl.ntelos.net ([216.12.86.13]:46112 "EHLO brightrain.aerifal.cx" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755529AbeDTOzp (ORCPT ); Fri, 20 Apr 2018 10:55:45 -0400 Received: from dalias by brightrain.aerifal.cx with local (Exim 3.15 #2) id 1f9XRS-0000jG-00; Fri, 20 Apr 2018 14:55:14 +0000 Date: Fri, 20 Apr 2018 10:55:14 -0400 From: Rich Felker To: "Eric W. Biederman" Cc: linux-arch@vger.kernel.org, linux-kernel@vger.kernel.org, Yoshinori Sato , linux-sh@vger.kernel.org Subject: Re: [REVIEW][PATCH 16/22] signal/sh: Use force_sig_fault where appropriate Message-ID: <20180420145514.GP3094@brightrain.aerifal.cx> References: <87604mhrnb.fsf@xmission.com> <20180420143811.9994-16-ebiederm@xmission.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20180420143811.9994-16-ebiederm@xmission.com> User-Agent: Mutt/1.5.21 (2010-09-15) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Apr 20, 2018 at 09:38:05AM -0500, Eric W. Biederman wrote: > Filling in struct siginfo before calling force_sig_info a tedious and > error prone process, where once in a great while the wrong fields > are filled out, and siginfo has been inconsistently cleared. > > Simplify this process by using the helper force_sig_fault. Which > takes as a parameters all of the information it needs, ensures > all of the fiddly bits of filling in struct siginfo are done properly > and then calls force_sig_info. > > In short about a 5 line reduction in code for every time force_sig_info > is called, which makes the calling function clearer. > > Cc: Yoshinori Sato > Cc: Rich Felker > Cc: linux-sh@vger.kernel.org > Signed-off-by: "Eric W. Biederman" > --- > arch/sh/kernel/traps_32.c | 19 +++++-------------- > arch/sh/math-emu/math.c | 9 ++------- > arch/sh/mm/fault.c | 10 +--------- > 3 files changed, 8 insertions(+), 30 deletions(-) > > diff --git a/arch/sh/kernel/traps_32.c b/arch/sh/kernel/traps_32.c > index e85e59c3d6df..660a4bc17698 100644 > --- a/arch/sh/kernel/traps_32.c > +++ b/arch/sh/kernel/traps_32.c > @@ -477,7 +477,6 @@ asmlinkage void do_address_error(struct pt_regs *regs, > { > unsigned long error_code = 0; > mm_segment_t oldfs; > - siginfo_t info; > insn_size_t instruction; > int tmp; > > @@ -537,12 +536,7 @@ asmlinkage void do_address_error(struct pt_regs *regs, > "access (PC %lx PR %lx)\n", current->comm, regs->pc, > regs->pr); > > - clear_siginfo(&info); > - info.si_signo = SIGBUS; > - info.si_errno = 0; > - info.si_code = si_code; > - info.si_addr = (void __user *)address; > - force_sig_info(SIGBUS, &info, current); > + force_sig_fault(SIGBUS, si_code, (void __user *)address, current); > } else { > inc_unaligned_kernel_access(); > > @@ -599,20 +593,17 @@ int is_dsp_inst(struct pt_regs *regs) > #ifdef CONFIG_CPU_SH2A > asmlinkage void do_divide_error(unsigned long r4) > { > - siginfo_t info; > + int code; > > - clear_siginfo(&info); > switch (r4) { > case TRAP_DIVZERO_ERROR: > - info.si_code = FPE_INTDIV; > + code = FPE_INTDIV; > break; > case TRAP_DIVOVF_ERROR: > - info.si_code = FPE_INTOVF; > + code = FPE_INTOVF; > break; > } > - > - info.si_signo = SIGFPE; > - force_sig_info(info.si_signo, &info, current); > + force_sig_fault(SIGFPE, code, NULL, current); > } > #endif > > diff --git a/arch/sh/math-emu/math.c b/arch/sh/math-emu/math.c > index d6d2213df078..a0fa8fc88739 100644 > --- a/arch/sh/math-emu/math.c > +++ b/arch/sh/math-emu/math.c > @@ -507,7 +507,6 @@ static int ieee_fpe_handler(struct pt_regs *regs) > unsigned short insn = *(unsigned short *)regs->pc; > unsigned short finsn; > unsigned long nextpc; > - siginfo_t info; > int nib[4] = { > (insn >> 12) & 0xf, > (insn >> 8) & 0xf, > @@ -560,12 +559,8 @@ static int ieee_fpe_handler(struct pt_regs *regs) > ~(FPSCR_CAUSE_MASK | FPSCR_FLAG_MASK); > task_thread_info(tsk)->status |= TS_USEDFPU; > } else { > - clear_siginfo(&info); > - info.si_signo = SIGFPE; > - info.si_errno = 0; > - info.si_code = FPE_FLTINV; > - info.si_addr = (void __user *)regs->pc; > - force_sig_info(SIGFPE, &info, tsk); > + force_sig_fault(SIGFPE, FPE_FLTINV, > + (void __user *)regs->pc, tsk); > } > > regs->pc = nextpc; > diff --git a/arch/sh/mm/fault.c b/arch/sh/mm/fault.c > index 4c98b6f20e02..b8e7bb84b6b1 100644 > --- a/arch/sh/mm/fault.c > +++ b/arch/sh/mm/fault.c > @@ -42,15 +42,7 @@ static void > force_sig_info_fault(int si_signo, int si_code, unsigned long address, > struct task_struct *tsk) > { > - siginfo_t info; > - > - clear_siginfo(&info); > - info.si_signo = si_signo; > - info.si_errno = 0; > - info.si_code = si_code; > - info.si_addr = (void __user *)address; > - > - force_sig_info(si_signo, &info, tsk); > + force_sig_fault(si_signo, si_code, (void __user *)address, tsk); > } > > /* > -- > 2.14.1 Acked-by: Rich Felker