如何把IWR6843的CCS工程代碼移植到IWR1843上
TI在毫米波產品上提供了非常多的例程供用戶參考,但有些演示例程只基于某些器件,沒有覆蓋到全部的毫米波產品。例如level_sensing的例程就沒有支持IWR1843的工程示例。本文就以level_sensing的例程為例,介紹如何把IWR6843的CCS工程代碼移植到IWR1843上。
本文引用地址:http://www.ex-cimer.com/article/202310/451850.htmIWR6843和IWR1843在硬件上是pin to pin兼容的,軟件上也是基于同一個mmWave SDK。但是IWR6843工作的頻率范圍是60~64GHz,而IWR6843工作的頻率范圍是76~81GHz。兩者pinmux定義,調用的庫函數也有些不同。軟件的移植主要就是基于上面幾點的不同。
本文介紹的移植基于mmwave_industrial_toolbox_4_9_0[1]里的level_sensing例程以及mmWave SDK 3.5[2]。
1. 首先在mmwave_industrial_toolbox_4_9_0labslevel_sensing目錄下新創建一個名為18xx_high_accuracy的文件夾。將68xx_high_accuracy目錄下的所有文件復制到新目錄18xx_high_accuracy下。
2. 把18xx_high_accuracysrc目錄下的兩個CCS工程文件修改文件名為projectspec/high_accuracy_18xx_dss.projectspec。然后分別用文本編輯器打開兩個工程文件,把“68”相關內容替換為“18”。例如把工程文件里的定義“-DSOC_XWR68XX”修改為“-DSOC_XWR18XX”。
3. 同樣,在18xx_high_accuracysrc目錄下的.c,.h文件里搜索“68”關鍵字,并替換為“18”。
4. 在配置初始化校準時,需要設定校準的頻率范圍。由于IWR6843和IWR1843的工作頻率范圍不同,所以相關代碼需要修改。
下面是IWR6843和IWR1843的mss_main.c里相關代碼的比較。
C:timmwave_industrial_toolbox_4_9_0labslevel_sensing68xx_high_accuracysrcmssmss_main.c
C:timmwave_industrial_toolbox_4_9_0labslevel_sensing18xx_high_accuracysrcmssmss_main.c
Line 754 gMmwMssMCB.cfg.openCfg.freqLimitLow = 600U;
Line 755 gMmwMssMCB.cfg.openCfg.freqLimitHigh = 640U;
Line 754 gMmwMssMCB.cfg.openCfg.freqLimitLow = 760U;
Line 755 gMmwMssMCB.cfg.openCfg.freqLimitHigh = 810U;
5. 由于IWR6843和IWR1843的工作頻率范圍不同,配置文件也要做相應的修改。在18xx_high_accuracychirp_configs目錄下修改cfg文件名cfg。修改配置里的起始頻率為77。
下面是IWR6843和IWR1843的配置文件的比較。
C:timmwave_industrial_toolbox_4_9_0labslevel_sensing68xx_high_accuracy chirp_configshigh_accuracy_demo_68xx.cfg
C:timmwave_industrial_toolbox_4_9_0labslevel_sensing18xx_high_accuracychirp_configshigh_accuracy_demo_18xx.cfg
Line 6 profileCfg 0 60 7 7 114.4 0 0 33.71 1 512 5000 0 0 48
Line 5 profileCfg 0 77 7 7 114.4 0 0 33.71 1 512 5000 0 0 48
6. Profilecfg有配置起始頻率和斜率參數,底層API里每位(bit)代表的單位對于60GHz芯片和77GHz芯片是不同的。下表是 AWR_PROFILE_CONF_SB contents[3]的部分內容,可以看出兩者的區別。
在通過cfg配置文件傳遞profilecfg、chirpcfg參數給MSS的時候,level sensing例程使用了cli庫,這個庫會調用SOC_getDeviceRFFreqScaleFactor()函數,判斷使用的芯片是哪一款,獲得不同的單位。當IWR6843時,賦值變量gCLI_mmwave_freq_scale_factor為2.7。而當使用的芯片為IWR1843時,gCLI_mmwave_freq_scale_factor變量值為3.6。
Cli庫會把輸入配置參數值轉換為射頻配置需要的值。例如cfg文件里profilecfg配置起始頻率為60或者77,在cli庫里的CLI_MMWaveProfileCfg()函數會通過下面的代碼做轉換。
所以對于輸入參數解析和射頻配置,移植時用戶不需要修改相關代碼。
在level sensing的例程的chirpcfg里和工作頻率相關的CHIRP_FREQ_START_VAR、CHIRP_FREQ_SLOPE_VARl兩個參數設置為0,代碼中沒有涉及。這兩個參數每位(bit)代表的單位可以在參考資料 [3] 里找到。
如果應用層需要使用射頻配置參數的時候,需要把射頻配置的值還原到實際的頻率或者斜率。這種情況做移植時,代碼需要根據77Ghz芯片對應的單位做相應修改。
7. 最后,保存修改,通過CCS導入工程編譯即可。
移植過程做68和18代碼替換的時候,還是需要要看看代碼是否有什么特殊含義。例如在IWR6843的mss_main.c里有一個#ifndef SOC_XWR68XX_ES1相關代碼,閱讀后發現是針對IWR6843 ES1.0芯片的操作,對于IWR1843可以將相關宏定義代碼去除。具體移植后的18xx_high_accuracy代碼可以在參考資料 [4] 里下載。
本文的方法也適用于AWR6843,AWR1843 CCS工程代碼的相互移植。
評論