痞子衡嵌入式:JLink命令行以及JFlash對於下載演算法的作用地址範圍認定

来源:https://www.cnblogs.com/henjay724/p/18414870
-Advertisement-
Play Games

大家好,我是痞子衡,是正經搞技術的痞子。今天痞子衡給大家分享的是JLink命令行以及JFlash對於下載演算法的作用地址範圍認定。 最近痞子衡在給一個 RT1170 客戶定製一個 Infineon MirrorBit 類型 64MB Flash 的 SEGGER 下載演算法,做完之後在 JFlash 下 ...



  大家好,我是痞子衡,是正經搞技術的痞子。今天痞子衡給大家分享的是JLink命令行以及JFlash對於下載演算法的作用地址範圍認定

  最近痞子衡在給一個 RT1170 客戶定製一個 Infineon MirrorBit 類型 64MB Flash 的 SEGGER 下載演算法,做完之後在 JFlash 下測試小數據下載沒有問題,但是大數據下載就報了地址範圍不適用的錯誤,所以今天我們就來深挖一下自製下載演算法時作用地址設定問題:

  • Note: 本文所測試 JLink 版本為 V7.94f

一、地址範圍設定

  關於 SEGGER 下載演算法製作,痞子衡之前寫過兩篇文章:《串列NOR Flash下載演算法(MDK工具篇) 一文講得是如何製作 FLM 演算法文件(MDK 演算法與 SEGGER 演算法是通用的),《串列NOR Flash下載演算法(J-Link工具篇)》 一文講得是配套 XML 文件寫法。

  XML 文件里的 BaseAddr 和 MaxSize 參數設定的地址範圍主要用於選定適用的 FLM 演算法文件(即 Loader),而生成 FLM 演算法文件源工程里的 FlashDev.c 文件里的 FLASH_BASE_ADDRESS 和 FLASH_BASE_SIZE 參數則是演算法在運行過程中用於判斷的有效下載數據地址範圍。

二、測試地址範圍

  有了以上理論基礎,現在我們測試一下地址範圍設定對下載的影響。我們基於恩智浦 MIMXRT1170-EVKB 評估板,選用一顆 64MB NOR Flash 連在 FlexSPI1 外設上(AHB 映射起始地址為 0x3000_0000,FLM 下載演算法里 FLASH_BASE_ADDRESS 固定設為 0x3000_0000)。

2.1 JLink命令行下測試

  先在 JLink 命令行下用 LoadFile 命令做測試,該命令支持所有主流格式的程式文件。為了方便設定下載起始地址,我們就用 .bin 格式做測試。

命令格式 LoadFile <FileName>, [<Addr> (.bin only)].
命令解釋 Load data file into target memory. Supported ext.: *.bin, *.mot, *.hex, *.srec, *.elf, *.out, *.axf

  如果 XML, FLM, LoadFile 地址範圍都設定無誤,命令執行時後臺會彈出下載進度條視窗,表明 FLM 演算法被成功調用且在正常擦寫 Flash。

  現在我們嘗試設定不同地址範圍(下表裡設定的非 0x3000_0000 - 0x33FF_FFFF 有效 64MB Flash 空間範圍之外的測試地址需要是真正的無效存儲空間地址,不能是 MCU 片內的 SRAM 映射地址),做更多測試,結果如下:

XML範圍設定 FLM範圍設定 LoadFile地址 測試結果
0x3000_0000 - 0x33FF_FFFF 設定範圍內 正常下載
設定範圍外 Writing target memory failed.
0x4000_0000 - 0x43FF_FFFF 0x3000_0000 - 0x33FF_FFFF XML範圍內 Writing target memory failed.
FLM範圍內 Writing target memory failed.
0x3000_0000 - 0x37FF_FFFF 0x3000_0000 - 0x33FF_FFFF XML且FLM範圍內 正常下載
XML範圍內但FLM範圍外 Writing target memory failed.
0x3000_0000 - 0x33FF_FFFF 0x3000_0000 - 0x31FF_FFFF XML且FLM範圍內 正常下載
XML範圍內但FLM範圍外 Writing target memory failed.
0x3000_0000 - 0x31FF_FFFF 0x3000_0000 - 0x33FF_FFFF XML且FLM範圍內 正常下載
XML範圍外但FLM範圍內 Writing target memory failed.
0x3000_0000 - 0x37FF_FFFF 0x3000_0000 - 0x33FF_FFFF內 正常下載
0x3400_0000 - 0x37FF_FFFF內 實際下載到Addr-0x4000000處

  上述測試結果表明,僅當程式下載地址在 XML 和 FLM 共同指向的範圍內,且屬於有效的 Flash 空間時,下載才正常進行。此外,表格最後一項測試表明,即使超出實際連接的 Flash 最大空間,下載也沒有報錯,這是因為 MCU 發送給 Flash 操作命令地址溢出了,地址溢出部分被 Flash 自動忽略了。

  • Note:要實現表格最後一項測試效果,在製作 FLM 下載演算法時,配置 MCU 存儲介面外設(對於 i.MXRT1170 來說是 FlexSPI)的 AHB 空間必須與 FlashDev.c 里設定一致,且這個空間不超過晶元系統分配給外設的最大 AHB 空間。

