在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

使用TRACE_EVENT定義tracepoint的方式

嵌入式與Linux那些事 ? 來源:嵌入式與Linux那些事 ? 2023-03-05 13:44 ? 次閱讀

內核的各個子系統已經有大量的跟蹤點,如果這些跟蹤點無法滿足工作中的需求,可以自己手動添加跟蹤點。

添加跟蹤點有兩種方式,一種是仿照events/目錄下的跟蹤點,使用TRACE_EVENT() 宏添加。另一種是參考內核目錄samples/trace_events添加。本文對這兩種方式分別進行介紹。

使用 TRACE_EVENT 定義 tracepoint

我們仿照events/timer/timer_start,添加一個timer_stat的跟蹤點,獲取start_pid和slack參數。

首先,需要在include/trace/events/timer.h頭文件種添加名為timer_stat的跟蹤點。

/**
*timer_stat-ftraceinterfacetimer_stat
*@timer:pointertostructtimer_list
*/
TRACE_EVENT(timer_stat,

TP_PROTO(structtimer_list*timer),

TP_ARGS(timer),

TP_STRUCT__entry(
__field(void*,timer)
__field(int,start_pid)
__field(int,slack)
),

TP_fast_assign(
__entry->timer=timer;
__entry->start_pid=timer->start_pid;
__entry->slack=timer->slack;
),

TP_printk("ftraceinterfacetimer_stat:timer=%ppid=%dslack=%d
",
__entry->timer,__entry->start_pid,__entry->slack)
);

TRACE_EVENT()宏如下

#defineTRACE_EVENT(name,proto,args,struct,assign,print)
DEFINE_TRACE(name)

name:表示跟蹤點的名字,如上面的timer_stat。

proto:表示跟蹤點調用的入參的原型,比如timer類型為struct timer_list *。

args:表示參數。

struct:定義跟蹤器內部使用的__entry數據結構。

assign:把參數復制到__entry數據結構中。

print:定義輸出的格式。

接著在kernel/kernel/time/timer.c debug_activate()添加trace_timer_stat()。

staticinlinevoid
debug_activate(structtimer_list*timer,unsignedlongexpires)
{
debug_timer_activate(timer);
trace_timer_start(timer,expires,timer->flags);
trace_timer_stat(timer);
}

重新編譯內核后,燒寫到設備中,即可看到sys節點已經有了新增的跟蹤點。

e39c674e-bb10-11ed-bfe3-dac502259ad0.png

使能跟蹤點后,查看trace點的輸出。

e3da4168-bb10-11ed-bfe3-dac502259ad0.png

編譯為獨立的ko文件

內核還提供了一個跟蹤點的例子,在samples/trace_events 目錄下。

trace_event_init()創建內核線程一個名為event-sample內核線程。

staticint__inittrace_event_init(void)
{
simple_tsk=kthread_run(simple_thread,NULL,"event-sample");
if(IS_ERR(simple_tsk))
return-1;

return0;
}

kthread_should_stop()用于創建的線程檢查結束標志,并決定是否退出。

staticintsimple_thread(void*arg)
{
intcnt=0;

while(!kthread_should_stop())
simple_thread_func(cnt++);

return0;
}

set_current_state() 來設置進程的狀態,設置為TASK_INTERRUPTIBLE表示是可以被信號和wake_up()喚醒的,當信號到來時,進程會被設置為可運行。

schedule_timeout()將當前task調度出cpu,重新調度間隔為HZ。接著trace_開頭的函數就會依次打印跟蹤點的信息。

