All of lore.kernel.org
 help / color / mirror / Atom feed
From: Lennox Wu <lennox.wu@gmail.com>
To: Richard Weinberger <richard@sigma-star.at>
Cc: open list <linux-kernel@vger.kernel.org>,
	linux-arch <linux-arch@vger.kernel.org>,
	Liqin Chen <liqin.linux@gmail.com>
Subject: Re: [PATCH 18/43] score: Use get_signal() signal_setup_done()
Date: Sat, 02 Aug 2014 14:41:38 +0800	[thread overview]
Message-ID: <53DC8822.9030901@gmail.com> (raw)
In-Reply-To: <CAF0htA4XuN035oYR5-13bzLnpHB1kUbe+igVstJ5QZXULbz58A@mail.gmail.com>

It was merged into Score's git tree, and it will show in the next PULL 
request.

Best,
Lennox

Lennox Wu 於 2014/7/21 下午 10:47 寫道:
> I am picking up some missed patches and merging them into our git
> tree. If the patch is missed, we will merge it.
>
> Best,
> Lennox
>
> 2014-07-21 22:03 GMT+08:00 Richard Weinberger <richard@sigma-star.at>:
>> From: Richard Weinberger <richard@nod.at>
>>
>> Use the more generic functions get_signal() signal_setup_done()
>> for signal delivery.
>>
>> Acked-by: Lennox Wu <lennox.wu@gmail.com>
>> Signed-off-by: Richard Weinberger <richard@nod.at>
>> ---
>>   arch/score/kernel/signal.c | 43 ++++++++++++++++++-------------------------
>>   1 file changed, 18 insertions(+), 25 deletions(-)
>>
>> diff --git a/arch/score/kernel/signal.c b/arch/score/kernel/signal.c
>> index a00fba3..1651807 100644
>> --- a/arch/score/kernel/signal.c
>> +++ b/arch/score/kernel/signal.c
>> @@ -173,15 +173,15 @@ badframe:
>>          return 0;
>>   }
>>
>> -static int setup_rt_frame(struct k_sigaction *ka, struct pt_regs *regs,
>> -               int signr, sigset_t *set, siginfo_t *info)
>> +static int setup_rt_frame(struct ksignal *ksig, struct pt_regs *regs,
>> +                         sigset_t *set)
>>   {
>>          struct rt_sigframe __user *frame;
>>          int err = 0;
>>
>> -       frame = get_sigframe(ka, regs, sizeof(*frame));
>> +       frame = get_sigframe(&ksig->ka, regs, sizeof(*frame));
>>          if (!access_ok(VERIFY_WRITE, frame, sizeof(*frame)))
>> -               goto give_sigsegv;
>> +               return -EFAULT;
>>
>>          /*
>>           * Set up the return code ...
>> @@ -194,7 +194,7 @@ static int setup_rt_frame(struct k_sigaction *ka, struct pt_regs *regs,
>>          err |= __put_user(0x80008002, frame->rs_code + 1);
>>          flush_cache_sigtramp((unsigned long) frame->rs_code);
>>
>> -       err |= copy_siginfo_to_user(&frame->rs_info, info);
>> +       err |= copy_siginfo_to_user(&frame->rs_info, &ksig->info);
>>          err |= __put_user(0, &frame->rs_uc.uc_flags);
>>          err |= __put_user(NULL, &frame->rs_uc.uc_link);
>>          err |= __save_altstack(&frame->rs_uc.uc_stack, regs->regs[0]);
>> @@ -202,26 +202,23 @@ static int setup_rt_frame(struct k_sigaction *ka, struct pt_regs *regs,
>>          err |= __copy_to_user(&frame->rs_uc.uc_sigmask, set, sizeof(*set));
>>
>>          if (err)
>> -               goto give_sigsegv;
>> +               return -EFAULT;
>>
>>          regs->regs[0] = (unsigned long) frame;
>>          regs->regs[3] = (unsigned long) frame->rs_code;
>> -       regs->regs[4] = signr;
>> +       regs->regs[4] = ksig->sig;
>>          regs->regs[5] = (unsigned long) &frame->rs_info;
>>          regs->regs[6] = (unsigned long) &frame->rs_uc;
>> -       regs->regs[29] = (unsigned long) ka->sa.sa_handler;
>> -       regs->cp0_epc = (unsigned long) ka->sa.sa_handler;
>> +       regs->regs[29] = (unsigned long) ksig->ka.sa.sa_handler;
>> +       regs->cp0_epc = (unsigned long) ksig->ka.sa.sa_handler;
>>
>>          return 0;
>> -
>> -give_sigsegv:
>> -       force_sigsegv(signr, current);
>> -       return -EFAULT;
>>   }
>>
>> -static void handle_signal(unsigned long sig, siginfo_t *info,
>> -       struct k_sigaction *ka, struct pt_regs *regs)
>> +static void handle_signal(struct ksignal *ksig, struct pt_regs *regs)
>>   {
>> +       int ret;
>> +
>>          if (regs->is_syscall) {
>>                  switch (regs->regs[4]) {
>>                  case ERESTART_RESTARTBLOCK:
>> @@ -229,7 +226,7 @@ static void handle_signal(unsigned long sig, siginfo_t *info,
>>                          regs->regs[4] = EINTR;
>>                          break;
>>                  case ERESTARTSYS:
>> -                       if (!(ka->sa.sa_flags & SA_RESTART)) {
>> +                       if (!(ksig->ka.sa.sa_flags & SA_RESTART)) {
>>                                  regs->regs[4] = EINTR;
>>                                  break;
>>                          }
>> @@ -245,17 +242,14 @@ static void handle_signal(unsigned long sig, siginfo_t *info,
>>          /*
>>           * Set up the stack frame
>>           */
>> -       if (setup_rt_frame(ka, regs, sig, sigmask_to_save(), info) < 0)
>> -               return;
>> +       ret = setup_rt_frame(ksig, regs, sigmask_to_save());
>>
>> -       signal_delivered(sig, info, ka, regs, 0);
>> +       signal_setup_done(ret, ksig, 0);
>>   }
>>
>>   static void do_signal(struct pt_regs *regs)
>>   {
>> -       struct k_sigaction ka;
>> -       siginfo_t info;
>> -       int signr;
>> +       struct ksignal ksig;
>>
>>          /*
>>           * We want the common case to go fast, which is why we may in certain
>> @@ -265,10 +259,9 @@ static void do_signal(struct pt_regs *regs)
>>          if (!user_mode(regs))
>>                  return;
>>
>> -       signr = get_signal_to_deliver(&info, &ka, regs, NULL);
>> -       if (signr > 0) {
>> +       if (get_signal(&ksig)) {
>>                  /* Actually deliver the signal.  */
>> -               handle_signal(signr, &info, &ka, regs);
>> +               handle_signal(&ksig, regs);
>>                  return;
>>          }
>>
>> --
>> 1.8.4.5
>>

  reply	other threads:[~2014-08-02  6:41 UTC|newest]

