日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > > 嵌入式微處理器
[導(dǎo)讀]最近使用ZYNQ做一個(gè)高速數(shù)據(jù)采集,需要訪問一個(gè)ADI的高速模數(shù)采樣芯片,該芯片是利用三線制實(shí)現(xiàn)讀以及寫的功能。三線制實(shí)現(xiàn)寫通信或許大家都經(jīng)常會(huì)這樣用,三線制實(shí)現(xiàn)讀/寫或許有的朋友就未曾這樣用過。今天就給大家分享一下,利用現(xiàn)成IP不寫任何代碼如何實(shí)現(xiàn)三線制SPI。


導(dǎo)讀:最近使用ZYNQ做一個(gè)高速數(shù)據(jù)采集,需要訪問一個(gè)ADI的高速模數(shù)采樣芯片,該芯片是利用三線制實(shí)現(xiàn)讀以及寫的功能。三線制實(shí)現(xiàn)寫通信或許大家都經(jīng)常會(huì)這樣用,三線制實(shí)現(xiàn)讀/寫或許有的朋友就未曾這樣用過。今天就給大家分享一下,利用現(xiàn)成IP不寫任何代碼如何實(shí)現(xiàn)三線制SPI。

背景

ADI很多芯片都采用三線制SPI進(jìn)行控制,以AD9467為例,AD9467是一款 pipeline架構(gòu)16位高速ADC芯片,采樣率高達(dá)250MSPS。在一些復(fù)雜系統(tǒng)中其應(yīng)用領(lǐng)域比較廣泛:

  • 多載波,多模式蜂窩接收機(jī)
  • 天線陣列定位
  • 功率放大器線性化
  • 無線寬帶通信系統(tǒng)
  • 雷達(dá)系統(tǒng)
  • 紅外成像系統(tǒng)
  • 通訊儀表系統(tǒng)等

從芯片框圖,大致可以看出,該芯片主要由以下部分組成:

  • 三線制SPI通信接口,實(shí)現(xiàn)芯片的寄存器讀寫控制。主要用于芯片模式配置。
  • LVDS接口:則負(fù)責(zé)數(shù)據(jù)的對(duì)外傳輸,遵循ANSI-644 標(biāo)準(zhǔn)。
  • CLK+/CLK-:為輸入時(shí)鐘,時(shí)鐘之于數(shù)字芯片相當(dāng)于心臟之于人,一切的動(dòng)作都是由時(shí)鐘驅(qū)動(dòng)的。
  • VIN+/VIN- :差分輸入,模擬信號(hào)輸入通道。

對(duì)于芯片的其他部分,不是本文介紹的重點(diǎn),這里來看看其SPI的通信時(shí)序圖:


結(jié)合SPI模式時(shí)序圖:

  • 在上升沿采樣
  • 下一位數(shù)據(jù)在CLK低期間變換

故,CPOL=0,CPHA=0.

另外,第一個(gè)bit用于標(biāo)識(shí)本次報(bào)文你發(fā)起的是讀還是寫操作,這種設(shè)計(jì)是不是有點(diǎn)類似I2C標(biāo)準(zhǔn)中的讀寫位?

柳暗花明

那么問題來了,我們需要做的SPI通信需要實(shí)現(xiàn)三線制SPI進(jìn)行讀以及寫:

  • 如果用單片機(jī)編程IO口去翻比較容易,但是要實(shí)現(xiàn)高速AD數(shù)據(jù)傳輸,常規(guī)的單片機(jī)就捉襟見肘了。LVDS接口的數(shù)據(jù)吞吐率很難做到。
  • 如果使用ZYNQ內(nèi)置的SPI外設(shè)也很容易,該外設(shè)很容易配成三線制模式。很不幸,外設(shè)引腳基本用掉了。不過可以考慮用EMIO把相應(yīng)的腳從PL端拉出去。
  • 如果利用ZYNQ PS端的GPIO也可以做到,也很不幸,做的板子PS端GPIO所剩無幾。
  • 利用賽靈思的AXI Quad SPI ?IP在PL端去實(shí)現(xiàn)。折騰一段時(shí)間,發(fā)現(xiàn)這個(gè)IP貌似不支持三線制SPI。
  • 自己用verilog HDL寫個(gè)IP掛在AXI總線上,實(shí)現(xiàn)Linux設(shè)備驅(qū)動(dòng),這個(gè)方案可以??上?,比較懶,不想重新造輪子!
  • .......