staticvoidsimple_thread_func(intcnt)
{
intarray[6];
intlen=cnt%5;
inti;

set_current_state(TASK_INTERRUPTIBLE);
schedule_timeout(HZ);

for(i=0;i

trace_foo_with_template_simple跟蹤點的實現方式也是使用的TRACE_EVENT ()宏,這里不再贅述。

最后將文件編譯為ko拷貝到設備上insmod后,即可看到sys目錄下已經有新增的節點。

cd/home/zhongyi/code/rk3399_linux_release_v2.5.1_20210301/kernel/samples/trace_events
make-C/home/zhongyi/code/rk3399_linux_release_v2.5.1_20210301/kernel/M=$(pwd)modules
root@firefly:/sys/kernel/debug/tracing#catavailable_events|grepsample
sample-trace:foo_bar
sample-trace:foo_bar_with_cond
race:foo_bar_with_fn
sample-trace:foo_with_template_simple
sample-trace:foo_with_template_cond
sample-trace:foo_with_template_fn
sample-trace:foo_with_template_print
power:pstate_sample
root@firefly:/sys/kernel/debug/tracing#cdevents/sample-trace/
root@firefly:/sys/kernel/debug/tracing/events/sample-trace#ls
enablefoo_bar_with_condfoo_with_template_fn
filterfoo_bar_with_fnfoo_with_template_print
foo_barfoo_with_template_condfoo_with_templ_simple
root@firefly:/sys/kernel/debug/tracing/events/sample-trace#echo1>enable
root@firefly:/sys/kernel/debug/tracing/events/sample-trace#cat/sys/kernel/debug/tracing/trace
e42b1336-bb10-11ed-bfe3-dac502259ad0.png

TRACE_EVENT_CONDITION()

在某些情況下,跟蹤點只有在某個條件發生時才會被調用,類似于

if(cond)
trace_foo();

TRACE_EVENT_CONDITION()宏就是這個作用,它和TRACE_EVENT()相比只是在參數中多加了一個cond條件。TP_CONDITION()會對條件做個判斷。

TRACE_EVENT(name,proto,args,struct,assign,printk)
TRACE_EVENT_CONDITION(name,proto,args,cond,struct,assign,printk)

詳細使用方法可以參考trace-events-sample.h。

TRACE_EVENT_FN()

TRACE_EVENT_FN()是在跟蹤點使能前和使能后分別打印一些信息。相比于TRACE_EVENT(),TRACE_EVENT_FN()多了兩個參數reg和unreg,

TRACE_EVENT(name,proto,args,struct,assign,printk)
TRACE_EVENT_FN(name,proto,args,struct,assign,printk,reg,unreg)

reg 和unreg原型為

voidreg(void)

reg函數在跟蹤點使能前打印,unreg函數在跟蹤點使能后打印。reg 和unreg可以根據實際情況置其中一個為NULL,也可以全部置為NULL。

詳細使用方法可以參考trace-events-sample.h。






審核編輯:劉清

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • cpu
    cpu
    +關注

    關注

    68

    文章

    11049

    瀏覽量

    216161
  • Trace
    +關注

    關注

    0

    文章

    19

    瀏覽量

    10728
  • 跟蹤器
    +關注

    關注

    0

    文章

    132

    瀏覽量

    20399

原文標題:ftrace(二)新增tracepoint

文章出處:【微信號:嵌入式與Linux那些事,微信公眾號:嵌入式與Linux那些事】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦
    熱點推薦

    怎樣通過trace生成系統cpu的loading圖

    1)打開調度相關的的event:其他event一次類推[root@k8s-node2 ~]# echo 1 > /sys/kernel/debug/tracing/events/sched
    發表于 06-28 09:05

    heap_trace_init_tohost 的 sysviewtrace_proc解析錯誤如何解決?

    event ID 463!或者代碼:全選File "~/esp_app_trace/espytrace/sysview.py", line 368, in _read_payload
    發表于 03-02 06:15

    Trace thickness

    Trace thickness The thickness of a trace is usually .0014 per ounce of copper. Our standard material is 1/2 ounce copper that is plate
    發表于 12-29 09:20 ?1664次閱讀

    TRACE32多核策略

      勞特巴赫的長期目標之一是促使TRACE32的硬件和軟件盡可能靈活。各種內核組合、各種多核拓撲結構、各種多核操作方式,即使是最復雜的調試和跟蹤的基礎結構,均可由TRACE32支持。
    發表于 09-12 18:58 ?9次下載

    Best Trace路由跟蹤工具

    Best Trace 路由跟蹤工具 Windows 客戶端
    發表于 04-13 13:46 ?4次下載

    利用tracepoint梳理調度器框架及主要流程

    : $ sudo perf list | grep sched: sched:sched_kthread_stop [Tracepoint event] sched
    的頭像 發表于 10-30 14:36 ?2406次閱讀

    Trace - Deembed Files

    Trace - Deembed Files
    發表于 02-01 09:47 ?0次下載
    <b class='flag-5'>Trace</b> - Deembed Files

    勞特巴赫trace32使用介紹(一)

    勞德巴赫trace32使用介紹安裝trace32使用帶有光驅的電腦把光盤中的安裝文件拷貝到u盤,然后就可以使用u盤安裝了。打開文件夾,雙擊安裝文件,一路next就可以安裝成功了。trace32連接
    發表于 12-28 19:22 ?20次下載
    勞特巴赫<b class='flag-5'>trace</b>32使用介紹(一)

    ThreadX(八)------事件集Event

    事件集Event
    發表于 12-28 19:26 ?9次下載
    ThreadX(八)------事件集<b class='flag-5'>Event</b>

    ThreadX(四)------TraceX使用

    TraceX使用簡介TraceX 軟件生成跟蹤bufTrace APItx_trace_enabletx_trace_enabletx_trace_event_filtertx_trace_event_unfiltertx_trace_disabletx_trace_isr_enter_inserttx_trace_isr
    發表于 12-28 19:33 ?1次下載
    ThreadX(四)------TraceX使用

    Systemverilog event的示例

    event是SystemVerilog語言中的一個強大特性,可以支持多個并發進程之間的同步。
    的頭像 發表于 10-17 10:21 ?1800次閱讀

    Ftrace使用tracefs文件系統保存控制文件

    Ftrace是Linux Kernel的官方tracing系統,支持Function trace、靜態tracepoint、動態Tracepoint的跟蹤,還提供各種Tracer,用于統計最大irq延遲、最大函數調用棧大小、調度
    的頭像 發表于 02-22 14:34 ?1419次閱讀

    Trace功能的添加、組態及測試

    本節為工程添加Trace曲線,在Trace中配置Diagram,并為每個Diagram組態變量監控。 具體操作介紹 1.在Application下添加Object,選擇Trace。添加Trac
    發表于 03-08 14:42 ?1465次閱讀

    Linux ftrace工具宏定義

    而后在 /sys/kernel/debug/trace 目錄下提供了各種跟蹤器(tracer)和 event 事件,一些常用的選項如下。 available_tracers:列出當前系統支持的跟蹤器。 available_events:列出當前系統支持的
    的頭像 發表于 07-20 11:18 ?870次閱讀

    如何對基于μTraceTrace32的LPC86x進行邊界掃描

    電子發燒友網站提供《如何對基于μTraceTrace32的LPC86x進行邊界掃描.pdf》資料免費下載
    發表于 08-17 10:22 ?7次下載
    如何對基于μ<b class='flag-5'>Trace</b>和<b class='flag-5'>Trace</b>32的LPC86x進行邊界掃描
    主站蜘蛛池模板: 黄色录像视频网站 | 色秀视频免费网站在线观看 | 亚洲激情| 性欧美视频videos6一9 | 91久久天天躁狠狠躁夜夜 | 欧美大黄 | 免费观看成人欧美1314www | 国产主播在线看 | 日本口工禁漫画无遮挡全彩 | 在线www| 天堂a| 欧美日韩国产一区二区三区不卡 | 精品特级毛片 | 久久免费精品国产72精品剧情 | аⅴ资源中文在线天堂 | 午夜寂寞视频在线观看 | 激情五月开心网 | 天天精品在线 | 俺去鲁婷婷六月色综合 | 中文天堂最新版资源新版天堂资源 | 极品美女洗澡后露粉嫩木耳视频 | 在线观看午夜 | 在线视频一区二区三区四区 | 免费观看三级毛片 | 亚洲 欧美 精品专区 极品 | 成人在线综合 | 黑粗硬大欧美视频 | 丁香亚洲综合五月天婷婷 | 狠狠色噜噜狠狠狠狠狠色综合久久 | 成人免费的性色视频 | 色多多最新地址福利地址 | 偷偷久久| 天天舔天天爱 | 国产片一区二区三区 | 3344成年在线视频免费播放男男 | 中文字幕xxx | 精品国产乱码一区二区三区 | 好黄好猛好爽好痛的视频 | 黄色大片视频网站 | 久久久久无码国产精品一区 | 美女写真福利视频 |