Thread overview: 68+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2014-07-21 14:02 Global signal cleanup, take 4 Richard Weinberger
2014-07-21 14:02 ` [PATCH 01/43] arc: Use get_signal() signal_setup_done() Richard Weinberger
2014-07-21 14:21   ` Vineet Gupta
2014-07-21 14:02 ` [PATCH 02/43] arm64: " Richard Weinberger
2014-07-21 14:02   ` Richard Weinberger
2014-07-21 14:02   ` Richard Weinberger
2014-07-21 14:02 ` [PATCH 03/43] avr32: " Richard Weinberger
2014-07-21 14:02 ` [PATCH 04/43] blackfin: " Richard Weinberger
2014-07-24  6:55   ` Steven Miao
2014-07-21 14:02 ` [PATCH 05/43] c6x: " Richard Weinberger
2014-07-21 14:02 ` [PATCH 06/43] cris: " Richard Weinberger
2014-08-11  5:35   ` Mikael Starvik
2014-07-21 14:02 ` [PATCH 07/43] frv: " Richard Weinberger
2014-07-21 14:02 ` [PATCH 08/43] hexagon: " Richard Weinberger
2014-07-21 14:02 ` [PATCH 09/43] ia64: " Richard Weinberger
2014-07-21 14:02   ` Richard Weinberger
2014-07-21 14:02 ` [PATCH 10/43] m32r: " Richard Weinberger
2014-07-21 14:02 ` [PATCH 11/43] m68k: " Richard Weinberger
2014-07-21 14:02 ` Richard Weinberger
2014-07-21 14:02   ` Richard Weinberger
2014-07-21 14:02 ` [PATCH 12/43] microblaze: " Richard Weinberger
2014-07-21 14:02 ` [PATCH 13/43] mips: " Richard Weinberger
2014-07-21 14:03 ` [PATCH 14/43] mn10300: " Richard Weinberger
2014-07-21 14:03 ` [PATCH 15/43] parisc: " Richard Weinberger
2014-07-21 14:03 ` [PATCH 16/43] powerpc: " Richard Weinberger
2014-07-21 14:03   ` Richard Weinberger
2014-07-21 14:03 ` [PATCH 17/43] s390: " Richard Weinberger
2014-07-21 14:03 ` [PATCH 18/43] score: " Richard Weinberger
2014-07-21 14:47   ` Lennox Wu
2014-08-02  6:41     ` Lennox Wu [this message]
2014-07-21 14:03 ` [PATCH 19/43] sh: " Richard Weinberger
2014-07-21 14:03   ` Richard Weinberger
2014-07-21 14:03 ` [PATCH 20/43] tile: " Richard Weinberger
2014-07-31 20:35   ` Chris Metcalf
2014-07-31 20:35     ` Chris Metcalf
2014-07-21 14:03 ` [PATCH 21/43] um: " Richard Weinberger
2014-07-21 14:03 ` [PATCH 22/43] unicore32: " Richard Weinberger
2014-07-21 14:03 ` [PATCH 23/43] xtensa: " Richard Weinberger
2014-07-21 14:03 ` [PATCH 24/43] tracehook_signal_handler: Remove sig, info, ka and regs Richard Weinberger
2014-07-21 14:03 ` [PATCH 25/43] Clean up signal_delivered() Richard Weinberger
2014-07-21 14:03 ` [PATCH 26/43] Rip out get_signal_to_deliver() Richard Weinberger
2014-07-21 14:03 ` [PATCH 27/43] sas_ss_flags: Remove nested ternary if Richard Weinberger
2014-07-21 14:03 ` [PATCH 28/43] arc: Use sigsp() Richard Weinberger
2014-07-21 14:22   ` Vineet Gupta
2014-07-21 14:03 ` [PATCH 29/43] arm64: " Richard Weinberger
2014-07-21 14:03   ` Richard Weinberger
2014-07-21 14:03   ` Richard Weinberger
2014-07-21 14:03 ` [PATCH 30/43] avr32: " Richard Weinberger
2014-07-21 14:03 ` [PATCH 31/43] blackfin: " Richard Weinberger
2014-07-24  6:55   ` Steven Miao
2014-07-21 14:03 ` [PATCH 32/43] c6x: " Richard Weinberger
2014-07-21 14:03 ` [PATCH 33/43] cris: " Richard Weinberger
2014-07-21 14:03 ` [PATCH 34/43] frv: " Richard Weinberger
2014-07-21 14:03 ` [PATCH 35/43] hexagon: " Richard Weinberger
2014-07-21 14:03 ` [PATCH 36/43] m32r: " Richard Weinberger
2014-07-21 14:03 ` [PATCH 37/43] m68k: " Richard Weinberger
2014-07-21 14:03   ` Richard Weinberger
2014-07-21 14:03 ` [PATCH 38/43] metag: " Richard Weinberger
2014-07-21 14:03 ` [PATCH 39/43] microblaze: " Richard Weinberger
2014-07-21 14:03 ` [PATCH 40/43] mips: " Richard Weinberger
2014-07-21 14:03 ` [PATCH 41/43] mn10300: " Richard Weinberger
2014-07-21 14:03 ` [PATCH 42/43] openrisc: " Richard Weinberger
2014-07-21 14:03   ` Richard Weinberger
2014-07-21 14:03 ` [PATCH 43/43] powerpc: " Richard Weinberger
2014-07-21 14:03   ` Richard Weinberger
2014-07-22  4:47 ` Global signal cleanup, take 4 Stephen Rothwell
2014-07-22  6:52   ` Richard Weinberger
2014-07-22 22:50     ` Stephen Rothwell

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=53DC8822.9030901@gmail.com \
    --to=lennox.wu@gmail.com \
    --cc=linux-arch@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=liqin.linux@gmail.com \
    --cc=richard@sigma-star.at \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.