www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁(yè) > 單片機(jī) > 單片機(jī)
[導(dǎo)讀]前幾篇介紹過(guò)UART串口,地址:http://blog.csdn.net/devintt/article/details/52512457這次講解一下另一個(gè)常用的串口:SPI通信科普SPI:是一種高速的,全雙工,同步的通信總線,并且在芯片的管腳上只占用四根線,分別

前幾篇介紹過(guò)UART串口,地址:http://blog.csdn.net/devintt/article/details/52512457
這次講解一下另一個(gè)常用的串口:SPI通信

科普SPI:是一種高速的,全雙工,同步的通信總線,并且在芯片的管腳上只占用四根線,分別是:SCK(時(shí)鐘)、MOSI(主機(jī)發(fā)送數(shù)據(jù))、MISO(主機(jī)接收數(shù)據(jù))、NSS(片選),其中NSS的片選信號(hào),大部分情況下我們使用的是軟件NSS,即為使用一個(gè)GPIO進(jìn)行軟件控制片選。值得注意的是,其中SPI有4中模式:分別是空閑時(shí)SCLK的電平高低、MISO采樣時(shí)第12個(gè)變化沿。


stm8s的SPI結(jié)構(gòu)如下圖,


如果用形象的比喻的話:SCK像一個(gè)發(fā)條齒輪,只有當(dāng)發(fā)條齒輪轉(zhuǎn)動(dòng)的時(shí)候(SCK輸出8個(gè)時(shí)鐘),MOSI才能將1Byte的數(shù)據(jù)發(fā)送出去,同時(shí),MISO將1Byte的數(shù)據(jù)接收回來(lái)。

使用SPI無(wú)非就一個(gè)初始化,一個(gè)數(shù)據(jù)發(fā)送/接收,兩大功能。

初始化分初始化為主機(jī)、從機(jī),不過(guò)一般和外部芯片通信單片機(jī)都是作為主機(jī)


//******************************************************************

//函數(shù)名:SPI_Master_Conf

//功能:硬件SPI主設(shè)備初始化

//輸入?yún)?shù):無(wú)

//返回值:無(wú)

//******************************************************************

voidSPI_Master_Conf(void)

{

CLK_PCKENR1|=0x02;//打開(kāi)SPI時(shí)鐘

/*PC6、PC5設(shè)置為輸出,最大10MHz*/

PC_DDR|=0x60;

PC_CR1|=0x60;

PC_CR2|=0x60;

SPI_CR1=0x04;

SPI_CR2=0x03;

SPI_CR1|=0x40;

/*

SPI_CR1_SPE=0;//禁止SPI

SPI_CR1_LSBFIRST=0;//先發(fā)送MSB

SPI_CR1_BR=0;//波特率設(shè)為fbus16MHz

SPI_CR1_MSTR=1;//主模式

SPI_CR1_CPOL=1;//空閑狀態(tài)時(shí)SCK為高電平

SPI_CR1_CPHA=1;//數(shù)據(jù)從第二個(gè)時(shí)鐘邊沿開(kāi)始采樣

SPI_CR2_BDM=0;//雙線單向模式

SPI_CR2_SSM=1;//使能軟件從設(shè)備管理

SPI_CR2_SSI=1;//內(nèi)部從設(shè)備選擇為主模式

SPI_CR1_SPE=1;//使能SPI

*/

}

//******************************************************************

//函數(shù)名:SPI_Slave_Conf

//功能:硬件SPI從設(shè)備初始化

//輸入?yún)?shù):無(wú)

//返回值:無(wú)

//******************************************************************

voidSPI_Slave_Conf(void)

{

//SPI_CR1_LSBFIRST=0;//先發(fā)送MSB

//SPI_CR1_SPE=0;//禁止SPI

SPI_CR1_BR=3;//波特率設(shè)為fbus/161MHz

SPI_CR1_MSTR=0;//從模式

SPI_CR1_CPOL=1;//空閑狀態(tài)時(shí)SCK為高電平

SPI_CR1_CPHA=1;//數(shù)據(jù)從第二個(gè)時(shí)鐘邊沿開(kāi)始采樣

//SPI_CR2_BDM=0;//雙線單向模式

SPI_CR2_SSM=1;//使能軟件從設(shè)備管理

SPI_CR2_SSI=1;//內(nèi)部從設(shè)備選擇為從模式

SPI_ICR_RXIE=1;//開(kāi)啟接收中斷

SPI_CR1_SPE=1;//使能SPI

}


發(fā)送方式一般有兩種:阻塞輪訓(xùn) 和 中斷 注意:發(fā)送的同時(shí)也在接收


//******************************************************************

//函數(shù)名:SPI_WriteByte

//功能:硬件SPI讀寫(xiě)一個(gè)字節(jié)數(shù)據(jù)

//輸入?yún)?shù):byte:數(shù)據(jù)

//返回值:無(wú)

//******************************************************************

u8SPI_WriteByte(u8byte)

{

while(SPI_SR_TXE==0);

SPI_DR=byte;

while(SPI_SR_RXNE==0);

returnSPI_DR;

}

