APB匯流排

来源:https://www.cnblogs.com/Yuya-memeda/archive/2022/06/15/15009936.html
-Advertisement-
Play Games

APB匯流排信號: APB匯流排狀態機與讀寫Timing IDIE是初始化態; SETUP是從機被PSELx選中以後進入的狀態,只維持一個cycle,下一個周期的上升沿到ENABLE態; ENABLE要使PENABLE HIGH,同時如果沒有繼續transfer那麼從ENABLE跳到IDIE,如果有繼續 ...


APB匯流排信號:

 

 

APB匯流排狀態機與讀寫Timing

 

 

  •  IDIE是初始化態;
  • SETUP是從機被PSELx選中以後進入的狀態,只維持一個cycle,下一個周期的上升沿到ENABLE態;
  • ENABLE要使PENABLE HIGH,同時如果沒有繼續transfer那麼從ENABLE跳到IDIE,如果有繼續transfer從ENABLE跳到SETUP(有點glitch可以接受);從SETUP到ENABLE調整期間所有信號(地址數據控制)都要保持穩定

 

 2個cycle進行一次transfer的timing;為了減低功耗,transfer結束後不會改變地址數據信號,除非下一次transfer開始。這實際上只要求clean PSELx信號(transfer結束回到LOW),但背靠背(back to back,讀寫交替的)傳輸中,PWRITE和PSEL可能會有glitch。

 

 

 APB從機讀取timing和寫基本一致,地址和PSEL,PENABLE無差異。PWRITE LOW表示讀,並且從機要在ENABLE狀態保持有效的PRDATA,該數據在ENABLE state的上升沿被採樣。

 

APB bridge

APB橋是APB架構中唯一的主機,同時APB也是AHB或ASB匯流排中的從機。

 

 APB從機

 

 從機WDATA可以在PSELx HIGH的時候,在1 PCLK的上升沿 或 PENABLE的上升沿被 latched。

從機RDATA要在PWRITE LOW並且PSELx 和 PENABLE 都HIGH時輸出。

 

APB到AHB

 

主機發起對APB從機的讀,T1時候AHB主機輸出了有效address;APB bridge採樣到address在T2上升沿,同時立即進行解碼decoding, 生成了PSELx選擇信號置為HIGH,PSELx對應的APB從機進入SETUP state;在下一個周期ENABLE state時APB從機必須提供有效的RDATA。而APB的RDATA通常直接給AHB匯流排;在ENABLE state時,在T4上升沿AHB採樣到RDATA。一次讀transfer完成。

burst read

 

 AHB對APB從機進行高頻讀取操作。一旦接受到RDATA,AHB HREADY為HIGH就進行下一個data的address更新,APB bridge開始新的一個APB從機的讀取操作。這樣在高頻操作中同樣是2個cycle完成一次讀取,APB bridge(作為AHB的從機)因此需要在第1個cycle置HREADT為LOW(插入1個 wait state),下1個cycle接受RDATA置HREADY為HIGH;但提高了AHB的工作頻率。

 

 

 APB bridge要採樣AHB主機輸出的HWDATA(還有地址,以及解碼生成PSELx),並且保持給APB從機2個cycle。

 

 在burst write中,只有AHB的第一個寫transfer是zero-wait state,由於APB匯流排需要2個cycle進行操作,因此burst中除了第一個transfer後續每個WDATA都要插入1個wait state。APB bridge必須要有2個address reg,確保在採樣更新AHB主機address的時候,同時也能把之前的address保持給APB從機。

back to back 傳輸,讀寫交替的

 

在T7-T8,顯然APB匯流排進入了IDIE state(但實際上我認為可以到setup,開始Addr3 的APB寫操作)

三態實現

APB匯流排推薦進行讀寫通道分離的機制。但允許通過三態合併讀寫為1路數據通道。

 

在APB匯流排以三態實現時,進行讀操作中:,SETUP state和IDIE state要有一個整個cycle的turnaround。圖中T5-6,T7-8,T10-11分別是APB的讀取SETUP,IDIE,讀取SETUP,PDATA都出現了turnaround。

 


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

