加入星計劃,您可以享受以下權益:

  • 創(chuàng)作內容快速變現(xiàn)
  • 行業(yè)影響力擴散
  • 作品版權保護
  • 300W+ 專業(yè)用戶
  • 1.5W+ 優(yōu)質創(chuàng)作者
  • 5000+ 長期合作伙伴
立即加入
  • 正文
    • 01、SPI的工作流程和時序
    • 02、AM62x處理器中SPI總線的特點
    • 03、AM62x的SPI應用
    • 04、總結
  • 推薦器件
  • 相關推薦
  • 電子產業(yè)圖譜
申請入駐 產業(yè)圖譜

技術帖 | AM62x處理器SPI的詳解與應用

03/15 10:50
2383
閱讀需 9 分鐘
加入交流群
掃碼加入
獲取工程師必備禮包
參與熱點資訊討論

SPI(Serial Peripheral Interface)通信總線以其高速、全雙工、同步的特性而被廣泛應用,它只需要四根線就能實現(xiàn)數(shù)據(jù)傳輸,有效地節(jié)約了芯片管腳的數(shù)量,同時為PCB布局帶來了空間上的優(yōu)化和便捷。正因為它簡單易用的特點,現(xiàn)在越來越多的芯片選擇集成SPI通信協(xié)議

作為TI Sitara?產品線新一代MPU產品,TI AM62x處理器特別配備了多達4路的SPI接口以及1路OSPI接口(有時也稱為QSPI),豐富的SPI接口配置使得該處理器能夠同時與多個設備進行通信連接,大大提高了系統(tǒng)的擴展性和靈活性。

在飛凌嵌入式推出的搭載了AM62x處理器的OK6254-C開發(fā)板上,NOR Flash存儲器正是通過連接到處理器的OSPI總線上進行工作的。這樣的設計充分利用了SPI通信協(xié)議的高速傳輸和全雙工特性,保證了開發(fā)板在數(shù)據(jù)處理和存儲方面的效率。本文就通過OK6254-C開發(fā)板為大家介紹一下AM62x的SPI。

01、SPI的工作流程和時序

我們首先需要了解一下SPI是如何工作的——通常SPI通過4個引腳與外部器件相連:

(1) MISO:主設備輸入/從設備輸出引腳

該引腳在從模式下發(fā)送數(shù)據(jù),在主模式下接收數(shù)據(jù);

(2) MOSI:主設備輸出/從設備輸入引腳

該引腳在主模式下發(fā)送數(shù)據(jù),在從模式下接收數(shù)據(jù);

(3) CLK:串口時鐘

作為主設備的輸出,從設備的輸入;

(4) NSS:從設備選擇

這是一個可選的引腳,用來選擇從設備。

SPI的工作流程是這樣的:

(1) 主機先將NSS信號拉低,這樣保證開始接收數(shù)據(jù);

(2) 當接收端檢測到時鐘的邊沿信號時,將立即讀取數(shù)據(jù)線上的信號,這樣就得到了一位數(shù)據(jù);

(3) 由于時鐘是隨數(shù)據(jù)一起發(fā)送的,因此指定數(shù)據(jù)的傳輸速度并不重要,盡管設備將具有可以運行的最高速度;

(4) 主機發(fā)送到從機時,主機產生相應的時鐘信號,然后數(shù)據(jù)一位一位地將從MOSI信號線上進行發(fā)送到從機;

(5) 主機接收從機數(shù)據(jù)時,如果從機需要將數(shù)據(jù)發(fā)送回主機,則主機將繼續(xù)生成預定數(shù)量的時鐘信號,并且從機會將數(shù)據(jù)通過MISO信號線發(fā)送。

SPI工作時序圖如下:

02、AM62x處理器中SPI總線的特點

在AM62x這款芯片中,TI將SPI的MISO與MOSI設計為d0和d1,具體哪一個作為輸入,哪一個作為輸出,是由設備樹中的 ti,pindir-d0-out-d1-in= <1>來設置的。

默認屬性值為0,即d0是輸入,d1是輸出;

當屬性值為1時,d0為輸出,d1為輸入。

03、AM62x的SPI應用

1. menuconfig配置:

將該項選中,SPI驅動將編譯進內核中。

makemenuconfiDeviceDrivers ->SPIsupport ->Usermode SPI device driver support

(注:在飛凌嵌入式OK6254-C開發(fā)板中,SPI驅動編譯已進去。)

2. 設備樹配置:

(1) 選擇需要使用的spi,這里我們用spi0,節(jié)點為&main_spi0;

(2) 將該節(jié)點所用的引腳復用為相應的功能。

spi0_pins_default: spi0-pins-default {    pinctrl-single,pins = <            AM62X_IOPAD(0x1B4, PIN_OUTPUT, 0) /* (A13) SPI0_CS0 */            AM62X_IOPAD(0x1B8, PIN_OUTPUT, 0) /* (C13) SPI0_CS1 */            AM62X_IOPAD(0x1C0, PIN_INPUT, 0) /* (B13) SPI0_D0 */            AM62X_IOPAD(0x1BC, PIN_OUTPUT, 0) /* (A14) SPI0_CLK */            AM62X_IOPAD(0x1C4, PIN_INPUT, 0) /* (B14) SPI0_D1 */        >;    };

