<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統 > 設計應用 > 如何把IWR6843的CCS工程代碼移植到IWR1843上

          如何把IWR6843的CCS工程代碼移植到IWR1843上

          作者:Chris Meng時間:2023-10-20來源:TI收藏

          在毫米波產品上提供了非常多的例程供用戶參考,但有些演示例程只基于某些器件,沒有覆蓋到全部的毫米波產品。例如level_sensing的例程就沒有支持的工程示例。本文就以level_sensing的例程為例,介紹如何把移植到上。

          本文引用地址:http://www.ex-cimer.com/article/202310/451850.htm

          在硬件上是pin to pin兼容的,軟件上也是基于同一個mmWave SDK。但是工作的頻率范圍是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]的部分內容,可以看出兩者的區別。

          pastedimage1667206092658v1.png-320x240.png

          在通過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()函數會通過下面的代碼做轉換。

          pastedimage1667206111688v2.png-320x240.png

          所以對于輸入參數解析和射頻配置,移植時用戶不需要修改相關代碼。

          在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 的相互移植。



          評論


          相關推薦

          技術專區

          關閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();