当前位置:首页 > 单片机 > 单片机
[导读] #include#define BAUD 9600 //波特率4800#define CRYSTAL 3686400 //晶振3M#define BAUD_set (unsigned int)( (unsigned long)CRYSTAL/(16*(unsigned long)BAUD)-1 ) //波特率计算#define BAUD_H (unsi

#include

#define BAUD 9600 //波特率4800
#define CRYSTAL 3686400 //晶振3M
#define BAUD_set (unsigned int)( (unsigned long)CRYSTAL/(16*(unsigned long)BAUD)-1 ) //波特率计算
#define BAUD_H (unsigned char)(BAUD_set>>8) //波特率寄存器
#define BAUD_L (unsigned char)(BAUD_set)

/*
//GPRS
#define GPRS_ONOFFH PORTA|=(1<#define GPRS_ONOFFL PORTA&=~(1<#define GPRS_RSTH PORTB|=(1<#define GPRS_RSTL PORTB&=~(1<


//通讯灯
#defineLED1H PORTC|=(1<#define LED1L PORTC&=~(1<#define LED2H PORTC|=(1<#define LED2L PORTC&=~(1<#define LED3H PORTC|=(1<#define LED3L PORTC&=~(1<*/

//25256
#define EEPROM_CSH PORTD|=(1<#define EEPROM_CSL PORTD&=~(1<#define EEPROM_WPH PORTD|=(1<#define EEPROM_WPL PORTD&=~(1<

#define SPIF 7


//////////////////////USRT0,USTR1 begin//////////////////////////
/////////////////////////////////////串口begin///////////////////////////////////////////
//串口0初始化
void USART0_Init()
{
UCSR0B = (1 << RXCIE0) | /*接收完成中断允许*/
// (1 << TXCIE0) | /*发送完成中断允许*/
(1 << RXEN0) | /*接收允许*/
(1 << TXEN0); /*发送允许*/
UBRR0H = BAUD_H; //设置波特率
UBRR0L = BAUD_L;
UCSR0C = (1 << URSEL0) | /*选择访问UCSRC寄存器*/
(3 << UCSZ00); /*UCSZ2 UCSZ1 UCSZ0=3 8个数据位*/
}


//串口1初始化
void USART1_Init()
{
UCSR1B = (1 << RXCIE1) | /*接收完成中断允许*/
// (1 << TXCIE1) | /*发送完成中断允许*/
(1 << RXEN0) | /*接收允许*/
(1 << TXEN0); /*发送允许*/
UBRR1H = BAUD_H; //设置波特率
UBRR1L = BAUD_L;
UCSR1C = (1 << URSEL1) | /*选择访问UCSRC寄存器*/
(3 << UCSZ10); /*UCSZ2 UCSZ1 UCSZ0=3 8个数据位*/
}


