| 1 | define connect | 
|---|
| 2 | target remote localhost:2346 | 
|---|
| 3 | end | 
|---|
| 4 |  | 
|---|
| 5 | # useful macros for Linux | 
|---|
| 6 | define dmesg | 
|---|
| 7 | set $__log_buf = $arg0 | 
|---|
| 8 | set $log_start = $arg1 | 
|---|
| 9 | set $log_end = $arg2 | 
|---|
| 10 | set $x = $log_start | 
|---|
| 11 | echo " | 
|---|
| 12 | while ($x < $log_end) | 
|---|
| 13 | set $c = (char)(($__log_buf)[$x++]) | 
|---|
| 14 | printf "%c" , $c | 
|---|
| 15 | end | 
|---|
| 16 | echo "\n | 
|---|
| 17 | end | 
|---|
| 18 | document dmesg | 
|---|
| 19 | dmesg __log_buf log_start log_end | 
|---|
| 20 | Print the content of the kernel message buffer | 
|---|
| 21 | end | 
|---|
| 22 |  | 
|---|
| 23 | define thread_info | 
|---|
| 24 | set $th = (struct thread_info*)$gp | 
|---|
| 25 | echo "thread_info=" | 
|---|
| 26 | print /x *$th | 
|---|
| 27 | end | 
|---|
| 28 | define task_struct | 
|---|
| 29 | set $th = (struct thread_info*)$gp | 
|---|
| 30 | set $ts = (struct task_struct*)$th->task | 
|---|
| 31 | echo "task_struct=" | 
|---|
| 32 | print /x *$ts | 
|---|
| 33 | end | 
|---|
| 34 | define active_mm | 
|---|
| 35 | set $th = (struct thread_info*)$gp | 
|---|
| 36 | set $ts = (struct task_struct*)$th->task | 
|---|
| 37 | set $amm = (struct mm_struct*)$ts->active_mm | 
|---|
| 38 | echo "active_mm=" | 
|---|
| 39 | print /x *$amm | 
|---|
| 40 | end | 
|---|
| 41 | define pgd | 
|---|
| 42 | set $th = (struct thread_info*)$gp | 
|---|
| 43 | set $ts = (struct task_struct*)$th->task | 
|---|
| 44 | set $ms = (struct mm_struct*)$ts->active_mm | 
|---|
| 45 | set $pg = (pgd_t*)$ms->pgd | 
|---|
| 46 | echo "pgd=" | 
|---|
| 47 | print /x {pgd_t[2048]}$pg | 
|---|
| 48 | end | 
|---|
| 49 |  | 
|---|
| 50 | define task_struct_header | 
|---|
| 51 | printf "Address      PID State     [User_EPC] [User-SP]  Kernel-SP  device comm\n" | 
|---|
| 52 | end | 
|---|
| 53 |  | 
|---|
| 54 | define task_struct_show | 
|---|
| 55 | # task_struct addr and PID | 
|---|
| 56 | printf "0x%08X %5d", $arg0, $arg0->pid | 
|---|
| 57 | # Place a '<' marker on the current task | 
|---|
| 58 | #  if ($arg0 == current) | 
|---|
| 59 | # For PowerPC, register r2 points to the "current" task | 
|---|
| 60 | if ($arg0 == $r2) | 
|---|
| 61 | printf "<" | 
|---|
| 62 | else | 
|---|
| 63 | printf " " | 
|---|
| 64 | end | 
|---|
| 65 | # State | 
|---|
| 66 | if ($arg0->state == 0) | 
|---|
| 67 | printf "Running   " | 
|---|
| 68 | else | 
|---|
| 69 | if ($arg0->state == 1) | 
|---|
| 70 | printf "Sleeping  " | 
|---|
| 71 | else | 
|---|
| 72 | if ($arg0->state == 2) | 
|---|
| 73 | printf "Disksleep " | 
|---|
| 74 | else | 
|---|
| 75 | if ($arg0->state == 4) | 
|---|
| 76 | printf "Zombie    " | 
|---|
| 77 | else | 
|---|
| 78 | if ($arg0->state == 8) | 
|---|
| 79 | printf "sTopped   " | 
|---|
| 80 | else | 
|---|
| 81 | if ($arg0->state == 16) | 
|---|
| 82 | printf "Wpaging   " | 
|---|
| 83 | else | 
|---|
| 84 | printf "%2d       ", $arg0->state | 
|---|
| 85 | end | 
|---|
| 86 | end | 
|---|
| 87 | end | 
|---|
| 88 | end | 
|---|
| 89 | end | 
|---|
| 90 | end | 
|---|
| 91 | # User PC | 
|---|
| 92 | set $pt_regs = (struct pt_regs*)($arg0->stack + 0x2000 - sizeof(struct pt_regs)) | 
|---|
| 93 | if ($pt_regs->cp0_epc) | 
|---|
| 94 | printf "0x%08X ", $pt_regs->cp0_epc | 
|---|
| 95 | else | 
|---|
| 96 | printf "           " | 
|---|
| 97 | end | 
|---|
| 98 | if ($pt_regs->regs[29]) | 
|---|
| 99 | printf "0x%08X ", $pt_regs->regs[29] | 
|---|
| 100 | else | 
|---|
| 101 | printf "           " | 
|---|
| 102 | end | 
|---|
| 103 | # Display the kernel stack pointer | 
|---|
| 104 | set $th = (struct thread_info*)$arg0->stack | 
|---|
| 105 | printf "0x%08X ", $th->ksp | 
|---|
| 106 | # device | 
|---|
| 107 | if ($arg0->signal->tty) | 
|---|
| 108 | printf "%s   ", $arg0->signal->tty->name | 
|---|
| 109 | else | 
|---|
| 110 | printf "(none) " | 
|---|
| 111 | end | 
|---|
| 112 | # comm | 
|---|
| 113 | printf "%s\n", $arg0->comm | 
|---|
| 114 | end | 
|---|
| 115 |  | 
|---|
| 116 | define find_next_task | 
|---|
| 117 | # Given a task address, find the next task in the linked list | 
|---|
| 118 | set $t = (struct task_struct *)$arg0 | 
|---|
| 119 | set $offset=((char *)&$t->tasks - (char *)$t) | 
|---|
| 120 | set $t=(struct task_struct *)((char *)$t->tasks.next- (char *)$offset) | 
|---|
| 121 | end | 
|---|
| 122 |  | 
|---|
| 123 | define ps | 
|---|
| 124 | # Print column headers | 
|---|
| 125 | task_struct_header | 
|---|
| 126 | set $t=&init_task | 
|---|
| 127 | task_struct_show $t | 
|---|
| 128 | find_next_task $t | 
|---|
| 129 | # Walk the list | 
|---|
| 130 | while &init_task!=$t | 
|---|
| 131 | # Display useful info about each task | 
|---|
| 132 | task_struct_show $t | 
|---|
| 133 | find_next_task $t | 
|---|
| 134 | end | 
|---|
| 135 | end | 
|---|
| 136 |  | 
|---|