日B视频 亚洲,啪啪啪网站一区二区,91色情精品久久,日日噜狠狠色综合久,超碰人妻少妇97在线,999青青视频,亚洲一区二卡,让本一区二区视频,日韩网站推荐

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

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

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

感芯科技MC3172多線程實時性測試

韓曉宇 ? 來源:韓曉宇 ? 作者:韓曉宇 ? 2022-09-13 09:15 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

之前在網(wǎng)上看到了感芯科技MC3172MCU,看介紹有硬件64位多線程處理,甚是感興趣,最近有幸收到一塊開發(fā)板,所以進行部分性能方面的測試。


MC3172簡介

感芯科技第一款32 位 RISC 處理器 MC3172 ,業(yè)內(nèi)首個64線程同步并行運行,線程資源可按需配置,

共享代碼段空間與數(shù)據(jù)段空間,硬件級實時響應(yīng),無需中斷服務(wù)程序,無需實時操作系統(tǒng)。

基于RISC-V RV32IMC 指令集,100%單周期指令,最高200MHz主頻,3.37coremark/MHz。

數(shù)據(jù)段與代碼段共享128K字節(jié)SRAM,可按需配置為96K代碼空間加32K數(shù)據(jù)空間,或64K代碼空間加

64K數(shù)據(jù)空間,或32K代碼空間加96K數(shù)據(jù)空間,靈活應(yīng)對各種應(yīng)用場景。

擁有豐富片內(nèi)外設(shè):12個可配置通信接口,可按需配置為UASRT或SPI或USBCAN總線形式,滿足多通

端口需求;6個雙緩沖24位計數(shù)器,可提供高精度PWM與輸入捕捉;64個GPIO,可提供豐富的自定義控制

接口。

產(chǎn)品特性

內(nèi)核 Core:

- 基于 RV32IMC 指令集,單周期乘法

- 64路線程同步并行運行,無需線程切換

- 線程資源可按需配置且無需操作系統(tǒng)

- 3.37coremark/MHz

- 100%單周期指令,時序確定

- 最高 200MHz 系統(tǒng)主頻

存儲器:

- 128KB SRAM可按需分配為:

96K代碼空間+32K數(shù)據(jù)空間

64K代碼空間+64K數(shù)據(jù)空間

32K代碼空間+96K數(shù)據(jù)空間

電源管理和低功耗:

- 核心供電電壓范圍:1.8V~1.98V,

- GPIO供電電壓:1.8V~3.3V

系統(tǒng)時鐘、復位

- 內(nèi)嵌 200MHz RC 振蕩器

- 內(nèi)嵌 8MHz RC 振蕩器

- 外部支持 4MHz~40MHz 高速振蕩器

- 外部支持 最高133MHz 輸入時鐘

- 上電復位(POR)


多線程實時性測試

由于這個芯片其他的測試例如引腳配置、定時器配置、串口配置等網(wǎng)友已經(jīng)有諸多帖子,所以我只對目前我感覺好奇的多線程實時性進行測試。

1.多線程配置(使用線程0、1、2、3,分頻?主頻)

這里我們4個線程組每個僅使用1個線程,分頻每個均為?主頻。線程空間定位2048字節(jié)。

pYYBAGMcGpqAAFsUAAGNlJ2V_h0268.png

2.測試思路和主要程序代碼

在僅配置4個線程的情況下,我們在不同的線程中通過切換GPIO0、1、2的引腳電平來判斷具體線程的響應(yīng)時序。具體配置如下:

線程0:用來初始化GPIOA引腳的0、1、2為輸出引腳。初始化完成后,設(shè)定全局變量u8g_sysInitSuccessFlg為1;

初始化完成后,每等待150個延時周期,對u8g_gpioAllowToggleFlg取反,并反轉(zhuǎn)GPIOA0。

線程1:等待線程0對GPIO初始化完成后,實時檢測u8g_gpioAllowToggleFlg的狀態(tài),并對GPIOA1進行翻轉(zhuǎn)。

