You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
31 lines
964 B
31 lines
964 B
#!/usr/bin/env python3
|
|
|
|
import cProfile
|
|
|
|
import pyprof2calltree
|
|
|
|
from tools.lib.logreader import LogReader
|
|
from selfdrive.controls.controlsd import controlsd_thread
|
|
from selfdrive.test.profiling.lib import SubMaster, PubMaster, SubSocket, ReplayDone
|
|
|
|
|
|
BASE_URL = "https://commadataci.blob.core.windows.net/openpilotci/"
|
|
SEGMENT = "99c94dc769b5d96e|2019-08-03--14-19-59/2"
|
|
|
|
|
|
if __name__ == "__main__":
|
|
segment = SEGMENT.replace('|', '/')
|
|
rlog_url = f"{BASE_URL}{segment}/rlog.bz2"
|
|
msgs = list(LogReader(rlog_url))
|
|
|
|
pm = PubMaster(['sendcan', 'controlsState', 'carState', 'carControl', 'carEvents', 'carParams'])
|
|
sm = SubMaster(msgs, 'can', ['thermal', 'health', 'liveCalibration', 'dMonitoringState', 'plan', 'pathPlan', 'model'])
|
|
can_sock = SubSocket(msgs, 'can')
|
|
|
|
with cProfile.Profile() as pr:
|
|
try:
|
|
controlsd_thread(sm, pm, can_sock)
|
|
except ReplayDone:
|
|
pass
|
|
|
|
pyprof2calltree.convert(pr.getstats(), 'cachegrind.out.controlsd')
|
|
|