2.2 JFlash下測試

  再在 JFlash 界面下做測試,打開軟體,創建工程時 Target Device 需要設定為 XML 文件 ChipInfo 中 Name,這樣可指定使用自製 FLM 文件。這裡也可以看到界面里 Flash banks 自動就識別到了 XML 所設定的地址範圍。

  • Note1:JFlash 認定的起始地址一定是 XML 中 BaseAddr。
  • Note2:當 XML 中 BaseAddr 與 FLM 中 FLASH_BASE_ADDRESS 一致時,JFlash 認定的空間長度由 XML 中 MaxSize 和 FLM 中 FLASH_BASE_SIZE 共同決定,兩者取其小。
  • Note3:當 XML 中 BaseAddr 與 FLM 中 FLASH_BASE_ADDRESS 不一致時,JFlash 認定的空間長度由 XML 中 MaxSize 決定。

  JFlash 下測試結果本質上其實和 JLink 命令下行為一致,我們可以理解為 JFlash 底層調用得就是 JLink 命令實現,只不過界面里做了更多檢查與附加功能。且上述 Note 表明 JFlash 在載入演算法時對地址空間長度做了預處理,所以當程式下載地址超出 JFlash 認定範圍時,JFlash 會彈框提示:

  至此,JLink命令行以及JFlash對於下載演算法的作用地址範圍認定痞子衡便介紹完畢了,掌聲在哪裡~~~

歡迎訂閱

文章會同時發佈到我的 博客園主頁CSDN主頁知乎主頁微信公眾號 平臺上。

微信搜索"痞子衡嵌入式"或者掃描下麵二維碼,就可以在手機上第一時間看了哦。

  最後歡迎關註痞子衡個人微信公眾號【痞子衡嵌入式】,一個專註嵌入式技術的公眾號,跟著痞子衡一起玩轉嵌入式。

痞子衡嵌入式-微信二維碼 痞子衡嵌入式-微信收款二維碼 痞子衡嵌入式-支付寶收款二維碼

  衡傑(痞子衡),目前就職於某全球頂級半導體原廠MCU系統部門,擔任高級嵌入式系統應用工程師。

  專欄內所有文章的轉載請註明出處:http://www.cnblogs.com/henjay724/

  與痞子衡進一步交流或咨詢業務合作請發郵件至 [email protected]

  可以關註痞子衡的Github主頁 https://github.com/JayHeng,有很多好玩的嵌入式項目。

  關於專欄文章有任何疑問請直接在博客下麵留言,痞子衡會及時回覆免費(劃重點)答疑。

  痞子衡郵箱已被私信擠爆,技術問題不推薦私信,堅持私信請先掃碼付款(5元起步)再發。



您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在 C# 中使用 RabbitMQ 通過簡訊發送重置後的密碼到用戶的手機號上,你可以按照以下步驟進行 1.安裝 RabbitMQ 客戶端庫 首先,確保你已經安裝了 RabbitMQ 客戶端庫。你可以通過 NuGet 包管理器來安裝: dotnet add package RabbitMQ.Clien ...
  • 在軟體行業,經常會聽到一句話“文不如表,表不如圖”說明瞭圖形在軟體應用中的重要性。同樣在WPF開發中,為了程式美觀或者業務需要,經常會用到各種個樣的圖形。今天以一些簡單的小例子,簡述WPF開發中幾何圖形(Geometry)相關內容,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 之前寫過兩篇關於Roslyn源生成器生成源代碼的用例,今天使用Roslyn的代碼修複器CodeFixProvider實現一個cs文件頭部註釋的功能, 代碼修複器會同時涉及到CodeFixProvider和DiagnosticAnalyzer, 實現FileHeaderAnalyzer 首先我們知道修 ...
  • 本文為大家介紹下.NET解壓/壓縮zip文件。雖然解壓縮不是啥核心技術,但壓縮性能以及進度處理還是需要關註下,針對使用較多的zip開源組件驗證,給大家提供個技術選型參考 之前在《.NET WebSocket高併發通信阻塞問題 - 唐宋元明清2188 - 博客園 (cnblogs.com)》講過,團隊 ...
  • 1. 生成式 AI 簡介 https://imp.i384100.net/LXYmq3 2. Python 語言 https://imp.i384100.net/5gmXXo 3. 統計和 R https://youtu.be/ANMuuq502rE?si=hw9GT6JVzMhRvBbF 4. 數 ...
  • 先看一下效果吧: 我們直接通過改造一下原版的TreeView來實現上面這個效果 我們先創建一個普通的TreeView 代碼很簡單: <TreeView> <TreeViewItem Header="人事部"/> <TreeViewItem Header="技術部"> <TreeViewItem He ...
  • 前言 推薦一款基於.NET 8、WPF、Prism.DryIoc、MVVM設計模式、Blazor以及MySQL資料庫構建的企業級工作流系統的WPF客戶端框架-AIStudio.Wpf.AClient 6.0。 項目介紹 框架採用了 Prism 框架來實現 MVVM 模式,不僅簡化了 MVVM 的典型 ...
  • docker安裝普羅米修斯+Granfan並監控容器 一、基本概念 ​ 1、之間的關係 ​ prometheus與grafana之間是相輔相成的關係。作為完美的分散式監控系統的Prometheus,就想布加迪威龍一樣示例和動力強勁。在猛的車也少不了儀錶盤來觀察。於是優雅的可視化平臺Grafana出現 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...