線程2:等待線程0對GPIO初始化完成后,實時檢測u8g_gpioAllowToggleFlg的狀態(tài),并對GPIOA2進行翻轉(zhuǎn)。

通過對比上升沿的時間差,即可知道線程運行的時序差。

volatile u8 u8g_sysInitSuccessFlg=0;
volatile u8 u8g_gpioAllowToggleFlg=0;
void thread0_main(void)
{
    while(1){
        u32 u32gpioToggleDelayCnt;
        INTDEV_SET_CLK_RST(GPIOA_BASE_ADDR,(INTDEV_RUN|INTDEV_IS_GROUP0|INTDEV_CLK_IS_CORECLK_DIV2));
        GPIO_SET_OUTPUT_EN_VALUE(GPIOA_BASE_ADDR,GPIO_PIN0,GPIO_SET_ENABLE);
        GPIO_SET_OUTPUT_EN_VALUE(GPIOA_BASE_ADDR,GPIO_PIN1,GPIO_SET_ENABLE);
        GPIO_SET_OUTPUT_EN_VALUE(GPIOA_BASE_ADDR,GPIO_PIN2,GPIO_SET_ENABLE);
        GPIO_SET_OUTPUT_EN_VALUE(GPIOA_BASE_ADDR,GPIO_PIN3,GPIO_SET_ENABLE);
        u8g_sysInitSuccessFlg = 1;
        while(1){
            u32gpioToggleDelayCnt = 150;
            while(u32gpioToggleDelayCnt--){NOP();}
            u8g_gpioAllowToggleFlg = !u8g_gpioAllowToggleFlg;
            GPIO_SET_OUTPUT_PIN_INV(GPIOA_BASE_ADDR,GPIO_PIN0);
        }
    }
    thread_end();
}
void thread1_main(void)
{
    while(1){
        while(!u8g_sysInitSuccessFlg){NOP();}
        while(1){
            if(u8g_gpioAllowToggleFlg){
                GPIO_SET_OUTPUT_PIN_TO_1(GPIOA_BASE_ADDR,GPIO_PIN1);
            }else{
                GPIO_SET_OUTPUT_PIN_TO_0(GPIOA_BASE_ADDR,GPIO_PIN1);
            }
        }
    }
    thread_end();
}
void thread2_main(void)
{
    while(1){
        while(!u8g_sysInitSuccessFlg){NOP();}
        while(1){
            if(u8g_gpioAllowToggleFlg){
                GPIO_SET_OUTPUT_PIN_TO_1(GPIOA_BASE_ADDR,GPIO_PIN2);
            }else{
                GPIO_SET_OUTPUT_PIN_TO_0(GPIOA_BASE_ADDR,GPIO_PIN2);
            }
        }
    }
    thread_end();
}

3.測試結(jié)果

信號說明:

黃色:GPIOA0電平 藍色:GPIOA1電平

(1).整體波形

pYYBAGMcIHCAP8nPAAC5G7K6gk4795.png

整體波形看起來線程基本時同時切換,同步運行,下面放大看看。

(2).上升沿觸發(fā)波形

pYYBAGMcIRuAKp3EAADJ8eLJusU710.png

注意:這里采用示波器的auto觸發(fā)模式,可以抓到每次觸發(fā)的時間會有不同,

  • 最快從線程1切換到線程2的時間為40ns左右。
  • 最慢從線程1切換到線程2的時間為120ns左右。

(3)結(jié)果分析

目前芯片配置為內(nèi)部高速RC時鐘200Mhz,配置每個線程的主頻為?主頻,也就是50Mhz。

此時對應(yīng)的線程切換時間范圍應(yīng)該在40ns~120ns之間。

我分析在當前配置下,硬件核心線程切換邏輯是:

poYBAGMcJ6uALowSAACDqBmLoFM350.png

