痞子衡嵌入式:i.MXRT1xxx系列GPIO提早供電會影響上電時序導致內部DCDC啟動失敗

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

大家好,我是痞子衡,是正經搞技術的痞子。今天痞子衡給大家介紹的是i.MXRT1xxx系列GPIO提早供電會影響上電時序導致內部DCDC啟動失敗。 最近有一個 RW612 產品線的同事在設計一個雙 MCU 系統 Demo 時發現,當 RW612 板卡和 RT1060 板卡通過 UART 對接時,如果 ...



  大家好,我是痞子衡,是正經搞技術的痞子。今天痞子衡給大家介紹的是i.MXRT1xxx系列GPIO提早供電會影響上電時序導致內部DCDC啟動失敗

  最近有一個 RW612 產品線的同事在設計一個雙 MCU 系統 Demo 時發現,當 RW612 板卡和 RT1060 板卡通過 UART 對接時,如果 RW612 板卡提前上電,RT1060 板卡後上電,會導致 RT1060 程式無法正常啟動。這其實是一個 i.MX RT 系列上典型的上電時序問題,今天痞子衡就和大家聊聊這個話題:

  • Note: 本文內容以 i.MXRT1060 為例,但基本也適用其他 i.MXRT1xxx 系列。

一、快速復現問題

  痞子衡同事在用兩塊 MCU 板卡(RW612+RT1060)對接時遇到了問題,想復現這個問題,其實沒有那麼複雜,我們可以用一個USB轉串口模塊(3.3V)代替 RW612 來和 RT1060 的 ROM ISP UART 口連接:

  痞子衡使用得這個USB轉串口模塊 TXD 和 RXD 驅動能力不同,空載電壓測得均是 3.55V,但是和未上電的 RT1060-EVKB 板卡對接時,電壓會有所下降,因此痞子衡測試了不同連接組合下的 RT1060 板卡上電啟動結果:

USB轉串口模塊一直通電 RT1060-EVKB J46未連接 RT1060-EVKB J46連接後
模塊TXD
晶元GPIO_AD_B0_13
模塊RXD
晶元GPIO_AD_B0_12
NVCC_GPIO
NVCC_SD1
NVCC_EMC
NVCC_SD0 DCDC_PSWITCH DCDC_IN VDD_SOC_IN
DCDC_LP
VDD_SOC_IN
DCDC_LP
程式啟動結果
未接 未接 0 0 0 0 0 1.275V 啟動成功
未接 0.83V 0.33V 0 0.33V 0.33V 0 1.275V 啟動成功
2.22V 未接 1.42V 0 1.42V 1.42V 0 0 啟動失敗
2.24V 1.79V 1.46V 0 1.46V 1.46V 0 0 啟動失敗

  從測試結果可以看到,RT1060 程式啟動失敗的主要原因是板卡上電後,VDD_SOC_IN 上沒有電壓(即主晶元內部 DCDC 沒有輸出)。

二、內部DCDC上電時序要求

  在分析啟動失敗問題前,首先需要簡單瞭解下 i.MXRT1xxx 晶元內部的 DCDC 模塊。在一些成本敏感的應用中,首推使用晶元內部 DCDC 供電給內核,因此 DCDC 模塊能否正常啟動決定了內核能否正常運行。

  在恩智浦官網文檔 《i.MX RT Hardware Development Guide for the MIMXRT1050/MIMXRT1060 Processor》 里對上電時序做瞭如下嚴格規定,其中最常發生問題的地方就是有效 DCDC_PSWITCH 和 DCDC_IN 之間至少 1ms 的延時(以 DCDC_IN 穩定在 3V 為時間起點,以 DCDC_PSWITCH 上升到 1.5V 為時間終點),如果不滿足這個 1ms 延時要求,內部 DCDC 模塊則可能會啟動失敗,無法正常輸出電壓給內核(DCDC_LP 腳)。

• The VDD_SNVS_IN supply must be turned on before any other power supply or connected (shorted) with the VDD_HIGH_IN supply.
• If a coin-cell battery is used to power VDD_SNVS_IN, ensure that it is connected before any other supply is switched on.
• An RC delay circuit is recommended for providing the delay between DCDC_IN stable and DCDC_PSWITCH. The total RC delay should be 5-15 ms.
• DCDC_IN must reach a minimum 3.0 V within 0.3 x RC.
• The delay from DCDC_IN stable at 3.0 V min to DCDC_PSWITCH reaching 0.5 x DCDC_IN (1.5 V) must be at least 1 ms.
• The power-up slew rate specification for other power domains is 360 V/s – 36k V/s.
• POR_B must be held low during the entire power up sequence

