Skip to content

Commit

Permalink
ST: Support show coroutines.
Browse files Browse the repository at this point in the history
  • Loading branch information
winlinvip committed Dec 10, 2020
1 parent c7c6d87 commit 9caeb60
Showing 1 changed file with 52 additions and 12 deletions.
64 changes: 52 additions & 12 deletions trunk/gdb/srs.py
Original file line number Diff line number Diff line change
@@ -1,30 +1,70 @@
import gdb, sys, traceback;
import gdb, traceback;

'''
Usage:
nn_coroutines
nn_coroutines 1000
'''
class NnCouroutines(gdb.Command):
def __init__(self):
super(NnCouroutines, self).__init__('nn_coroutines', gdb.COMMAND_DATA)

# https://sourceware.org/gdb/current/onlinedocs/gdb/Python-API.html#Python-API
def invoke(self, arg, from_tty):
nn_interval=1000
nn_coroutines = 1
# Parse args.
args = arg.split(' ')
if args[0] != '':
nn_interval = int(args[0])
try:
if len(arg) > 0:
prev = pthis = arg
print('start from %s'%(arg))
else:
prev = pthis = gdb.parse_and_eval('&_st_this_thread->tlink').__str__()
print('start from &_st_this_thread->tlink')
print('first is: %s'%(pthis))
nn_coroutines, pnext = 1, pthis
pnext = prev = pthis = gdb.parse_and_eval('&_st_this_thread->tlink').__str__()
print('interval: %s, first: %s, args(%s): %s'%(nn_interval, pthis, len(args), args))
while True:
v = gdb.parse_and_eval('((_st_clist_t*)%s)->next'%pnext)
prev = pnext = str(v.__str__()).split(' ')[0]
if pnext == pthis:
break
nn_coroutines += 1
if len(arg) > 0 or (nn_coroutines%1000) == 0:
if (nn_coroutines%nn_interval) == 0:
print('next is %s, total %s'%(pnext, nn_coroutines))
print('total coroutines: %s'%(nn_coroutines))
except:
print('Error: prev=%s, this=%s, next=%s, v=%s'%(prev, pthis, pnext, v))
traceback.print_exc()
# Result.
print('total coroutines: %s'%(nn_coroutines))

NnCouroutines()
NnCouroutines()

'''
Usage:
show_coroutines
'''
class ShowCouroutines(gdb.Command):
def __init__(self):
super(ShowCouroutines, self).__init__('show_coroutines', gdb.COMMAND_DATA)

# https://sourceware.org/gdb/current/onlinedocs/gdb/Python-API.html#Python-API
def invoke(self, arg, from_tty):
offset = gdb.parse_and_eval('(int)(&(((_st_thread_t*)(0))->tlink))').__str__()
_st_this_thread = gdb.parse_and_eval('_st_this_thread').__str__()
pnext = prev = pthis = gdb.parse_and_eval('&_st_this_thread->tlink').__str__()
this_thread2 = gdb.parse_and_eval('(_st_thread_t*)(%s - %s)'%(pthis, offset)).__str__()
#print('offset=%s, _st_this_thread=%s, pthis-offset=%s'%(offset, _st_this_thread, this_thread2))
try:
while True:
trd = gdb.parse_and_eval('(_st_thread_t*)(%s - %s)'%(pnext, offset)).__str__()
jmpbuf = gdb.parse_and_eval('((_st_thread_t*)%s)->context.__jmpbuf'%(trd)).__str__().split(', ')
rbp, rsp, crip = int(jmpbuf[1]), int(jmpbuf[6]), None
if rbp > 0 and rsp > 0:
crip = gdb.execute('x/2xa %s'%(rbp), to_string=True).split('\t')[2].strip()
print('thread: %s, caller: %s'%(trd, crip))
v = gdb.parse_and_eval('((_st_clist_t*)%s)->next'%pnext)
prev = pnext = str(v.__str__()).split(' ')[0]
if pnext == pthis:
break
except:
print('Error: prev=%s, this=%s, next=%s'%(prev, pthis, pnext))
traceback.print_exc()

ShowCouroutines()

1 comment on commit 9caeb60

@winlinvip
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please sign in to comment.