審核編輯:湯梓紅

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

    關(guān)注

    147

    文章

    19160

    瀏覽量

    404810
  • 多線程
    +關(guān)注

    關(guān)注

    0

    文章

    279

    瀏覽量

    21133
  • RISC-V
    +關(guān)注

    關(guān)注

    49

    文章

    2954

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

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

    逆風C++QT中控臺逆向課程

    ,成為眾多應(yīng)用程序開發(fā)的熱門選擇。尤其在工業(yè)中控系統(tǒng)中,QT的多線程處理能力和消息通信機制,為復雜業(yè)務(wù)邏輯的高效執(zhí)行提供了堅實基礎(chǔ)。然而,當需要對這些QT應(yīng)用進行逆向分析時,多線程邏輯與消息處理的復雜便成為首要挑戰(zhàn)。
    的頭像 發(fā)表于 04-27 10:06 ?74次閱讀

    Java并發(fā)編程的“基石”——多線程概念初識

    。Java 的內(nèi)存可見性機制(如 happens-before 原則)能夠確保在極端并發(fā)下,任何一個調(diào)度節(jié)點看到的集群狀態(tài)都是一致且準確的,從根本上杜絕了“腦裂”和資源超賣。 其次是 精妙的多線程協(xié)同
    發(fā)表于 04-16 18:50

    【瑞薩RA × Zephyr評測】多線程和看門狗

    本文章旨在評估使用 Zephyr RTOS 在 Renesas FPB-RA6E2 開發(fā)板上實現(xiàn)多線程調(diào)度與硬件看門狗功能的應(yīng)用。評估內(nèi)容包括任務(wù)調(diào)度、看門狗初始化流程、主程序邏輯的詳細解析,以及實驗現(xiàn)象與數(shù)據(jù)分析。
    的頭像 發(fā)表于 01-10 10:23 ?2678次閱讀
    【瑞薩RA × Zephyr評測】<b class='flag-5'>多線程</b>和看門狗

    解析Linux的進程、線程和協(xié)程

    和系統(tǒng)資源。線程的引入使得多核處理器得以充分利用,因為多線程程序可以更有效地分配和管理多核心的計算資源。 線程的特點包括: (1)共享線程
    發(fā)表于 12-22 11:00

    多線程的系統(tǒng)

    的優(yōu)先級足夠高,就會立馬得到響應(yīng)。相比其他裸機系統(tǒng),多線程系統(tǒng)的實時又被提高了。 多線程系統(tǒng)大概的偽代碼具體見代碼清單所示: int flag1 = 0; int flag2 =
    發(fā)表于 12-08 07:55

    Linux多線程對比單線程的優(yōu)勢

    ?!柑岣唔憫?yīng)」:線程可以使程序更加響應(yīng)用戶輸入或其他事件,避免阻塞。線程相比單線程的優(yōu)點:「并發(fā)性」:多線程可以同時執(zhí)行多個任務(wù),而單
    發(fā)表于 12-01 06:11

    RK3588核心板/開發(fā)板RT-Linux系統(tǒng)實時及硬件中斷延遲測試

    本文介紹瑞微RK3588芯片平臺RT-Linux系統(tǒng)實時及硬件中斷延遲測試,基于觸覺智能RK3588核心板/開發(fā)板演示。Linux-RT實時
    的頭像 發(fā)表于 11-28 18:57 ?1055次閱讀
    RK3588核心板/開發(fā)板RT-Linux系統(tǒng)<b class='flag-5'>實時</b><b class='flag-5'>性</b>及硬件中斷延遲<b class='flag-5'>測試</b>

    【飛凌OK153-S開發(fā)板評測】系統(tǒng)實時及codesys測試

    接牛刀小試章節(jié),今天我們主要測試下OK153-S開發(fā)板系統(tǒng)實時以及是否可以跑codesys底層runtime。 因OK153-S開發(fā)板只有一個網(wǎng)口,后面跑codesys測試Ether
    發(fā)表于 11-28 14:00

    【飛凌OK-T153 開發(fā)板試用】實時測試

    實時測試 本文以cyclictest工具為例測試中斷響應(yīng)時間或延遲 cyclictest所測得的延時包含中斷延時 + 調(diào)度延時兩部分,如下圖 中斷延時(interrupt late
    發(fā)表于 11-22 05:29

    rt-thread studio 如何進行多線程編譯?

    ,使用的是5800h+32g內(nèi)存+sn550 ssd,開啟16線程編譯時cpu的占用率也只能到30%,編譯完整個工程需要3分鐘 感覺多線程編譯設(shè)置沒有生效,有辦法提高編譯速度嗎 rtthread studio版本是 2.2.9
    發(fā)表于 10-11 09:16

    RK3576核心板/開發(fā)板RT-Linux系統(tǒng)實時及硬件中斷延遲測試

    本文介紹瑞微RK3576芯片平臺RT-Linux系統(tǒng)實時及硬件中斷延遲測試,基于觸覺智能RK3576開發(fā)板PurplePiOH2演示。Linux-RT
    的頭像 發(fā)表于 09-30 16:52 ?2204次閱讀
    RK3576核心板/開發(fā)板RT-Linux系統(tǒng)<b class='flag-5'>實時</b><b class='flag-5'>性</b>及硬件中斷延遲<b class='flag-5'>測試</b>

    微RK35XX系列Linux實時詳細測試對比( PREEMPT_RT和Xenomai )

    需求。本文基于觸覺智能旗下瑞微RK系列開發(fā)板,歷經(jīng)240小時實測!展開RT-Linux實時系統(tǒng)兩大內(nèi)核:PREEMPT_RT與Xenomai實時
    的頭像 發(fā)表于 09-30 16:37 ?2145次閱讀
    瑞<b class='flag-5'>芯</b>微RK35XX系列Linux<b class='flag-5'>實時</b><b class='flag-5'>性</b>詳細<b class='flag-5'>測試</b>對比( PREEMPT_RT和Xenomai )

    【HZ-T536開發(fā)板免費體驗】—— linux創(chuàng)建線程

    自己的私有資源。 在linux系統(tǒng)中,線程狀態(tài)通常反映了當前線程的當前活動和執(zhí)行階段。 主要分為: 1。運行轉(zhuǎn)態(tài) 2。阻塞轉(zhuǎn)態(tài) 3。終止狀態(tài) 如何區(qū)分單線程多線程? 在單個程序中只
    發(fā)表于 09-01 21:31

    多線程的安全注意事項

    多線程安全是指多個線程同時訪問或修改共享資源時,能夠保證程序的正確和可靠。 開發(fā)者選擇TaskPool或Worker進行多線程開發(fā)時,在
    發(fā)表于 06-20 07:49

    工控一體機多線程任務(wù)調(diào)度優(yōu)化:聚徽分享破解工業(yè)復雜流程高效協(xié)同密碼

    在當今工業(yè) 4.0 的浪潮下,工業(yè)生產(chǎn)正朝著高度自動化、智能化的方向大步邁進。生產(chǎn)流程日益復雜,眾多任務(wù)需要同時、高效地協(xié)同執(zhí)行,這對工業(yè)控制系統(tǒng)的核心 —— 工控一體機提出了前所未有的挑戰(zhàn)。多線程
    的頭像 發(fā)表于 05-28 14:06 ?754次閱讀
    保山市| 山阳县| 石楼县| 维西| 岳普湖县| 通辽市| 滁州市| 西丰县| 舟曲县| 安远县| 思茅市| 黄骅市| 横山县| 锡林郭勒盟| 丹棱县| 阜城县| 新田县| 阿克陶县| 正镶白旗| 吉林市| 怀安县| 萍乡市| 庄浪县| 安国市| 来安县| 陇川县| 霍城县| 明水县| 凌云县| 宝兴县| 潮州市| 沛县| 永宁县| 烟台市| 阳春市| 吉首市| 佛冈县| 新龙县| 峨边| 余庆县| 翁牛特旗|