三、GPIO提早供電的影響

  現在我們查看一下 RT1060-EVKB 原理圖設計,外部電源輸入 DCDC_3V3 負責給 NVCC_GPIO/SD1/EMC 以及 DCDC_IN 供電,同時 DCDC_IN 也經過了一個 RC 延時電路供電給 DCDC_PSWITCH,這是符合硬體設計要求的。

  由於 RT1060 上 GPIO_AD_Bx 和 GPIO_Bx 兩組 PAD 供電均來自於 NVCC_GPIO,當其中任何一個 GPIO 有電壓時,均可能會漏電到 NVCC_GPIO。因此我們提前將 USB 轉串口模塊通過 ROM ISP UART 連到板卡,即會漏電到了 NVCC_GPIO->DCDC_3V3->DCDC_IN->DCDC_PSWITCH,即相當於給 DCDC_PSWITCH 的 RC 電路預充了一定電,等板卡正式上電,RC 電路升壓到 1.5V 的時間就會縮短。這也就是上個小節表格裡為何 DCDC_PSWITCH 預充到 0.33V 時不影響上電時序,而預充到 1.42V 時就不行了,因為延時小於 1ms 了。

  根據 RT1060-EVKB 這樣的電源電路設計,不僅僅 ROM ISP UART 兩個引腳提前上電會影響晶元啟動,屬於 NVCC_GPIO/SD1/EMC 供電下的任何一個 GPIO 提前上電都會產生相同的效果。但是 NVCC_SD0 供電下的 GPIO 則不會影響啟動,因為它在走線上和 DCDC_PSWITCH 之間沒有連接。

四、多板卡連接的解決方案

  現在我們知道了問題產生的原因,以後遇到此類問題,第一時間先去測量 i.MXRT1xxx 內部 DCDC 輸出(DCDC_LP)的電壓(如果為 0,則一定是上電時序問題)。那該如何規避問題呢?以與 RT1060-EVKB 連接為例則有如下三個方法:

  • 方法一: 兩個板卡之間用 UART 信號連接時串上隔離電阻(比如1K歐姆),這樣能降低漏電到 NVCC_GPIO 的電壓(以實測為準)。
  • 方法二: 選用不幹擾 DCDC_PSWITCH 信號的 GPIO 組(對於 RT1060-EVKB,則是 GPIO_SD_B0_xx 引腳)進行連接。
  • 方法三: 將 RT1060-EVKB 板卡,改為外部 PMIC 供電,棄用主晶元內部 DCDC。

  至此,i.MXRT1xxx系列GPIO提早供電會影響上電時序導致內部DCDC啟動失敗便介紹完畢了,掌聲在哪裡~~~

歡迎訂閱

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

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

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

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

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

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

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

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

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

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



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

-Advertisement-
Play Games
更多相關文章
  • 構建類型是動態代碼生成過程中的關鍵一環,通過靈活運用 TypeBuilder 和相關工具,我們可以實現各種複雜類型的動態生成,為程式的靈活性和可擴展性提供有力支持。總的來說,本章節通過演示如何使用 Emit 來動態創建類型,包括定義欄位、方法、屬性和事件等, 幫助讀者理解如何在運行時生成和操作類型信... ...
  • 前言 本文的主題是 Visual Studio 調試 NuGet 包,以及符號包的概念,如何去發佈一個 NuGet 包,讓我們的 NuGet 包支持 SouceLink,這些都是我們開發中比較容易忽視的內容,但是熟悉了以後可以讓我們在調試中得心應手,也是開源項目開發的基礎篇。 demo 源代碼在文末 ...
  • 在Orleans 7中,Grain放置是指確定將Grain對象放置在Orleans集群中的哪些物理節點上的過程。 Grain是Orleans中的基本單位,代表應用程式中的邏輯單元或實體。Grain放置策略是一種機制,用於根據不同的因素,將Grain對象放置在合適的節點上,以實現負載均衡、最小化網路延 ...
  • 在之前的WPF示例中,都會用到一個MVVM框,也是一個比較常的MVVM框架,就是MVVM工具包【CommunityToolkit.Mvvm】,今天專門以一個簡單的小例子,簡述一下MVVM工具包的常見用法,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 概述:通過對數組進行排序,代碼更好地利用了緩存,從而提高了程式的性能。這種現象通常被稱為"緩存友好"(cache-friendly)或"空間局部性"(spatial locality) 今天做一個數組數據計算時,發現一個效率問題,給大家分享一下 一個數組排序和不排序時同樣的邏輯處理速度是不一樣的。排 ...
  • // Stream MS HelpManual: https://learn.microsoft.com/zh-cn/dotnet/api/system.io.stream?view=net-8.0 // FileStream 官方手冊: https://learn.microsoft.com/zh ...
  • Grain 是 Orleans 框架中的基本單元,代表了應用程式中的一個實體或者一個計算單元。 每個Silo都是一個獨立的進程,Silo負責載入、管理和執行Grain實例,並處理來自客戶端的請求以及與其他Silo之間的通信。 通信原理 在相同的Silo中,Grain與Grain之間的通信通過直接的方 ...
  • SystemEvents 是一個開發 win32 視窗項目很常用的類,其中封裝了一些常用的系統廣播消息。在 WinUI3 項目中,SystemEvents 事件經常無法觸發,簡單排查了一下原因。 SystemEvent 內封裝了一個線程和一個視窗,通過視窗消息在內部線程上調用事件,內部使用了 Sys ...
