Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
58124996
Commit
58124996
authored
Mar 21, 2006
by
Tony Luck
Browse files
Options
Browse Files
Download
Plain Diff
Pull delete-sigdelayed into release branch
parents
6a8a8e14
b0a06623
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
1 addition
and
127 deletions
+1
-127
arch/ia64/kernel/entry.S
arch/ia64/kernel/entry.S
+0
-14
arch/ia64/kernel/signal.c
arch/ia64/kernel/signal.c
+0
-101
include/asm-ia64/signal.h
include/asm-ia64/signal.h
+0
-2
include/asm-ia64/thread_info.h
include/asm-ia64/thread_info.h
+1
-10
No files found.
arch/ia64/kernel/entry.S
View file @
58124996
...
@@ -1102,9 +1102,6 @@ skip_rbs_switch:
...
@@ -1102,9 +1102,6 @@ skip_rbs_switch:
st8
[
r2
]=
r8
st8
[
r2
]=
r8
st8
[
r3
]=
r10
st8
[
r3
]=
r10
.
work_pending
:
.
work_pending
:
tbit.nz
p6
,
p0
=
r31
,
TIF_SIGDELAYED
//
signal
delayed
from
MCA
/
INIT
/
NMI
/
PMI
context
?
(
p6
)
br.cond.sptk.few
.
sigdelayed
;;
tbit.z
p6
,
p0
=
r31
,
TIF_NEED_RESCHED
//
current_thread_info
()->
need_resched
==
0
?
tbit.z
p6
,
p0
=
r31
,
TIF_NEED_RESCHED
//
current_thread_info
()->
need_resched
==
0
?
(
p6
)
br.cond.sptk.few
.
notify
(
p6
)
br.cond.sptk.few
.
notify
#ifdef CONFIG_PREEMPT
#ifdef CONFIG_PREEMPT
...
@@ -1131,17 +1128,6 @@ skip_rbs_switch:
...
@@ -1131,17 +1128,6 @@ skip_rbs_switch:
(
pLvSys
)
br
.
cond
.
sptk
.
few
.
work_pending_syscall_end
(
pLvSys
)
br
.
cond
.
sptk
.
few
.
work_pending_syscall_end
br.cond.sptk.many
.
work_processed_kernel
//
don
't re-check
br.cond.sptk.many
.
work_processed_kernel
//
don
't re-check
//
There
is
a
delayed
signal
that
was
detected
in
MCA
/
INIT
/
NMI
/
PMI
context
where
//
it
could
not
be
delivered
.
Deliver
it
now
.
The
signal
might
be
for
us
and
//
may
set
TIF_SIGPENDING
,
so
redrive
ia64_leave_
*
after
processing
the
delayed
//
signal
.
.
sigdelayed
:
br.call.sptk.many
rp
=
do_sigdelayed
cmp.eq
p6
,
p0
=
r0
,
r0
//
p6
<-
1
,
always
re
-
check
(
pLvSys
)
br
.
cond
.
sptk
.
few
.
work_pending_syscall_end
br.cond.sptk.many
.
work_processed_kernel
//
re
-
check
.
work_pending_syscall_end
:
.
work_pending_syscall_end
:
adds
r2
=
PT
(
R8
)+
16
,
r12
adds
r2
=
PT
(
R8
)+
16
,
r12
adds
r3
=
PT
(
R10
)+
16
,
r12
adds
r3
=
PT
(
R10
)+
16
,
r12
...
...
arch/ia64/kernel/signal.c
View file @
58124996
...
@@ -588,104 +588,3 @@ ia64_do_signal (sigset_t *oldset, struct sigscratch *scr, long in_syscall)
...
@@ -588,104 +588,3 @@ ia64_do_signal (sigset_t *oldset, struct sigscratch *scr, long in_syscall)
}
}
return
0
;
return
0
;
}
}
/* Set a delayed signal that was detected in MCA/INIT/NMI/PMI context where it
* could not be delivered. It is important that the target process is not
* allowed to do any more work in user space. Possible cases for the target
* process:
*
* - It is sleeping and will wake up soon. Store the data in the current task,
* the signal will be sent when the current task returns from the next
* interrupt.
*
* - It is running in user context. Store the data in the current task, the
* signal will be sent when the current task returns from the next interrupt.
*
* - It is running in kernel context on this or another cpu and will return to
* user context. Store the data in the target task, the signal will be sent
* to itself when the target task returns to user space.
*
* - It is running in kernel context on this cpu and will sleep before
* returning to user context. Because this is also the current task, the
* signal will not get delivered and the task could sleep indefinitely.
* Store the data in the idle task for this cpu, the signal will be sent
* after the idle task processes its next interrupt.
*
* To cover all cases, store the data in the target task, the current task and
* the idle task on this cpu. Whatever happens, the signal will be delivered
* to the target task before it can do any useful user space work. Multiple
* deliveries have no unwanted side effects.
*
* Note: This code is executed in MCA/INIT/NMI/PMI context, with interrupts
* disabled. It must not take any locks nor use kernel structures or services
* that require locks.
*/
/* To ensure that we get the right pid, check its start time. To avoid extra
* include files in thread_info.h, convert the task start_time to unsigned long,
* giving us a cycle time of > 580 years.
*/
static
inline
unsigned
long
start_time_ul
(
const
struct
task_struct
*
t
)
{
return
t
->
start_time
.
tv_sec
*
NSEC_PER_SEC
+
t
->
start_time
.
tv_nsec
;
}
void
set_sigdelayed
(
pid_t
pid
,
int
signo
,
int
code
,
void
__user
*
addr
)
{
struct
task_struct
*
t
;
unsigned
long
start_time
=
0
;
int
i
;
for
(
i
=
1
;
i
<=
3
;
++
i
)
{
switch
(
i
)
{
case
1
:
t
=
find_task_by_pid
(
pid
);
if
(
t
)
start_time
=
start_time_ul
(
t
);
break
;
case
2
:
t
=
current
;
break
;
default:
t
=
idle_task
(
smp_processor_id
());
break
;
}
if
(
!
t
)
return
;
task_thread_info
(
t
)
->
sigdelayed
.
signo
=
signo
;
task_thread_info
(
t
)
->
sigdelayed
.
code
=
code
;
task_thread_info
(
t
)
->
sigdelayed
.
addr
=
addr
;
task_thread_info
(
t
)
->
sigdelayed
.
start_time
=
start_time
;
task_thread_info
(
t
)
->
sigdelayed
.
pid
=
pid
;
wmb
();
set_tsk_thread_flag
(
t
,
TIF_SIGDELAYED
);
}
}
/* Called from entry.S when it detects TIF_SIGDELAYED, a delayed signal that
* was detected in MCA/INIT/NMI/PMI context where it could not be delivered.
*/
void
do_sigdelayed
(
void
)
{
struct
siginfo
siginfo
;
pid_t
pid
;
struct
task_struct
*
t
;
clear_thread_flag
(
TIF_SIGDELAYED
);
memset
(
&
siginfo
,
0
,
sizeof
(
siginfo
));
siginfo
.
si_signo
=
current_thread_info
()
->
sigdelayed
.
signo
;
siginfo
.
si_code
=
current_thread_info
()
->
sigdelayed
.
code
;
siginfo
.
si_addr
=
current_thread_info
()
->
sigdelayed
.
addr
;
pid
=
current_thread_info
()
->
sigdelayed
.
pid
;
t
=
find_task_by_pid
(
pid
);
if
(
!
t
)
return
;
if
(
current_thread_info
()
->
sigdelayed
.
start_time
!=
start_time_ul
(
t
))
return
;
force_sig_info
(
siginfo
.
si_signo
,
&
siginfo
,
t
);
}
include/asm-ia64/signal.h
View file @
58124996
...
@@ -158,8 +158,6 @@ struct k_sigaction {
...
@@ -158,8 +158,6 @@ struct k_sigaction {
#define ptrace_signal_deliver(regs, cookie) do { } while (0)
#define ptrace_signal_deliver(regs, cookie) do { } while (0)
void
set_sigdelayed
(
pid_t
pid
,
int
signo
,
int
code
,
void
__user
*
addr
);
#endif
/* __KERNEL__ */
#endif
/* __KERNEL__ */
# endif
/* !__ASSEMBLY__ */
# endif
/* !__ASSEMBLY__ */
...
...
include/asm-ia64/thread_info.h
View file @
58124996
...
@@ -29,13 +29,6 @@ struct thread_info {
...
@@ -29,13 +29,6 @@ struct thread_info {
mm_segment_t
addr_limit
;
/* user-level address space limit */
mm_segment_t
addr_limit
;
/* user-level address space limit */
int
preempt_count
;
/* 0=premptable, <0=BUG; will also serve as bh-counter */
int
preempt_count
;
/* 0=premptable, <0=BUG; will also serve as bh-counter */
struct
restart_block
restart_block
;
struct
restart_block
restart_block
;
struct
{
int
signo
;
int
code
;
void
__user
*
addr
;
unsigned
long
start_time
;
pid_t
pid
;
}
sigdelayed
;
/* Saved information for TIF_SIGDELAYED */
};
};
#define THREAD_SIZE KERNEL_STACK_SIZE
#define THREAD_SIZE KERNEL_STACK_SIZE
...
@@ -89,7 +82,6 @@ struct thread_info {
...
@@ -89,7 +82,6 @@ struct thread_info {
#define TIF_NEED_RESCHED 2
/* rescheduling necessary */
#define TIF_NEED_RESCHED 2
/* rescheduling necessary */
#define TIF_SYSCALL_TRACE 3
/* syscall trace active */
#define TIF_SYSCALL_TRACE 3
/* syscall trace active */
#define TIF_SYSCALL_AUDIT 4
/* syscall auditing active */
#define TIF_SYSCALL_AUDIT 4
/* syscall auditing active */
#define TIF_SIGDELAYED 5
/* signal delayed from MCA/INIT/NMI/PMI context */
#define TIF_POLLING_NRFLAG 16
/* true if poll_idle() is polling TIF_NEED_RESCHED */
#define TIF_POLLING_NRFLAG 16
/* true if poll_idle() is polling TIF_NEED_RESCHED */
#define TIF_MEMDIE 17
#define TIF_MEMDIE 17
#define TIF_MCA_INIT 18
/* this task is processing MCA or INIT */
#define TIF_MCA_INIT 18
/* this task is processing MCA or INIT */
...
@@ -101,13 +93,12 @@ struct thread_info {
...
@@ -101,13 +93,12 @@ struct thread_info {
#define _TIF_NOTIFY_RESUME (1 << TIF_NOTIFY_RESUME)
#define _TIF_NOTIFY_RESUME (1 << TIF_NOTIFY_RESUME)
#define _TIF_SIGPENDING (1 << TIF_SIGPENDING)
#define _TIF_SIGPENDING (1 << TIF_SIGPENDING)
#define _TIF_NEED_RESCHED (1 << TIF_NEED_RESCHED)
#define _TIF_NEED_RESCHED (1 << TIF_NEED_RESCHED)
#define _TIF_SIGDELAYED (1 << TIF_SIGDELAYED)
#define _TIF_POLLING_NRFLAG (1 << TIF_POLLING_NRFLAG)
#define _TIF_POLLING_NRFLAG (1 << TIF_POLLING_NRFLAG)
#define _TIF_MCA_INIT (1 << TIF_MCA_INIT)
#define _TIF_MCA_INIT (1 << TIF_MCA_INIT)
#define _TIF_DB_DISABLED (1 << TIF_DB_DISABLED)
#define _TIF_DB_DISABLED (1 << TIF_DB_DISABLED)
/* "work to do on user-return" bits */
/* "work to do on user-return" bits */
#define TIF_ALLWORK_MASK (_TIF_NOTIFY_RESUME|_TIF_SIGPENDING|_TIF_NEED_RESCHED|_TIF_SYSCALL_TRACE|_TIF_SYSCALL_AUDIT
|_TIF_SIGDELAYED
)
#define TIF_ALLWORK_MASK (_TIF_NOTIFY_RESUME|_TIF_SIGPENDING|_TIF_NEED_RESCHED|_TIF_SYSCALL_TRACE|_TIF_SYSCALL_AUDIT)
/* like TIF_ALLWORK_BITS but sans TIF_SYSCALL_TRACE or TIF_SYSCALL_AUDIT */
/* like TIF_ALLWORK_BITS but sans TIF_SYSCALL_TRACE or TIF_SYSCALL_AUDIT */
#define TIF_WORK_MASK (TIF_ALLWORK_MASK&~(_TIF_SYSCALL_TRACE|_TIF_SYSCALL_AUDIT))
#define TIF_WORK_MASK (TIF_ALLWORK_MASK&~(_TIF_SYSCALL_TRACE|_TIF_SYSCALL_AUDIT))
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment