RM新时代网站-首页

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

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

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

Firefly關(guān)于SPI簡介

firefly ? 來源:firefly ? 作者:firefly ? 2019-11-20 11:21 ? 次閱讀
SPI 使用

SPI是一種高速的,全雙工,同步串行通信接口,用于連接微控制器傳感器、存儲設(shè)備等。 Firefly-RK3399 開發(fā)板提供了 SPI1 (單片選)接口,具體位置如下圖:

SPI工作方式

SPI以主從方式工作,這種模式通常有一個主設(shè)備和一個或多個從設(shè)備,需要至少4根線,分別是:

CS 片選信號 SCLK 時鐘信號 MOSI 主設(shè)備數(shù)據(jù)輸出、從設(shè)備數(shù)據(jù)輸入 MISO 主設(shè)備數(shù)據(jù)輸入,從設(shè)備數(shù)據(jù)輸出

Linux內(nèi)核用CPOL和CPHA的組合來表示當(dāng)前SPI的四種工作模式:

CPOL=0,CPHA=0 SPI_MODE_0 CPOL=0,CPHA=1 SPI_MODE_1 CPOL=1,CPHA=0 SPI_MODE_2 CPOL=1,CPHA=1 SPI_MODE_3

CPOL:表示時鐘信號的初始電平的狀態(tài),0為低電平,1為高電平。CPHA:表示在哪個時鐘沿采樣,0為第一個時鐘沿采樣,1為第二個時鐘沿采樣。SPI的四種工作模式波形圖如下:

驅(qū)動編寫

下面以 W25Q128FV Flash模塊為例簡單介紹SPI驅(qū)動的編寫。

硬件連接

Firefly-RK3399 與 W25Q128FV 硬件連接如下表:

編寫Makefile/Kconfig

在kernel/drivers/spi/Kconfig中添加對應(yīng)的驅(qū)動文件配置:

config SPI_FIREFLY tristate "Firefly SPI demo support " default y help Select this option if your Firefly board needs to run SPI demo.

在kernel/drivers/spi/Makefile中添加對應(yīng)的驅(qū)動文件名:

obj-$(CONFIG_SPI_FIREFLY) += spi-firefly-demo.o

config中選中所添加的驅(qū)動文件,如:

│ Symbol: SPI_FIREFLY [=y] │ Type : tristate │ Prompt: Firefly SPI demo support │ Location: │ -> Device Drivers │ -> SPI support (SPI [=y]) │ Defined at drivers/spi/Kconfig:704 │ Depends on: SPI [=y] && SPI_MASTER [=y]
配置DTS節(jié)點

在kernel/arch/arm64/boot/dts/rockchip/rk3399-firefly-demo.dtsi中添加SPI驅(qū)動結(jié)點描述,如下所示:

/* Firefly SPI demo */ &spi1 { spi_demo: spi-demo@00{ status = "okay"; compatible = "firefly,rk3399-spi"; reg = <0x00>; spi-max-frequency = <48000000>; /* rk3399 driver support SPI_CPOL | SPI_CPHA | SPI_CS_HIGH */ //spi-cpha; /* SPI mode: CPHA=1 */ //spi-cpol; /* SPI mode: CPOL=1 */ //spi-cs-high; }; }; &spidev0 { status = "disabled"; };
  • status:如果要啟用SPI,則設(shè)為okay,如不啟用,設(shè)為disable。

  • spi-demo@00:由于本例子使用CS0,故此處設(shè)為00,如果使用CS1,則設(shè)為01。

  • compatible:這里的屬性必須與驅(qū)動中的結(jié)構(gòu)體:of_device_id 中的成員compatible 保持一致。

  • reg:此處與spi-demo@00保持一致,本例設(shè)為:0x00。

  • spi-max-frequency:此處設(shè)置spi使用的最高頻率。Firefly-RK3399最高支持48000000。

  • spi-cpha,spi-cpol:SPI的工作模式在此設(shè)置,本例所用的模塊SPI工作模式為SPI_MODE_0或者SPI_MODE_3,這里我們選用SPI_MODE_0,如果使用SPI_MODE_3,spi_demo中打開spi-cpha和spi-cpol即可。

  • spidev0: 由于spi_demo與spidev0使用一樣的硬件資源,需要把spidev0關(guān)掉才能打開spi_demo

定義SPI驅(qū)動

在內(nèi)核源碼目錄kernel/drivers/spi/中創(chuàng)建新的驅(qū)動文件,如:spi-firefly-demo.c 在定義 SPI 驅(qū)動之前,用戶首先要定義變量 of_device_id 。 of_device_id 用于在驅(qū)動中調(diào)用dts文件中定義的設(shè)備信息,其定義如下所示:

static struct of_device_id firefly_match_table[] = {{ .compatible = "firefly,rk3399-spi",},{},};

此處的compatible與DTS文件中的保持一致。

spi_driver定義如下所示:

static struct spi_driver firefly_spi_driver = { .driver = { .name = "firefly-spi", .owner = THIS_MODULE, .of_match_table = firefly_match_table,}, .probe = firefly_spi_probe,};
注冊SPI設(shè)備

在初始化函數(shù)static int __init spidev_init(void)中向內(nèi)核注冊SPI驅(qū)動: spi_register_driver(&firefly_spi_driver);

如果內(nèi)核啟動時匹配成功,則SPI核心會配置SPI的參數(shù)(mode、speed等),并調(diào)用firefly_spi_probe。

讀寫 SPI 數(shù)據(jù)

firefly_spi_probe中使用了兩種接口操作讀取W25Q128FV的ID: firefly_spi_read_w25x_id_0接口直接使用了spi_transfer和spi_message來傳送數(shù)據(jù)。 firefly_spi_read_w25x_id_1接口則使用SPI接口spi_write_then_read來讀寫數(shù)據(jù)。

成功后會打?。?/p>

root@rk3399_firefly_box:/ # dmesg | grep firefly-spi [ 1.006235] firefly-spi spi0.0: Firefly SPI demo program [ 1.006246] firefly-spi spi0.0: firefly_spi_probe: setup mode 0, 8 bits/w, 48000000 Hz max [ 1.006298] firefly-spi spi0.0: firefly_spi_read_w25x_id_0: ID = ef 40 18 00 00 [ 1.006361] firefly-spi spi0.0: firefly_spi_read_w25x_id_1: ID = ef 40 18 00 00
打開SPI demo

spi-firefly-demo默認(rèn)沒有打開,如果需要的話可以使用以下補(bǔ)丁打開demo驅(qū)動:

--- a/kernel/arch/arm64/boot/dts/rockchip/rk3399-firefly-demo.dtsi +++ b/kernel/arch/arm64/boot/dts/rockchip/rk3399-firefly-demo.dtsi @@ -64,7 +64,7 @@ /* Firefly SPI demo */ &spi1 {spi_demo: spi-demo@00{ - status = "disabled"; + status = "okay"; compatible = "firefly,rk3399-spi"; reg = <0x00>; spi-max-frequency = <48000000>; @@ -76,6 +76,6 @@ }; &spidev0 { - status = "okay"; + status = "disabled"; };

注意:由于spi1_rxd和spi1_txd兩個腳可復(fù)用為uart4_rx和uart4_tx,所以要留意關(guān)閉掉uart4的使用,如下:

kernel/arch/arm64/boot/dts/rockchip/rk3399-firefly-port.dtsi &uart4 { current-speed = <9600>; no-loopback-test; status = "disabled"; };
常用SPI接口

下面是常用的 SPI API 定義:

void spi_message_init(struct spi_message *m); void spi_message_add_tail(struct spi_transfer *t, struct spi_message *m); int spi_sync(struct spi_device *spi, struct spi_message *message) ; int spi_write(struct spi_device *spi, const void *buf, size_t len); int spi_read(struct spi_device *spi, void *buf, size_t len); ssize_t spi_w8r8(struct spi_device *spi, u8 cmd); ssize_t spi_w8r16(struct spi_device *spi, u8 cmd); ssize_t spi_w8r16be(struct spi_device *spi, u8 cmd); int spi_write_then_read(struct spi_device *spi, const void *txbuf, unsigned n_tx, void *rxbuf, unsigned n_rx);
接口使用

Linux提供了一個功能有限的SPI用戶接口,如果不需要用到IRQ或者其他內(nèi)核驅(qū)動接口,可以考慮使用接口spidev編寫用戶層程序控制SPI設(shè)備。 在 Firefly-RK3399 開發(fā)板中對應(yīng)的路徑為: /dev/spidev0.0

spidev對應(yīng)的驅(qū)動代碼: kernel/drivers/spi/spidev.c

內(nèi)核config需要選上SPI_SPIDEV:

│ Symbol: SPI_SPIDEV [=y] │ Type : tristate │ Prompt: User mode SPI device driver support │ Location: │ -> Device Drivers │ -> SPI support (SPI [=y]) │ Defined at drivers/spi/Kconfig:684 │ Depends on: SPI [=y] && SPI_MASTER [=y]

DTS配置如下:

&spi1 { status = "okay"; max-freq = <48000000>; spidev@00 { compatible = "linux,spidev"; reg = <0x00>; spi-max-frequency = <48000000>; }; };

詳細(xì)使用說明請參考文檔 spidev 。

FAQs
Q1: SPI數(shù)據(jù)傳送異常

A1: 確保 SPI 4個引腳的 IOMUX 配置正確, 確認(rèn) TX 送數(shù)據(jù)時,TX 引腳有正常的波形,CLK 頻率正確,CS 信號有拉低,mode 與設(shè)備匹配。


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

    關(guān)注

    87

    文章

    11292

    瀏覽量

    209321
  • 嵌入式主板
    +關(guān)注

    關(guān)注

    7

    文章

    6085

    瀏覽量

    35295
  • Firefly
    +關(guān)注

    關(guān)注

    2

    文章

    538

    瀏覽量

    7027
收藏 人收藏

    評論

    相關(guān)推薦

    Firefly-RK3399 SPI接口使用相關(guān)資料分享

    1、SPI接口使用簡介SPI 是一種高速的,全雙工,同步串行通信接口,用于連接微控制器、傳感器、存儲設(shè)備等。 Firefly-RK3399 開發(fā)板提供了
    發(fā)表于 06-13 17:06

    SPI、IIC、IIS、UART、SDIO、GPIO 簡介

    SPI、IIC、IIS、UART、SDIO、GPIO 簡介
    發(fā)表于 10-29 17:00 ?0次下載

    常見總線簡介CAN、USART、SPI、SCI等

    常見總線簡介,包括CAN、USART、SPI、SCI等
    發(fā)表于 11-30 14:08 ?0次下載

    firefly多窗口顯示簡介

    Firefly-RK3288平臺擁有強(qiáng)大的多線程運算和圖像處理能力,基于Firefly-RK3288可以實現(xiàn)多窗口顯示的功能,用戶可以在Android系統(tǒng)下同時運行不同的應(yīng)用,也可以對當(dāng)前多個窗口進(jìn)行打開、關(guān)閉、放大、縮小、最大化、最小化等操作。
    的頭像 發(fā)表于 11-01 15:13 ?1499次閱讀
    <b class='flag-5'>firefly</b>多窗口顯示<b class='flag-5'>簡介</b>

    firefly雙屏互動簡介

    基于Firefly-RK3288高性能開源平臺,可以做雙屏互動功能,Firefly-RK3288同時接MIPI
    的頭像 發(fā)表于 11-01 15:31 ?1541次閱讀
    <b class='flag-5'>firefly</b>雙屏互動<b class='flag-5'>簡介</b>

    Firefly-RK3399--FAQs簡介

    Firefly-RK3399 的 HDMI 能自動識別顯示的分辨率。
    的頭像 發(fā)表于 11-19 15:27 ?3187次閱讀
    <b class='flag-5'>Firefly</b>-RK3399--FAQs<b class='flag-5'>簡介</b>

    Firefly關(guān)于的屏幕模組簡介

    Firefly
    的頭像 發(fā)表于 11-20 10:47 ?1472次閱讀
    <b class='flag-5'>Firefly</b><b class='flag-5'>關(guān)于</b>的屏幕模組<b class='flag-5'>簡介</b>

    Firefly關(guān)于-RTC 使用簡介

    Firefly-RK3399 開發(fā)板上有 一個集成于RK808上的RTC(Real Time Clock),主要功能有時鐘,日歷,鬧鐘,周期性中斷,雙通道32KHz時鐘輸出。
    的頭像 發(fā)表于 11-20 11:14 ?2488次閱讀
    <b class='flag-5'>Firefly</b><b class='flag-5'>關(guān)于</b>-RTC 使用<b class='flag-5'>簡介</b>

    Firefly關(guān)于RK3288電源適配器簡介

    firefly電源適配器 5V-3A電源適配器
    的頭像 發(fā)表于 11-25 10:01 ?2526次閱讀
    <b class='flag-5'>Firefly</b><b class='flag-5'>關(guān)于</b>RK3288電源適配器<b class='flag-5'>簡介</b>

    Firefly-RK3128主板ADC簡介

    Firefly-RK3128 開發(fā)板有一個 3 通道(0/1/2)、10 比特精度的 SAR ADC (Successive Approximation Register,逐次逼近寄存器),
    的頭像 發(fā)表于 11-28 17:17 ?3507次閱讀
    <b class='flag-5'>Firefly</b>-RK3128主板ADC<b class='flag-5'>簡介</b>

    Firefly-RK3128主板啟動模式簡介

    Firefly-RK3128 有靈活的啟動方式。
    的頭像 發(fā)表于 11-29 09:27 ?5253次閱讀

    Firefly-PX3-SE--WIFI模塊及以太網(wǎng)簡介

    關(guān)于Firefly-PX3-SE網(wǎng)絡(luò)的使用,目前在設(shè)置app里面只能使用WiFi以及WIFI熱點功能,以太網(wǎng)功能暫時還沒添加。
    的頭像 發(fā)表于 12-02 16:56 ?1454次閱讀

    SPI Nand Flash簡介

    1.SPI Nand Flash簡介SPI Nand Flash顧名思義就是串行接口的Nand Flash,它和普通并行的Nand Flash相似,比如:SLC Nand Flash。2.SP
    發(fā)表于 12-02 10:51 ?34次下載
    <b class='flag-5'>SPI</b> Nand Flash<b class='flag-5'>簡介</b>

    SPI通信簡介

    目錄(?)[-]SPI簡介SPI特點1采用主-從模式Master-Slave 的控制方式2采用同步方式Synchronous傳輸數(shù)據(jù)3數(shù)據(jù)交換Data Exchanges4 SPI有四
    發(fā)表于 12-22 19:14 ?9次下載
    <b class='flag-5'>SPI</b>通信<b class='flag-5'>簡介</b>

    FPGA中關(guān)于SPI的使用

    FPGA中關(guān)于SPI的使用
    的頭像 發(fā)表于 04-12 10:13 ?907次閱讀
    RM新时代网站-首页