《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 嵌入式技術(shù) > 解決方案 > 如何快速、簡(jiǎn)單地遷移Keil MDK工程項(xiàng)目到其他開發(fā)工具

如何快速、簡(jiǎn)單地遷移Keil MDK工程項(xiàng)目到其他開發(fā)工具

2023-09-20
作者:火星
來源:與非網(wǎng)
關(guān)鍵詞: KeilMDK RISC-V GCC

  Keil MDK作為嵌入式行業(yè)常用的開發(fā)工具,嵌入式工程師們都很熟悉。但是最近聽說Arm公司要把Keil MDK合并到Arm Development Studio里,所以Keil MDK的版本更新已經(jīng)基本停止了,大家都還在使用很老版本的Keil MDK,功能上并不是很方便,希望找到更好的替代工具。此外,從近期舉辦的包括RISC-V中國(guó)峰會(huì)在內(nèi)的多個(gè)行業(yè)活動(dòng)來看,RISC-V在中國(guó)的發(fā)展如火如荼并且勢(shì)頭很猛,因此還要考慮開發(fā)工具是否會(huì)長(zhǎng)期支持RISC-V并可以通過移植重用相關(guān)設(shè)計(jì)。

  但是替代Keil MDK需要考慮項(xiàng)目工程如何遷移到其他工具,由于工程文件格式不同、以及底層編譯技術(shù)的差異, Keil MDK的工程文件與其他工具平臺(tái)并不完全兼容,需要一定量的遷移工作。本文就根據(jù)筆者的經(jīng)驗(yàn),分享一下如何快速把Keil MDK的代碼遷移到其他平臺(tái),并且解決不同平臺(tái)之間項(xiàng)目文件不兼容的問題。

  目前遷移Keil MDK代碼常見的目標(biāo)平臺(tái)有兩個(gè),分別是GCC和IAR。下面就給大家分別介紹并比較一下兩者的區(qū)別:

  概覽:

  ·GCC也很常見但是它只是一種編譯器,需要配合IDE使用,常見的選擇有VSCODE,或者Eclipse這些IDE,由于都是免費(fèi)的組件,需要自己動(dòng)手搭建,要有一定的IDE搭建知識(shí)才能使用起來,當(dāng)然最大的好處是免費(fèi)。有些朋友因?yàn)橐恍┍娝苤奶厥庠颍坏貌环艞壥褂肒eil MDK,如果又苦于沒有預(yù)算購買其他工具的話,就基本上只有GCC可選了;

  ·如果有預(yù)算買商用工具,另一個(gè)選擇是IAR,IAR是Keil同級(jí)別的商用工具,性能與用戶體驗(yàn)都不錯(cuò),且自帶IDE,不需要配置,直接安裝即用。同時(shí),除了支持基于Arm的項(xiàng)目,IAR的Embedded Workbench工具還有支持RISC-V的版本,這對(duì)項(xiàng)目和應(yīng)用比較多或者希望進(jìn)一步擴(kuò)展RISC-V架構(gòu)項(xiàng)目的工程師具有很重要的意義。這是因?yàn)閺腎AR Embedded Workbench  for Arm移植到IAR  Embedded Workbench for RISC-V的過程非方便,因?yàn)楹芏辔募A內(nèi)容已經(jīng)統(tǒng)一了。

  項(xiàng)目遷移流程對(duì)比:

  首先要聲明,遷移項(xiàng)目分為兩大部分工作,第一是項(xiàng)目文件格式的適配,第二是項(xiàng)目代碼的適配。

  1.項(xiàng)目文件的適配是一定要做的,而且方法和途經(jīng)比較確定。

  2.正常情況下,如果項(xiàng)目里使用的都是標(biāo)準(zhǔn)C/C++,那么應(yīng)該編譯是沒問題的。但是項(xiàng)目代碼的適配可能涉及到一些不是標(biāo)準(zhǔn)C/C++的遷移,例如某些特殊要求下,標(biāo)準(zhǔn)的C/C++代碼難以實(shí)現(xiàn)某些功能,而使用編譯器的內(nèi)聯(lián)函數(shù)(Intrinsic)可以更高效的實(shí)現(xiàn)這些功能。如果涉及非標(biāo)準(zhǔn)C/C++,那么就需要用戶針對(duì)性的對(duì)這些非標(biāo)準(zhǔn)C/C++進(jìn)行跨編譯平臺(tái)的遷移。

  關(guān)于非標(biāo)指令的遷移,這里不做介紹,因?yàn)樯婕暗闹噶钐啵豢赡茉谝黄锝榻B完,大家碰到了可以單獨(dú)處理。

  下面為大家介紹下通用的項(xiàng)目工程遷移指導(dǎo):

  從Keil遷移到GCC

  一般需要修改以下內(nèi)容:

  1.工程目錄配置:從。uvproj文件里查看Keil MDK的文件目錄,把相同的文件配置到GCC的Makefile文件目錄里;

  2.連接(Linker)文件:Keil MDK的連接器文件是。sct, 根據(jù)對(duì)應(yīng)的描述,可以手寫一個(gè)GCC對(duì)應(yīng)支持格式的連接文件;

  3.啟動(dòng)代碼:一般服務(wù)好的芯片廠商會(huì)制作不同編譯器平臺(tái)的啟動(dòng)代碼,在例程文檔里可以找找看,如果有看到支持GCC的格式,就可以直接拿來用。如果沒有的話,就需要手寫了。不同的芯片都要單獨(dú)寫啟動(dòng)文件,純自己手寫的難度比較大,需要對(duì)芯片非常了解,一般需要芯片廠商的人支持才行,這里不多做贅述。

  4.制作Makefile工程文件,包括

  a.源文件的工程目錄配置,

  b.GCC格式的連接文件替換,

  c.把Keil MDK的編譯參數(shù)和連接參數(shù)復(fù)制到Makefile的對(duì)應(yīng)參數(shù)中;

  d.添加設(shè)備信息和調(diào)試配置(GDB)

  遷移之后還要進(jìn)行驗(yàn)證,包含編譯結(jié)果的驗(yàn)證,編譯后可執(zhí)行文件代碼尺寸、運(yùn)行速度的驗(yàn)證和調(diào)整。如果代碼尺寸或者運(yùn)行速度不達(dá)標(biāo),還需要調(diào)整編譯器優(yōu)化選項(xiàng)。調(diào)整優(yōu)化選項(xiàng)后,記得也要重新測(cè)試代碼執(zhí)行結(jié)果是否符合預(yù)期,因?yàn)椴煌膬?yōu)化選項(xiàng)可能造成代碼運(yùn)行結(jié)果的變化。

  從Keil遷移到IAR

  如果是遷移到IAR,推薦使用IAR官方的項(xiàng)目轉(zhuǎn)換工具IAR Project Converter,遷移過程就會(huì)非常方便。在IAR的Embedded Workbench for Arm工具的菜單欄里,點(diǎn)擊Tools à IAR Project Converter, 就可以自動(dòng)把Keil的工程文件和代碼轉(zhuǎn)換成IAR格式,最后再把。s啟動(dòng)文件換成IAR格式的就可以,一般在芯片公司提供的代碼示例里都有不同格式的。s文件,直接找到IAR版本的替換原有的就可以。當(dāng)然遷移之后還是要校驗(yàn)一下編譯是否正常,測(cè)試下代碼是否運(yùn)行正常。如果用IAR,基本不用擔(dān)心代碼體積變大,或者運(yùn)行速度拖慢,IAR擁有非常好的編譯優(yōu)化,一般情況下編譯結(jié)果會(huì)更優(yōu),只需要找到合適的編譯選項(xiàng)就OK了。

  總結(jié):

  Keil項(xiàng)目遷移到其他平臺(tái)技術(shù)上可行,尤其是代碼中不涉及非標(biāo)的C/C++代碼時(shí),具備項(xiàng)目遷移經(jīng)驗(yàn)的情況下是完全可實(shí)施的,需要擔(dān)心的只是工作量的問題。

  至于選擇遷移到IAR還是GCC,主要考慮以下幾點(diǎn):

  ·是否有充足的預(yù)算。相信大家最常見的遷移原因就是眾所周知的合規(guī)問題,如果必須遷移,又沒有預(yù)算,只有硬著頭皮轉(zhuǎn)GCC了。如果能有預(yù)算,可以考慮購買IAR正版,選IAR的話遷移也都是比較方便的,并沒什么風(fēng)險(xiǎn),付錢的工具還是比免費(fèi)的要靠譜得多,而且還能得到相應(yīng)的支持。當(dāng)然,如果同一家廠商能夠同時(shí)支持Arm和RISC-V的工程開發(fā),則可能有更高的投資回報(bào)(ROI)。

  ·對(duì)不同工具的熟悉程度。跨平臺(tái)遷移需要對(duì)工具有一定的熟悉度,尤其是遷移到GCC,由于GCC版本眾多,又沒有成熟的IDE,又沒有技術(shù)支持的情況下,如果工程師對(duì)開發(fā)工具并不精通,還是很難順利遷移成功。如果沒有相關(guān)經(jīng)驗(yàn),還是建議選擇IAR,畢竟IAR官方自帶的自動(dòng)化轉(zhuǎn)換工具還是很方便的,如果有正版IAR License,還可以有IAR官方人員回復(fù)你遷移過程中碰到的問題,IAR官方的技術(shù)支持申請(qǐng)鏈接是https://www.iar.com/cn/knowledge/support/request-technical-support/。

  ·遷移風(fēng)險(xiǎn)是否能夠接受。即使是項(xiàng)目的代碼本身遷移成功,也不代表項(xiàng)目整體的遷移成功了,有可能遷移到GCC之后由于編譯性能的降低,生成的可執(zhí)行代碼在現(xiàn)有的硬件平臺(tái)上性能不滿足!最常見的就是代碼體積變大,F(xiàn)LASH不夠用了,或者RAM不夠了,前期努力白費(fèi)T_T 。為了避免這種風(fēng)險(xiǎn),穩(wěn)妥的路徑還是采用商用級(jí)別的編譯器,IAR還是比較穩(wěn)的。IAR支持14天免費(fèi)試用,可以直接去申請(qǐng)個(gè)試用版試試能否遷移成功,試用鏈接https://www.iar.com/cn/product/architectures/arm/iar-embedded-workbench-for-arm/iar-embedded-workbench-for-arm---free-trial-version/

  以上內(nèi)容基于自己的經(jīng)驗(yàn)和知識(shí)總結(jié),希望對(duì)各位考慮項(xiàng)目遷移的朋友們有幫助,如果有錯(cuò)誤,歡迎指正!



更多精彩內(nèi)容歡迎點(diǎn)擊==>>電子技術(shù)應(yīng)用-AET<<

mmexport1621241704608.jpg

本站內(nèi)容除特別聲明的原創(chuàng)文章之外,轉(zhuǎn)載內(nèi)容只為傳遞更多信息,并不代表本網(wǎng)站贊同其觀點(diǎn)。轉(zhuǎn)載的所有的文章、圖片、音/視頻文件等資料的版權(quán)歸版權(quán)所有權(quán)人所有。本站采用的非本站原創(chuàng)文章及圖片等內(nèi)容無法一一聯(lián)系確認(rèn)版權(quán)者。如涉及作品內(nèi)容、版權(quán)和其它問題,請(qǐng)及時(shí)通過電子郵件或電話通知我們,以便迅速采取適當(dāng)措施,避免給雙方造成不必要的經(jīng)濟(jì)損失。聯(lián)系電話:010-82306118;郵箱:aet@chinaaet.com。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲欧美国产三级| 久久一区精品| 久久av二区| 午夜精品久久久久久久久久久久| 亚洲精品1区| 亚洲成人在线视频网站| 黄色亚洲免费| 国色天香一区二区| 狠狠色狠狠色综合日日五| 国产午夜一区二区三区| 国产精品永久免费视频| 国产精品毛片高清在线完整版| 欧美日韩视频| 欧美日韩亚洲成人| 欧美日韩一二区| 欧美天天影院| 国产精品劲爆视频| 国产精品欧美一区喷水| 国产精品热久久久久夜色精品三区| 欧美日韩裸体免费视频| 欧美日韩国产在线播放网站| 欧美精品福利| 欧美日韩一卡二卡| 国产精品久久久久久久久借妻| 国产精品男gay被猛男狂揉视频| 国产精品成人一区二区艾草| 国产精品a久久久久| 欧美午夜在线| 国产精品欧美日韩一区二区| 国产欧美日韩精品丝袜高跟鞋| 国产欧美一区二区三区久久| 国产日韩欧美| 国产一区二区精品久久99| 国产一区二区三区高清在线观看| 国内精品久久久久影院优 | 欧美日本亚洲| 欧美三日本三级少妇三2023| 国产精品久久久久久久免费软件| 国产区亚洲区欧美区| 国产亚洲精品v| 亚洲第一综合天堂另类专| 亚洲精品在线一区二区| 中文国产成人精品| 欧美一级成年大片在线观看| 亚洲国产精品成人va在线观看| 亚洲精品国产精品国自产在线| 一本色道久久综合亚洲精品不卡| 亚洲欧美电影在线观看| 欧美在线观看视频一区二区三区| 久久亚洲二区| 欧美日韩国产成人高清视频| 国产精品美女久久久久av超清| 国产一区二区高清| 亚洲欧洲精品一区二区| 亚洲一区二区视频| 亚洲国产婷婷综合在线精品| 在线亚洲免费视频| 久久精品一区二区三区不卡牛牛| 欧美高清视频一区二区三区在线观看| 欧美日韩一区精品| 国产综合色产| 99v久久综合狠狠综合久久| 亚洲欧美日韩精品久久久| 亚洲黄色成人网| 亚洲欧美在线aaa| 嫩草成人www欧美| 国产精品成人一区二区艾草| 在线播放亚洲一区| 正在播放欧美视频| 亚洲国产一成人久久精品| 亚洲综合不卡| 美女主播一区| 国产欧美一区二区三区国产幕精品| 亚洲国产日韩一区二区| 午夜精品久久久久久久久| 亚洲精选一区二区| 久久av在线| 欧美日韩精品一区二区在线播放 | 国产精品久久久久久久久免费桃花| 狠狠色狠狠色综合日日91app| 一本色道久久99精品综合| 亚洲高清免费| 篠田优中文在线播放第一区| 欧美寡妇偷汉性猛交| 国产日韩欧美在线视频观看| 99亚洲伊人久久精品影院红桃| 亚洲国产精品一区制服丝袜 | 性做久久久久久免费观看欧美| 欧美激情精品久久久久久蜜臀 | 亚洲午夜在线| 日韩一二在线观看| 久久午夜精品一区二区| 国产精品免费一区二区三区在线观看 | 99国产精品国产精品毛片| 久久精品人人| 国产精品亚洲综合| 中日韩高清电影网| 99精品99久久久久久宅男| 老鸭窝亚洲一区二区三区| 国产麻豆视频精品| 亚洲视频一区在线| 一区二区三区波多野结衣在线观看| 麻豆亚洲精品| 国内精品写真在线观看| 午夜激情综合网| 午夜在线观看免费一区| 欧美日韩亚洲高清| 亚洲精品在线二区| 亚洲老板91色精品久久| 猛男gaygay欧美视频| 在线播放亚洲一区| 亚洲高清资源综合久久精品| 久久久久欧美| 国产一区二区久久久| 亚洲欧美一区在线| 欧美一级二级三级蜜桃| 国产精品v日韩精品| 一区二区冒白浆视频| 一区二区三区欧美成人| 欧美日韩国产成人在线| 亚洲六月丁香色婷婷综合久久| 99精品视频免费观看| 欧美成人在线免费观看| 亚洲成人资源网| 亚洲国内欧美| 欧美不卡在线视频| 亚洲激情国产| 99re6热在线精品视频播放速度| 欧美激情第二页| 亚洲免费福利视频| 亚洲视频每日更新| 国产精品久久999| 亚洲尤物在线| 久久久精品免费视频| 国内一区二区在线视频观看| 久久精品国产成人| 暖暖成人免费视频| 91久久一区二区| 一区二区三区四区五区精品视频| 欧美日韩亚洲综合一区| 亚洲视频国产视频| 欧美亚洲免费电影| 国产专区精品视频| 亚洲日韩欧美视频| 欧美日韩卡一卡二| 亚洲一区二区三区免费视频| 欧美一区二区精品在线| 国内精品久久久久影院色 | 亚洲欧美综合精品久久成人| 国产麻豆精品在线观看| 亚洲风情在线资源站| 欧美电影免费观看高清| 99这里只有久久精品视频| 亚洲欧美综合另类中字| 国产视频在线观看一区| 亚洲日本激情| 欧美色网一区二区| 欧美一级午夜免费电影| 免费亚洲婷婷| 亚洲视频在线观看三级| 久久久av水蜜桃| 亚洲欧洲视频在线| 午夜视频久久久| 一区精品久久| 亚洲午夜久久久久久尤物| 国产日韩欧美在线播放不卡| 亚洲国产精品ⅴa在线观看| 欧美日韩视频在线一区二区| 亚洲欧美一区二区三区在线| 欧美成人精品福利| 亚洲桃色在线一区| 久久夜色撩人精品| 亚洲美女av网站| 久久国产精品99精品国产| 亚洲国产精品免费| 欧美一级视频精品观看| 亚洲国产成人不卡| 欧美亚洲综合网| 亚洲精品欧美精品| 久久精品电影| 日韩视频专区| 久久久久久久高潮| 99精品国产在热久久下载| 久久久久久久一区| 日韩一级精品| 久久综合导航| 亚洲一区999| 欧美大片在线看| 午夜老司机精品| 欧美日韩免费一区二区三区视频| 欧美一区2区三区4区公司二百| 欧美精品三级在线观看| 欧美在线三级| 国产精品草莓在线免费观看| 亚洲黄色性网站| 国产美女精品人人做人人爽| 一本久久a久久免费精品不卡| 好吊色欧美一区二区三区视频| 亚洲自啪免费| 亚洲人久久久|