精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

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

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

3天內不再提示

揭秘ARM架構對Linux調測特性的支持

Linux閱碼場 ? 來源:Linux閱碼場 ? 作者:Linux閱碼場 ? 2022-08-22 14:51 ? 次閱讀

一、淺談手機性能的可觀測性

1.概述

手機上的性能指標是綜合的變化,由上圖可以看的出來手機更關注人跟機器的交互這,云系統則是比較關注機器跟機器的交互。

手機系統比較特別的地方在于資源都是比較受限,例如: 電量,性能…因此針對用戶體驗是需要特別庖丁解牛來建立指標。

指標(METRIC) -業界有特定的體驗度量模型,目標是發現產品和服務中的問題及理解使用者的行為和偏好。

性能體驗度量是多層次,多個維度的,只用一項指標去表征的所有性能特征是遠遠不夠的。

c5bf8638-21c9-11ed-ba43-dac502259ad0.png

以上是幾個個常用指標,這些指標常常是互相搭配的例如Andrid近年常用的GSM+HEART。度量模型圍繞用戶使用的旅程,識別關鍵體驗路徑(KEP),為不同接觸點分解出不同的性能指標。

2.性能追蹤

c5d29066-21c9-11ed-ba43-dac502259ad0.png

實際上如何構建手機可觀測性,我們都會采取分層次拆解,由上圖可以看的出來藉助于Android/Linux系統的生態系已經有不少工具可以用于追蹤系統的信息

性能追蹤在手機裝置面臨的挑戰:

1、低開銷:不會降低用戶的體驗,因為手機資源是受限的所以如何有性的采集會是很大的考驗。

2、不可接觸:開發人員無法實時獲取使用者的故障第一現場信息,用戶很多操作行為都是不容易在現,因此識別關鍵體驗路徑會是開發的過程之一。

3、偶發性:低概率,不易復現(Heisen berg Bug),對于第三方應用跟系統交互或是用戶行為常常有偶發性不易在現的問題需要準確的追蹤機制輔助找到原因。

4、不可預見:用已知模式分析未知問題。

講師介紹了一些Android上常見的工具

?Systrace : 用于將設備活動保存到跟蹤檔的Android 工具。

?cpu_profile : 在android平臺實現周期性采集調用棧。

?simpleperf : simpleperf是Anroid平臺的一套性能分析工具,功能大致與linux perf相似。

?nanotrace : 通過在虛擬機(包括解析器和編譯程序)中插樁,獲取從APK到framework層的執行路徑的調用鏈和函數執行時長。

?objtrace : 動態跟蹤函數參數值。

?blktrace : blktrace 結合btt可以統計一個IO是在調度隊列停留的時間長,還是在硬件上消耗的時間長。

?Hitrace : 對于跨設備/進程/線程的業務流程處理,通過相同的traceid在整個業務流程中傳遞,將調用層次、各種輸出信息關聯和展現。

3.可觀測性之Logging

c5dd7d64-21c9-11ed-ba43-dac502259ad0.png

上圖由上而下的拆解展示日志的重要性,首先我們需要了解用戶行為,關注用戶體驗并記錄對應的錯誤日志,當時系統狀態與硬件狀態用于改善用戶體驗。

手機系統的日志系統時常需要整合第三方應用,因為第三方應用不開源,管理日志上常常沒有足夠權限,還有手機儲存大小受限因此最終的日志系統方案都是朝可以匯整日志并更精準建立模型為目標。

總結以上幾點用戶體驗是感性的,不單單只是數字因此講者認科技應該是有溫度的。

Q&A

Q : 是否有AI優化思路?

A: 目前還在努力,有嘗試用AI分析用戶體驗不過效果不明顯。目前比較多還是在做基礎體驗度量。

Q : 跑分跟用戶體驗怎么看?

A: 跑分不能直接當用戶體驗偵率,累積布局偏移可參考。

Q: nanotrace可否第三方插莊?

A: yes

Q : 是否能找到喚醒源?

A:可打開irq,ipi中斷事件可以看到換醒源。

二、揭秘ARM架構對Linux調測特性的支持

講師簡介:張健, 現就職于北京大簡技術有限公司, 14年ARM架構和操作系統一線研發經驗. 在北京, 柏林, 拉斯維加斯, 多地發表技術演講。

首先,本次分享從調試視角、性能影響兩個角度出發,對調試特性進行了宏觀的分類。

1.調試類型

調試包含兩個維度的特性:調試視角維度與性能影響維度。

1.調試視角維度

從調試視角維度出發,調試分為external debug與self-hosted debug,前者包括openocd、kgdb、ftrace、perf等內核調試基礎設施,后者則是通過JTAG、FTOI等體系結構相關調試接口連接芯片,同時用調試軟件控制硬件調試器進行調試。

