日B视频 亚洲,啪啪啪网站一区二区,91色情精品久久,日日噜狠狠色综合久,超碰人妻少妇97在线,999青青视频,亚洲一区二卡,让本一区二区视频,日韩网站推荐

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

如何利用現成IP不寫代碼實現三線制SPI?

璟琰乀 ? 來源:嵌入式客棧 ? 作者:嵌入式客棧 ? 2020-12-22 14:22 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

最近使用ZYNQ做一個高速數據采集,需要訪問一個ADI的高速模數采樣芯片,該芯片是利用三線制實現讀以及寫的功能。三線制實現寫通信或許大家都經常會這樣用,三線制實現讀/寫或許有的朋友就未曾這樣用過。今天就分享一下利用現成IP不寫任何代碼怎么實現三線制SPI。

背景ADI很多芯片都采用三線制SPI進行控制,以AD9467為例,AD9467是一款 pipeline架構16位高速ADC芯片,采樣率高達250MSPS。在一些復雜系統中其應用領域比較廣泛:

多載波,多模式蜂窩接收機

天線陣列定位

功率放大器線性化

無線寬帶通信系統

雷達系統

紅外成像系統

通訊儀表系統等

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

Rbae6f.png

三線制SPI通信接口,實現芯片的寄存器讀寫控制。主要用于芯片模式配置。

LVDS接口:則負責數據的對外傳輸,遵循ANSI-644 標準。

CLK+/CLK-:為輸入時鐘,時鐘之于數字芯片相當于心臟之于人,一切的動作都是由時鐘驅動的。

VIN+/VIN- :差分輸入,模擬信號輸入通道。

對于芯片的其他部分,不是本文介紹的重點,這里來看看其SPI的通信時序圖:

nuQjAv.png

結合SPI模式時序圖:

在上升沿采樣

下一位數據在CLK低期間變換

故,CPOL=0,CPHA=0.

另外,第一個bit用于標識本次報文你發(fā)起的是讀還是寫操作,這種設計是不是有點類似I2C標準中的讀寫位?

柳暗花明那么問題來了,我們需要做的SPI通信需要實現三線制SPI進行讀以及寫:

如果用單片機編程IO口去翻比較容易,但是要實現高速AD數據傳輸,常規(guī)的單片機就捉襟見肘了。LVDS接口的數據吞吐率很難做到。

如果使用ZYNQ內置的SPI外設也很容易,該外設很容易配成三線制模式。很不幸,外設引腳基本用掉了。不過可以考慮用EMIO把相應的腳從PL端拉出去。

如果利用ZYNQ PS端的GPIO也可以做到,也很不幸,做的板子PS端GPIO所剩無幾。

利用賽靈思的AXI Quad SPI IP在PL端去實現。折騰一段時間,發(fā)現這個IP貌似不支持三線制SPI。

自己用verilog HDL寫個IP掛在AXI總線上,實現Linux設備驅動,這個方案可以??上?,比較懶,不想重新造輪子!

。。.。。.。

經過一番折騰,在ADI官方發(fā)現了一個寶藏:

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

官方實現了SPI engine IP 框架:

執(zhí)行模塊 Execution Module:主模塊,用于處理SPI引擎命令流并實現SPI總線接口邏輯

AXI接口模塊:內存映射軟件可訪問SPI引擎命令流和/或卸載核心的接口

Offload模塊:存儲SPI引擎命令流,由外部事件觸發(fā)執(zhí)行

互連Interconnect 模塊:將多個SPI Engine命令流連接到SPI Engine執(zhí)行模塊

其verilog HDL代碼庫位于:

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

PS/PL設計下好hdl庫,按照向導將庫make,執(zhí)行對應的tcl腳本,生成了hdl庫相應所需文件。然后按照需要設計以下block設計:

I3UfIn.png

將PS端的DDR以及PL所需的時鐘FCLK_CLK0配置好,這里輸出100MHz

從ip庫里拉出來axi_spi_engine_v1_0以及spi_engine_execution_v1_0,按照上面圖連好線

連好AXI接口,以及相應的復位、時鐘信號等

設置需要幾個片選信號,可根據需要幾個從芯片可以設置多個片選信號,比如我設置2個,這樣在linux設備樹上就對應掛載兩個設備。

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

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

FB3aEn.png

如果是三線模式時,three_wire會變成1,這個通過AXI總線命令傳過來。

