?? main.c
字號:
/****************************************Copyright (c)**************************************************
** Guangzou ZLG-MCU Development Co.,LTD.
** graduate school
** http://www.zlgmcu.com
**
**--------------File Info-------------------------------------------------------------------------------
** File name: main.c
** Last modified Date: 2004-09-16
** Last Version: 1.0
** Descriptions: The main() function example template
**
**------------------------------------------------------------------------------------------------------
** Created by: Litiantian
** Created date: 2007-01-04
** Version: 1.0
** Descriptions: LPC2300系列ARM SSP用作SPI從機應用示例
**
**------------------------------------------------------------------------------------------------------
** Modified by: xuxiaoqun
** Modified date: 2008-05-08
** Descriptions: 對代碼風格和注釋進行了調整、校對
********************************************************************************************************/
#include "config.h"
#define SSP_INT 10 // SPI中斷源ID
#define BEEP (1 << 30) // 定義BEEP口
#define SLAVE_CS (1 << 16) // 從機片選口
volatile uint8 RcvFlag = 0; // 接收到新數據標志
volatile uint8 RcvData = 0; // 接收到的數據
/*********************************************************************************************************
** 函數名稱:SSP_IRQ
** 函數功能:SSP中斷服務函數
** 入口參數:無
** 出口參數:無
*********************************************************************************************************/
void __irq SSP_IRQ(void)
{
RcvData = SSP0DR; // 接收數據
RcvFlag = 0x01; // 接收到新數據
SSP0ICR = 0x03; // 清除標志位
VICVectAddr = 0x00;
}
/***********************************************************************
** 函數名稱:SPIInit
** 功能說明:初始化SPI為主機,并初始化相關引腳
** 入口參數:無
** 出口參數:無
*************************************************************************/
void SPIInit(void)
{
/* 設置硬件SPI的通訊腳 */
PINSEL0 |= 0xc0000000; // 設置P0.15腳為SCK腳
PINSEL1 = (0x03 << 2) | (0x03 << 4); // 設置P0.17、P0.18管腳為SPI接口
/* 初始化P0.16為GPIO輸出,用作片選腳 */
IO0DIR |= SLAVE_CS;
/* 設置SPI的工作方式 */
S0SPCR = (0 << 3) | // CPHA = 0, 數據在SCK 的第一個時鐘沿采樣
(1 << 4) | // CPOL = 1, SCK 為低有效
(1 << 5) | // MSTR = 1, SPI 處于主模式
(0 << 6) | // LSBF = 0, SPI 數據傳輸MSB (位7)在先
(0 << 7); // SPIE = 0, SPI 中斷被禁止
S0SPCCR = 0x52; // 設置SPI時鐘分頻
}
/*********************************************************************************************************
** 函數名稱:SSPSlave_Init
** 函數功能:將SSP控制器設置為從機SPI,并初始化其引腳
** 入口參數:無
** 出口參數:無
**********************************************************************************************************/
void SSPSlave_Init(void)
{
PCONP |= (1 << 21); // 在外設功率控制寄存器里使能SSP外設,默認情況下,該外設已被使能
/* 初始化P2.22、P2.23、P2.26、P2.27為SSP接口引腳。*/
PINSEL5 |= (0x03 << 12) | (0x03 << 14) | (0x03 << 20) | (0x03 << 22);
/* 初始化SSP的通訊方式,設置數據長度為8bit,幀格式為SPI,SCK 為低有效, */
/* 數據在SCK 的第一個時鐘沿采樣,設置位速率。 */
SSP0CR0 = (0x00 << 8) | // SCR 設置SPI位速率
(0x00 << 7) | // CPHA 時鐘輸出相位,僅SPI模式有效
(0x01 << 6) | // CPOL 時鐘輸出極性,僅SPI模式有效
(0x00 << 4) | // FRF 幀格式 00=SPI,01=SSI,10=Microwire,11=保留
(0x07 << 0); // DSS 數據長度,0000-0010=保留,0011=4位,0111=8位,1111=16位
SSP0CR1 = (0x00 << 3) | // SOD 從機輸出禁能,1=禁止,0=允許
(0x01 << 2) | // MS 主從選擇,0=主機,1=從機
(0x01 << 1) | // SSE SSP使能,1=允許SSP與其它設備通信
(0x00 << 0); // LBM 回寫模式
/* 初始化SSP的中斷接口 */
SSP0ICR = 0x03; // 清除接收溢出和超時中斷
SSP0IMSC = 0x02; // 中斷使能寄存器,使能接收超時中斷
VICIntEnClr |= (1 << SSP_INT); // 禁止SPI中斷
VICVectPri10 = 0x05; // 設置SPI中斷優先級為5
VICVectAddr10 = (uint32)SSP_IRQ; // 裝入SPI中斷服務程序地址
VICIntEnable |= (1 << SSP_INT); // 使能SPI中斷
IRQEnable(); // IRQ中斷使能
}
/*********************************************************************************************************
* 函數名稱:SPI_SendData
* 函數功能:SPI接口向SSP從機發送數據
* 入口參數:data 待發送的數據
* 出口參數:無
*********************************************************************************************************/
void SPI_SendData(uint8 data)
{
IO0CLR |= SLAVE_CS;
S0SPDR = data;
while (0 == (S0SPSR & 0x80)); // 等待SPIF置位,即等待數據發送完畢
S0SPSR = 0; // 清除SPIF標志
IO0SET |= SLAVE_CS;
}
/********************************************************************************************************
** 函數名稱:DelayNS
** 函數功能:長軟件延時
** 入口參數:dly 延時參數,值越大,延時越久
** 出口參數:無
********************************************************************************************************/
void DelayNS(uint32 dly)
{
uint32 i = 0;
for(; dly > 0; dly--)
{
for (i = 0; i < 50000; i++);
}
}
/*******************************************************************************************
** 函數名稱:main
** 函數功能:LPC2400系列ARM SSP用作SPI從機應用示例
** 入口參數:無
** 出口參數:無
** 調試說明:需用杜邦線將P0.15~P0.18分別P2.22、P2.23、P2.26、P2.27短接;將BEEP和P3.30腳短接。
*******************************************************************************************/
int main(void)
{
uint32 i = 0;
FIO3DIR |= BEEP; // 初始化BEEP口
FIO3SET |= BEEP; // 關閉蜂鳴器
SPIInit(); // 初始化SPI接口
SSPSlave_Init(); // 初始化SSP接口
for (i = 0; i < 8; i++)
{
RcvFlag = 0; // 清除接收到新數據標志
SPI_SendData(i); // 發送數據
DelayNS(100); // 延時
if (RcvFlag != 0) // 如果接收到新數據
{
if (RcvData == i)
{
/* 接收的數據是否與發送的數據相同,通訊無誤,蜂鳴器長鳴一次 */
FIO3CLR |= BEEP;
DelayNS(150);
FIO3SET |= BEEP;
}
/* 數據錯誤,BEEP一直響 */
else
{
FIO3CLR |= BEEP;
}
}
/* 通訊出錯,BEEP一直響 */
else
{
FIO3CLR |= BEEP;
}
}
while (1);
return (0);
}
/*********************************************************************************************************
** End Of File
********************************************************************************************************/
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -