女人荫蒂被添全过程13种图片,亚洲+欧美+在线,欧洲精品无码一区二区三区 ,在厨房拨开内裤进入毛片

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

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

如何利用現(xiàn)成IP不寫(xiě)代碼實(shí)現(xiàn)三線制SPI?

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

掃碼添加小助手

加入工程師交流群

最近使用ZYNQ做一個(gè)高速數(shù)據(jù)采集,需要訪問(wèn)一個(gè)ADI的高速模數(shù)采樣芯片,該芯片是利用三線制實(shí)現(xiàn)讀以及寫(xiě)的功能。三線制實(shí)現(xiàn)寫(xiě)通信或許大家都經(jīng)常會(huì)這樣用,三線制實(shí)現(xiàn)讀/寫(xiě)或許有的朋友就未曾這樣用過(guò)。今天就分享一下利用現(xiàn)成IP不寫(xiě)任何代碼怎么實(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ī)

天線陣列定位

功率放大器線性化

無(wú)線寬帶通信系統(tǒng)

雷達(dá)系統(tǒng)

紅外成像系統(tǒng)

通訊儀表系統(tǒng)等

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

Rbae6f.png

三線制SPI通信接口,實(shí)現(xiàn)芯片的寄存器讀寫(xiě)控制。主要用于芯片模式配置。

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),這里來(lái)看看其SPI的通信時(shí)序圖:

nuQjAv.png

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

在上升沿采樣

下一位數(shù)據(jù)在CLK低期間變換

故,CPOL=0,CPHA=0.

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

柳暗花明那么問(wèn)題來(lái)了,我們需要做的SPI通信需要實(shí)現(xiàn)三線制SPI進(jìn)行讀以及寫(xiě):

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

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

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

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

自己用verilog HDL寫(xiě)個(gè)IP掛在AXI總線上,實(shí)現(xiàn)Linux設(shè)備驅(qū)動(dòng),這個(gè)方案可以。可惜,比較懶,不想重新造輪子!

。。.。。.。

經(jīng)過(guò)一番折騰,在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)存映射軟件可訪問(wèn)SPI引擎命令流和/或卸載核心的接口

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

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

其verilog HDL代碼庫(kù)位于:

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

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

I3UfIn.png

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

從ip庫(kù)里拉出來(lái)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è)備樹(shù)上就對(duì)應(yīng)掛載兩個(gè)設(shè)備。

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

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

FB3aEn.png

如果是三線模式時(shí),three_wire會(huì)變成1,這個(gè)通過(guò)AXI總線命令傳過(guò)來(lái)。

sdo_t則可以控制sdo內(nèi)部信號(hào)是否輸出,如果門(mén)控關(guān)斷則mosi腳變成高阻,可以采樣外部信號(hào),從而傳入可以通過(guò)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;

比如,我是這樣寫(xiě)的:

`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線制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設(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è)備樹(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; }; };

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

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

總結(jié)一下利用ADI提高的IP庫(kù),不用敲一行代碼可以很容易就實(shí)現(xiàn)了三線制SPI,香吧?該方案可以同時(shí)兼容三線制/四線制SPI,是一個(gè)成熟穩(wěn)定的方案。為什么ZYNQ芯片這樣一款SOC芯片以及Linux會(huì)被人喜歡,由此可見(jiàn)一斑。因?yàn)橛写罅砍墒斓妮喿涌晒┦褂茫槐刈约喝ピ燧喿印亩铀佼a(chǎn)品的研發(fā)進(jìn)度,使用戶可以專注于自己需要解決的應(yīng)用問(wèn)題。

責(zé)任編輯:haq

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 芯片
    +關(guān)注

    關(guān)注

    459

    文章

    52383

    瀏覽量

    439106
  • 驅(qū)動(dòng)
    +關(guān)注

    關(guān)注

    12

    文章

    1912

    瀏覽量

    86757
  • SPI
    SPI
    +關(guān)注

    關(guān)注

    17

    文章

    1793

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    AD7606C-18的硬件串行模式,如何使用三線SPI

    問(wèn)題,八個(gè)通通道輸入均連在一起,結(jié)果如下圖所示。 但是當(dāng)我使用三線SPI模式讀取數(shù)據(jù)時(shí),數(shù)據(jù)就錯(cuò)亂了,即使SCLK頻率降低到5MHz,數(shù)據(jù)也是完全錯(cuò)亂的。我可以確定三線模式下,SCLK,BUSY之間的時(shí)序
    發(fā)表于 04-28 07:49

    三線相四的區(qū)別

    在電力系統(tǒng)中,三線相四是兩種常見(jiàn)的供電方式,它們各自具有獨(dú)特的特點(diǎn)和應(yīng)用場(chǎng)景。本文將從基本結(jié)構(gòu)、電壓特性、應(yīng)用領(lǐng)域、優(yōu)缺點(diǎn)以及保護(hù)方法等方面,詳細(xì)探討
    的頭像 發(fā)表于 03-16 17:59 ?1647次閱讀
    <b class='flag-5'>三</b>相<b class='flag-5'>三線</b>和<b class='flag-5'>三</b>相四<b class='flag-5'>線</b>的區(qū)別

    ADS1248內(nèi)部集成的恒流源可否同時(shí)驅(qū)動(dòng)多路差分輸入,實(shí)現(xiàn)三線制接法?

    我想采用PT100三線制接法,通過(guò)ADS1248實(shí)現(xiàn)多路測(cè)溫,但是有以下問(wèn)題:ADS1248內(nèi)部集成的恒流源可否同時(shí)驅(qū)動(dòng)多路差分輸入,實(shí)現(xiàn)三線制接法。在閱讀官網(wǎng)的數(shù)據(jù)手冊(cè)都介紹的是一
    發(fā)表于 01-14 07:39

    請(qǐng)問(wèn)DAC80508M的SPI總線支持三線模式嗎?如果SPI總線上面只掛了一個(gè)DAC80508M,CS腳可以直接接地嗎?

    1. 請(qǐng)問(wèn)DAC80508M的SPI總線支持三線模式嗎?如果SPI總線上面只掛了一個(gè)DAC80508M,CS腳可以直接接地嗎? 1. BRDCAST-DATA[15:0]寄存器無(wú)法寫(xiě)入數(shù)據(jù),
    發(fā)表于 11-20 06:00

    三線電源濾波器的優(yōu)勢(shì)

    三線電源濾波器,作為現(xiàn)代電力系統(tǒng)中不可或缺的電氣元件,其重要性日益凸顯。在復(fù)雜多變的工業(yè)與商業(yè)用電環(huán)境中,三線電源濾波器以其獨(dú)特的優(yōu)勢(shì),為電力系統(tǒng)的穩(wěn)定運(yùn)行和電氣設(shè)備的可靠工作
    的頭像 發(fā)表于 10-10 09:03 ?763次閱讀
    <b class='flag-5'>三</b>相<b class='flag-5'>三線</b>電源濾波器的優(yōu)勢(shì)

    磁性開(kāi)關(guān)兩三線怎么互接

    磁性開(kāi)關(guān),又稱為磁簧開(kāi)關(guān)或霍爾開(kāi)關(guān),是一種利用磁場(chǎng)的變化來(lái)控制電路通斷的電子元件。它廣泛應(yīng)用于各種自動(dòng)控制、安全保護(hù)、位置檢測(cè)等領(lǐng)域。磁性開(kāi)關(guān)根據(jù)其引腳數(shù)量的不同,可以分為兩式和三線式兩種
    的頭像 發(fā)表于 08-26 15:24 ?7097次閱讀

    人體三線感應(yīng)開(kāi)關(guān)面板怎么接線

    人體三線感應(yīng)開(kāi)關(guān)面板的接線過(guò)程是一個(gè)相對(duì)直接且需要細(xì)致操作的過(guò)程。 一、準(zhǔn)備階段 工具準(zhǔn)備 :確保手邊有合適的工具,如剪線鉗、螺絲刀、絕緣膠帶等。 材料檢查 :檢查人體三線感應(yīng)開(kāi)關(guān)面板、電線(包括
    的頭像 發(fā)表于 08-26 15:22 ?3191次閱讀

    感應(yīng)開(kāi)關(guān)二三線優(yōu)缺點(diǎn)在哪

    干擾: 由于供電和信號(hào)共用一根,容易受到電磁干擾。 信號(hào)范圍有限: 信號(hào)同時(shí)承擔(dān)供電和信號(hào)傳輸,可能導(dǎo)致信號(hào)范圍和穩(wěn)定性不如三線制。 故障診斷困難: 當(dāng)出現(xiàn)故障時(shí),難以判斷是供電問(wèn)題還是信號(hào)問(wèn)題。
    的頭像 發(fā)表于 08-26 15:19 ?3446次閱讀

    磁性開(kāi)關(guān)兩制和三線制區(qū)別在哪

    制磁性開(kāi)關(guān) 兩制磁性開(kāi)關(guān)是指?jìng)鞲衅骱涂刂破髦g只需要兩根導(dǎo)線連接,一根用于供電,另一根用于信號(hào)傳輸。兩制磁性開(kāi)關(guān)的工作原理是利用磁場(chǎng)的變化來(lái)檢測(cè)物體的位置或狀態(tài)。 三線制磁性開(kāi)關(guān)
    的頭像 發(fā)表于 08-26 15:14 ?6127次閱讀

    三線的磁性開(kāi)關(guān)串聯(lián)使用方法

    三線的磁性開(kāi)關(guān)在工業(yè)自動(dòng)化和控制系統(tǒng)中扮演著重要角色,它們常用于檢測(cè)磁場(chǎng)的存在或變化,并據(jù)此控制電路的通斷。在需要將多個(gè)磁性開(kāi)關(guān)串聯(lián)使用時(shí),需要特別注意其接線方式和使用條件,以確保系統(tǒng)的穩(wěn)定性
    的頭像 發(fā)表于 08-26 15:11 ?5282次閱讀

    三線磁性開(kāi)關(guān)的接線方法及工作原理

    的作用而閉合,從而實(shí)現(xiàn)開(kāi)關(guān)的導(dǎo)通;當(dāng)磁鐵遠(yuǎn)離干簧管時(shí),磁簧片會(huì)因失去磁場(chǎng)的作用而斷開(kāi),從而實(shí)現(xiàn)開(kāi)關(guān)的斷開(kāi)。 三線磁性開(kāi)關(guān)的分別為:公共
    的頭像 發(fā)表于 08-26 15:09 ?6794次閱讀

    磁性開(kāi)關(guān)兩三線的區(qū)別

    磁性開(kāi)關(guān),又稱為磁控開(kāi)關(guān)或磁簧開(kāi)關(guān),是一種利用磁場(chǎng)變化來(lái)實(shí)現(xiàn)電路通斷的開(kāi)關(guān)器件。它廣泛應(yīng)用于各種自動(dòng)化控制系統(tǒng)、安全防護(hù)系統(tǒng)、家用電器等領(lǐng)域。磁性開(kāi)關(guān)根據(jù)接線方式的不同,可以分為兩式和三線
    的頭像 發(fā)表于 08-26 14:36 ?5128次閱讀

    求助,關(guān)于PGA309三線校準(zhǔn)與四校準(zhǔn)的問(wèn)題求解

    目前在用PGA309開(kāi)發(fā)一款壓力變送器,采用四校準(zhǔn)可以校準(zhǔn),但是如果直接采用三線校準(zhǔn)就不可以校準(zhǔn),必須要先通過(guò)四校準(zhǔn)一次,然后才可以采用三線校準(zhǔn),就是一塊新的PCB如果直接用
    發(fā)表于 08-16 06:20

    PGA309想要實(shí)現(xiàn)三線制通信校準(zhǔn)遇到的疑問(wèn)求解

    我目前已經(jīng)實(shí)現(xiàn)了PGA309四制通信校準(zhǔn)壓力變送器,現(xiàn)在想要實(shí)現(xiàn)三線制通信校準(zhǔn),遇到了一點(diǎn)困難,想要得到一些幫助,下面描述一下具體問(wèn)題: 1.我所說(shuō)的
    發(fā)表于 08-09 07:18

    三線熱電偶怎么判斷好壞

    三線熱電偶是一種常用的溫度測(cè)量?jī)x器,其工作原理是利用兩種不同金屬的熱電勢(shì)差來(lái)測(cè)量溫度。在實(shí)際應(yīng)用中,如何判斷三線熱電偶的好壞是一個(gè)非常重要的問(wèn)題。 外觀檢查 首先,我們需要對(duì)三線熱電偶
    的頭像 發(fā)表于 07-23 17:14 ?1842次閱讀
    主站蜘蛛池模板: 长垣县| 阿荣旗| 西峡县| 阳原县| 股票| 瓦房店市| 汝南县| 克山县| 望城县| 申扎县| 云林县| 灵寿县| 平遥县| 山西省| 大同县| 墨竹工卡县| 平潭县| 正阳县| 曲沃县| 凤翔县| 米易县| 涟源市| 常德市| 蓝山县| 新野县| 灵丘县| 荣昌县| 宝丰县| 扬中市| 新丰县| 开江县| 琼中| 武邑县| 彭水| 临沧市| 麻栗坡县| 南川市| 利辛县| 罗源县| 辛集市| 墨江|