-Advertisement-
Play Games
更多相關文章
  • 日常開發中,我們都會用到線程池,一般會用execute()和submit()方法提交任務。但是當你用過CompletableFuture之後,就會發現以前的線程池處理任務有多難用,功能有多簡陋,CompletableFuture又是多麼簡潔優雅。 要知道CompletableFuture已經隨著Ja ...
  • 能夠理解服務監控三要素 能夠理解常用的APM系統優勢差異 能夠基於IDEA集成Skywalking Agent 能基於生產環境使用Skywalking Agent 掌握Rocketbot 性能分析 鏈路追蹤 儀錶盤應用 Webhook 1 Skywalking概述 隨著互聯網架構的擴張,分散式系統變 ...
  • 作者:永動的圖靈機 鏈接:https://juejin.cn/post/6844904033488994317 統一結果返回 目前的前後端開發大部分數據的傳輸格式都是json,因此定義一個統一規範的數據格式有利於前後端的交互與UI的展示。 統一結果的一般形式 是否響應成功; 響應狀態碼; 狀態碼描述 ...
  • 今天產品下了新需求,要給系統加雙語切換,在做到國家城市庫映射的時候,我在度娘上找了個雙語版的資料庫,可是系統已經在生產半年了,直接換表肯定是要背鍋的,轉念一想,要是能把城市信息直接替換為拼音不就行了,在此將操作步驟整理下來。 首先需要安裝一下擴展overtrue/pinyin,執行命令,我的框架是6 ...
  • 函數中參數傳值 1、基本數據類型傳值 當函數中傳入的參數為基本數據類型時,函數中對傳入參數的操作不會對函數外的數據產生影響。由於基本數據類型的變數名指向的是具體的數值,在函數內部,相當於將參數進行了拷貝,函數內只對拷貝後的參數進行操作。 基本數據類型 public class ParamsTrans ...
  • 1.1.1 JAVA概述 Java版本 原網址(https://www.oracle.com/java/technologies/java-se-support-roadmap.html) Oracle 將僅將某些版本指定為長期支持 (LTS) 版本。Java SE 7、8、11 和 17 是 LT ...
  • 本項目將使用python3去識別圖片是否為色情圖片,會使用到PIL這個圖像處理庫,並且編寫演算法來劃分圖像的皮膚區域 介紹一下PIL: PIL(Python Image Library)是一種免費的圖像處理工具包,這個軟體包提供了基本的圖像處理功能,如:改變圖像大小,旋轉 圖像,圖像格式轉化,色場空間 ...
  • Android Jetpack Navigation基本使用 本篇主要介紹一下 Android Jetpack 組件 Navigation 導航組件的 基本使用 當看到 Navigation單詞的時候 應該就大概知道 這是一個關於導航用的,下麵我來簡單介紹一下 如何使用Navigation組件的基本 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 在我們開發過程中基本上不可或缺的用到一些敏感機密數據,比如SQL伺服器的連接串或者是OAuth2的Secret等,這些敏感數據在代碼中是不太安全的,我們不應該在源代碼中存儲密碼和其他的敏感數據,一種推薦的方式是通過Asp.Net Core的機密管理器。 機密管理器 在 ASP.NET Core ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 順序棧的介面程式 目錄順序棧的介面程式頭文件創建順序棧入棧出棧利用棧將10進位轉16進位數驗證 頭文件 #include <stdio.h> #include <stdbool.h> #include <stdlib.h> 創建順序棧 // 指的是順序棧中的元素的數據類型,用戶可以根據需要進行修改 ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • C總結與剖析:關鍵字篇 -- <<C語言深度解剖>> 目錄C總結與剖析:關鍵字篇 -- <<C語言深度解剖>>程式的本質:二進位文件變數1.變數:記憶體上的某個位置開闢的空間2.變數的初始化3.為什麼要有變數4.局部變數與全局變數5.變數的大小由類型決定6.任何一個變數,記憶體賦值都是從低地址開始往高地 ...
  • 如果讓你來做一個有狀態流式應用的故障恢復,你會如何來做呢? 單機和多機會遇到什麼不同的問題? Flink Checkpoint 是做什麼用的?原理是什麼? ...
  • C++ 多級繼承 多級繼承是一種面向對象編程(OOP)特性,允許一個類從多個基類繼承屬性和方法。它使代碼更易於組織和維護,並促進代碼重用。 多級繼承的語法 在 C++ 中,使用 : 符號來指定繼承關係。多級繼承的語法如下: class DerivedClass : public BaseClass1 ...
  • 前言 什麼是SpringCloud? Spring Cloud 是一系列框架的有序集合,它利用 Spring Boot 的開發便利性簡化了分散式系統的開發,比如服務註冊、服務發現、網關、路由、鏈路追蹤等。Spring Cloud 並不是重覆造輪子,而是將市面上開發得比較好的模塊集成進去,進行封裝,從 ...
  • class_template 類模板和函數模板的定義和使用類似,我們已經進行了介紹。有時,有兩個或多個類,其功能是相同的,僅僅是數據類型不同。類模板用於實現類所需數據的類型參數化 template<class NameType, class AgeType> class Person { publi ...
  • 目錄system v IPC簡介共用記憶體需要用到的函數介面shmget函數--獲取對象IDshmat函數--獲得映射空間shmctl函數--釋放資源共用記憶體實現思路註意 system v IPC簡介 消息隊列、共用記憶體和信號量統稱為system v IPC(進程間通信機制),V是羅馬數字5,是UNI ...