(3) 描述節(jié)點的屬性,具體配置項的功能見注釋。

&main_spi0 {  status = "okay";  pinctrl-names = "default";  pinctrl-0 = <&spi0_pins_default>; /* 描述引腳復用節(jié)點 */  ti,spi-num-cs = <2>;      /* 描述片選的數(shù)量 */??ti,pindir-d0-out-d1-in?=?<1>;?/*?描述輸入輸出分別是哪個?*/??  /* 描述子節(jié)點spidev0設備 */  spidev@0 {              spi-max-frequency = <24000000>; /* 描述spidev0設備的最大頻率 */              reg = <0>;   /* 描述spidev0設備所用的片選,這里是第0個 */              spi-cs-high;  /* 描述spidev0設備高有效 */              compatible = "rohm,dh2228fv";  /* 描述spidev0設備所用驅動 */  };  /* 描述子節(jié)點spidev1設備 */  spidev@1 {              spi-max-frequency = <24000000>;              reg = <1>;              compatible = "rohm,dh2228fv";  };};

3. 編譯燒錄:

在源碼路徑下輸入以下命令:

. build.shsudo ./build.sh kernel

沒有報錯即為編譯成功。

將源碼路徑下的image中的OK6254-C.dtb文件放到開發(fā)板的/boot目錄中,重啟開發(fā)板即可。

4. SPI測試:

將spi0_D0和spi0_D1短接

重啟開發(fā)板后,在/dev目錄下看到多出兩個spidev設備。

使用我們的測試程序

fltest_spidev_test -D /dev/spidev3.0 -s 42000

有如下打印信息即為成功:

spimode: 0bitsper word: 8maxspeed: 42000 Hz (42 KHz)FFFF FF FF FF FF4000 00 00 00 95FFFF FF FF FF FFFFFF FF FF FF FFFFFF FF FF FF FFDEAD BE EF BA ADF00D

04、總結

TI AM62x處理器有著豐富的SPI資源,而SPI又可以作為許多設備的總線,這使得AM62x能夠接入許多SPI接口的設備,因此在那些對SPI有著比較多需求的應用場景下,TI AM62x無疑是一個非常好的主控選擇。

推薦器件

更多器件
器件型號 數(shù)量 器件廠商 器件描述 數(shù)據(jù)手冊 ECAD模型 風險等級 參考價格 更多信息
M95M02-DRMN6TP 1 STMicroelectronics 2 Mbit serial SPI bus EEPROM

ECAD模型

下載ECAD模型
$2.36 查看
SN74HC14D 1 Texas Instruments 6-ch, 2-V to 6-V inverters with Schmitt-Trigger inputs 14-SOIC -40 to 85

ECAD模型

下載ECAD模型
$0.2 查看
SN74LVC1G97DCKRE4 1 Texas Instruments Configurable Multiple-Function Gate 6-SC70 -40 to 125

ECAD模型

下載ECAD模型
暫無數(shù)據(jù) 查看
飛凌嵌入式

飛凌嵌入式

保定飛凌嵌入式技術有限公司,創(chuàng)建于2006年,是一家專注嵌入式核心控制系統(tǒng)研發(fā)、設計和生產的高新技術企業(yè),是國內較早專業(yè)從事嵌入式技術的企業(yè)之一。 經(jīng)過十幾年的發(fā)展與積累,公司擁有業(yè)內優(yōu)秀的軟硬件研發(fā)團隊,在北京及保定建立兩大研發(fā)基地,在蘇州、深圳設有華東、華南技術服務中心,并在北美、歐洲以及亞太等其他國家和地區(qū)擁有國際業(yè)務網(wǎng)絡。公司研發(fā)的智能設備核心平臺廣泛應用于物聯(lián)網(wǎng)、工控、軌道交通、醫(yī)療、電力、商業(yè)電子、智能家居、安防、機器人、環(huán)境監(jiān)測等諸多領域。

保定飛凌嵌入式技術有限公司,創(chuàng)建于2006年,是一家專注嵌入式核心控制系統(tǒng)研發(fā)、設計和生產的高新技術企業(yè),是國內較早專業(yè)從事嵌入式技術的企業(yè)之一。 經(jīng)過十幾年的發(fā)展與積累,公司擁有業(yè)內優(yōu)秀的軟硬件研發(fā)團隊,在北京及保定建立兩大研發(fā)基地,在蘇州、深圳設有華東、華南技術服務中心,并在北美、歐洲以及亞太等其他國家和地區(qū)擁有國際業(yè)務網(wǎng)絡。公司研發(fā)的智能設備核心平臺廣泛應用于物聯(lián)網(wǎng)、工控、軌道交通、醫(yī)療、電力、商業(yè)電子、智能家居、安防、機器人、環(huán)境監(jiān)測等諸多領域。收起

查看更多

相關推薦

電子產業(yè)圖譜

秉承專業(yè)態(tài)度,專注智能設備核心平臺研發(fā)與制造,以技術研發(fā)創(chuàng)新為主導,以客戶實用化,產品化為目標,把握嵌入式行業(yè)的前沿發(fā)展需求,利用核心技術為客戶提供穩(wěn)定、可靠、功能優(yōu)異的高品質產品。合作聯(lián)系:17713286011