一周排行
    -Advertisement-
    Play Games
  • 1、預覽地址:http://139.155.137.144:9012 2、qq群:801913255 一、前言 隨著網路的發展,企業對於信息系統數據的保密工作愈發重視,不同身份、角色對於數據的訪問許可權都應該大相徑庭。 列如 1、不同登錄人員對一個數據列表的可見度是不一樣的,如數據列、數據行、數據按鈕 ...
  • 前言 上一篇文章寫瞭如何使用RabbitMQ做個簡單的發送郵件項目,然後評論也是比較多,也是準備去學習一下如何確保RabbitMQ的消息可靠性,但是由於時間原因,先來說說設計模式中的簡單工廠模式吧! 在瞭解簡單工廠模式之前,我們要知道C#是一款面向對象的高級程式語言。它有3大特性,封裝、繼承、多態。 ...
  • Nodify學習 一:介紹與使用 - 可樂_加冰 - 博客園 (cnblogs.com) Nodify學習 二:添加節點 - 可樂_加冰 - 博客園 (cnblogs.com) 介紹 Nodify是一個WPF基於節點的編輯器控制項,其中包含一系列節點、連接和連接器組件,旨在簡化構建基於節點的工具的過程 ...
  • 創建一個webapi項目做測試使用。 創建新控制器,搭建一個基礎框架,包括獲取當天日期、wiki的請求地址等 創建一個Http請求幫助類以及方法,用於獲取指定URL的信息 使用http請求訪問指定url,先運行一下,看看返回的內容。內容如圖右邊所示,實際上是一個Json數據。我們主要解析 大事記 部 ...
  • 最近在不少自媒體上看到有關.NET與C#的資訊與評價,感覺大家對.NET與C#還是不太瞭解,尤其是對2016年6月發佈的跨平臺.NET Core 1.0,更是知之甚少。在考慮一番之後,還是決定寫點東西總結一下,也回顧一下.NET的發展歷史。 首先,你沒看錯,.NET是跨平臺的,可以在Windows、 ...
  • Nodify學習 一:介紹與使用 - 可樂_加冰 - 博客園 (cnblogs.com) Nodify學習 二:添加節點 - 可樂_加冰 - 博客園 (cnblogs.com) 添加節點(nodes) 通過上一篇我們已經創建好了編輯器實例現在我們為編輯器添加一個節點 添加model和viewmode ...
  • 前言 資料庫併發,數據審計和軟刪除一直是數據持久化方面的經典問題。早些時候,這些工作需要手寫複雜的SQL或者通過存儲過程和觸發器實現。手寫複雜SQL對軟體可維護性構成了相當大的挑戰,隨著SQL字數的變多,用到的嵌套和複雜語法增加,可讀性和可維護性的難度是幾何級暴漲。因此如何在實現功能的同時控制這些S ...
  • 類型檢查和轉換:當你需要檢查對象是否為特定類型,並且希望在同一時間內將其轉換為那個類型時,模式匹配提供了一種更簡潔的方式來完成這一任務,避免了使用傳統的as和is操作符後還需要進行額外的null檢查。 複雜條件邏輯:在處理複雜的條件邏輯時,特別是涉及到多個條件和類型的情況下,使用模式匹配可以使代碼更 ...
  • 在日常開發中,我們經常需要和文件打交道,特別是桌面開發,有時候就會需要載入大批量的文件,而且可能還會存在部分文件缺失的情況,那麼如何才能快速的判斷文件是否存在呢?如果處理不當的,且文件數量比較多的時候,可能會造成卡頓等情況,進而影響程式的使用體驗。今天就以一個簡單的小例子,簡述兩種不同的判斷文件是否... ...
  • 前言 資料庫併發,數據審計和軟刪除一直是數據持久化方面的經典問題。早些時候,這些工作需要手寫複雜的SQL或者通過存儲過程和觸發器實現。手寫複雜SQL對軟體可維護性構成了相當大的挑戰,隨著SQL字數的變多,用到的嵌套和複雜語法增加,可讀性和可維護性的難度是幾何級暴漲。因此如何在實現功能的同時控制這些S ...