經(jīng)過一番折騰,在ADI官方發(fā)現(xiàn)了一個(gè)寶藏:

https://wiki.analog.com/resources/fpga/peripherals/spi_engine

官方實(shí)現(xiàn)了SPI engine IP 框架:

  • 執(zhí)行模塊 Execution Module:主模塊,用于處理SPI引擎命令流并實(shí)現(xiàn)SPI總線接口邏輯
  • AXI接口模塊:內(nèi)存映射軟件可訪問SPI引擎命令流和/或卸載核心的接口
  • Offload模塊:存儲(chǔ)SPI引擎命令流,由外部事件觸發(fā)執(zhí)行
  • 互連Interconnect 模塊:將多個(gè)SPI Engine命令流連接到SPI Engine執(zhí)行模塊

其verilog HDL代碼庫位于:

https://github.com/analogdevicesinc/hdl.git

PS/PL設(shè)計(jì)

下好hdl庫,按照向?qū)靘ake,執(zhí)行對(duì)應(yīng)的tcl腳本,生成了hdl庫相應(yīng)所需文件。然后按照需要設(shè)計(jì)以下block設(shè)計(jì):

  • 將PS端的DDR以及PL所需的時(shí)鐘FCLK_CLK0配置好,這里輸出100MHz
  • 從ip庫里拉出來axi_spi_engine_v1_0以及spi_engine_execution_v1_0,按照上面圖連好線
  • 連好AXI接口,以及相應(yīng)的復(fù)位、時(shí)鐘信號(hào)等
  • 設(shè)置需要幾個(gè)片選信號(hào),可根據(jù)需要幾個(gè)從芯片可以設(shè)置多個(gè)片選信號(hào),比如我設(shè)置2個(gè),這樣在linux設(shè)備樹上就對(duì)應(yīng)掛載兩個(gè)設(shè)備。

然后在頂層設(shè)計(jì)文件進(jìn)行例化,這里問題來了,spi_1還是4個(gè)腳,如果就這樣拉出到PL端的引腳上,還是四線制,那么該怎么改呢?

看看wiki中圖以及描述,發(fā)現(xiàn)需要還需要在轉(zhuǎn)一下:


  • 如果是三線模式時(shí),three_wire會(huì)變成1,這個(gè)通過AXI總線命令傳過來。
  • sdo_t則可以控制sdo內(nèi)部信號(hào)是否輸出,如果門控關(guān)斷則mosi腳變成高阻,可以采樣外部信號(hào),從而傳入可以通過2路選擇器傳入sdi轉(zhuǎn)而為讀信號(hào)。

從而添加如下代碼在頂層文件:

assign?phy_sclk?=?spi_sclk;
assign?phy_cs?=?spi_cs;
assign?phy_mosi?=?spi_sdo_t???1'bz?:?spi_sdo;
assign?spi_sdi?=?spi_three_wire???phy_mosi?:?phy_miso;

比如,我是這樣寫的:

`timescale?1ns?/?100ps
//頂層設(shè)計(jì)文件
module?system_top?(
//DDR信號(hào)
inout???[14:0]??ddr_addr,
inout???[?2:0]??ddr_ba,
inout???????????ddr_cas_n,
inout???????????ddr_ck_n,
inout???????????ddr_ck_p,
inout???????????ddr_cke,
inout???????????ddr_cs_n,
inout???[?3:0]??ddr_dm,
inout???[31:0]??ddr_dq,
inout???[?3:0]??ddr_dqs_n,
inout???[?3:0]??ddr_dqs_p,
inout???????????ddr_odt,
inout???????????ddr_ras_n,
inout???????????ddr_reset_n,
inout???????????ddr_we_n,
//必須的一些PS信號(hào)
inout???????????fixed_io_ddr_vrn,
inout???????????fixed_io_ddr_vrp,
//54個(gè)PS?MIO引腳
inout???[53:0]??fixed_io_mio,
//PS時(shí)鐘引腳
inout???????????fixed_io_ps_clk,
//PS上電復(fù)位信號(hào)
inout???????????fixed_io_ps_porb,
//PS?SRSTB信號(hào)
inout???????????fixed_io_ps_srstb,

output?[1:0]???????spi_0_cs,
output?????????????spi_0_sclk,
input??????????????spi_0_sdi,
output?????????????spi_0_sdo,
);
??
wire?ip_spi_0_cs;
wire?ip_spi_0_sclk;
wire?ip_spi_0_sdi;
wire?ip_spi_0_sdo;
wire?ip_spi_0_three_wire;???
wire?ip_spi_0_sdo_t;

assign?spi_0_cs?=?ip_spi_0_cs;
assign?spi_0_sclk?=?ip_spi_0_sclk;
//如此處理,這樣引出的SPI可以兼容3線制以及4線制SPI
assign?spi_0_sdo?=?ip_spi_0_sdo_t???1'bz?:?ip_spi_0_sdo;
assign?ip_spi_0_sdi?=?ip_spi_0_three_wire???spi_0_sdo?:?spi_0_sdi;

//例化block設(shè)計(jì)
ip_block_wrapper?i_system_wrapper?(
????//DDR以及常規(guī)MIO、時(shí)鐘、復(fù)位等信號(hào)
????.DDR_addr(ddr_addr),
????.DDR_ba(ddr_ba),
????.DDR_cas_n(ddr_cas_n),
????.DDR_ck_n(ddr_ck_n),
????.DDR_ck_p(ddr_ck_p),
????.DDR_cke(ddr_cke),
????.DDR_cs_n(ddr_cs_n),
????.DDR_dm(ddr_dm),
????.DDR_dq(ddr_dq),
????.DDR_dqs_n(ddr_dqs_n),
????.DDR_dqs_p(ddr_dqs_p),
????.DDR_odt(ddr_odt),
????.DDR_ras_n(ddr_ras_n),
????.DDR_reset_n(ddr_reset_n),
????.DDR_we_n(ddr_we_n),
????.FIXED_IO_ddr_vrn(fixed_io_ddr_vrn),
????.FIXED_IO_ddr_vrp(fixed_io_ddr_vrp),
????.FIXED_IO_mio(fixed_io_mio),
????.FIXED_IO_ps_clk(fixed_io_ps_clk),
????.FIXED_IO_ps_porb(fixed_io_ps_porb),
????.FIXED_IO_ps_srstb(fixed_io_ps_srstb),???????

??????//連至頂層
????.spi_0_cs(ip_spi_0_cs),
????.spi_0_sclk(ip_spi_0_sclk),
????.spi_0_sdi(ip_spi_0_sdi),
????.spi_0_sdo(ip_spi_0_sdo),
????.spi_0_sdo_t(ip_spi_0_sdo_t),
????.spi_0_three_wire(ip_spi_0_three_wire)?????
??);????
endmodule

Linux端配置

首先需要配置設(shè)備樹:

&axi_spi_engine_0?{
????status?=?"okay";
????//配置SPI控制器匹配字段,這樣會(huì)自動(dòng)編譯ADI?提供的SPI?控制器驅(qū)動(dòng)
????compatible?=?"adi,axi-spi-engine-1.00.a";
????spi-rx-bus-width?=?<1>;
????spi-tx-bus-width?=?<1>;?
????bits-per-word?=?<8>;
????interrupt-parent?=?<&intc>;
????interrupts?=?<0?30?4>;??????
????num-cs?=?<4>;

????#address-cells?=?<0x1>;
?? ?#size-cells?=?<0x0>;????
????ad9467_0:?ad9467@0?{
????????compatible?=?"adi,ad9467";
????????reg?=?<0>;
????????spi-max-frequency?=?<500000>;
????????#address-cells?=?<1>;
????????#size-cells?=?<1>;

????????spi-rx-bus-width?=?<1>;?
????????spi-tx-bus-width?=?<1>;
????????bits-per-word?=?<8>;
????????spi-3wire;????????
????};

????ad9467_1:?ad9467@1?{
????????compatible?=?"spidev";
????????reg?=?<1>;
????????spi-max-frequency?=?<500000>;
????????#address-cells?=?<1>;
????????#size-cells?=?<1>;????????
?
????????spi-rx-bus-width?=?<1>;?
????????spi-tx-bus-width?=?<1>;
????????bits-per-word?=?<8>;
????????//這個(gè)字段需要使能,表示該設(shè)備是三線制
????????spi-3wire;???????????
????};??????
};

基于ADI提高的Linux代碼庫:

https://github.com/analogdevicesinc/Linux

配置相應(yīng)的SPI控制器驅(qū)動(dòng),然后編譯部署。由于該demo涉及些項(xiàng)目其他的技術(shù)細(xì)節(jié),這里就不描述了,來看看療效:


看這個(gè)波形或許會(huì)有朋友問:為啥數(shù)據(jù)發(fā)送結(jié)束,SDO/SDI復(fù)用腳波形有一個(gè)上升的漸變暫態(tài)過程,這是由于此時(shí)從端芯片從輸出態(tài)轉(zhuǎn)為高阻態(tài),而主端芯片此時(shí)也是高阻態(tài),由于線路電容效應(yīng)故而會(huì)有這樣一個(gè)變化過程。

總結(jié)一下

利用ADI提高的IP庫,不用敲一行代碼可以很容易就實(shí)現(xiàn)了三線制SPI,香吧?該方案可以同時(shí)兼容三線制/四線制SPI,是一個(gè)成熟穩(wěn)定的方案。為什么ZYNQ芯片這樣一款SOC芯片以及Linux會(huì)被人喜歡,由此可見一斑。因?yàn)橛写罅砍墒斓妮喿涌晒┦褂?,而不必自己去造輪子。從而加速產(chǎn)品的研發(fā)進(jìn)度,使用戶可以專注于自己需要解決的應(yīng)用問題。這里有一個(gè)tips拿走不謝:

在做應(yīng)用開發(fā)時(shí),首先梳理出需求,要干什么?去往哪里?但別急著擼代碼,先搜搜看有沒有現(xiàn)成的輪子,拒絕重新造輪子!一定會(huì)加速開發(fā)進(jìn)程。但也需要注意一下開源資源是否可以免費(fèi)商用,注意知識(shí)產(chǎn)權(quán)IP問題!

END

來源:嵌入式客棧,作者:逸珺

版權(quán)歸原作者所有,如有侵權(quán),請(qǐng)聯(lián)系刪除。

推薦閱讀

樹莓派Pico:僅4美元的MCU

嵌入式Linux開發(fā)板裸機(jī)程序燒寫方法總結(jié)

國產(chǎn)16位MCU的痛點(diǎn),可以用這款物美價(jià)廉產(chǎn)品


→點(diǎn)關(guān)注,不迷路←

免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺(tái)僅提供信息存儲(chǔ)服務(wù)。文章僅代表作者個(gè)人觀點(diǎn),不代表本平臺(tái)立場(chǎng),如有問題,請(qǐng)聯(lián)系我們,謝謝!

嵌入式ARM

掃描二維碼,關(guān)注更多精彩內(nèi)容

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動(dòng)電源

在工業(yè)自動(dòng)化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動(dòng)力設(shè)備,其驅(qū)動(dòng)電源的性能直接關(guān)系到整個(gè)系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動(dòng)勢(shì)抑制與過流保護(hù)是驅(qū)動(dòng)電源設(shè)計(jì)中至關(guān)重要的兩個(gè)環(huán)節(jié),集成化方案的設(shè)計(jì)成為提升電機(jī)驅(qū)動(dòng)性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動(dòng)電源

LED 驅(qū)動(dòng)電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個(gè)照明設(shè)備的使用壽命。然而,在實(shí)際應(yīng)用中,LED 驅(qū)動(dòng)電源易損壞的問題卻十分常見,不僅增加了維護(hù)成本,還影響了用戶體驗(yàn)。要解決這一問題,需從設(shè)計(jì)、生...

關(guān)鍵字: 驅(qū)動(dòng)電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動(dòng)電源的公式,電感內(nèi)電流波動(dòng)大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計(jì) 驅(qū)動(dòng)電源

電動(dòng)汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動(dòng)汽車的核心技術(shù)之一是電機(jī)驅(qū)動(dòng)控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動(dòng)系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動(dòng)汽車的動(dòng)力性能和...

關(guān)鍵字: 電動(dòng)汽車 新能源 驅(qū)動(dòng)電源

在現(xiàn)代城市建設(shè)中,街道及停車場(chǎng)照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨(dú)特的優(yōu)勢(shì)逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動(dòng)電源 LED

LED通用照明設(shè)計(jì)工程師會(huì)遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動(dòng)電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動(dòng)電源的電磁干擾(EMI)問題成為了一個(gè)不可忽視的挑戰(zhàn)。電磁干擾不僅會(huì)影響LED燈具的正常工作,還可能對(duì)周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動(dòng)電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動(dòng)電源

關(guān)鍵字: LED 驅(qū)動(dòng)電源 開關(guān)電源

LED驅(qū)動(dòng)電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動(dòng)LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動(dòng)電源
關(guān)閉