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
38a62779
Commit
38a62779
authored
Jun 15, 2020
by
Al Viro
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[elf-fdpic] move allocation of elf_thread_status into elf_dump_thread_status()
Signed-off-by:
Al Viro
<
viro@zeniv.linux.org.uk
>
parent
5074c7f6
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
10 additions
and
14 deletions
+10
-14
fs/binfmt_elf_fdpic.c
fs/binfmt_elf_fdpic.c
+10
-14
No files found.
fs/binfmt_elf_fdpic.c
View file @
38a62779
...
...
@@ -1466,12 +1466,13 @@ struct elf_thread_status
* we need to keep a linked list of every thread's pr_status and then create
* a single section for them in the final core file.
*/
static
int
elf_dump_thread_status
(
long
signr
,
struct
elf_thread_status
*
t
)
static
struct
elf_thread_status
*
elf_dump_thread_status
(
long
signr
,
struct
task_struct
*
p
,
int
*
sz
)
{
struct
task_struct
*
p
=
t
->
thread
;
int
sz
=
0
;
struct
elf_thread_status
*
t
;
t
->
num_notes
=
0
;
t
=
kzalloc
(
sizeof
(
struct
elf_thread_status
),
GFP_KERNEL
);
if
(
!
t
)
return
t
;
fill_prstatus
(
&
t
->
prstatus
,
p
,
signr
);
elf_core_copy_task_regs
(
p
,
&
t
->
prstatus
.
pr_reg
);
...
...
@@ -1479,16 +1480,16 @@ static int elf_dump_thread_status(long signr, struct elf_thread_status *t)
fill_note
(
&
t
->
notes
[
0
],
"CORE"
,
NT_PRSTATUS
,
sizeof
(
t
->
prstatus
),
&
t
->
prstatus
);
t
->
num_notes
++
;
sz
+=
notesize
(
&
t
->
notes
[
0
]);
*
sz
+=
notesize
(
&
t
->
notes
[
0
]);
t
->
prstatus
.
pr_fpvalid
=
elf_core_copy_task_fpregs
(
p
,
NULL
,
&
t
->
fpu
);
if
(
t
->
prstatus
.
pr_fpvalid
)
{
fill_note
(
&
t
->
notes
[
1
],
"CORE"
,
NT_PRFPREG
,
sizeof
(
t
->
fpu
),
&
t
->
fpu
);
t
->
num_notes
++
;
sz
+=
notesize
(
&
t
->
notes
[
1
]);
*
sz
+=
notesize
(
&
t
->
notes
[
1
]);
}
return
sz
;
return
t
;
}
static
void
fill_extnum_info
(
struct
elfhdr
*
elf
,
struct
elf_shdr
*
shdr4extnum
,
...
...
@@ -1621,20 +1622,15 @@ static int elf_fdpic_core_dump(struct coredump_params *cprm)
for
(
ct
=
current
->
mm
->
core_state
->
dumper
.
next
;
ct
;
ct
=
ct
->
next
)
{
tmp
=
kzalloc
(
sizeof
(
*
tmp
),
GFP_KERNEL
);
tmp
=
elf_dump_thread_status
(
cprm
->
siginfo
->
si_signo
,
ct
->
task
,
&
thread_status_size
);
if
(
!
tmp
)
goto
end_coredump
;
tmp
->
thread
=
ct
->
task
;
tmp
->
next
=
thread_list
;
thread_list
=
tmp
;
}
for
(
tmp
=
thread_list
;
tmp
;
tmp
=
tmp
->
next
)
{
int
sz
=
elf_dump_thread_status
(
cprm
->
siginfo
->
si_signo
,
tmp
);
thread_status_size
+=
sz
;
}
/* now collect the dump for the current */
fill_prstatus
(
prstatus
,
current
,
cprm
->
siginfo
->
si_signo
);
elf_core_copy_regs
(
&
prstatus
->
pr_reg
,
cprm
->
regs
);
...
...
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