新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > MDK(Keil)實現Kconfig圖形化配置

        MDK(Keil)實現Kconfig圖形化配置

        作者:嵌入式筆記v 時間:2025-03-26 來源:今日頭條 收藏

        背景

        在嵌入式開發中通常使用.h頭文件宏定義配置各種參數,來適配各種應用場景,以及統一修改工程中使用到的參數,避免漏改引起的程序bug。在一個相對比較復雜的項目中,往往需要配置各種各樣的參數, 不同功能的模塊對應不同.h,而有效配置項目是具有關聯性,比如A模塊依賴B模塊,如果模塊B關閉(如#define MODULE_B 0)時,那么就不應該啟用模塊A,當依賴層級比較多時,容易出現修改這忘了改那,尤其隨著時間拉長,對項目沒有之前那么熟悉的情況,依靠記憶配置存在隱患。

        本文引用地址:http://www.104case.com/article/202503/468636.htm

        參考linux開發,使用make menuconfig命令調用Kconfig進行配置,不僅可以管理如此龐大的工程,同時又顯得非常直觀,高大上~, 剛好手上項目是基于GD32 MDK開發的,因為是多人參與的項目,需要考慮團隊適應,因此不方便移植到linux平臺上(menuconfig本身的linux kernel量身打造的,在linux中搭建環境更加方便),于是萌生了搭建WIndows中MDK使用Kconfig環境想法,開干~

        Windows中menuconfig

        安裝依賴

        menuconfig(KConfig)圖形化依賴ncurses和kconfiglib庫,python已經幫我們實現了,因此我們這里使用python來安裝。這里我以python3為例子(python安裝這里就不介紹了,并且需要將python添加到系統環境變量中)

        檢測python是否安裝成功

        這里我們使用pyhton 的pip來安裝。

        1. 安裝windows-curses

        python -m pip install windows-curses

        安裝windows-curses庫

        出現”Successfully installed windows-curses-xxx“ 表示安裝成功。

        另外如果安裝失敗,有可能是你的pip版本太低, 根據提示更新:

        python -m pip install --upgrade pip
        1. 安裝kconfiglib

        python -m pip install kconfiglib

        安裝kconfiglib庫

        出現”Successfully installed kconfiglib-xxx“ 表示安裝成功。

        至此依賴庫已安裝好,根據自己電腦上安裝的python路徑查看是否真的生成我們所要的文件:

        python3Libsite-packagesgenconfig.py //作用將menuconfig生成的.config文件轉成.h頭文件


        python3Scriptsmenuconfig.exe


        1. 嘗試menuconfig

        首先我們需要一個Kconfig,關于Kconfig語法,這篇文章不過多介紹。這里摘用網上一個簡單的例子:

        mainmenu "Kconfig Demo"

        menu "Test Params setting"
        config TEST_ENABLE
           bool "Enable test work"
           default n    help
               Will print debug information if enable.

        config TEST_SHOW_STRING    string "The show string info"
           default "Test 123"config TEST_SHOW_INT    int "The show int info"
           range 0 255
           default 123config TEST_TOP_ENABLE    bool "Test Top Func"
           default n    help
               Function Test Top

        config TEST_SUB_0_ENABLE    bool "Test Sub 0 Func"
           default n    help
               Function Test Sub 0config TEST_SUB_1_ENABLE    bool "Test Sub 1 Func"
           default n
           depends on TEST_TOP_ENABLE    help
               Function Test Sub 1config TEST_SHOW_SUB_INT    int
           default 456 if TEST_SUB_0_ENABLE && TEST_SUB_1_ENABLE    default 123endmenu
        • 使用cmd命令行

        使用win+R打開cmd, 并切到測試Kconfig所在路徑,并輸入:menuconfig


        如出現以下圖片,表示成功了:

        cmd執行menuconfig成功

        • 使用powershll命令行


        執行也是正常,結果跟cmd一致,這里就不重復貼圖了。

        • 使用git bash命令行

        git bash執行失敗

        發現執行出錯,提示:Redirection is not supported 重定向不支持。個人猜測是git bash命令行是類linux shell的,而我們使用的menuconfig是基于windows的,2者系統重定向符合不一致,導致無法執行(如果讀者有更準確的答案,歡迎留言分享)。

        在MDK中使用

        好了,我們的重點來了,如何在mdk如何使用menconfig呢?

        1. 將Kconfig添加到Keil工程中

        這里我們隨便拿一個原子簡單的例程,只要能編譯即可(即使編譯錯誤也行不影響)。我們將Kconfig拷貝到工程目錄下:

        工程示例

        1. 配置工程

        點擊”魔術棒" 工程配置,選擇User欄:

        配置keil工程

        在Before Build/Rebuild(編譯/重新編譯前執行)欄填入:menuconfig,并勾選

        配置Befort Build/Rebuild

        然后OK保存,嘗試編譯,在Keil的Build Output編譯輸出欄中又出現錯誤:Redirection is not supported

        執行menuconfig報錯

        懷疑是MDK的終端也是重定向符合不匹配的問題,這里我嘗試了好幾次方法,嘗試通過指定cmd和powershell執行menuconfig,發現還是不行。

        1. 解決重定向

        因為我們在第三步已經驗證通過cmd和powershell是能夠正常運行menuconfig,解決思路就是通過它們間距來執行。

        于是通過編寫python腳本config.py來實現(這里參考了網友,表示感謝~),具體如下:

        import osimport sysfrom kconfiglib import Kconfigfrom menuconfig import menuconfigdef project_menuconfig(config='.config', file='Kconfig'):
           os.environ['MENUCONFIG_STYLE'] = 'default path=fg:black,bg:white separator=fg:white,bg:blue,bold selection=fg:white,bg:red,bold help=path'
           os.environ['KCONFIG_CONFIG_HEADER'] = '#n# Automatically generated file: Do not edit !!!n#n'
           os.environ['KCONFIG_CONFIG'] = config    
           # 判斷是否在Windows下執行, 若是則啟動一個獨立的命令行提示符窗口來執行menuconfig
           if sys.platform.startswith('win'):
               os.system('start /wait cmd.exe /c menuconfig.exe %s' % file)    else:
               menuconfig(Kconfig(filename=file))if __name__ == '__main__':
           project_menuconfig()

        簡單介紹下腳本作用:定義個project_menuconfig函數用于區分當前環境是否為windows,如果是,則執行命令:

        'start /wait cmd.exe /c menuconfig.exe %s' % file

        其中:

        start:: 啟動一個新的命令行

        /wait: 與start命令一起使用,表示在啟動新程序或命令后,當前命令行等待執行完 成在繼續執行后續命令

        cmd.exe:指定使用cmd命令行

        menuconfig:就是我們要執行的命令

        %s file:其中file函數未傳參,使用默認值Kconfig

        并放到工程目錄下:

        將config.py添加到工程中

        接著,修改MDK工程User配置:


        再次嘗試編譯,正常出現圖形化界面,即成功解決~


        4.生成配置頭文件

        使用menuconfig解析Kconfig文件,在其路徑生成.config(默認名,文件名稱可修改)

        menuconfig生成.config文件

        我們打開.config看下其內容:

        .

        接下來我們還需要依據.config生成我們最終所需的.h頭文件,這里我們就需要用到genconfig.py腳本文件(在第二步驟安裝依賴庫時),并在MDK中添加以下命令,使其自動生成。

        python D:Mysoftworkpython3Libsite-packagesgenconfig.py --header-path myconfig.h


        其中:

        D:Mysoftworkpython3Libsite-packagesgenconfig.py 根據自己實際python安裝路徑

        --header-path 指定輸出頭文件名,如果不指定,則默認生成config.h,其他選項可--help查看

        myconfig.h 我們指定生成的頭文件名

        接著再次編譯,發現工程路徑下成功生成了myconfig.h配置頭文件


        myconfig.h內容

        至此,我們成功實現了在Window中MDK使用menuconfig-Kconfig實現

        Kconfig語法

        環境搭建成功,后面就是運用于實際項目中,關于kconfig語法本篇沒有過多介紹,相關介紹,可以參看:

        Kconfig官網:
        https://www.kernel.org/doc/html/latest/kbuild/kconfig-language.html

        RTT-Thread介紹:
        https://www.rt-thread.org/document/site/#/development-tools/build-config-system/Kconfig

        結語

        綜上所述,關于Windows如何使用menuconfig-Kconfig介紹,相信大家有了一定了解,可以運用于自己的實際項目哦。如果有任何疑問,歡迎點贊轉發,以及留言討論, 另外喜歡嵌入式技術的小伙伴,可以關注走一波哈。好了,今天的分享到此咯,下次再見~



        關鍵詞: 圖形化配置

        評論


        技術專區

        關閉
        主站蜘蛛池模板: 太湖县| 桐柏县| 定边县| 涟水县| 右玉县| 贡嘎县| 遂昌县| 射洪县| 哈尔滨市| 祁东县| 通辽市| 莲花县| 沅陵县| 蒙山县| 武冈市| 昌宁县| 威远县| 子洲县| 芒康县| 射洪县| 息烽县| 巫溪县| 广丰县| 庆元县| 敦煌市| 洞口县| 西丰县| 马龙县| 平和县| 柏乡县| 阿坝县| 海兴县| 长葛市| 大港区| 临湘市| 乐昌市| 巍山| 新巴尔虎右旗| 彭泽县| 汤阴县| 咸宁市|