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

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

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

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

感芯科技MC3172多線程實(shí)時(shí)性測(cè)試

韓曉宇 ? 來(lái)源:韓曉宇 ? 作者:韓曉宇 ? 2022-09-13 09:15 ? 次閱讀

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


MC3172簡(jiǎn)介

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

共享代碼段空間與數(shù)據(jù)段空間,硬件級(jí)實(shí)時(shí)響應(yīng),無(wú)需中斷服務(wù)程序,無(wú)需實(shí)時(shí)操作系統(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)對(duì)各種應(yīng)用場(chǎng)景。

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

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

接口

產(chǎn)品特性

內(nèi)核 Core:

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

- 64路線程同步并行運(yùn)行,無(wú)需線程切換

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

- 3.37coremark/MHz

- 100%單周期指令,時(shí)序確定

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

存儲(chǔ)器:

- 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)時(shí)鐘、復(fù)位

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

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

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

- 外部支持 最高133MHz 輸入時(shí)鐘

- 上電復(fù)位(POR)


多線程實(shí)時(shí)性測(cè)試

由于這個(gè)芯片其他的測(cè)試?yán)缫_配置、定時(shí)器配置、串口配置等網(wǎng)友已經(jīng)有諸多帖子,所以我只對(duì)目前我感覺(jué)好奇的多線程實(shí)時(shí)性進(jìn)行測(cè)試。

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

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

pYYBAGMcGpqAAFsUAAGNlJ2V_h0268.png

2.測(cè)試思路和主要程序代碼

在僅配置4個(gè)線程的情況下,我們?cè)诓煌木€程中通過(guò)切換GPIO0、1、2的引腳電平來(lái)判斷具體線程的響應(yīng)時(shí)序。具體配置如下:

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

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

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

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

通過(guò)對(duì)比上升沿的時(shí)間差,即可知道線程運(yùn)行的時(shí)序差。

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.測(cè)試結(jié)果

信號(hào)說(shuō)明:

黃色:GPIOA0電平 藍(lán)色:GPIOA1電平

(1).整體波形

pYYBAGMcIHCAP8nPAAC5G7K6gk4795.png

整體波形看起來(lái)線程基本時(shí)同時(shí)切換,同步運(yùn)行,下面放大看看。

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

pYYBAGMcIRuAKp3EAADJ8eLJusU710.png

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

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

(3)結(jié)果分析

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

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

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

poYBAGMcJ6uALowSAACDqBmLoFM350.png

審核編輯:湯梓紅

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

    關(guān)注

    146

    文章

    17886

    瀏覽量

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

    關(guān)注

    0

    文章

    279

    瀏覽量

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

    關(guān)注

    46

    文章

    2510

    瀏覽量

    48383
收藏 人收藏

    評(píng)論

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

    一種實(shí)時(shí)多線程VSLAM框架vS-Graphs介紹

    針對(duì)現(xiàn)有VSLAM系統(tǒng)語(yǔ)義表達(dá)不足、地圖可解釋差的問(wèn)題,本文提出vS-Graphs,一種實(shí)時(shí)多線程VSLAM框架。該方案顯著提升了重建地圖的語(yǔ)義豐富度、可解釋及定位精度。實(shí)驗(yàn)表明
    的頭像 發(fā)表于 04-19 14:07 ?321次閱讀
    一種<b class='flag-5'>實(shí)時(shí)</b><b class='flag-5'>多線程</b>VSLAM框架vS-Graphs介紹

    迅為RK3588開(kāi)發(fā)板實(shí)時(shí)系統(tǒng)編譯-Preemption系統(tǒng)/ Xenomai系統(tǒng)編譯-實(shí)時(shí)系統(tǒng)測(cè)試-Preemption測(cè)試

    聯(lián)網(wǎng)之后,使用apt安裝,輸入 以下命令: apt-get install rt-tests 在燒寫(xiě)非實(shí)時(shí)內(nèi)核的buildroot鏡像之后,使用cyclictest測(cè)試,執(zhí)行以下命令
    發(fā)表于 03-11 10:54

    請(qǐng)問(wèn)如何在Python中實(shí)現(xiàn)多線程與多進(jìn)程的協(xié)作?

    大家好!我最近在開(kāi)發(fā)一個(gè)Python項(xiàng)目時(shí),需要同時(shí)處理多個(gè)任務(wù),且每個(gè)任務(wù)需要不同的計(jì)算資源。我想通過(guò)多線程和多進(jìn)程的組合來(lái)實(shí)現(xiàn)并發(fā),但遇到了一些問(wèn)題。 具體來(lái)說(shuō),我有兩個(gè)任務(wù),一個(gè)是I/O密集型
    發(fā)表于 03-11 06:57

    請(qǐng)問(wèn)rt-thread studio如何進(jìn)行多線程編譯?

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

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

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

    socket 多線程編程實(shí)現(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 ?932次閱讀

    航電實(shí)時(shí)測(cè)試系統(tǒng)解決方案

    航電實(shí)時(shí)測(cè)試系統(tǒng)主要應(yīng)用于航空座艙的實(shí)時(shí)測(cè)試。座艙測(cè)試過(guò)程中,輸入和輸出信號(hào)的實(shí)時(shí)
    的頭像 發(fā)表于 10-23 15:34 ?659次閱讀
    航電<b class='flag-5'>實(shí)時(shí)</b><b class='flag-5'>測(cè)試</b>系統(tǒng)解決方案

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

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

    摩爾線程與羽人科技完成大語(yǔ)言模型訓(xùn)練測(cè)試

    (YuRen-7b)大語(yǔ)言模型的訓(xùn)練測(cè)試測(cè)試結(jié)果顯示,訓(xùn)練效率達(dá)到預(yù)期,夸娥千卡智算集群展現(xiàn)出了高度的兼容和穩(wěn)定性,為羽人科技未來(lái)的零代碼訓(xùn)練平臺(tái)向摩爾線程夸娥千卡智算集群的遷移提
    的頭像 發(fā)表于 08-27 16:19 ?787次閱讀

    延時(shí)僅33us,Linux-RT實(shí)時(shí)性能測(cè)試分享—基于瑞微RK3562J國(guó)產(chǎn)平臺(tái)

    本文主要介紹瑞微RK3562J的實(shí)時(shí)測(cè)試,開(kāi)發(fā)環(huán)境如下:U-Boot:U-Boot-2017.09Kernel:Linux-RT-5.10.198LinuxSDK:LinuxSDK
    發(fā)表于 08-22 13:51

    一文掌握Python多線程

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

    實(shí)測(cè)14us,Linux-RT實(shí)時(shí)性能及開(kāi)發(fā)案例分享—基于全志T507-H國(guó)產(chǎn)平臺(tái)

    是rt-tests測(cè)試套件下的測(cè)試工具,也是rt-tests下使用最廣泛的測(cè)試工具,一般主要用來(lái)測(cè)試內(nèi)核的延遲,從而判斷內(nèi)核的實(shí)時(shí)
    發(fā)表于 07-25 15:58

    LWIP多線程強(qiáng)烈建議開(kāi)啟LWIP_ASSERT_CORE_LOCKED宏,這個(gè)在RTT里面要怎么實(shí)現(xiàn)?

    LWIP多線程強(qiáng)烈建議開(kāi)啟LWIP_ASSERT_CORE_LOCKED宏,這個(gè)在RTT里面要怎么實(shí)現(xiàn),之前參考網(wǎng)上代碼,這樣寫(xiě),壓力測(cè)試下有概率斷言失敗 extern sys_mutex_t
    發(fā)表于 07-25 06:27

    ESP32會(huì)不會(huì)有多線程問(wèn)題,需要加鎖嗎?

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

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

    最近在開(kāi)發(fā) 延保服務(wù) 頻道頁(yè)時(shí),為了提高查詢(xún)效率,使用到了多線程技術(shù)。為了對(duì)多線程方案設(shè)計(jì)有更加充分的了解,在業(yè)余時(shí)間讀完了《圖解 Java 多線程設(shè)計(jì)模式》這本書(shū),覺(jué)得收獲良多。本篇文章將介紹其中
    的頭像 發(fā)表于 06-26 14:18 ?641次閱讀
    從<b class='flag-5'>多線程</b>設(shè)計(jì)模式到對(duì) CompletableFuture 的應(yīng)用
    主站蜘蛛池模板: 夜夜橹橹网站夜夜橹橹 | 被公侵犯肉体中文字幕一区二区 | 欧美日本一区二区三区道 | 久操伊人网 | 污污的网站免费阅读 | 好大好硬好深好爽视频h | 国模绪| 欧美激情第一欧美在线 | 欧美大香a蕉免费 | 亚洲婷婷综合色高清在线 | 99视频网址| 香蕉视频久久久 | 国产最好的精华液网站 | 在线精品国产成人综合第一页 | 立即播放免费毛片一级 | 欧美不卡一区 | 男男憋尿play按小腹 | 天天干夜夜做 | 日本理论午夜中文字幕第一页 | 丁香婷婷综合网 | 在线观看视频在线观看 | 国内精品久久久久久影院老狼 | 免费色视频网站 | 一本到卡二卡三卡四卡 | 5566成人| 日本黄色大片在线播放视频免费观看 | 日韩一卡 二卡 三卡 四卡 免费视频 | 夜色福利久久久久久777777 | 1300部小u女视频免费 | 伊人啪| 91精品欧美激情在线播放 | 天天草天天操 | se97se成人亚洲网站在线观看 | 你懂的在线观看网站 | 黄色大秀 | 欧美亚洲综合在线观看 | 色综合色综合色综合 | 天天色综| 亚洲综合日韩欧美一区二区三 | free性乌克兰高清videos | 一级毛片西西人体44rt高清 |