aboutsummaryrefslogtreecommitdiffstats
path: root/arch/parisc/kernel/signal.c
diff options
context:
space:
mode:
Diffstat (limited to 'arch/parisc/kernel/signal.c')
-rw-r--r--arch/parisc/kernel/signal.c16
1 files changed, 8 insertions, 8 deletions
diff --git a/arch/parisc/kernel/signal.c b/arch/parisc/kernel/signal.c
index 594459bde14e..3790a3237172 100644
--- a/arch/parisc/kernel/signal.c
+++ b/arch/parisc/kernel/signal.c
@@ -113,6 +113,8 @@ sys_rt_sigreturn(struct pt_regs *regs, int in_syscall)
113 (usp - sigframe_size); 113 (usp - sigframe_size);
114 DBG(2,"sys_rt_sigreturn: frame is %p\n", frame); 114 DBG(2,"sys_rt_sigreturn: frame is %p\n", frame);
115 115
116 regs->orig_r28 = 1; /* no restarts for sigreturn */
117
116#ifdef CONFIG_64BIT 118#ifdef CONFIG_64BIT
117 compat_frame = (struct compat_rt_sigframe __user *)frame; 119 compat_frame = (struct compat_rt_sigframe __user *)frame;
118 120
@@ -462,6 +464,9 @@ handle_signal(unsigned long sig, siginfo_t *info, struct k_sigaction *ka,
462static inline void 464static inline void
463syscall_restart(struct pt_regs *regs, struct k_sigaction *ka) 465syscall_restart(struct pt_regs *regs, struct k_sigaction *ka)
464{ 466{
467 if (regs->orig_r28)
468 return;
469 regs->orig_r28 = 1; /* no more restarts */
465 /* Check the return code */ 470 /* Check the return code */
466 switch (regs->gr[28]) { 471 switch (regs->gr[28]) {
467 case -ERESTART_RESTARTBLOCK: 472 case -ERESTART_RESTARTBLOCK:
@@ -482,8 +487,6 @@ syscall_restart(struct pt_regs *regs, struct k_sigaction *ka)
482 * we have to do is fiddle the return pointer. 487 * we have to do is fiddle the return pointer.
483 */ 488 */
484 regs->gr[31] -= 8; /* delayed branching */ 489 regs->gr[31] -= 8; /* delayed branching */
485 /* Preserve original r28. */
486 regs->gr[28] = regs->orig_r28;
487 break; 490 break;
488 } 491 }
489} 492}
@@ -491,6 +494,9 @@ syscall_restart(struct pt_regs *regs, struct k_sigaction *ka)
491static inline void 494static inline void
492insert_restart_trampoline(struct pt_regs *regs) 495insert_restart_trampoline(struct pt_regs *regs)
493{ 496{
497 if (regs->orig_r28)
498 return;
499 regs->orig_r28 = 1; /* no more restarts */
494 switch(regs->gr[28]) { 500 switch(regs->gr[28]) {
495 case -ERESTART_RESTARTBLOCK: { 501 case -ERESTART_RESTARTBLOCK: {
496 /* Restart the system call - no handlers present */ 502 /* Restart the system call - no handlers present */
@@ -525,9 +531,6 @@ insert_restart_trampoline(struct pt_regs *regs)
525 flush_user_icache_range(regs->gr[30], regs->gr[30] + 4); 531 flush_user_icache_range(regs->gr[30], regs->gr[30] + 4);
526 532
527 regs->gr[31] = regs->gr[30] + 8; 533 regs->gr[31] = regs->gr[30] + 8;
528 /* Preserve original r28. */
529 regs->gr[28] = regs->orig_r28;
530
531 return; 534 return;
532 } 535 }
533 case -ERESTARTNOHAND: 536 case -ERESTARTNOHAND:
@@ -539,9 +542,6 @@ insert_restart_trampoline(struct pt_regs *regs)
539 * slot of the branch external instruction. 542 * slot of the branch external instruction.
540 */ 543 */
541 regs->gr[31] -= 8; 544 regs->gr[31] -= 8;
542 /* Preserve original r28. */
543 regs->gr[28] = regs->orig_r28;
544
545 return; 545 return;
546 } 546 }
547 default: 547 default: