色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

3天內(nèi)不再提示

使用TRACE_EVENT定義tracepoint的方式

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

內(nèi)核的各個子系統(tǒng)已經(jīng)有大量的跟蹤點,如果這些跟蹤點無法滿足工作中的需求,可以自己手動添加跟蹤點。

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

使用 TRACE_EVENT 定義 tracepoint

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

首先,需要在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:表示跟蹤點調(diào)用的入?yún)⒌脑?,比如timer類型為struct timer_list *。

args:表示參數(shù)。

struct:定義跟蹤器內(nèi)部使用的__entry數(shù)據(jù)結(jié)構(gòu)。

assign:把參數(shù)復(fù)制到__entry數(shù)據(jù)結(jié)構(gòu)中。

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);
}

重新編譯內(nèi)核后,燒寫到設(shè)備中,即可看到sys節(jié)點已經(jīng)有了新增的跟蹤點。

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

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

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

編譯為獨立的ko文件

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

trace_event_init()創(chuàng)建內(nèi)核線程一個名為event-sample內(nèi)核線程。

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()用于創(chuàng)建的線程檢查結(jié)束標志,并決定是否退出。

staticintsimple_thread(void*arg)
{
intcnt=0;

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

return0;
}

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

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

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跟蹤點的實現(xiàn)方式也是使用的TRACE_EVENT ()宏,這里不再贅述。

最后將文件編譯為ko拷貝到設(shè)備上insmod后,即可看到sys目錄下已經(jīng)有新增的節(jié)點。

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()

在某些情況下,跟蹤點只有在某個條件發(fā)生時才會被調(diào)用,類似于

if(cond)
trace_foo();

TRACE_EVENT_CONDITION()宏就是這個作用,它和TRACE_EVENT()相比只是在參數(shù)中多加了一個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()多了兩個參數(shù)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函數(shù)在跟蹤點使能前打印,unreg函數(shù)在跟蹤點使能后打印。reg 和unreg可以根據(jù)實際情況置其中一個為NULL,也可以全部置為NULL。

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






審核編輯:劉清

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

    關(guān)注

    68

    文章

    10901

    瀏覽量

    212629
  • Trace
    +關(guān)注

    關(guān)注

    0

    文章

    19

    瀏覽量

    10579
  • 跟蹤器
    +關(guān)注

    關(guān)注

    0

    文章

    131

    瀏覽量

    20062

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

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

收藏 人收藏

    評論

    相關(guān)推薦

    怎樣通過trace生成系統(tǒng)cpu的loading圖

    1)打開調(diào)度相關(guān)的的event:其他event一次類推[root@k8s-node2 ~]# echo 1 > /sys/kernel/debug/tracing/events/sched
    發(fā)表于 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
    發(fā)表于 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
    發(fā)表于 12-29 09:20 ?1570次閱讀

    TRACE32多核策略

      勞特巴赫的長期目標之一是促使TRACE32的硬件和軟件盡可能靈活。各種內(nèi)核組合、各種多核拓撲結(jié)構(gòu)、各種多核操作方式,即使是最復(fù)雜的調(diào)試和跟蹤的基礎(chǔ)結(jié)構(gòu),均可由TRACE32支持。
    發(fā)表于 09-12 18:58 ?9次下載

    Best Trace路由跟蹤工具

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

    利用tracepoint梳理調(diào)度器框架及主要流程

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

    Trace - Deembed Files

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

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

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

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

    事件集Event
    發(fā)表于 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
    發(fā)表于 12-28 19:33 ?1次下載
    ThreadX(四)------TraceX使用

    Systemverilog event的示例

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

    Ftrace使用tracefs文件系統(tǒng)保存控制文件

    Ftrace是Linux Kernel的官方tracing系統(tǒng),支持Function trace、靜態(tài)tracepoint、動態(tài)Tracepoint的跟蹤,還提供各種Tracer,用于統(tǒng)計最大irq延遲、最大函數(shù)調(diào)用棧大小、調(diào)度
    的頭像 發(fā)表于 02-22 14:34 ?1179次閱讀

    Trace功能的添加、組態(tài)及測試

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

    Linux ftrace工具宏定義

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

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

    電子發(fā)燒友網(wǎng)站提供《如何對基于μTraceTrace32的LPC86x進行邊界掃描.pdf》資料免費下載
    發(fā)表于 08-17 10:22 ?4次下載
    如何對基于μ<b class='flag-5'>Trace</b>和<b class='flag-5'>Trace</b>32的LPC86x進行邊界掃描
    主站蜘蛛池模板: 久久人妻无码毛片A片麻豆| 欲香欲色天天天综合和网| 芭乐草莓樱桃丝瓜18岁大全| 全免费a级毛片免费看| 国产精品99久久久久久人韩国| 亚洲涩福利高清在线| 嗯别插太快好深再深点| 港台三级大全| 月夜直播免费看| 视频网站入口在线看| 极品美女穴| 白洁在线观看| 亚洲精品中文字幕一二三四区| 蜜芽最新域名解析网站| 国产精品久久久久精品A片软件| 抽插H浊水H嫩B父皇| 网友自拍区视频精品| 久久久精品免费视频| 成人网18免费韩国| 一本到2v不卡区| 日本午夜精品理论片A级APP发布| 嘿嘿视频在线观看 成人| 芭乐草莓樱桃丝瓜18岁大全| 亚洲色图激情小说| 睡觉被偷偷进入magnet| 欧美另类与牲交ZOZOZO| 精品久久久久久久高清| 古代荡乳尤物H妓女调教| 2019伊人查蕉在线观看| 亚洲精品无夜久久久久久久久| 日本高清天码一区在线播放| 久久视频这里只精品6国产| 国产精品久久久久久精品... | 黄色三级三级免费看| 办公室的秘密2中文字幕| 中国老太太xxx| 亚洲黄色在线观看| 日韩欧美精品有码在线播放| 美娇妻的性奴史1一4| 黑人BBCVIDEOS极品| 国产精品久久久久久熟妇吹潮软件|