針對(duì)FPGA的完全可配置嵌入式32位RISC處理器
Mico32可以用于各種存儲(chǔ)系統(tǒng),同時(shí)使用內(nèi)嵌存儲(chǔ)器用于存儲(chǔ)指令和數(shù)據(jù)。內(nèi)嵌存儲(chǔ)器可以建立一個(gè)本地哈佛結(jié)構(gòu),并允許單周期訪問(wèn)指令和數(shù)據(jù)。對(duì)于更大的存儲(chǔ)器需求,處理器通過(guò)一個(gè)仲裁器連接到其他的存儲(chǔ)器模塊或接口。這可以是用FPGA的存儲(chǔ)器資源來(lái)實(shí)現(xiàn)的 “片上”存儲(chǔ)器,或接口至外部存儲(chǔ)器,諸如SSRAM、Flash和DRAM。處理所有訪問(wèn)協(xié)議至外部存儲(chǔ)器的合適接口模塊是由MSB提供的。提供可選的指令和數(shù)據(jù)高速緩存,能夠配置成各種選擇(高速緩存的大小,高速緩存塊的大小等等)。
通過(guò)一個(gè)開(kāi)放源碼Wishbone總線接口,該處理器連接到各種外圍元件。針對(duì)快速周轉(zhuǎn)周期,圖形用戶界面可以輕松和快速地創(chuàng)建處理器平臺(tái)。除了標(biāo)準(zhǔn)存儲(chǔ)器控制器,這可能包括各種接口,不僅支持I2C、通用IO、定時(shí)器,UART以及SPI,還能支持更復(fù)雜的模塊,如PCI接口或TriSpeed以太網(wǎng)MAC。
直接存儲(chǔ)器訪問(wèn)(DMA)控制器是可用的,添加主器件(master)至Wishbone總線,以免除處理器的數(shù)據(jù)傳輸工作。這也允許有DMA功能的外設(shè)高效地直接傳輸數(shù)據(jù)到存儲(chǔ)系統(tǒng),從而節(jié)省了片上總線的帶寬。
除了外圍元件和DMA,用戶可以自定義仲裁方案??偩€結(jié)構(gòu)產(chǎn)生器支持主器件(master)方和從器件(Slave)方的總線仲裁。如果能夠滿足系統(tǒng)性能的要求,主器件方總線仲裁提供了一個(gè)簡(jiǎn)單的低成本解決方案。然而,如果在設(shè)計(jì)中有多個(gè)總線主器件和多個(gè)從器件,在任何時(shí)間主器件方總線仲裁限制與單總線主器件通信。在許多設(shè)計(jì)中,通過(guò)兩個(gè)或兩個(gè)以上的總線主器件同時(shí)與獨(dú)立的從器件進(jìn)行通信,從器件方仲裁改進(jìn)了性能。圖3展示了可用的仲裁方案?!?p align="center">
圖3 仲裁方案
用戶還可以創(chuàng)建自己的基于Wishbone總線的外設(shè)元件,然后通過(guò)整合到MSB自動(dòng)連接到總線。因此,LatticeMico32的架構(gòu)提供了兩種可能性:第一,人們可以創(chuàng)建定制的元件,將它放人MSB中的可用元件列表(圖4)。第二,可以構(gòu)建出所謂的Passthru元件,可以將Wishbone接口引出到核的外面,因此,用戶可以在FPGA的其他部分添加任何邏輯塊。
圖4 創(chuàng)建定制的外圍組件
linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)
評(píng)論