//串口0查询方式发送数据
void USART0_Transmit(unsigned char data)
{
while(!(UCSR0A&(1< /*等待发送缓冲器为空。UDRE数据寄存器空标志位,
当发送缓冲器空时被置1;发送缓冲器包含需要发送的数据时清零*/
UDR0=data; //将数据放入缓冲器,发送数据
}


//串口1查询方式发送数据
void USART1_Transmit(unsigned char data)
{
while(!(UCSR1A&(1< /*等待发送缓冲器为空。UDRE数据寄存器空标志位,
当发送缓冲器空时被置1;发送缓冲器包含需要发送的数据时清零*/
UDR1=data; //将数据放入缓冲器,发送数据
}

/*
//发送GPRS命令给手机模块
void USART1_Tx_Str(char *s,unsigned char cnt)
{
while(cnt--)
{
USART1_Transmit(*s);
s++;
}
}
*/
/////////////////////////////////////////////串口end/////////////////////////////////////


/*
unsigned char usart0_receive(void)
{
while(!(UCSR0A&(1<return UDR0; //从缓冲器中获取并返回数据
}
*/

////////////////////////USRT1,USRT2 end///////////////////////


///////////////////////////////////////////GPRS begin////////////////////////////////////
//延时ms
/*
void delayms(unsigned int ms)
{
unsigned int i,j;
for(i=0;i for(j=0;j<3500;j++) ;
}


//GPRS开机
void GPRS_On()
{
GPRS_RSTH; GPRS_ONOFFH; delayms(20);
GPRS_RSTL; delayms(10);
GPRS_ONOFFL;LED1L;LED2L;LED3L;delayms(1800);
GPRS_ONOFFH;LED1H;LED2H;LED3H;delayms(200);
LED1L;LED2L;
}


//GPRS关机
void GPRS_Off()
{
GPRS_ONOFFL;delayms(1800);
GPRS_ONOFFH;delayms(5000);
GPRS_RSTL;
}


//GPRS复位
void GPRS_Rst()
{
GPRS_Off();
GPRS_On();
}
*/
////////////////////////////////////////GPRS end/////////////////////////////////////////


////////////////////////////////////eeprom begin//////////////////////////////////////
void SPI_MasterInit(void)
{
EEPROM_WPH;
delayms(20);
SPCR =(1</*
使能SPI,选择主机模式,SCK=fosc/128,选择SPI模式CPOL=0,CPHA=0
*/
}

unsigned char SPI_MasterTransmit(unsigned char cData)
{
//启动数据传输
SPDR = cData;
//等待数据传输结束
while(!(SPSR&(1<//发送完成后,清除发送标志
// SPSR&=~(1< return SPDR;
//每次发送数据的同时,也会接收到数据。
}

//EEPROM写使能
void EEPROM_WREN()
{
EEPROM_CSL; //拉低片选端
SPI_MasterTransmit(0x06); //0x06为写使能的指令
EEPROM_CSH; //抬高片选端,结束
}

//EEPROM写禁止
void EEPROM_WRDI()
{
EEPROM_CSL;//delayms(20);
SPI_MasterTransmit(0x04); //0x04为写禁止的指令
EEPROM_CSH;//delayms(20);
}

//写状态寄存器
void EEPROM_WRSR()
{
EEPROM_WREN();
EEPROM_CSL; //使能
SPI_MasterTransmit(0x01); //0x01为写状态寄存器的指令
SPI_MasterTransmit(0x82); //把0x82写入状态寄存器
EEPROM_CSH; //抬高片选,结束
}

/*
读状态寄存器。读SPI从机数据时,主机要给从机发送任意数据,才能收到从机返回的数据.
即0x00可以是任何数据(但是不能是25256的指令,例如0x01,0x04之类的)
*/
unsigned char EEPROM_RDSR()
{
unsigned char StatusReg;
EEPROM_WREN();
// EEPROM_WRDI(); //如使用此句,不使用EEPROM_WREN(),则读出0x80
EEPROM_CSL; //使能
SPI_MasterTransmit(0x05); //0x05为读状态寄存器指令
StatusReg=SPI_MasterTransmit(0x00); //给25256发送任意数据
/*
此处原为:
SPDR = 0x00;
while(!(SPSR&(1<StatusReg=SPDR;
时出错,读出数据都为0xff。想不清楚为什么
*/
EEPROM_CSH;
return StatusReg;
}

//25256字节写
void EEPROM_ByteWrite(unsigned int Address,unsigned char Data)
{
EEPROM_WREN();
EEPROM_CSL; //使能
SPI_MasterTransmit(0x02); //0x02为写指令
SPI_MasterTransmit(Address/256); //地址高位
SPI_MasterTransmit(Address%256); //地址低位
SPI_MasterTransmit(Data); //写入数据
EEPROM_CSH;delayms(50);
}

//25256页写。试验结果,只能连续写入三个字节
void EEPROM_PageWrite(unsigned int Address,unsigned char *Data,unsigned char NData)
{
unsigned char i;
EEPROM_WREN();
EEPROM_CSL;
SPI_MasterTransmit(0x02);//页写指令
SPI_MasterTransmit(Address/256); //地址高位
SPI_MasterTransmit(Address%256); //地址低位
for(i=0;i {
SPI_MasterTransmit(*Data); //写入数据
Data++;
}
EEPROM_CSH;
}

//25256读
unsigned char EEPROM_Read(unsigned int Address)
{
unsigned char dataa;
EEPROM_CSL; //使能
SPI_MasterTransmit(0x03); //0x03为读25256的指令
SPI_MasterTransmit(Address/256); //地址高位
SPI_MasterTransmit(Address%256); //地址低位
dataa=SPI_MasterTransmit(0x00);//发送任意数据
EEPROM_CSH;
return dataa; //返回读到的数据
}
////////////////////////////////////eeprom end////////////////////////////////////////


//端口初始化
void Port_Init()
{
PORTA=0xff;
DDRA=0x30; //PA4,PA5输出1
PORTB=0xbf;
DDRB=0xb7; //PB1输出1,PB2输出1,PB3输入0,PB4输出1,PB0输出1(用于新终端开关电源控制),PB5PB7为输出1
PORTC=0xff;
DDRC=0xd0; //PC4输出1,PC6,PC7输出1
PORTD=0xff;
DDRD=0x26; //PD0输入0,PD1输出1,PD5PD2输出1
}


void main(void)
{
// unsigned char dataa,i,j;
SREG=0x80; //开放全局中断
Port_Init();
USART0_Init();
USART1_Init();
// GPRS_On();
SPI_MasterInit();EEPROM_WRSR();

while(1)
{
USART0_Transmit(0x22);
USART0_Transmit(0x33);
EEPROM_ByteWrite(0x2030,0x48); //给25256地址0x2030写入数据0x48
USART0_Transmit(EEPROM_Read(0x2010));
USART0_Transmit(EEPROM_Read(0x2030));//读出地址0x2030中数据,从串口0发送出来
USART0_Transmit(0x44);
USART0_Transmit(0x55);
USART0_Transmit(EEPROM_RDSR());
EEPROM_PageWrite(0x1001,"456789",6); //输出结果0xff,0xff,0xff,0x37,0x38,0x39
USART0_Transmit(EEPROM_Read(0x1001));
USART0_Transmit(EEPROM_Read(0x1002));
USART0_Transmit(EEPROM_Read(0x1003));
USART0_Transmit(EEPROM_Read(0x1004));
USART0_Transmit(EEPROM_Read(0x1005));
USART0_Transmit(EEPROM_Read(0x1006));
USART0_Transmit(0x11);
}
}

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

P430颅内出血检测设备的研制策略 1 引言 在中国有许多因创伤性颅脑损伤的患者急需抢救,但相当一部分颅内出血患者因未能及时诊断,延误了抢救和治疗时机.因而出现脑血肿或脑疝后压

关键字: 单片机 LCD 医疗设备 eeprom

1 前言   近年来,数字化电视技术迅猛发展,特别是遥控系统的面市,各厂商在电视机中加人微处理器(MCU),各种人工智能化彩电完全替代了老式电视手动(机械式)控制和记忆方式。随着电视专用

关键字: eeprom 串行通信 i2c总线

物联网(IoT)没有表现出短期流行的迹象。每一新应用都添加许多端点到互联网。不同的无线技术激增,在大部分射频(RF)频谱运行,就是最好的证明。 工程师在对广泛的IoT端点进行调

关键字: eeprom RFID 物联网

通过在单个器件中集成EEPROM存储和RFID联接,工程师可以设计IoT端点,使其可存储工作数据并与服务工程师通信,即使电源故障或完全断电。 这呈现了服务和维护的全新范例,并且完全适用于IoT。

关键字: eeprom RFID 电源资讯

24C02:256 个字节的 EEPROM。一般情况下,EEPROM 拥有 30 万到 100 万次的寿命。基于 I2C 通信协议的器件。I2C 是一个通信协议,它拥有严密的通信时序逻辑要求,而EEPROM 是一个器件,...

关键字: 51单片机 eeprom

在向 EEPROM 连续写入多个字节的数据时,如果每写一个字节都要等待几 ms 的话,整体上的写入效率就太低了。因此 EEPROM 的厂商就想了一个办法,把 EEPROM 分页管理。24C01、24C02 这两个型号是...

关键字: eeprom 单片机 页写入

物联网(IoT)没有表现出短期流行的迹象。每一新应用都添加许多端点到互联网。不同的无线技术激增,在大部分射频(RF)频谱运行,就是最好的证明。

关键字: eeprom IoT RFID

//**************************************************//实验目的://熟悉使用单片机模拟读写24C01EEPROM//1、首先向24C01EEPROM写入数据//2、在...

关键字: 24c01 eeprom pic单片机 模拟读写

移植环境1,主机环境:VMare下CentOS 5.5 ,1G内存。2,集成开发环境:Elipse IDE3,编译编译环境:arm-linux-gcc v4.4.3,arm-none-eabi-gcc v4.5.1。4,...

关键字: eeprom i2c mini2440 u-boot 移植
关闭
关闭