c5ee9414-21c9-11ed-ba43-dac502259ad0.png

其中,紅色所示技術為硬件調試接口,藍色所示技術為相關軟件調試工具。軟硬件調試工具共享CPU和內核所提供的調試能力。

2.性能影響維度

從性能影響維度出發,調試分為影響(多為停止)當前CPU狀態的侵入式調試和不影響CPU運行的非侵入式調試。前者多會暫停當前CPU的執行流,同時通過相關機制(比如,AR cross trigger)告知其他核當前被調試的狀態,從而影響系統狀態。

這種調試類型雖然帶來了強大的調試能力,但是在芯片和內核的設計開發時需要考慮CPU調試過程中與其他外圍設備的關系,因為CPU的調試狀態不會影響到其他硬件,一致性等問題是該方法的經典挑戰;對于非侵入式的調試類型,它不會直接停止當前的CPU運行狀態,更多對系統起到監控跟蹤的作用。

c5ff74d2-21c9-11ed-ba43-dac502259ad0.png

接下來,分享從斷點、Trace、PMU三類調試手段出發講述ARM架構的系統調試特性。

2.侵入式調試手段之斷點

斷點調試是侵入式的,單純依賴用戶態基礎設施或頂層應用無法達到啟停系統的能力要求。因此,斷點調試的設計需要硬件和操作系統的支持,即斷點調試要有陷入高特權級別環境的能力。

用戶通過配置編譯選項獲得指定平臺下的gdb調試器,將被追蹤程序當作參數傳遞gdb調試器,gdb調試器fork出被調試程序子進程,兩者通過PTRACE_XXX請求建立連接。

對于軟件斷點,gdb將通過符號表等信息在開發者指定的位置填入調試指令(x86為INT3,ARM為BRK/BRKT);對于硬件斷點,gdb會將指定位置的地址寫入到調試寄存器中。

當程序運行至軟件斷點或硬件斷點處,子進程會觸發相應異常,待異常信號被gdb捕獲后,通過比對記錄的斷點信息來判斷是否是調試原因所觸發的異常,如此來實現gdb調試進程的啟停能力。

c60d1ea2-21c9-11ed-ba43-dac502259ad0.png

3.非侵入調試類型之Trace

ARM Coresight架構是遵循可觀測性的架構設計,Cortex Processor后的ETM負責在處理器外部抓取指令序列,不影響CPU的運行狀態。并且,Trace信息的傳輸未經系統總線,減少了對系統帶寬的影響。Coresight架構中存在多個執行流抓取點,存在多個對應的ETM,多個ETM收集的信息會傳入下游的Funnel,Funnel將根據數據所存在的信息將執行流信息進行分流處理。

c61a271e-21c9-11ed-ba43-dac502259ad0.png

關于具體的互聯結構可以查看對應版本的設備樹文件。(所在源碼目錄為/arch/arm64/boot/dts)

4.非侵入調試類型之Performance Monitor Unit(PMU)

CPU中存在PMU部件,該部件會監控CPU的相關性能信息,用戶可以通過訪問相應的寄存器獲取相關信息。perf是一種可以訪問PMU的用戶態工具。

c62d3b4c-21c9-11ed-ba43-dac502259ad0.png

perf訪問PMU的相關流程如下:

1.使用perf_pmu_register注冊PMU事件。

2.perf_event_open系統調用打開對應事件的文件描述符,從中讀取記錄的值。

審核編輯 :李倩

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

    關注

    68

    文章

    10825

    瀏覽量

    211149
  • Linux
    +關注

    關注

    87

    文章

    11229

    瀏覽量

    208927
  • ARM架構
    +關注

    關注

    14

    文章

    177

    瀏覽量

    36289

原文標題:PODS峰會筆記: 淺談手機性能的可觀測性&揭秘ARM架構對Linux調測特性的支持(Day3)

文章出處:【微信號:LinuxDev,微信公眾號:Linux閱碼場】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    什么是ARM架構?什么是X86架構?兩者的區別是什么?

    一、什么是ARM架構? (一)起源與發展 ARM 架構由英國劍橋的 Acorn 計算機公司開發。因市場無合適產品,Acorn 自行設計出第一款微處理器,命名為
    的頭像 發表于 09-06 10:40 ?675次閱讀

    ARMxy ARM工業邊緣計算網關帶Ubuntu OS支持二次開發

    OS的優勢以及二次開發的重要性。 一、ARMxy網關的技術特性 ARMxy系列邊緣計算網關是基于ARM架構設計的高性能計算設備,具備以下技術特性: 高性能處理器:采用先進的
    的頭像 發表于 08-19 15:32 ?340次閱讀
    ARMxy <b class='flag-5'>ARM</b>工業邊緣計算網關帶Ubuntu OS<b class='flag-5'>支持</b>二次開發

    請問Lierda 5G EVK具體支持哪些linux系統?

    Lierda 5G EVK這款產品的開發驅動適用于Ubantu 18.04或者centos嗎,ARM架構的主機,接這個調驅動麻不麻煩
    發表于 06-04 07:50

    Linux 6.10集成RISC-V更新,支持Rust編程語言

    本次補丁升級中,Linux內核進一步擴展了對應于RISC-V架構的Rust編程語言支持。在此之前,Rust已可應用在x86_64、龍芯LoongArch以及ARM64等多種
    的頭像 發表于 05-23 17:16 ?908次閱讀

    fpga封裝技術和arm架構的優缺點

    FPGA封裝技術和ARM架構是兩個不同的概念,分別屬于硬件設計的不同領域。
    的頭像 發表于 03-26 15:51 ?754次閱讀

    英特爾與Arm聯手助力初創企業開發Arm架構SoC

    據介紹,此次合作旨在聯合推動使用Intel 18A制程工藝研發Arm架構SoC的初創企業發展。英特爾和Arm將攜手提供IP和制造及相關金融支持,助力初創企業持續進行創新和增長。這些企業
    的頭像 發表于 03-25 15:34 ?365次閱讀

    Arm v9芯片新架構揭秘

    從中長期來看,隨著單芯片 ARM 核數增加、基于 ARM 架構芯片數量的上升以及ARM 應用場景的增加,公司仍將保持增長。據公司公告數據顯示,2023 財年,高端芯片采用
    發表于 02-27 14:14 ?5316次閱讀
    <b class='flag-5'>Arm</b> v9芯片新<b class='flag-5'>架構</b><b class='flag-5'>揭秘</b>

    arm架構和x86架構區別 linux是x86還是arm

    ARM架構和x86架構是兩種不同的計算機處理器架構,它們在體系結構、指令集、應用領域等方面有著明顯的區別。Linux操作系統則具有廣泛的適配
    的頭像 發表于 01-30 13:46 ?1.7w次閱讀

    arm開發板如何安裝linux系統

    工具和軟件: 一臺運行Linux系統的電腦 一個支持ARM架構的開發板 一個USB轉串口模塊 一根Micro USB線纜 一個SD卡讀卡器 一個空的SD卡 一個USB鍵盤和鼠標(可選)
    的頭像 發表于 01-24 14:19 ?3006次閱讀

    Linux內核中信號詳解

    ? 1 信號的角色 1.1 x86/64架構信號定義 1.2 ARM架構信號定義 1.3 RISC-V架構信號定義 1.4 信號的系統調用 1.5 信號工作原理 2 信號的響應行為 3
    的頭像 發表于 01-13 09:40 ?1331次閱讀
    <b class='flag-5'>Linux</b>內核中信號詳解

    rk3399移植Linux內核

    Linux內核移植到RK3399上。 首先,我們需要了解RK3399的硬件架構特性。RK3399采用的是ARM架構,具有雙核Cortex-
    的頭像 發表于 01-08 09:56 ?1056次閱讀

    Linux內核內存管理架構解析

    內存管理子系統可能是linux內核中最為復雜的一個子系統,其支持的功能需求眾多,如頁面映射、頁面分配、頁面回收、頁面交換、冷熱頁面、緊急頁面、頁面碎片管理、頁面緩存、頁面統計等,而且對性能也有很高
    的頭像 發表于 01-04 09:24 ?635次閱讀
    <b class='flag-5'>Linux</b>內核內存管理<b class='flag-5'>架構</b>解析

    Debian宣布停止i386架構支持

    近日,在英國劍橋市舉行的小規模DebConf活動中,Debian GNU/Linux的發布團隊召開春季會議,探討了未來發展方向,其中包括停止對i386架構支持
    的頭像 發表于 12-19 10:16 ?812次閱讀

    基于Debian的Sparky Linux 7.2的亮點

    Linux kernel 6.1 LTS 提供支持,Sparky Linux 7.2采用 LXQt 1.2.0 和 KDE Plasma 5.27.5,現在提供 ARMHF 和 ARM
    的頭像 發表于 12-14 10:13 ?570次閱讀
    基于Debian的Sparky <b class='flag-5'>Linux</b> 7.2的亮點

    Arm架構學習—開啟Armv9時代

    在上一篇文章“從A76到A78——在變化中學習Arm架構”中,我們了解了Arm處理器微架構的基本組成,介紹了Armv8架構最后幾代經典處理
    的頭像 發表于 11-27 16:46 ?1229次閱讀
    <b class='flag-5'>Arm</b>微<b class='flag-5'>架構</b>學習—開啟Armv9時代