#pragmavector=SPI_RXNE_vector

__interruptvoidSPI_RXNE_IRQHandler(void)

{

RxBuf[cnt++]=SPI_DR;

}

這里的#pragma vector=SPI_RXNE_vector 是IAR工程的中斷函數(shù)入口地址。SPI_DR為接收到的數(shù)據(jù)(其實(shí)就是寄存器的值)


這里給出的代碼使用的是SPI的其中一個(gè)MODE,實(shí)際使用的話還需要結(jié)合外部芯片的SPI的MODE是哪個(gè),通過(guò)修改配置 SPI控制器 SPI_CR1 (這個(gè)寄存器主要是修改SPI通信配置的)。

最后需要驗(yàn)證SPI初始化、通信成功了沒(méi),你只需要將MOSI和MISO(也就是PC5和PC6)短接在一起,發(fā)什么,接什么,也就是:u8 temp =SPI_WriteByte(0x5A); 如果通信成功的話,temp就是0x5A了。



附上stm8s在IAR環(huán)境下的項(xiàng)目工程,包括了SPI、IIC、PWM、AWU、USART、EEPROM等片上硬件的初始化代碼。

http://download.csdn.NET/detail/devintt/9454188



本站聲明: 本文章由作者或相關(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)系本站刪除。
換一批
延伸閱讀

SPI 是英語(yǔ)Serial Peripheral interface的縮寫(xiě),顧名思義就是串行外圍設(shè)備接口。是Motorola(摩托羅拉)首先在其MC68HCXX系列處理器上定義的。SPI是一種單主機(jī)、高速的,全雙工,同步...

關(guān)鍵字: spi spi通信原理

為什么要加鎖在SMP系統(tǒng)中,如果僅僅是需要串行地增加一個(gè)變量的值,那么使用原子操作的函數(shù)(API)就可以了。但現(xiàn)實(shí)中更多的場(chǎng)景并不會(huì)那么簡(jiǎn)單,比如需要將一個(gè)結(jié)構(gòu)體A中的數(shù)據(jù)提取出來(lái),然后格式化、解析,再添加到另一個(gè)結(jié)構(gòu)體...

關(guān)鍵字: spi ic ck

為什么要加鎖在SMP系統(tǒng)中,如果僅僅是需要串行地增加一個(gè)變量的值,那么使用原子操作的函數(shù)(API)就可以了。但現(xiàn)實(shí)中更多的場(chǎng)景并不會(huì)那么簡(jiǎn)單,比如需要將一個(gè)結(jié)構(gòu)體A中的數(shù)據(jù)提取出來(lái),然后格式化、解析,再添加到另一個(gè)結(jié)構(gòu)體...

關(guān)鍵字: spi ic ck

SPI接口通信原理

關(guān)鍵字: spi 通訊

Linux 點(diǎn)擊上方藍(lán)字 記得關(guān)注我們哦! 內(nèi)核里已經(jīng)提供spi接口小屏的設(shè)備驅(qū)動(dòng),在內(nèi)核的配置選項(xiàng): make?menuconfig?ARCH=arm?CROSS_COMPILE=arm-linux-gnueabihf...

關(guān)鍵字: spi 內(nèi)核

  SPI即串行外圍設(shè)備接口,是一種高速的,全雙工,同步的通信總線,由于其在芯片的管腳上只占用四根線,節(jié)約了芯片的管腳,同時(shí)為PCB的布局上節(jié)省空間,提供方便,出于這種簡(jiǎn)單易用的特性,很多AD轉(zhuǎn)

關(guān)鍵字: spi 隔離芯片

你知道首款2Gb大容量高性能SPI NOR Flash產(chǎn)品嗎?業(yè)界領(lǐng)先的半導(dǎo)體器件供應(yīng)商兆易創(chuàng)新GigaDevice(股票代碼 603986)今日宣布,隆重推出國(guó)內(nèi)首款容量高達(dá)2Gb、高性能SPI NOR Flash——...

關(guān)鍵字: 2gb nor spi 兆易創(chuàng)新 flash產(chǎn)品

摘 要: Xilinx 7系列FPGA是Xilinx公司最新推出的一個(gè)芯片系列,Kintex7是該系列芯片中的一種,擁有大量的可編程資源。即便如此,在一些多模式的大型復(fù)雜的系統(tǒng)設(shè)計(jì)中,芯片的資源

關(guān)鍵字: Flash FPGA spi

引言 近年來(lái),城市污水處理產(chǎn)業(yè)進(jìn)入快速發(fā)展期。污水排放企業(yè)將污水集中排放到污水處理廠進(jìn)行集中污水處理,排污企業(yè)根據(jù)排污量繳費(fèi)。而傳統(tǒng)的污水排放量主要是由人工對(duì)排污企業(yè)的現(xiàn)場(chǎng)流量計(jì)進(jìn)行抄收

關(guān)鍵字: spi 數(shù)據(jù) 監(jiān)控
關(guān)閉