sdo_t則可以控制sdo內部信號是否輸出,如果門控關斷則mosi腳變成高阻,可以采樣外部信號,從而傳入可以通過2路選擇器傳入sdi轉而為讀信號。

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

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//頂層設計文件module system_top (//DDR信號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信號inout fixed_io_ddr_vrn,inout fixed_io_ddr_vrp,//54個PS MIO引腳inout [53:0] fixed_io_mio,//PS時鐘引腳inout fixed_io_ps_clk,//PS上電復位信號inout fixed_io_ps_porb,//PS SRSTB信號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線制SPIassign 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設計ip_block_wrapper i_system_wrapper ( //DDR以及常規(guī)MIO、時鐘、復位等信號 .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端配置首先需要配置設備樹:

&axi_spi_engine_0 { status = “okay”; //配置SPI控制器匹配字段,這樣會自動編譯ADI 提供的SPI 控制器驅動 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》; //這個字段需要使能,表示該設備是三線制 spi-3wire; }; };

配置相應的SPI控制器驅動,然后編譯部署。由于該demo涉及些項目其他的技術細節(jié),這里就不描述了,來看看療效:

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

總結一下利用ADI提高的IP庫,不用敲一行代碼可以很容易就實現了三線制SPI,香吧?該方案可以同時兼容三線制/四線制SPI,是一個成熟穩(wěn)定的方案。為什么ZYNQ芯片這樣一款SOC芯片以及Linux會被人喜歡,由此可見一斑。因為有大量成熟的輪子可供使用,而不必自己去造輪子。從而加速產品的研發(fā)進度,使用戶可以專注于自己需要解決的應用問題。

責任編輯:haq

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯系本站處理。 舉報投訴
  • 芯片
    +關注

    關注

    463

    文章

    54507

    瀏覽量

    470061
  • 驅動
    +關注

    關注

    12

    文章

    1996

    瀏覽量

    88738
  • SPI
    SPI
    +關注

    關注

    17

    文章

    1900

    瀏覽量

    102276
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    工業(yè)設備必備:三線電源濾波器詳解

    干擾不僅影響設備自身的穩(wěn)定性,還會通過電網傳播,導致控制系統誤動作、通信異常甚至設備損壞。三線電源濾波器正是為了解決這些問題而設計的。 一、工作原理與核心構成 原理是利用電感和電容元件構建一個低通濾波網絡
    的頭像 發(fā)表于 04-24 11:04 ?105次閱讀
    工業(yè)設備必備:<b class='flag-5'>三</b>相<b class='flag-5'>三線</b>電源濾波器詳解

    一線圈和三線圈無線充區(qū)別

    三線圈無線充電技術革新充電體驗,提升效率、穩(wěn)定性和自由放置能力,拓展多場景應用。
    的頭像 發(fā)表于 04-18 08:23 ?188次閱讀
    一線圈和<b class='flag-5'>三線</b>圈無線充區(qū)別

    三線圈無線充電器原理是什么?

    三線圈無線充電實現多設備智能協同,提升充電效率與靈活性。
    的頭像 發(fā)表于 04-15 08:17 ?478次閱讀
    <b class='flag-5'>三線</b>圈無線充電器原理是什么?

    三線 380v 電壓能轉換成 220v 電壓嗎?一文講清原理、方法與安全規(guī)范

    原理與安全規(guī)范,絕非隨意接線即可實現。本文從原理、合規(guī)方法、安全禁忌、選型要點四大維度,全面解析三線380V轉220V的核心知識,助力企業(yè)安全、穩(wěn)定實現電壓轉換。一、
    的頭像 發(fā)表于 03-30 11:09 ?1022次閱讀
    <b class='flag-5'>三</b>相<b class='flag-5'>三線</b> 380v 電壓能轉換成 220v 電壓嗎?一文講清原理、方法與安全規(guī)范

    三線電表功率因數全 1.00?別被表面數據蒙蔽了

    無功補償運維中,三線制電表顯示B相功率因數1.00并非實際補償效果,需警惕A、C相雙1.00帶來的誤導,實際功率因數可能偏低,需科學分析。
    的頭像 發(fā)表于 02-28 13:09 ?257次閱讀
    <b class='flag-5'>三</b>相<b class='flag-5'>三線</b>電表功率因數全 1.00?別被表面數據蒙蔽了

    工業(yè)現場傳感器接線秘籍:兩、四穩(wěn)、三線剛剛好

    工業(yè)現場傳感器接線總出錯?兩三線、四制傳感器傻傻分不清?本文用一張表格+步圖解,教你快速掌握ZAM5404采集模塊的接線要領,其他ADC模塊同樣適用。前言在工業(yè)現場,4~20m
    的頭像 發(fā)表于 02-25 13:09 ?609次閱讀
    工業(yè)現場傳感器接線秘籍:兩<b class='flag-5'>線</b>省<b class='flag-5'>線</b>、四<b class='flag-5'>線</b>穩(wěn)、<b class='flag-5'>三線</b>剛剛好

    無線充電器單線圈和三線

    無線充電從單線圈到三線圈進化,突破物理限制,提升效率,實現靈活充電。
    的頭像 發(fā)表于 01-06 08:34 ?735次閱讀
    無線充電器單線圈和<b class='flag-5'>三線</b>圈

    三線制電表的功率因數怎么看

    高壓相電表分為三線和四制,三線表測量功率因數時需考慮相位偏移,總功率因數反映系統性能
    的頭像 發(fā)表于 01-04 11:17 ?612次閱讀
    <b class='flag-5'>三</b>相<b class='flag-5'>三線</b>制電表的功率因數怎么看

    老舊產淘汰,數據孤島輕松破:EtherNet/IP與DeviceNet協議轉換實戰(zhàn)

    老舊產淘汰,數據孤島輕松破:EtherNet/IP與DeviceNet協議轉換實戰(zhàn) 本案例是用北京疆鴻智能技術有限公司生產的JH-EIP-DEVN型EtherNet/IP轉Devi
    的頭像 發(fā)表于 12-15 14:50 ?474次閱讀
    老舊產<b class='flag-5'>線</b><b class='flag-5'>不</b>淘汰,數據孤島輕松破:EtherNet/<b class='flag-5'>IP</b>與DeviceNet協議轉換實戰(zhàn)

    變頻器兩制和三線制接線的區(qū)別

    在工業(yè)自動化控制系統中,變頻器的接線方式直接影響設備運行的穩(wěn)定性和安全性。其中,兩制和三線制是兩種典型的控制接線模式,其區(qū)別主要體現在信號傳輸方式、抗干擾能力以及應用場景等方面。以下從技術
    的頭像 發(fā)表于 12-08 07:35 ?1511次閱讀
    變頻器兩<b class='flag-5'>線</b>制和<b class='flag-5'>三線</b>制接線的區(qū)別

    無線充電單線圈和三線

    現代無線充電技術通過線圈設計優(yōu)化,提升充電效率與靈活性,三線圈系統實現動態(tài)路徑調節(jié),增強抗干擾與溫控能力。
    的頭像 發(fā)表于 11-26 08:18 ?660次閱讀
    無線充電單線圈和<b class='flag-5'>三線</b>圈

    外殼防護等級(IP代碼)全解讀

    什么是外殼防護等級(IP代碼IP代碼,全稱為“國際防護等級”,是由國際電工委員會制定的全球通用標準。這一標準旨在為電子設備外殼的防護能力提供一個清晰、統一的評判體系。簡單來說,
    的頭像 發(fā)表于 10-14 12:13 ?1539次閱讀
    外殼防護等級(<b class='flag-5'>IP</b><b class='flag-5'>代碼</b>)全解讀

    FPGA利用DMA IP實現ADC數據采集

    DMA IP核來實現高效數據傳輸的步驟,包括創(chuàng)建項目、配置ADC接口、添加和連接DMA IP核、設計控制邏輯、生成比特流、軟件開發(fā)及系統集成。文章還強調了系統實現中不可或缺的
    的頭像 發(fā)表于 07-29 14:12 ?5376次閱讀

    零知開源——STM32F1驅動MAX31865讀取三線PT100溫度傳感器

    三線制PT100的特殊跳線修改,以及完整的代碼解析。文中還將解析PT100的溫度計算原理,并展示實際運行效果。 一、硬件簡介1. MAX31865模塊MAX31865是專用于RTD(電阻溫度檢測器
    發(fā)表于 05-23 18:27

    零知開源——STM32F1驅動MAX31865讀取三線PT100溫度傳感器

    本教程詳細介紹了如何使用零知標準板(STM32F103RBT6)通過MAX31865模塊讀取三線制PT100鉑電阻溫度,并通過I2C OLED實時顯示溫度值和電阻值。教程內容包括硬件接線配置、三線
    的頭像 發(fā)表于 05-23 18:05 ?3419次閱讀
    零知開源——STM32F1驅動MAX31865讀取<b class='flag-5'>三線</b>PT100溫度傳感器
    寿宁县| 喀什市| 古蔺县| 绥化市| 田阳县| 南京市| 湖南省| 成安县| 库尔勒市| 桐城市| 盐边县| 固阳县| 临汾市| 寻乌县| 南丰县| 屏南县| 新疆| 碌曲县| 迭部县| 马鞍山市| 乌拉特前旗| 武陟县| 阜南县| 南阳市| 宜州市| 西充县| 城固县| 石城县| 通城县| 邯郸市| 正蓝旗| 饶河县| 保山市| 葵青区| 广河县| 文水县| 呈贡县| 藁城市| 东安县| 漾濞| 额敏县|