mirror of
https://github.com/apache/nuttx.git
synced 2025-01-13 06:18:40 +08:00
gdb: move profiling commands to profile.py
Add simple time command to test time cost of a command. Usage: (gdb) time memleak ... (gdb) Time elapsed: 1.23456s Signed-off-by: xuxingliang <xuxingliang@xiaomi.com>
This commit is contained in:
parent
6949ff6a7d
commit
73467989c5
2 changed files with 63 additions and 19 deletions
62
tools/gdb/nuttxgdb/profile.py
Normal file
62
tools/gdb/nuttxgdb/profile.py
Normal file
|
@ -0,0 +1,62 @@
|
|||
############################################################################
|
||||
# tools/gdb/nuttxgdb/profile.py
|
||||
#
|
||||
# SPDX-License-Identifier: Apache-2.0
|
||||
#
|
||||
# Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
# contributor license agreements. See the NOTICE file distributed with
|
||||
# this work for additional information regarding copyright ownership. The
|
||||
# ASF licenses this file to you under the Apache License, Version 2.0 (the
|
||||
# "License"); you may not use this file except in compliance with the
|
||||
# License. You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||
# License for the specific language governing permissions and limitations
|
||||
# under the License.
|
||||
#
|
||||
############################################################################
|
||||
|
||||
import gdb
|
||||
|
||||
from .utils import import_check
|
||||
|
||||
|
||||
class Profile(gdb.Command):
|
||||
"""Profile a gdb command
|
||||
|
||||
Usage: profile <gdb command>
|
||||
"""
|
||||
|
||||
def __init__(self):
|
||||
self.cProfile = import_check(
|
||||
"cProfile", errmsg="cProfile module not found, try gdb-multiarch.\n"
|
||||
)
|
||||
if not self.cProfile:
|
||||
return
|
||||
|
||||
super().__init__("profile", gdb.COMMAND_USER)
|
||||
|
||||
def invoke(self, args, from_tty):
|
||||
self.cProfile.run(f"gdb.execute('{args}')", sort="cumulative")
|
||||
|
||||
|
||||
class Time(gdb.Command):
|
||||
"""Time a gdb command
|
||||
|
||||
Usage: time <gdb command>
|
||||
"""
|
||||
|
||||
def __init__(self):
|
||||
super().__init__("time", gdb.COMMAND_USER)
|
||||
|
||||
def invoke(self, args, from_tty):
|
||||
import time
|
||||
|
||||
start = time.time()
|
||||
gdb.execute(args)
|
||||
end = time.time()
|
||||
gdb.write(f"Time elapsed: {end - start:.6f}s\n")
|
|
@ -345,6 +345,7 @@ def sizeof(t: Union[str, gdb.Type]):
|
|||
|
||||
return t.sizeof
|
||||
|
||||
|
||||
# Machine Specific Helper Functions
|
||||
|
||||
|
||||
|
@ -911,22 +912,3 @@ class Addr2Line(gdb.Command):
|
|||
except gdb.error as e:
|
||||
gdb.write(f"Ignore {arg}: {e}\n")
|
||||
self.print_backtrace(addresses)
|
||||
|
||||
|
||||
class Profile(gdb.Command):
|
||||
"""Profile a gdb command
|
||||
|
||||
Usage: profile <gdb command>
|
||||
"""
|
||||
|
||||
def __init__(self):
|
||||
self.cProfile = import_check(
|
||||
"cProfile", errmsg="cProfile module not found, try gdb-multiarch.\n"
|
||||
)
|
||||
if not self.cProfile:
|
||||
return
|
||||
|
||||
super().__init__("profile", gdb.COMMAND_USER)
|
||||
|
||||
def invoke(self, args, from_tty):
|
||||
self.cProfile.run(f"gdb.execute('{args}')", sort="cumulative")
|
||||
|
|
Loading…
Reference in a new issue