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

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

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

3天內不再提示

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

韓曉宇 ? 來源:韓曉宇 ? 作者:韓曉宇 ? 2022-09-13 09:15 ? 次閱讀

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


MC3172簡介

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

共享代碼段空間與數據段空間,硬件級實時響應,無需中斷服務程序,無需實時操作系統。

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

數據段與代碼段共享128K字節SRAM,可按需配置為96K代碼空間加32K數據空間,或64K代碼空間加

64K數據空間,或32K代碼空間加96K數據空間,靈活應對各種應用場景。

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

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

接口。

產品特性

內核 Core:

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

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

- 線程資源可按需配置且無需操作系統

- 3.37coremark/MHz

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

- 最高 200MHz 系統主頻

存儲器:

- 128KB SRAM可按需分配為:

96K代碼空間+32K數據空間

64K代碼空間+64K數據空間

32K代碼空間+96K數據空間

電源管理和低功耗:

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

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

系統時鐘、復位

- 內嵌 200MHz RC 振蕩器

- 內嵌 8MHz RC 振蕩器

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

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

- 上電復位(POR)


多線程實時性測試

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

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

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

pYYBAGMcGpqAAFsUAAGNlJ2V_h0268.png

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

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

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

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

線程1:等待線程0對GPIO初始化完成后,實時檢測u8g_gpioAllowToggleFlg的狀態,并對GPIOA1進行翻轉。

線程2:等待線程0對GPIO初始化完成后,實時檢測u8g_gpioAllowToggleFlg的狀態,并對GPIOA2進行翻轉。

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

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.測試結果

信號說明:

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

(1).整體波形

pYYBAGMcIHCAP8nPAAC5G7K6gk4795.png

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

(2).上升沿觸發波形

pYYBAGMcIRuAKp3EAADJ8eLJusU710.png

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

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

(3)結果分析

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

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

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

poYBAGMcJ6uALowSAACDqBmLoFM350.png

審核編輯:湯梓紅

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

    關注

    146

    文章

    17650

    瀏覽量

    357228
  • 多線程
    +關注

    關注

    0

    文章

    279

    瀏覽量

    20201
  • RISC-V
    +關注

    關注

    46

    文章

    2448

    瀏覽量

    47861
收藏 人收藏

    評論

    相關推薦

    請問如何在Python中實現多線程與多進程的協作?

    大家好!我最近在開發一個Python項目時,需要同時處理多個任務,且每個任務需要不同的計算資源。我想通過多線程和多進程的組合來實現并發,但遇到了一些問題。 具體來說,我有兩個任務,一個是I/O密集型
    發表于 03-11 06:57

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

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

    華為云 X 實例 CPU 性能測試詳解與優化策略

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

    socket 多線程編程實現方法

    在現代網絡編程中,多線程技術被廣泛應用于提高服務器的并發處理能力。Socket編程是網絡通信的基礎,而將多線程技術應用于Socket編程,可以顯著提升服務器的性能。 多線程編程的基本概念 多線
    的頭像 發表于 11-12 14:16 ?737次閱讀

    Python中多線程和多進程的區別

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

    摩爾線程與羽人科技完成大語言模型訓練測試

    (YuRen-7b)大語言模型的訓練測試。測試結果顯示,訓練效率達到預期,夸娥千卡智算集群展現出了高度的兼容和穩定性,為羽人科技未來的零代碼訓練平臺向摩爾線程夸娥千卡智算集群的遷移提
    的頭像 發表于 08-27 16:19 ?689次閱讀

    延時僅33us,Linux-RT實時性能測試分享—基于瑞微RK3562J國產平臺

    本文主要介紹瑞微RK3562J的實時測試,開發環境如下:U-Boot:U-Boot-2017.09Kernel:Linux-RT-5.10.198LinuxSDK:LinuxSDK
    發表于 08-22 13:51

    一文掌握Python多線程

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

    實測14us,Linux-RT實時性能及開發案例分享—基于全志T507-H國產平臺

    是rt-tests測試套件下的測試工具,也是rt-tests下使用最廣泛的測試工具,一般主要用來測試內核的延遲,從而判斷內核的實時
    發表于 07-25 15:58

    LWIP多線程強烈建議開啟LWIP_ASSERT_CORE_LOCKED宏,這個在RTT里面要怎么實現?

    LWIP多線程強烈建議開啟LWIP_ASSERT_CORE_LOCKED宏,這個在RTT里面要怎么實現,之前參考網上代碼,這樣寫,壓力測試下有概率斷言失敗 extern sys_mutex_t
    發表于 07-25 06:27

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

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

    多線程設計模式到對 CompletableFuture 的應用

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

    7M16插頭環境適應測試

      德索工程師說道7M16插頭環境適應測試是評估該類型插頭在不同環境條件下工作性能和穩定性的重要環節。以下是關于7M16插頭環境適應
    的頭像 發表于 06-14 18:04 ?462次閱讀
    7<b class='flag-5'>芯</b>M16插頭環境適應<b class='flag-5'>性</b><b class='flag-5'>測試</b>

    摩爾線程與智譜AI完成大模型性能測試與適配

    近日,摩爾線程與智譜AI在人工智能領域開展了一輪深入的合作,共同對GPU大模型進行了適配及性能測試。此次測試不僅涵蓋了大模型的推理能力,還涉及了基于摩爾線程夸娥(KUAE)千卡智算集群
    的頭像 發表于 06-14 16:40 ?1313次閱讀

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

    的POSIX API等),實現產品快速上市的期望。 Linux-RT實時測試(Cyclictest工具) Cyclictest常用于實時系統的基準
    發表于 06-03 09:50
    主站蜘蛛池模板: 天天综合网色 | 天天干天天射天天操 | 三级完整在线观看高清视频 | 国产色视频网站免费观看 | 天天夜夜狠狠一区二区三区 | 日本精品一在线观看视频 | 18女毛片| 国产h视频在线观看网站免费 | 男女爱爱是免费看 | 伊人网综合在线观看 | 亚洲bt欧美bt高清bt777 | 国产成人毛片视频不卡在线 | h免费视频 | 五月婷婷欧美 | 伊人啪啪网 | 色视频国产 | 人人公开免费超级碰碰碰视频 | 激情婷婷网 | 在线观看高清免费播放 | 久久va | 亚洲欧美高清 | 欧美破处视频在线 | 亚洲综合色站 | 国产精品久久新婚兰兰 | 另类free性欧美护士 | 亚洲日本一区二区三区 | 真实偷清晰对白在线视频 | 4虎影院永久地址www | 又粗又大又爽又色又过瘾视频 | 激情五月激情综合色区 | 免费v片网站 | 婷婷国产| 另类激情网 | 国产精品资源网 | 久久精品美女 | 一区一精品 | 国产三级观看久久 | 日本人爽p大片免费看 | 天天天做天天天天爱天天想 | 婷婷在线观看网站 | 色久优优 |