How to get object virtual address from a kernel core dump
Buland Kumar Singh
6b65726e656c at gmail.com
Tue Mar 22 23:41:18 EDT 2016
On 18 March 2016 at 15:28, Mohammad Y. Zachariah <eng.myz at gmail.com> wrote:
>
> Hello everyone,
>
> I'm taking the way of analysing kernel core dumps as a learning approach using 'crash tool'. One of the interesting crash commands is 'struct' which can print kernel struct definition and/or the actual contents of the structure.
>
> According to struct help page, I need the virtual address of the struct in order to view/print its contents, for example:
>
> crash> mm_struct.pgd ffff810022e7d080 -px
> pgd_t *pgd = 0xffff81000e3ac000
> -> {
> pgd = 0x2c0a6067
> }
>
> My question is how to find the mm_struct address "ffff810022e7d080" in the above example in the first place??
>
Hello Zach,
1) Determine the struct task_struct * from ps or set command of crash.
Eg:
crash> set 1
PID: 1
COMMAND: "init"
TASK: ffff881029867500 [THREAD_INFO: ffff882029b32000]
CPU: 2
STATE: TASK_INTERRUPTIBLE
crash> ps 1
PID PPID CPU TASK ST %MEM VSZ RSS COMM
1 0 2 ffff881029867500 IN 0.0 24852 1632 init
In above example, struct task_struct * is 0xffff881029867500
2) Determine struct mm_struct * from struct task_struct *
crash> task_struct.mm -ox
struct task_struct {
[0x480] struct mm_struct *mm;
}
crash> task_struct.mm ffff881029867500
mm = 0xffff882026b68700
In above example, struct mm_struct * is 0xffff882026b68700
3) Finally determine pgd_t from struct mm_struct *
crash> mm_struct.pgd -ox
struct mm_struct {
[0x50] pgd_t *pgd;
}
crash> mm_struct.pgd 0xffff882026b68700
pgd = 0xffff882026a9e000
You achieve the above steps in one line;
Eg:
crash> px ((struct task_struct *)0xffff881029867500)->mm.pgd
$1 = (pgd_t *) 0xffff882026a9e000
--
BKS
More information about the Kernelnewbies
mailing list