Commit f720257c authored by yonghong-song's avatar yonghong-song Committed by GitHub

support "long" and "unsigned long" type in trace.py (#1977)

Currently, trace.py does not support "long" and "unsigned long"
types and it often caught users with a surprise and they are
not sure what is the problem. For example, for kernel function:
  void blk_mq_delay_kick_requeue_list(struct request_queue *q, unsigned long msecs)
The following
  $ sudo ./trace.py 'blk_mq_delay_kick_requeue_list(void *notused, unsigned long msecs) "msecs = %lu", msecs'
  list index out of range

With this patch,
  $ sudo ./trace.py 'blk_mq_delay_kick_requeue_list(void *notused, unsigned long msecs) "msecs = %lu", msecs'
  PID     TID     COMM            FUNC             -
  ^C
  $ sudo ./trace.py 'blk_mq_delay_kick_requeue_list(void *notused, unsigned long msecs) "msecs = %ld", msecs'
  PID     TID     COMM            FUNC             -
  ^C
  $ sudo ./trace.py 'blk_mq_delay_kick_requeue_list(void *notused, unsigned long msecs) "msecs = %lx", msecs'
  PID     TID     COMM            FUNC             -
  ^C
  $
Signed-off-by: default avatarYonghong Song <yhs@fb.com>
parent 72bb0d56
...@@ -180,10 +180,10 @@ class Probe(object): ...@@ -180,10 +180,10 @@ class Probe(object):
def _parse_types(self, fmt): def _parse_types(self, fmt):
for match in re.finditer( for match in re.finditer(
r'[^%]%(s|u|d|llu|lld|hu|hd|x|llx|c|K|U)', fmt): r'[^%]%(s|u|d|lu|llu|ld|lld|hu|hd|x|lx|llx|c|K|U)', fmt):
self.types.append(match.group(1)) self.types.append(match.group(1))
fmt = re.sub(r'([^%]%)(u|d|llu|lld|hu|hd)', r'\1d', fmt) fmt = re.sub(r'([^%]%)(u|d|lu|llu|ld|lld|hu|hd)', r'\1d', fmt)
fmt = re.sub(r'([^%]%)(x|llx)', r'\1x', fmt) fmt = re.sub(r'([^%]%)(x|lx|llx)', r'\1x', fmt)
fmt = re.sub('%K|%U', '%s', fmt) fmt = re.sub('%K|%U', '%s', fmt)
self.python_format = fmt.strip('"') self.python_format = fmt.strip('"')
...@@ -283,10 +283,12 @@ static inline bool %s(char const *ignored, uintptr_t str) { ...@@ -283,10 +283,12 @@ static inline bool %s(char const *ignored, uintptr_t str) {
expr = expr.replace("STRCMP", fname, 1) expr = expr.replace("STRCMP", fname, 1)
return expr return expr
p_type = {"u": ct.c_uint, "d": ct.c_int, p_type = {"u": ct.c_uint, "d": ct.c_int, "lu": ct.c_ulong,
"ld": ct.c_long,
"llu": ct.c_ulonglong, "lld": ct.c_longlong, "llu": ct.c_ulonglong, "lld": ct.c_longlong,
"hu": ct.c_ushort, "hd": ct.c_short, "hu": ct.c_ushort, "hd": ct.c_short,
"x": ct.c_uint, "llx": ct.c_ulonglong, "c": ct.c_ubyte, "x": ct.c_uint, "lx": ct.c_ulong, "llx": ct.c_ulonglong,
"c": ct.c_ubyte,
"K": ct.c_ulonglong, "U": ct.c_ulonglong} "K": ct.c_ulonglong, "U": ct.c_ulonglong}
def _generate_python_field_decl(self, idx, fields): def _generate_python_field_decl(self, idx, fields):
...@@ -320,9 +322,11 @@ static inline bool %s(char const *ignored, uintptr_t str) { ...@@ -320,9 +322,11 @@ static inline bool %s(char const *ignored, uintptr_t str) {
dict(_fields_=fields)) dict(_fields_=fields))
c_type = {"u": "unsigned int", "d": "int", c_type = {"u": "unsigned int", "d": "int",
"lu": "unsigned long", "ld": "long",
"llu": "unsigned long long", "lld": "long long", "llu": "unsigned long long", "lld": "long long",
"hu": "unsigned short", "hd": "short", "hu": "unsigned short", "hd": "short",
"x": "unsigned int", "llx": "unsigned long long", "x": "unsigned int", "lx": "unsigned long",
"llx": "unsigned long long",
"c": "char", "K": "unsigned long long", "c": "char", "K": "unsigned long long",
"U": "unsigned long long"} "U": "unsigned long long"}
fmt_types = c_type.keys() fmt_types = c_type.keys()
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment