91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

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

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

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

保證BPF程序安全的BPF驗(yàn)證器介紹

Linux閱碼場(chǎng) ? 來源:Linux內(nèi)核之旅 ? 作者:梁金榮 ? 2021-05-03 11:27 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

1. 前言

我們可以使用BPF對(duì)Linux內(nèi)核進(jìn)行跟蹤,收集我們想要的內(nèi)核數(shù)據(jù),從而對(duì)Linux中的程序進(jìn)行分析和調(diào)試。與其它的跟蹤技術(shù)相比,使用BPF的主要優(yōu)點(diǎn)是幾乎可以訪問Linux內(nèi)核和應(yīng)用程序的任何信息,同時(shí),BPF對(duì)系統(tǒng)性能影響很小,執(zhí)行效率很高,而且開發(fā)人員不需要因?yàn)槭占瘮?shù)據(jù)而修改程序。

本文將介紹保證BPF程序安全的BPF驗(yàn)證器,然后以BPF程序的工具集BCC為例,分享kprobes和tracepoints類型的BPF程序的使用及程序編寫示例。

2. BPF驗(yàn)證器

BPF借助跟蹤探針收集信息并進(jìn)行調(diào)試和分析,與其它依賴于重新編譯內(nèi)核的工具相比,BPF程序的安全性更高。重新編譯內(nèi)核引入外部模塊的方式,可能會(huì)因?yàn)槌绦虻腻e(cuò)誤而產(chǎn)生系統(tǒng)奔潰。BPF程序的驗(yàn)證器會(huì)在BPF程序加載到內(nèi)核之前分析程序,消除這種風(fēng)險(xiǎn)。

BPF驗(yàn)證器執(zhí)行的第一項(xiàng)檢查是對(duì)BPF虛擬機(jī)加載的代碼進(jìn)行靜態(tài)分析,目的是確保程序能夠按照預(yù)期結(jié)束。驗(yàn)證器在進(jìn)行第一項(xiàng)檢查時(shí)所做工作為:

程序不包含控制循環(huán);

程序不會(huì)執(zhí)行超過內(nèi)核允許的最大指令數(shù);

程序不包含任何無法到達(dá)的指令;

程序不會(huì)超出程序界限。

BPF驗(yàn)證器執(zhí)行的第二項(xiàng)檢查是對(duì)BPF程序進(jìn)行預(yù)運(yùn)行,所做工作為:

分析BPF程序執(zhí)行的每條指令,確保不會(huì)執(zhí)行無效指令;

檢查所有內(nèi)存指針是否可以正確訪問和引用;

預(yù)運(yùn)行將程序控制流的執(zhí)行結(jié)果通知驗(yàn)證器,確保BPF程序最終都會(huì)執(zhí)行BPF_EXIT指令。

3. 內(nèi)核探針 kprobes

內(nèi)核探針可以跟蹤大多數(shù)內(nèi)核函數(shù),并且系統(tǒng)損耗最小。當(dāng)跟蹤的內(nèi)核函數(shù)被調(diào)用時(shí),附加到探針的BPF代碼將被執(zhí)行,之后內(nèi)核將恢復(fù)正常模式。

3.1 kprobes類BPF程序的優(yōu)缺點(diǎn)

優(yōu)點(diǎn) 動(dòng)態(tài)跟蹤內(nèi)核,可跟蹤的內(nèi)核函數(shù)眾多,能夠提取內(nèi)核絕大部分信息。

缺點(diǎn) 沒有穩(wěn)定的應(yīng)用程序二進(jìn)制接口,可能隨著內(nèi)核版本的演進(jìn)而更改。

3.2 kprobes

kprobe程序允許在執(zhí)行內(nèi)核函數(shù)之前插入BPF程序。當(dāng)內(nèi)核執(zhí)行到kprobe掛載的內(nèi)核函數(shù)時(shí),先運(yùn)行BPF程序,BPF程序運(yùn)行結(jié)束后,返回繼續(xù)開始執(zhí)行內(nèi)核函數(shù)。下面是一個(gè)使用kprobe的bcc程序示例,功能是監(jiān)控內(nèi)核函數(shù)kfree_skb函數(shù),當(dāng)此函數(shù)觸發(fā)時(shí),記錄觸發(fā)它的進(jìn)程pid,進(jìn)程名字和觸發(fā)次數(shù),并打印出觸發(fā)此函數(shù)的進(jìn)程pid,進(jìn)程名字和觸發(fā)次數(shù):

#!/usr/bin/python3

# coding=utf-8

from __future__ import print_function

from bcc import BPF

from time import sleep

# define BPF program

bpf_program = “”“

#include 《uapi/linux/ptrace.h》

struct key_t{

u64 pid;

};

BPF_HASH(counts, struct key_t);

int trace_kfree_skb(struct pt_regs *ctx) {

u64 zero = 0, *val, pid;

pid = bpf_get_current_pid_tgid() 》》 32;

struct key_t key = {};

key.pid = pid;

val = counts.lookup_or_try_init(&key, &zero);

if (val) {

(*val)++;

}

return 0;

}

”“”

def pid_to_comm(pid):

try:

comm = open(“/proc/%s/comm” % pid, “r”).read().rstrip()

return comm

except IOError:

return str(pid)

# load BPF

b = BPF(text=bpf_program)

b.attach_kprobe(event=“kfree_skb”, fn_name=“trace_kfree_skb”)

# header

print(“Tracing kfree_skb.。. Ctrl-C to end.”)

print(“%-10s %-12s %-10s” % (“PID”, “COMM”, “DROP_COUNTS”))

while 1:

sleep(1)

for k, v in sorted(b[“counts”].items(),key = lambda counts: counts[1].value):

print(“%-10d %-12s %-10d” % (k.pid, pid_to_comm(k.pid), v.value))

該bcc程序主要包括兩個(gè)部分,一部分是python語言,一部分是c語言。python部分主要做的工作是BPF程序的加載和操作BPF程序的map,并進(jìn)行數(shù)據(jù)處理。c部分會(huì)被llvm編譯器編譯為BPF字節(jié)碼,經(jīng)過BPF驗(yàn)證器驗(yàn)證安全后,加載到內(nèi)核中執(zhí)行。python和c中出現(xiàn)的陌生函數(shù)可以查下面這兩個(gè)手冊(cè),在此不再贅述:

python部分遇到的陌生函數(shù)可以查這個(gè)手冊(cè): 點(diǎn)此跳轉(zhuǎn)

c部分中遇到的陌生函數(shù)可以查這個(gè)手冊(cè): 點(diǎn)此跳轉(zhuǎn)

需要說明的是,該BPF程序類型是kprobe,它是在這里進(jìn)行程序類型定義的:

b.attach_kprobe(event=“kfree_skb”, fn_name=“trace_kfree_skb”)

b.attach_kprobe()指定了該BPF程序類型為kprobe;

event=“kfree_skb”指定了kprobe掛載的內(nèi)核函數(shù)為kfree_skb;

fn_name=“trace_kfree_skb”指定了當(dāng)檢測(cè)到內(nèi)核函數(shù)kfree_skb時(shí),執(zhí)行程序中的trace_kfree_skb函數(shù);

BPF程序的第一個(gè)參數(shù)總為ctx,該參數(shù)稱為上下文,提供了訪問內(nèi)核正在處理的信息,依賴于正在運(yùn)行的BPF程序的類型。CPU將內(nèi)核正在執(zhí)行任務(wù)的不同信息保存在寄存器中,借助內(nèi)核提供的宏可以訪問這些寄存器,如PT_REGS_RC。

程序運(yùn)行結(jié)果如下:

e2411330-a100-11eb-8b86-12bb97331649.png

3.3 kretprobes

相比于內(nèi)核探針kprobe程序,kretprobe程序是在內(nèi)核函數(shù)有返回值時(shí)插入BPF程序。當(dāng)內(nèi)核執(zhí)行到kretprobe掛載的內(nèi)核函數(shù)時(shí),先執(zhí)行內(nèi)核函數(shù),當(dāng)內(nèi)核函數(shù)返回時(shí)執(zhí)行BPF程序,運(yùn)行結(jié)束后返回。

以上面的BPF程序?yàn)槔?,若要使用kretprobe,可以這樣修改:

b.attach_kretprobe(event=“kfree_skb”, fn_name=“trace_kfree_skb”)

b.attach_kretprobe()指定了該BPF程序類型為kretprobe,kretprobe類型的BPF程序?qū)⒃诟櫟膬?nèi)核函數(shù)有返回值時(shí)執(zhí)行BPF程序;

event=“kfree_skb”指定了kretprobe掛載的內(nèi)核函數(shù)為kfree_skb;

fn_name=“trace_kfree_skb”指定了當(dāng)內(nèi)核函數(shù)kfree_skb有返回值時(shí),執(zhí)行程序中的trace_kfree_skb函數(shù);

4. 內(nèi)核靜態(tài)跟蹤點(diǎn) tracepoint

tracepoint是內(nèi)核靜態(tài)跟蹤點(diǎn),它與kprobe類程序的主要區(qū)別在于tracepoint由內(nèi)核開發(fā)人員在內(nèi)核中編寫和修改。

4.1 tracepoint 程序的優(yōu)缺點(diǎn)

優(yōu)點(diǎn) 跟蹤點(diǎn)是靜態(tài)的,ABI更穩(wěn)定,不隨內(nèi)核版本的變化而致不可用。

缺點(diǎn) 跟蹤點(diǎn)是內(nèi)核人員添加的,不會(huì)全面涵蓋內(nèi)核的所有子系統(tǒng)。

4.2 tracepoint 可用跟蹤點(diǎn)

系統(tǒng)中所有的跟蹤點(diǎn)都定義在/sys/kernel/debug/traceing/events目錄中:

e24d14fa-a100-11eb-8b86-12bb97331649.png

使用命令perf list 也可以列出可使用的tracepoint點(diǎn):

e2629bc2-a100-11eb-8b86-12bb97331649.png

對(duì)于bcc程序來說,以監(jiān)控kfree_skb為例,tracepoint程序可以這樣寫:

b.attach_tracepoint(tp=“skb:kfree_skb”, fn_name=“trace_kfree_skb”)

bcc遵循tracepoint命名約定,首先是指定要跟蹤的子系統(tǒng),這里是“skb:”,然后是子系統(tǒng)中的跟蹤點(diǎn)“kfree_skb”:

e29048b0-a100-11eb-8b86-12bb97331649.png

5. 總結(jié)

本文主要介紹了保證BPF程序安全的BPF驗(yàn)證器,然后以BPF程序的工具集BCC為例,分享了kprobes和tracepoints類型的BPF程序的使用及程序編寫示例。本文分享的是內(nèi)核跟蹤,那么用戶空間程序該如何跟蹤呢,這將在后面的文章中逐步分享,感謝閱讀。

原文標(biāo)題:梁金榮:使用eBPF追蹤LINUX內(nèi)核

文章出處:【微信公眾號(hào):Linuxer】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

