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

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(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)時鐘、復(fù)位

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

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

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

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

- 上電復(fù)位(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之間。

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

poYBAGMcJ6uALowSAACDqBmLoFM350.png

審核編輯:湯梓紅

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

    關(guān)注

    146

    文章

    17301

    瀏覽量

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

    關(guān)注

    0

    文章

    278

    瀏覽量

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

    關(guān)注

    45

    文章

    2314

    瀏覽量

    46343
收藏 人收藏

    評論

    相關(guān)推薦

    華為云 X 實例 CPU 性能測試詳解與優(yōu)化策略

    ? 2.2 Sysbench單線程CPU性能測試 ? 2.3 Sysbench多線程CPU性能測試(4線程) ? 2.4 高強度
    的頭像 發(fā)表于 12-30 14:52 ?146次閱讀
    華為云 X 實例 CPU 性能<b class='flag-5'>測試</b>詳解與優(yōu)化策略

    socket 多線程編程實現(xiàn)方法

    在現(xiàn)代網(wǎng)絡(luò)編程中,多線程技術(shù)被廣泛應(yīng)用于提高服務(wù)器的并發(fā)處理能力。Socket編程是網(wǎng)絡(luò)通信的基礎(chǔ),而將多線程技術(shù)應(yīng)用于Socket編程,可以顯著提升服務(wù)器的性能。 多線程編程的基本概念 多線
    的頭像 發(fā)表于 11-12 14:16 ?430次閱讀

    Python中多線程和多進程的區(qū)別

    Python作為一種高級編程語言,提供了多種并發(fā)編程的方式,其中多線程與多進程是最常見的兩種方式之一。在本文中,我們將探討Python中多線程與多進程的概念、區(qū)別以及如何使用線程池與進程池來提高并發(fā)執(zhí)行效率。
    的頭像 發(fā)表于 10-23 11:48 ?455次閱讀
    Python中<b class='flag-5'>多線程</b>和多進程的區(qū)別

    一文掌握Python多線程

    使用線程可以把占據(jù)長時間的程序中的任務(wù)放到后臺去處理。
    的頭像 發(fā)表于 08-05 15:46 ?902次閱讀

    ESP32會不會有多線程問題,需要加鎖嗎?

    ESP32會不會有多線程問題,需要加鎖嗎
    發(fā)表于 07-19 08:05

    多線程設(shè)計模式到對 CompletableFuture 的應(yīng)用

    最近在開發(fā) 延保服務(wù) 頻道頁時,為了提高查詢效率,使用到了多線程技術(shù)。為了對多線程方案設(shè)計有更加充分的了解,在業(yè)余時間讀完了《圖解 Java 多線程設(shè)計模式》這本書,覺得收獲良多。本篇文章將介紹其中
    的頭像 發(fā)表于 06-26 14:18 ?402次閱讀
    從<b class='flag-5'>多線程</b>設(shè)計模式到對 CompletableFuture 的應(yīng)用

    基于全志T507-H的Linux-RT實時測試案例分享

    的POSIX API等),實現(xiàn)產(chǎn)品快速上市的期望。 Linux-RT實時測試(Cyclictest工具) Cyclictest常用于實時系統(tǒng)的基準(zhǔn)
    發(fā)表于 06-03 09:50

    bootloader開多線程做引導(dǎo)程序,跳app初始化后直接進hardfualt,為什么?

    如標(biāo)題,想做一個遠程升級的項目,bootloader引導(dǎo)區(qū)域和app都是開多線程跑的,就是自己寫了個小的任務(wù)調(diào)度器,沒什么功能主要是想讓程序快速的響應(yīng),延時不會對其他程序造成堵塞,程序測試
    發(fā)表于 04-18 06:07

    鴻蒙OS開發(fā)實例:【ArkTS類庫多線程CPU密集型任務(wù)TaskPool】

    CPU密集型任務(wù)是指需要占用系統(tǒng)資源處理大量計算能力的任務(wù),需要長時間運行,這段時間會阻塞線程其它事件的處理,不適宜放在主線程進行。例如圖像處理、視頻編碼、數(shù)據(jù)分析等。 基于多線程并發(fā)機制處理CPU密集型任務(wù)可以提高CPU
    的頭像 發(fā)表于 04-01 22:25 ?875次閱讀
    鴻蒙OS開發(fā)實例:【ArkTS類庫<b class='flag-5'>多線程</b>CPU密集型任務(wù)TaskPool】

    鴻蒙APP開發(fā):【ArkTS類庫多線程】TaskPool和Worker的對比

    TaskPool(任務(wù)池)和Worker的作用是為應(yīng)用程序提供一個多線程的運行環(huán)境,用于處理耗時的計算任務(wù)或其他密集型任務(wù)??梢杂行У乇苊膺@些任務(wù)阻塞主線程,從而最大化系統(tǒng)的利用率,降低整體資源消耗,并提高系統(tǒng)的整體性能。
    的頭像 發(fā)表于 03-26 22:09 ?690次閱讀
    鴻蒙APP開發(fā):【ArkTS類庫<b class='flag-5'>多線程</b>】TaskPool和Worker的對比

    鴻蒙原生應(yīng)用開發(fā)-ArkTS語言基礎(chǔ)類庫多線程I/O密集型任務(wù)開發(fā)

    使用異步并發(fā)可以解決單次I/O任務(wù)阻塞的問題,但是如果遇到I/O密集型任務(wù),同樣會阻塞線程中其它任務(wù)的執(zhí)行,這時需要使用多線程并發(fā)能力來進行解決。 I/O密集型任務(wù)的性能重點通常不在于CPU的處理
    發(fā)表于 03-21 14:57

    java實現(xiàn)多線程的幾種方式

    Java實現(xiàn)多線程的幾種方式 多線程是指程序中包含了兩個或以上的線程,每個線程都可以并行執(zhí)行不同的任務(wù)或操作。Java中的多線程可以提高程序
    的頭像 發(fā)表于 03-14 16:55 ?767次閱讀

    AT socket可以多線程調(diào)用嗎?

    請問AT socket 可以多線程調(diào)用嗎? 有互鎖機制嗎,還是要自己做互鎖。
    發(fā)表于 03-01 08:22

    什么是多核多線程?多核多線程如何提高程序的運行效率?

    線程無法充分利用多核處理器的并行計算能力。
    的頭像 發(fā)表于 02-20 10:22 ?1453次閱讀

    linux多線程編程實例

    linux線程
    的頭像 發(fā)表于 02-15 21:16 ?508次閱讀
    linux<b class='flag-5'>多線程</b>編程實例
    主站蜘蛛池模板: 狠狠狠色丁香婷婷综合久久88| 久久青草精品免费资源站| 手机看片欧美日韩| 美女视频黄又黄又免费高清| 中文字幕在线乱码免费毛片| 久久综合视频网| 欧美黑人粗硬大在线看| 尻逼尻逼| bt天堂在线观看| 久久作爱视频| 成年片色大黄全免费| 国产真实乱xxxav| 美女扒开尿口给男人桶爽视频| 成年毛片| 久久综合色区| 国产三级精品播放| 午夜视频在线观看www中文| www.综合色| 国产特级毛片aaaaaa毛片| 操美女网址| 欧美一级特黄aaaaaa在线看首页| 亚色综合| 久操视频在线播放| 九九草在线观看| 欧美人与zoxxxx视频| 成人中文字幕一区二区三区 | 日本一二区视频| 欧美极品第1页专区| 欧美一二三区在线| 日本不卡视频在线观看| 中文字幕第二区| 性欧美黑人| 绝色村妇的泛滥春情| 特级黄一级播放| 久久久久免费精品国产| 午夜视频在线观看一区二区| 亚洲国产精品热久久2022| 成人免费久久精品国产片久久影院 | 五月婷六月| 校园激情综合网| 免费视频一区二区性色|