求两个51单片机模拟SPI通信程序,主机和从机的程序!!

求两个51单片机模拟SPI通信程序,主机和从机的程序!!,第1张

1.定义三个gpio: p0-sclk, p1-sdi, p2-sdo;p0用于模拟spi的clock,p1用于接收数据,p2用于f发送数据;硬件上单片机A的p0接单片机B的p0,A的p1接B的p2,A的p2接B的p12.发送程序:clock拉低,sdo输出0或1(数据),延时一定时间,clock拉高,延时一定时间,这样A就发送一位数据到B,循环8次就发送一个字节数据3.接收程序:检测clock状态,如果为低,就读取sdi,直到clock拉高,结束该次输入,重复8次,读取一个字节注意:1。clock空闲状态为高,发送数据就拉低;2.还需要加入起始停止同步协议,可根据需要进行完善

求SPI的SSD1306在linux下的测试程序理解SPI的驱动框架,还是从最基本的三个入口点触发,platform_device,platform_bus,platform_driver。

其中内核一提供给platform_bus,platform_driver在spi_s3c24xx_gpio.c和spi_s3c24xxc.c中,其中spi_s3c24xx_gpio.c用于IO模拟SPI (本例讨论的是IO模拟SPI),spi_s3c24xxc.c用于s3c24xx的硬件SPI。因此,我们需要动手写一个platform_device。

看看spi_s3c24xx_gpio.c做了些什么。

static int s3c2410_spigpio_probe(struct platform_device *dev)

{

... ...

/* [cgw]: 分配一个SPI主机 */

master = spi_alloc_master(&dev->dev, sizeof(struct s3c2410_spigpio))

... ...

sp = spi_master_get_devdata(master)

platform_set_drvdata(dev, sp)

/* [cgw]: 分配与spi硬件相关的配置,如指定哪些IO为MISO,MOSI,SCLK,CS,SPI工作模式,最大时钟等等 */

/* copy in the plkatform data */

sp->info = dev->dev.platform_data

/* [cgw]: 提供实现SPI各种模式的时序的基本方法,和CS的激活方法 */

/* setup spi bitbang adaptor */

sp->bitbang.master = spi_master_get(master)

sp->bitbang.chipselect =

stc spi的例程

#include "reg51.h"

#define FOSC18432000L

#define BAUD(256 - FOSC / 32 / 115200)

typedef unsigned char BYTE

typedef unsigned int WORD

typedef unsigned long DWORD

sfr AUXR = 0x8e //Auxiliary register

sfr SPSTAT = 0xcd //SPI status register

#define SPIF0x80//SPSTAT.7

#define WCOL0x40//SPSTAT.6

sfr SPCTL = 0xce //SPI control register

#define SSIG0x80//SPCTL.7

#define SPEN0x40//SPCTL.6

#define DORD0x20//SPCTL.5

#define MSTR0x10//SPCTL.4

#define CPOL0x08//SPCTL.3

#define CPHA0x04//SPCTL.2

#define SPDHH 0x00//CPU_CLK/4

#define SPDH0x01//CPU_CLK/16

#define SPDL0x02//CPU_CLK/64

#define SPDLL 0x03//CPU_CLK/128

sfr SPDAT = 0xcf //SPI data register

sbit SPISS = P1^3 //SPI slave select, connect to other MCU's SS(P1.4) pin

sfr IE2 = 0xAF //interrupt enable rgister 2

#define ESPI0x02//IE2.1

void InitUart()

void InitSPI()

void SendUart(BYTE dat) //send data to PC

BYTE RecvUart() //receive data from PC

bit MSSEL //1: master 0:slave

///////////////////////////////////////////////////////////

void main()

{

InitUart()//initial UART

InitSPI() //initial SPI

IE2 |= ESPI

EA = 1

while (1)

{

if (RI)

{

SPCTL = SPEN | MSTR//set as master

MSSEL = 1

ACC = RecvUart()

SPISS = 0 //pull low slave SS

SPDAT = ACC//trigger SPI send

}

}

}

///////////////////////////////////////////////////////////

void spi_isr() interrupt 9 using 1 //SPI interrupt routine 9 (004BH)

{

SPSTAT = SPIF | WCOL //clear SPI status

if (MSSEL)

{

SPCTL = SPEN //reset as slave

MSSEL = 0

SPISS = 1 //push high slave SS

SendUart(SPDAT) //return received SPI data

}

else

{ //for salve (receive SPI data from master and

SPDAT = SPDAT // send previous SPI data to master)

}

}

///////////////////////////////////////////////////////////

void InitUart()

{

SCON = 0x5a //set UART mode as 8-bit variable baudrate

TMOD = 0x20 //timer1 as 8-bit auto reload mode

AUXR = 0x40 //timer1 work at 1T mode

TH1 = TL1 = BAUD //115200 bps

TR1 = 1

}

///////////////////////////////////////////////////////////

void InitSPI()

{

SPDAT = 0 //initial SPI data

SPSTAT = SPIF | WCOL //clear SPI status

SPCTL = SPEN //slave mode

}

///////////////////////////////////////////////////////////

void SendUart(BYTE dat)

{

while (!TI) //wait pre-data sent

TI = 0//clear TI flag

SBUF = dat//send current data

}

///////////////////////////////////////////////////////////

BYTE RecvUart()

{

while (!RI) //wait receive complete

RI = 0//clear RI flag

return SBUF //return receive data

}


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12070847.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-20
下一篇 2023-05-20

发表评论

登录后才能评论

评论列表(0条)

保存