責(zé)任編輯:haq

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

    關(guān)注

    4

    文章

    1468

    瀏覽量

    42875
  • Linux
    +關(guān)注

    關(guān)注

    88

    文章

    11760

    瀏覽量

    219032
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    村田通信設(shè)備濾波:選型與應(yīng)用指南

    、性能優(yōu)良。今天,我們就來深入了解一下村田的各類濾波。 文件下載: LFB2H2G45SG7B734.pdf 一、芯片多層LC濾波 1. BPF濾波 村田的
    的頭像 發(fā)表于 01-30 17:45 ?1224次閱讀

    深入解析WE-BPF多層芯片帶通濾波:設(shè)計(jì)、特性與應(yīng)用考量

    深入解析WE-BPF多層芯片帶通濾波:設(shè)計(jì)、特性與應(yīng)用考量 在電子設(shè)備的設(shè)計(jì)中,濾波是保障信號(hào)質(zhì)量和系統(tǒng)穩(wěn)定性的關(guān)鍵組件。今天,我們將詳細(xì)剖析Würth Elektronik eiSos
    的頭像 發(fā)表于 01-29 16:45 ?216次閱讀

    深入了解WE - BPF多層芯片帶通濾波:從規(guī)格到應(yīng)用注意事項(xiàng)

    深入了解WE-BPF多層芯片帶通濾波:從規(guī)格到應(yīng)用注意事項(xiàng) 在電子設(shè)備的設(shè)計(jì)過程中,濾波是不可或缺的重要組件,它能夠?qū)π盘?hào)進(jìn)行篩選和處理,保證設(shè)備正常運(yùn)行。今天我們就來詳細(xì)探討Wü
    的頭像 發(fā)表于 01-07 18:10 ?737次閱讀

    詳解WE - BPF多層芯片帶通濾波:從參數(shù)到使用注意事項(xiàng)

    詳解WE - BPF多層芯片帶通濾波:從參數(shù)到使用注意事項(xiàng) 在電子產(chǎn)品的設(shè)計(jì)中,濾波是一個(gè)至關(guān)重要的組件,它能夠幫助我們精確地篩選出所需頻率的信號(hào),抑制不需要的干擾。今天,我們就來詳細(xì)了解一下W
    的頭像 發(fā)表于 12-29 15:55 ?286次閱讀

    探索YAGEO Phicomp 2.4 - 2.5 GHz帶通濾波:設(shè)計(jì)與性能解析

    帶通濾波——BPF1608LM02R2400A,它屬于1608系列,工作頻率在2.4 - 2.5 GHz,在眾多無線應(yīng)用中有著廣泛的用途。 文件下載: BPF1608LM02R2400A.pdf 產(chǎn)品
    的頭像 發(fā)表于 12-28 17:40 ?1144次閱讀

    村田通信設(shè)備濾波:技術(shù)特性與應(yīng)用解析

    的一系列濾波產(chǎn)品在通信設(shè)備中得到了廣泛應(yīng)用。本文將詳細(xì)介紹村田通信設(shè)備濾波的多種類型、技術(shù)特性以及應(yīng)用場(chǎng)景。 文件下載: LFL215G51TC1A149.pdf 1. 濾波類型
    的頭像 發(fā)表于 12-24 17:00 ?368次閱讀

    單片機(jī)開發(fā)功能安全中編譯

    期間顯示的防御代碼。僅僅因?yàn)樵趩卧獪y(cè)試期間已經(jīng)實(shí)現(xiàn)了防御性代碼的覆蓋范圍,因此并不能保證其已存在于完整的系統(tǒng)中。 在功能安全這個(gè)陌生的領(lǐng)域,編譯可能超出了其要素。這就是為什么目標(biāo)代碼驗(yàn)證
    發(fā)表于 12-01 06:44

    JY-BPF-C4R5+帶通濾波技術(shù)解析:2-7MHz頻段的航空與通信系統(tǒng)核心組件

    在低頻射頻領(lǐng)域,2-7MHz頻段廣泛應(yīng)用于航空通信、專用通信系統(tǒng)等場(chǎng)景,對(duì)帶通濾波的插入損耗、阻抗匹配及環(huán)境適應(yīng)性提出了特殊要求。杰盈通訊推出的JY-BPF-C4R5+帶通濾波,憑借低插入損耗
    的頭像 發(fā)表于 11-17 15:05 ?377次閱讀
    JY-<b class='flag-5'>BPF</b>-C4R5+帶通濾波<b class='flag-5'>器</b>技術(shù)解析:2-7MHz頻段的航空與通信系統(tǒng)核心組件

    基于優(yōu)化算法的黑盒系統(tǒng)驗(yàn)證策略

    自動(dòng)駕駛的安全驗(yàn)證保證系統(tǒng)在給定環(huán)境中正確及安全操作的過程。系統(tǒng)的期望行為通過某些規(guī)范標(biāo)準(zhǔn)來定義,而系統(tǒng)失敗指其行為違反了這些規(guī)定。
    的頭像 發(fā)表于 10-16 10:32 ?550次閱讀
    基于優(yōu)化算法的黑盒系統(tǒng)<b class='flag-5'>驗(yàn)證</b>策略

    看不見的安全防線:信而泰儀表如何驗(yàn)證零信任有效性

    ——從靜態(tài)防御轉(zhuǎn)向動(dòng)態(tài)信任評(píng)估,從粗放權(quán)限分配轉(zhuǎn)向最小化權(quán)限原則。本文將深入解析零信任安全架構(gòu)的核心機(jī)理,并基于零信任實(shí)現(xiàn)方案,全面介紹如何通過信而泰測(cè)試儀表進(jìn)行專業(yè)驗(yàn)證,確保零信任的安全
    發(fā)表于 09-09 15:33

    如何驗(yàn)證硬件加速是否真正提升了通信協(xié)議的安全性?

    驗(yàn)證硬件加速是否真正提升通信協(xié)議的安全性,需從 安全功能正確性、抗攻擊能力增強(qiáng)、安全性能適配、合規(guī)一致性 等核心維度展開,結(jié)合實(shí)驗(yàn)室測(cè)試與真實(shí)場(chǎng)景驗(yàn)
    的頭像 發(fā)表于 08-27 10:16 ?1140次閱讀
    如何<b class='flag-5'>驗(yàn)證</b>硬件加速是否真正提升了通信協(xié)議的<b class='flag-5'>安全</b>性?

    編譯功能安全驗(yàn)證的關(guān)鍵要素

    在汽車、工業(yè)、醫(yī)療等安全關(guān)鍵型應(yīng)用中,確保功能安全合規(guī)性需要嚴(yán)格的工具鏈驗(yàn)證。開發(fā)安全關(guān)鍵型軟件的企業(yè)必須遵守ISO 26262、IEC 61508、ISO 62304等國際標(biāo)準(zhǔn)對(duì)編譯
    的頭像 發(fā)表于 07-05 13:37 ?1577次閱讀

    Analog Devices Inc. ADMV8526-EVALZ評(píng)估板數(shù)據(jù)手冊(cè)

    Analog Devices Inc. ADMV8526-EVALZ評(píng)估板用于評(píng)估ADMV8526數(shù)字可調(diào)諧帶通濾波 (BPF)。ADMV8526具有1.25GHz至2.60GHz可調(diào)F~CENTER~頻率范圍,采用8位值(256狀態(tài)),集成正在申請(qǐng)專利的插值技術(shù)。
    的頭像 發(fā)表于 06-20 14:37 ?837次閱讀
    Analog Devices Inc. ADMV8526-EVALZ評(píng)估板數(shù)據(jù)手冊(cè)

    超窄帶低波數(shù)拉曼濾光片的新升級(jí)(from 360-3000nm)

    超窄帶低波數(shù)拉曼濾光片的新升級(jí)from360nmto3000nm超窄帶陷波濾光片(BraggNotchFilter,簡稱BNF)和帶通濾光片(BraggBandpassFilter,簡稱BPF
    的頭像 發(fā)表于 05-28 11:13 ?2408次閱讀
    超窄帶低波數(shù)拉曼濾光片的新升級(jí)(from 360-3000nm)

    超窄帶低波數(shù)拉曼濾光片的新升級(jí)(from 350nm to 3000nm)

    超窄帶陷波濾光片(Bragg Notch Filter,簡稱BNF)和帶通濾光片(Bragg Bandpass Filter,簡稱BPF)是目前實(shí)現(xiàn)超低波數(shù)拉曼光譜(通常50cm-1以下才稱為超低波數(shù)拉曼)測(cè)量常用的方法。設(shè)計(jì)波長覆蓋350-3000nm波段,超低波數(shù)拉曼信號(hào)可低至10cm-1.
    的頭像 發(fā)表于 04-09 16:54 ?902次閱讀
    超窄帶低波數(shù)拉曼濾光片的新升級(jí)(from 350nm to 3000nm)