| # System calls |
| |
| On Linux and Android (userdebug builds only) Perfetto can keep track of system |
| calls. |
| |
| Right now only the syscall number is recorded in the trace, the arguments are |
| not stored to limit the trace size overhead. |
| |
| At import time, the Trace Processor uses an internal syscall mapping table, |
| currently supporting x86, x86_64, ArmEabi, aarch32 and aarch64. These tables are |
| generated through the |
| [`extract_linux_syscall_tables`](/tools/extract_linux_syscall_tables) script. |
| |
| ## UI |
| |
| At the UI level system calls are shown inlined with the per-thread slice tracks: |
| |
| ![](/docs/images/syscalls.png "System calls in the thread tracks") |
| |
| ## SQL |
| |
| At the SQL level, syscalls are no different than any other userspace slice |
| event. They get interleaved in the per-thread slice stack and can be easily |
| filtered by looking for the 'sys_' prefix: |
| |
| ```sql |
| select ts, dur, t.name as thread, s.name, depth from slices as s |
| left join thread_track as tt on s.track_id = tt.id |
| left join thread as t on tt.utid = t.utid |
| where s.name like 'sys_%' |
| ``` |
| |
| ts | dur | thread | name |
| ---|-----|--------|------ |
| 856325324372751 | 439867648 | s.nexuslauncher | sys_epoll_pwait |
| 856325324376970 | 990 | FpsThrottlerThr | sys_recvfrom |
| 856325324378376 | 2657 | surfaceflinger | sys_ioctl |
| 856325324419574 | 1250 | android.anim.lf | sys_recvfrom |
| 856325324428168 | 27344 | android.anim.lf | sys_ioctl |
| 856325324451345 | 573 | FpsThrottlerThr | sys_getuid |
| |
| ## TraceConfig |
| |
| ```protobuf |
| data_sources: { |
| config { |
| name: "linux.ftrace" |
| ftrace_config { |
| ftrace_events: "raw_syscalls/sys_enter" |
| ftrace_events: "raw_syscalls/sys_exit" |
| } |
| } |
| } |
| ``` |