# $NetBSD: lwps,v 1.6 2019/07/17 09:14:24 skrll Exp $
define lwps
set $i = 0
while ($i < 2)
if ($i == 0)
set $p = allproc.lh_first
end
if ($p)
printf "\t lwp pid lid flag wchan\n"
end
while ($p)
set $l = $p->p_lwps.lh_first
set $j = 0
while ($j < $p->p_nlwps)
printf "0x%016lx %5d %5d %8x 0x%016lx", \
$l, $p->p_pid, $l->l_lid, $l->l_flag, $l->l_wchan
if ($l->l_wmesg)
printf " (%s)", (char *)$l->l_wmesg
# If the preceding command cannot dereference the pointer, use this instead:
# printf " (%lx)", $l->l_wmesg
end
set $l = $l->l_sibling.le_next
printf "\n"
set $j++
end
set $p = $p->p_list.le_next
end
set $i++
end
end
document lwps
ps for lwps
end
define threadinfo
set $l = (struct lwp *)$arg0
set $pid = $arg1
set $j = 0
set $n = $l->l_name
#if ($n == 0)
# set $n = (char *)""
#end
printf " laddr pid lid flag wchan\n"
printf "%16lx %5d %5d %8x %16lx", \
$l, $pid, $l->l_lid, $l->l_flag, $l->l_wchan
if ($n != 0)
printf " %16s", $n
end
printf "\n\n"
kvm proc $l
where
printf "\n"
end
document threadinfo
Print out the stack and other data of a single thread.
end
define procthreadsaddr
set $p = (struct proc *)$arg0
set $l = $p->p_lwps.lh_first
set $nlwps = $p->p_nlwps
set $pid = $p->p_pid
printf " paddr pid flag stat n firstlwp command\n"
printf "%16lx %5d %8x %4x %5d %16lx %16s\n\n", \
$p, $pid, $p->p_flag, $p->p_stat, \
$nlwps, $p->p_lwps.lh_first, \
(char *) $p->p_comm
while ($l)
threadinfo $l $pid
set $l = $l->l_sibling.le_next
set $j++
end
end
document procthreadsaddr
Print out the stack of all threads in a particular process,
found via struct proc * address.
end
define procthreadspid
set $pid = (unsigned)$arg0
set $p = allproc.lh_first
while ($p)
if ($pid == $p->p_pid)
procthreadsaddr $p
loop_break
end
set $p = $p->p_list.le_next
end
end
document procthreadspid
Print out the stack of all threads in a particular process,
found via PID.
end
define threadlist
set $p = allproc.lh_first
while ($p)
procthreadsaddr $p
set $p = $p->p_list.le_next
end
end
document threadlist
Print out the stack of all threads in the system.
end
define lock
set $ld = (struct lockdebug *)ld_rb_tree
set $a = $ld->ld_lock
set $b = (volatile void *)$arg0
while ($ld && $a != $b)
if ($a < $b)
set $ld = (struct lockdebug *)$ld->ld_rb_node.rb_nodes[1]
end
if ($a > $b)
set $ld = (struct lockdebug *)$ld->ld_rb_node.rb_nodes[0]
end
if ($ld == 0)
loop_break
end
set $a = $ld->ld_lock
# printf "a=%lx b=%lx ld=%lx a<b %d a>b %d\n", $a, $b, $ld, ($a < $b), ($a > $b)
end
if ($ld)
printf "lock address : %#018lx type : ", \
(long)$ld->ld_lock
if ($ld->ld_flags & 0x2)
printf "sleep/adaptive\n"
else
printf "spin\n"
end
printf "initialized : %#018lx", \
(long)$ld->ld_initaddr
if ($ld->ld_lockops->lo_type == 0x2)
printf " interlock: %#018lx\n", $ld->ld_locked
else
printf "\n"
printf "shared holds : %18u exclusive: ", \
$ld->ld_shares
if (($ld->ld_flags & 0x1) != 0)
printf "1\n"
else
printf "0\n"
end
printf "shares wanted: %18u exclusive: %18u\n", \
(unsigned)$ld->ld_shwant, (unsigned)$ld->ld_exwant
printf "cpu last held: %18u\n", \
(unsigned)$ld->ld_cpu
printf "current lwp : %#018lx last held: %#018lx\n", \
(long)0, (long)$ld->ld_lwp
printf "last locked : %#018lx unlocked : %#018lx\n", \
(long)$ld->ld_locked, (long)$ld->ld_unlocked
end
end
end
document lock
Print out lockdebug info like ddb does.
end