keilc单片机采集的日期数据是从单片机的片上时钟获取的么?

请问片上时钟包含日期采集么?keilc单片机采集的日期数据是从单片机的片上时钟获取的么?

1个回答

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
从keilc语言采集数据获得的日期是否是从片上时钟得到的呢?

单片机的片上时钟信号是否包含了日期的信息,从keilc语言采集数据获得的日期是否是从片上时钟得到的呢?

单片机的时间是从时钟芯片获得的么,在keilc编程中是怎么实现的?

时钟芯片是怎么同步采集和单片机之间的时间的?单片机的时间是从时钟芯片获得的么,在keilc编程中是怎么实现的?

keilc从片上的时钟芯片获取的时间是如何和上位机的时钟同步的?

keilc从片上的时钟芯片获取的时间是如何和上位机的时钟同步的?单片机的片上时钟可以得到日期的么,还是别的方式得到的?

单片机,倒计时,时钟设计,c语言编程

求单片机,倒计时,时钟设计,c语言编程的程序和原理图。大佬们快救救我吧,我找崩溃了

关于51单片机制作时钟的问题?

用51单片机做时钟,我没用1302,就是一个简单的时钟,可以用6个数码管显示时分秒,可以用3个按键实现功能选择和加减。这些在开发板上都可以实现,之后我想在此基础上我想用AT24C02实现断电保护功能,当我的程序写完之后,发现无法实现,这个只能实现的是用按键控制的数字,比如我用按键将时间调成000019,之后让它自己往上加,然后我再断电,等我在上电的时候数码管上显示的还是000019,这个现象是属于断电保护还是代码出问题了,我有点不太清楚,代码如下,请求大家帮助。谢谢。 #include<reg52.h> sbit lsa=P2^2; sbit lsb=P2^3; sbit lsc=P2^4; sbit k1=P3^1; sbit k2=P3^0; sbit k3=P3^2; sbit SDA=P2^0; sbit SCL=P2^1; typedef unsigned int ui; typedef unsigned char uc; ui code shuju[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07, 0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71}; ui disp[6]; ui num,shi,fen,miao; ui ss=0; void delay(ui i) { while(i--); } void Delay10us() { unsigned char a,b; for(b=1;b>0;b--) for(a=2;a>0;a--); } void I2cStart() { SDA=1; Delay10us(); SCL=1; Delay10us();//?????????SDA???????>4.7us SDA=0; Delay10us();//?????????>4us SCL=0; Delay10us(); } void I2cStop() { SDA=0; Delay10us(); SCL=1; Delay10us();//??????????4.7us SDA=1; Delay10us(); } void respons() { ui b; SCL=1; while(SDA)//????????????????豸??SDA???? { b++; if(b>200) //???????2000us???????????????????????????????? { SCL=0; Delay10us(); } } SCL=0; Delay10us(); } void I2cSendByte(unsigned char dat) { unsigned char a=0,b=0;//???255??????????????1us????????255us?? for(a=0;a<8;a++)//?????8λ???????λ??? { SDA=dat>>7; //?????????SCL=0??????????????SDA??? dat=dat<<1; Delay10us(); SCL=1; Delay10us();//???????>4.7us SCL=0; Delay10us();//??????4us } SDA=1; Delay10us(); SCL=0; Delay10us(); } unsigned char I2cReadByte() { unsigned char a=0,dat=0; SDA=1; //?????????????????SCL????0 Delay10us(); for(a=0;a<8;a++)//????8????? { SCL=1; Delay10us(); dat<<=1; dat|=SDA; Delay10us(); SCL=0; Delay10us(); } return dat; } void write_add(unsigned char addr,unsigned char dat) { I2cStart(); I2cSendByte(0xa0);//????д??????? respons(); I2cSendByte(addr);//?????д??????? respons(); I2cSendByte(dat); //???????? respons(); I2cStop(); } unsigned char read_add(unsigned char addr) { unsigned char num; I2cStart(); I2cSendByte(0xa0); //????д??????? respons(); I2cSendByte(addr); //???????????? respons(); I2cStart(); I2cSendByte(0xa1); //???????????? respons(); num=I2cReadByte(); //??????? I2cStop(); return num; } void init24c02() { SDA=1; Delay10us(); SCL=1; Delay10us(); miao=read_add(1); fen=read_add(2); shi=read_add(3); } void datapros() { disp[0]=shuju[miao%10]; disp[1]=shuju[miao/10]; disp[2]=shuju[fen%10]; disp[3]=shuju[fen/10]; disp[4]=shuju[shi%10]; disp[5]=shuju[shi/10]; } void display() { ui i; for(i=0;i<6;i++) { switch(i) { case(0): lsa=0;lsb=0;lsc=0;break; case(1): lsa=1;lsb=0;lsc=0;break; case(2): lsa=0;lsb=1;lsc=0;break; case(3): lsa=1;lsb=1;lsc=0;break; case(4): lsa=0;lsb=0;lsc=1;break; case(5): lsa=1;lsb=0;lsc=1;break; } P0=disp[i]; delay(100); P0=0x00; } } void init() { TMOD=0x01; TH0=0xfc; TL0=0x18; //1ms EA=1; TR0=1; ET0=1; } void key() { if(k1==0) { delay(100); { if(k1==0) { ss=ss+2; while(!k1); switch(ss) { case(2): lsa=0;lsb=0;lsc=0;TR0=0;break; case(4): lsa=0;lsb=1;lsc=0;break; case(6): lsa=0;lsb=0;lsc=1;break; case(8): ss=0;TR0=1;break; } } } } if(ss!=0) { if(k2==0) { delay(100); { if(k2==0) { while(!k2); if(ss==2) { miao++; if(miao==60) miao=0; write_add(1,miao); } if(ss==4) { fen++; if(fen==60) fen=0; write_add(2,fen); } if(ss==6) { shi++; if(shi==24) shi=0; write_add(3,shi); } } } } if(k3==0) { delay(100); if(k3==0) { while(!k3); if(ss==2) { miao--; if(miao==-1) miao=59; write_add(1,miao); } if(ss==4) { fen--; if(fen==-1) fen=59; write_add(2,fen); } if(ss==6) { shi--; if(shi==-1) shi=23; write_add(3,shi); } } } } } void main() { init(); init24c02(); while(1) { key(); datapros(); display(); } } void init0() interrupt 1 { TH0=0xfc; TL0=0x18; num++; if(num==1000) { miao++; num=0; if(miao==60) { miao=0; fen++; if(fen==60) { fen=0; shi++; if(shi==24) { shi=0; write_add(3,shi); } write_add(2,fen); } write_add(1,miao); } } }

C8051F的单片机调试时,在时钟初始化中 OSCICN = 0x88;语句出现问题

单片机开发的新手,真心求助各位前辈 代码附在下面,遇到的问题是在用keil debug的时候, OSCICN = 0x88;这句话会卡住很久,之后程序会被复位,无法往下进行 改成OSCICN = 0x08;以后debug运行到这一句就会自动退出调试界面 代码如下,用途是使用串口发一个编号: #include <c8051f020.h> #include <string.h> #define BAUDRATE 9600 #define Fosc 22118400 #define uchar unsigned char #define uint unsigned int void Clock_Init(void) { int n = 0; OSCXCN = 0x67; for(n=0;n<500;n++); while(!(OSCXCN&0x80)) OSCICN = 0x88; } void PORT_Init (void) { XBR0 = 0x05; XBR1 = 0x14; XBR2 = 0x44; } void INT_Init (void) { TCON |= 0x05; EX0 = 1; EX1 = 1; } void MCU_Init() { EA = 0; WDTCN = 0xDE; WDTCN = 0xAD; Clock_Init(); PORT_Init(); INT_Init(); EA = 1; } void delay(uint z) { uint x,y; for(x=0;x<z;x++) for(y=0;y<121;y++); } void UART0_Init(void) { SCON0 = 0x40; T2CON = 0x30; RCAP2H = (65536-Fosc/BAUDRATE/32)/256; RCAP2L = (65536-Fosc/BAUDRATE/32)%256; TI0 = 0; RI0 = 0; IE |= 0x90; IE &= 0x95; TR2 = 1; } void send_char(uchar c) { SBUF0 = c; while(TI0==0); TI0 = 0; delay(50); } void main (void) { int n0=48; int n1=49; int n3=51; int i = 0; MCU_Init(); UART0_Init(); TCON &=0xFD; delay(50); send_char(n0); send_char(n0); send_char(n0); send_char(n3); }

keil编译无误,把程序烧到单片机上后,不满足某个else if条件也会执行相应语句

keil编译无误,把程序烧到单片机上后,不满足else if((P2&0x0D)==9)这个条件也会执行相应语句 #include "C8051F020.h" /* P20控制直行,P22控制左行,P23控制右行 */ void Delay() { int i,j; for(i=1000;i>0;i--) for(j=1000;j>0;j--) ; } void Reset_Sources_Init() { WDTCN = 0xDE; //关看门狗 WDTCN = 0xAD; } void Timer_Init() //定时器08位重装载 { //选择系统时钟 CKCON = 0x08; TCON = 0x10; TMOD = 0x02; TL0 = 0x0FA; TH0 = 0x0FA; } void PCA_Init() { PCA0CN = 0x40; //使能 PCA0MD = 0x04; //选择系统时钟 PCA0CPM0 = 0x42; //选择8位pwm PCA0CPH0 = 0x80; //占空比 PCA0CPM1 =0x42; //选择8位pwm PCA0CPH1 =0x80; //占空比 } void Port_IO_Init() { XBR0 = 0x10; //Cex0, Cex1连到P0.0,P0.1 XBR2 = 0x40; //交叉开关使能 P0MDOUT = 0x03; //P0.0,P0.1推挽输出 P2MDOUT = 0x00; } void Oscillator_Init() { int i=0; OSCXCN=0x67; for(i=0;i<3000;i++); } void Init_Device(void) { Reset_Sources_Init(); Timer_Init(); PCA_Init(); Port_IO_Init(); Oscillator_Init(); } void main() { P2=0xFD; //P21一直是低电平,没用了,用P20,P22,P23这三个脚 Init_Device(); while(1) { if(((P2&0x0D)==12)||((P2&0x0D)==13)) { PCA0CPH0 =0x80; PCA0CPH1 =0x80; P2=0xFD; // Delay(); } else if((P2&0x0D)==8) { PCA0CPH0 =0x60; PCA0CPH1 =0x0D0; P2=0xFD; Delay(); } else if((P2&0x0D)==9) //大幅左转 { PCA0CPH0 =0x0D0; PCA0CPH1 =0x0D0; P2=0xFD; Delay(); } else if((P2&0x0D)==4) { PCA0CPH0 =0x0D0; PCA0CPH1 =0x60; P2=0xFD; Delay(); } else if((P2&0x0D)==5) //大幅右转 { PCA0CPH0 =0x0D0; PCA0CPH1 =0x40; P2=0xFD; Delay(); } else { PCA0CPH0 =0x80; PCA0CPH1 =0x80; P2=0xFD; // Delay(); } } } 单步调试的时候没发现问题,但是一经烧到单片机后,刚运行时符合预期,但过一小会儿就不符合预期了,后来十分确定的发现是跑到else if((P2&0x0D)==9)里面去了,我就纳闷了,不符合条件这么会进到这条else if语句里去呢?

单片机设计电子秒表at89c51 求仿真原理图

利用单片机的定时器/计数器定时和计数,并使用LED数码管显示计时的时间来制作一 个电子秒表。 设计要求 (1)能够多次计时; (2)能够查询计时时间

51单片机定时器中断问题

代码如下,设置断点后发现,程序不进入定时器中断函数 #include <REG52.H> #include <intrins.h> #define uchar unsigned char #define uint unsigned int sbit key=P3^7; uchar display[8][8]; /*rank:Z,H,B,I,T,I,心,U*/ uchar code table_cha[8][8]={0x7E, 0x40, 0x20, 0x10, 0x08, 0x04, 0x02, 0x7E, 0x66, 0x66, 0x66, 0x7E, 0x7E, 0x66, 0x66, 0x66, 0x3E, 0x66, 0x66, 0x7E, 0x7E, 0x66, 0x66, 0x3E, 0x3C, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x3C, 0x7E, 0x7E, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x3C, 0x18, 0x18, 0x18, 0x18, 0x18, 0x18, 0x3C, 0x00, 0x66, 0xFF, 0xFF, 0xFF, 0x7E, 0x3C, 0x18, 0x66, 0x66, 0x66, 0x66, 0x66, 0x66, 0x7E, 0x3C}; void sinter() { IE=0x83; //允许INT0和T0中断 IP=0x01; //设置中断优先级 TCON=0x01; //设置INT0工作方式为边沿触发 TMOD=0x00; TH0=0xc0; TL0=0; //假设为方式0,初值为1100/0000/00000B 要求的定时值为1.024ms TR0=1; } void delay5us(void) //误差 -0.026765046296us STC 1T 22.1184Mhz { unsigned char b; for(b=7;b>0;b--); //for(a=2;a>0;a--); } void delay(uint i) { while (i--){ delay5us();}//12t的mcu 注释这个延时即可 } //将table_cha中第cha行元素赋给display第y列 void type(uchar cha,uchar y) { uchar xx; for (xx=0;xx<8;xx++) { display[xx][y]=table_cha[cha][xx]; } } //使display中元素均为le void clear(char le) { uchar i,j; for (j=0;j<8;j++) { for (i=0;i<8;i++) display[j][i]=le; } } void flash() { clear(0); type(0,0); delay(60000); delay(60000); //0.6s type(1,0); delay(60000); delay(60000); type(2,0); delay(60000); delay(60000); type(3,0); delay(60000); delay(60000); type(4,0); delay(60000); delay(60000); type(5,0); delay(60000); delay(60000); type(6,0); delay(60000); delay(60000); type(7,0); delay(60000); delay(60000); clear(0); } void main() { while(1) { flash(); } clear(0); } void print() interrupt 1 { uchar i; static uchar layer=0; P1=0; for (i=0;i<8;i++) { P2=1<<i; //依次扫描1-8片 delay(3); P0=display[layer][i]; delay(3); } P1=1<<layer; if (layer<7) layer++; else layer=0; TH0=0xc0; TL0=0; } void pause () interrupt 0 { while(!key){} }

合泰单片机ht66f70a的超声波程序

我在用合泰单片机ht66f70a弄一个项目,请问哪位大神有它的超声波例程吗? 请求参考,急用,谢谢。 下面是我写的程序,为啥led不亮。超声波感应不了。哪里有错吗?求大神指点指点 _pf口接led的 #include "HT66F70A.h" #define led_port _pf #define led_portc _pfc #define TX _pa0 #define RX _pa3 #define uchar unsigned char #define uint unsigned int uchar outcomeh,outcomel; /*bit success_flag;*/ uint ju_li; uint N; uint ce_ju() { float recome_date; _emi=0; _t0af=0x00; _tm0al=0xe8;//比较器A低位 03e8=1000;达到该值,自动清0; _tm0ah=0x03;//比较器A高位 _tm0dl=0x00; _tm0dh=0x00; TX=1; GCC_DELAY(40); TX=0; while(RX=0); _t0on=1; _emi=1; while(RX=1); _t0on=1; outcomeh=_tm0dh; outcomel=_tm0dl; recome_date=N*500+outcomeh*256+outcomel; recome_date=recome_date*17/1000; return recome_date; } void main() { _cp1c=0x08; led_portc=0x00; led_port=0x00; _mf0e=0x01; _t0ae=0x01; _tm0c0=0b00001000;//选择fsys/4时钟//0.5us _tm0c1=0b11000001;//1100 0001 定时器工作模式 _t0af=0x00; _mf0f=0x00; _emi=1; _tm0al=0xe8;//比较器A低位 03e8=1000;达到该值,自动清0; _tm0ah=0x03;//比较器A高位 _tm0dl=0x00; _tm0dh=0x00; _t0on=1; while(1) { ju_li=ce_ju(); if(ju_li<200) { led_port=0xff; } else { led_port=0x00; } } } void __attribute((interrupt(0x04))) int_isr(void) { N++; _t0af=0x00; }

单片机运行出现 expression with possibly no effect

#include <reg51.h> #include <intrins.h> #define uchar unsigned char #define uint unsigned int sbit CS88 = P2^2; //8X8点阵使能 sbit DS1302=P2^7; //HJ-C52主板 时钟复位 关掉DS1302 以免影响其他IO口实验。 sbit LCD1602=P2^5;//HJ-C52主板 LCD1602复位 关掉LCD1602显示 以免影响其他IO口实验。 void delay1(); //Motor sbit F1 = P1^0; sbit F2 = P1^1; sbit F3 = P1^2; sbit F4 = P1^3; unsigned char code FFW[8]={0xfe,0xfc,0xfd,0xf9,0xfb,0xf3,0xf7,0xf6}; //反转 unsigned char code FFZ[8]={0xf6,0xf7,0xf3,0xfb,0xf9,0xfd,0xfc,0xfe}; //正转 unsigned int K, rate; sbit dula=P2^6; sbit wela=P2^7; sbit LCD_RS = P1^0; sbit LCD_RW = P1^1; sbit LCD_EN = P2^5; int time; int succeed_flag; uchar timeL; uchar timeH; uchar distance; uchar H; sbit Trig=P2^4; sbit Echo=P3^2; uchar code dis1[] = {"The juli is: "}; uchar dis2[] = {0x30,0x31,0x32,0x33,0x34,0x35,0x36,0x37,0x38,0x39}; /********************************************************** * * * 步进电机驱动 * ***********************************************************/ void motor_ffw(void) { unsigned char i; for (i=0; i<8; i++) //一个周期转30度 { P1 = FFW[i]&0x1f; //取数据 delay1(); //调节转速 } } /******************************************** 延时程序 *********************************************/ void delay1(void) { unsigned int k,t; t=rate; while(t--) { for(k=0; k<150; k++) { } } } /******************************************************** * *步进电机运行 * *********************************************************/ void motor_turn(void) { unsigned char x; rate=0x0a; x=0x40; do { motor_ffw(); //加速 rate--; }while(rate!=0x01); do { motor_ffw(); //匀速 x--; }while(x!=0x01); do { motor_ffw(); //减速 rate++; }while(rate!=0x0a); } void delay2(int ms) { int i; while(ms--) { for(i = 0; i< 110; i++) { _nop_(); } } } void delay2_20us() { uchar a ; for(a=0;a<100;a++); } bit lcd_busy() { bit result; LCD_RS = 0; LCD_RW = 1; LCD_EN = 1; _nop_(); _nop_(); _nop_(); _nop_(); result = (bit)(P0&0x80); LCD_EN = 0; return result; } void lcd_wcmd(uchar cmd) { while(lcd_busy()); LCD_RS = 0; LCD_RW = 0; LCD_EN = 0; _nop_(); _nop_(); P0 = cmd; _nop_(); _nop_(); LCD_EN = 1; _nop_(); _nop_(); LCD_EN = 0; } void lcd_wdat(uchar dat) { while(lcd_busy()); LCD_RS = 1; LCD_RW = 0; LCD_EN = 0; P0 = dat; _nop_(); _nop_(); LCD_EN = 1; _nop_(); _nop_(); LCD_EN = 0; } void lcd_pos(uchar pos) { lcd_wcmd(pos|0x80); //数据指针=80+地址变量 } void lcd_init() { dula=0; wela=0; lcd_wcmd(0x38); //16*2显示,5*7点阵,8位数据 delay2(5); lcd_wcmd(0x38); delay2(5); lcd_wcmd(0x38); delay2(5); lcd_wcmd(0x0c); //显示开,关光标 delay2(5); lcd_wcmd(0x06); //移动光标 delay2(5); lcd_wcmd(0x01); //清除LCD的显示内容 delay2(5); } main() { uchar i,a,b,c; delay2(10); lcd_init(); // 初始化LCD Trig=0; //首先拉低脉冲输入引脚 EA=1; //打开总中断0 TMOD=0x10; //定时器1,16位工作方式 while(1) { EA=0; //关总中断 Trig=1; //超声波输入端 delay2_20us(); //延时20us Trig=0; //产生一个20us的脉冲 while(Echo==0); //等待Echo回波引脚变高电平 succeed_flag=0; //清测量成功标志 EA=1; EX0=1; //打开外部中断0 TH1=0; //定时器1清零 TL1=0; //定时器1清零 TF1=0; //计数溢出标志 TR1=1; //启动定时器1 delay2(20); //等待测量的结果 TR1=0; //关闭定时器1 EX0=0; //关闭外部中断0 if(succeed_flag==1) { time=timeH*256+timeL; distance=time*0.0172; //毫米 H=100 - distance; } if(succeed_flag==0) { distance=0; //没有回波则清零 } a=H/100; b=(H%100)/10; c=H%10; lcd_wcmd(0x06); //向右移动光标 lcd_pos(0); //设置显示位置为第一行的第1个字符 i = 0; while(dis1[i] != '\0') { //显示字符 lcd_wdat(dis1[i]); i++; delay2(2); //控制两字之间显示速度 } lcd_pos(0x45); //设置显示位置为第二行第1个字符 lcd_wdat(dis2[a]); delay2(2); lcd_wdat(dis2[b]); delay2(2); lcd_wdat(dis2[c]); delay2(2); lcd_wdat('c'); delay2(2); lcd_wdat('m'); delay2(2); if(distance>10) motor_turn; } } void exter() interrupt 0 // 外部中断0是0号 { EX0=0; //关闭外部中断 timeH =TH1; //取出定时器的值 timeL =TL1; //取出定时器的值 succeed_flag=1;//至成功测量的标志 } void timer1() interrupt 3 // { TH1=0; TL1=0; } 出现这种情况为什么MAIN.C(252): warning C275: expression with possibly no effect

关于keil编译1602的错误

我从网上下载了LCD1602液晶显示块的程序,然后添加到为我的工程之后(我学的工程设计LCD1602 DS1302数字时钟),编译就出现了如果所示的错误,有没有大神知道这个怎么搞。我的使用的是51单片机![图片说明](https://img-ask.csdn.net/upload/201805/18/1526634184_692577.png)

STM32串口如何实现一个发数据,另外一个接收数据

在keil5在编程环境下,想要实现的功能是:利用中断,让串口四接收数据,串口一发送数据 部分代码如下: int main(void) { //初始化USART1和UART4 配置模式为 115200 8-N-1,通过USART1发送数据,通过UART4接收数据 Debug_USART1_Config(); Debug_UART4_Config(); while(1) { } } 、、、、、、、、、中断函数如下、、、、、、、、、 相关宏定义 #define DEBUG_R_USART_IRQHandler UART4_IRQHandler #define DEBUG_R_USART_IRQ UART4_IRQn //串口四的中断程序:用于接收数据 void DEBUG_R_USART_IRQHandler(void) { if(USART_GetITStatus(UART4,USART_IT_RXNE)!=RESET) { USART_ClearFlag(UART4,USART_IT_RXNE); // USART_ClearITPendingBit(UART4,USART_IT_RXNE); //清除中断标志 ucTemp = USART_ReceiveData(UART4); } } //串口一的中断程序:用于发送数据 void DEBUG_T_USART_IRQHandler(void) { if(USART_GetITStatus(USART1,USART_IT_RXNE)!=RESET) { USART_ClearFlag(USART1,USART_IT_RXNE); //清除标志 // USART_ClearITPendingBit(USART1,USART_IT_RXNE); //清除中断预处理位 USART_SendData(USART1,ucTemp); } } 、、、、、、、、中断函数的配置、、、、、、、、、 //接收串口引脚定义 /*******************************************************/ #define DEBUG_USART UART4 #define DEBUG_USART_CLK RCC_APB1Periph_UART4 #define DEBUG_USART_BAUDRATE 115200 //串口波特率 #define DEBUG_USART_RX_GPIO_PORT GPIOA #define DEBUG_USART_RX_GPIO_CLK RCC_AHB1Periph_GPIOA #define DEBUG_USART_RX_PIN GPIO_Pin_1 #define DEBUG_USART_RX_AF GPIO_AF_UART4 #define DEBUG_USART_RX_SOURCE GPIO_PinSource1 #define DEBUG_USART_TX_GPIO_PORT GPIOA #define DEBUG_USART_TX_GPIO_CLK RCC_AHB1Periph_GPIOA #define DEBUG_USART_TX_PIN GPIO_Pin_0 #define DEBUG_USART_TX_AF GPIO_AF_UART4 #define DEBUG_USART_TX_SOURCE GPIO_PinSource0 #define DEBUG_R_USART_IRQHandler UART4_IRQHandler #define DEBUG_R_USART_IRQ UART4_IRQn /************************************************************/ //发送串口引脚定义 /*******************************************************/ #define DEBUG_T_USART USART1 #define DEBUG_T_USART_CLK RCC_APB2Periph_USART1 #define DEBUG_T_USART_BAUDRATE 115200 //串口波特率 #define DEBUG_T_USART_RX_GPIO_PORT GPIOA #define DEBUG_T_USART_RX_GPIO_CLK RCC_AHB1Periph_GPIOA #define DEBUG_T_USART_RX_PIN GPIO_Pin_10 #define DEBUG_T_USART_RX_AF GPIO_AF_USART1 #define DEBUG_T_USART_RX_SOURCE GPIO_PinSource10 #define DEBUG_T_USART_TX_GPIO_PORT GPIOA #define DEBUG_T_USART_TX_GPIO_CLK RCC_AHB1Periph_GPIOA #define DEBUG_T_USART_TX_PIN GPIO_Pin_9 #define DEBUG_T_USART_TX_AF GPIO_AF_USART1 #define DEBUG_T_USART_TX_SOURCE GPIO_PinSource9 #define DEBUG_T_USART_IRQHandler USART1_IRQHandler #define DEBUG_T_USART_IRQ USART1_IRQn /************************************************************/ static void NVIC_Configuration(void) //串口四的中断参数的配置 { NVIC_InitTypeDef NVIC_InitStructure; /* 嵌套向量中断控制器组选择 */ NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2); /* 配置UART4为中断源 */ NVIC_InitStructure.NVIC_IRQChannel = DEBUG_R_USART_IRQ; /* 抢断优先级为1 */ NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1; /* 子优先级为1 */ NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1; /* 使能中断 */ NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; /* 初始化配置NVIC */ NVIC_Init(&NVIC_InitStructure); } static void T_NVIC_Configuration(void) //串口一的中断参数的配置 { NVIC_InitTypeDef NVIC_InitStructure; /* 嵌套向量中断控制器组选择 */ NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2); /* 配置USART1为中断源 */ NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn; /* 抢断优先级为1 */ NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1; /* 子优先级为1 */ NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1; /* 使能中断 */ NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; /* 初始化配置NVIC */ NVIC_Init(&NVIC_InitStructure); } 、、、、、、、、有关串口的配置、、、、、、、、 void Debug_UART4_Config(void) { GPIO_InitTypeDef GPIO_InitStructure; USART_InitTypeDef USART_InitStructure; RCC_AHB1PeriphClockCmd(DEBUG_USART_RX_GPIO_CLK|DEBUG_USART_TX_GPIO_CLK,ENABLE); /* 使能 USART 时钟 */ RCC_APB1PeriphClockCmd(DEBUG_USART_CLK, ENABLE); /* GPIO初始化 */ GPIO_InitStructure.GPIO_OType = GPIO_OType_PP; GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; /* 配置Tx引脚为复用功能 */ GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF; GPIO_InitStructure.GPIO_Pin = DEBUG_USART_TX_PIN ; GPIO_Init(DEBUG_USART_TX_GPIO_PORT, &GPIO_InitStructure); /* 配置Rx引脚为复用功能 */ GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF; GPIO_InitStructure.GPIO_Pin = DEBUG_USART_RX_PIN; GPIO_Init(DEBUG_USART_RX_GPIO_PORT, &GPIO_InitStructure); /* 连接 PXx 到 USARTx_Tx*/ GPIO_PinAFConfig(DEBUG_USART_RX_GPIO_PORT,DEBUG_USART_RX_SOURCE,DEBUG_USART_RX_AF); /* 连接 PXx 到 USARTx__Rx*/ GPIO_PinAFConfig(DEBUG_USART_TX_GPIO_PORT,DEBUG_USART_TX_SOURCE,DEBUG_USART_TX_AF); /* 配置串DEBUG_USART 模式 */ /* 波特率设置:DEBUG_USART_BAUDRATE */ USART_InitStructure.USART_BaudRate = DEBUG_USART_BAUDRATE; /* 字长(数据位+校验位):8 */ USART_InitStructure.USART_WordLength = USART_WordLength_8b; /* 停止位:1个停止位 */ USART_InitStructure.USART_StopBits = USART_StopBits_1; /* 校验位选择:不使用校验 */ USART_InitStructure.USART_Parity = USART_Parity_No; /* 硬件流控制:不使用硬件流 */ USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None; /* USART模式控制:同时使能接收和发送 */ USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx; /* 完成USART初始化配置 */ USART_Init(DEBUG_USART, &USART_InitStructure); /* 嵌套向量中断控制器NVIC配置 */ NVIC_Configuration(); /* 使能串口接收中断 */ USART_ITConfig(DEBUG_USART, USART_IT_RXNE, ENABLE); //使能了接收中断,那么ORE中断也同时被开启了。 /* 使能串口 */ USART_Cmd(DEBUG_USART, ENABLE); } void Debug_USART1_Config(void) { GPIO_InitTypeDef GPIO_InitStructure; USART_InitTypeDef USART_InitStructure; RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA,ENABLE); /* 使能 USART 时钟 */ RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1, ENABLE); /* GPIO初始化 */ GPIO_InitStructure.GPIO_OType = GPIO_OType_PP; GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; /* 配置Tx引脚为复用功能 */ GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF; GPIO_InitStructure.GPIO_Pin = DEBUG_USART_TX_PIN ; GPIO_Init(DEBUG_T_USART_TX_GPIO_PORT, &GPIO_InitStructure); /* 配置Rx引脚为复用功能 */ GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF; GPIO_InitStructure.GPIO_Pin = DEBUG_T_USART_RX_PIN; GPIO_Init(DEBUG_T_USART_RX_GPIO_PORT, &GPIO_InitStructure); /* 连接 PXx 到 USARTx_Tx*/ GPIO_PinAFConfig(DEBUG_T_USART_RX_GPIO_PORT,DEBUG_T_USART_RX_SOURCE,DEBUG_T_USART_RX_AF); /* 连接 PXx 到 USARTx__Rx*/ GPIO_PinAFConfig(DEBUG_T_USART_TX_GPIO_PORT,DEBUG_T_USART_TX_SOURCE,DEBUG_T_USART_TX_AF); /* 配置串DEBUG_USART 模式 */ /* 波特率设置:DEBUG_USART_BAUDRATE */ USART_InitStructure.USART_BaudRate = DEBUG_T_USART_BAUDRATE; /* 字长(数据位+校验位):8 */ USART_InitStructure.USART_WordLength = USART_WordLength_8b; /* 停止位:1个停止位 */ USART_InitStructure.USART_StopBits = USART_StopBits_1; /* 校验位选择:不使用校验 */ USART_InitStructure.USART_Parity = USART_Parity_No; /* 硬件流控制:不使用硬件流 */ USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None; /* USART模式控制:同时使能接收和发送 */ USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx; /* 完成USART初始化配置 */ USART_Init(DEBUG_T_USART, &USART_InitStructure); /* 嵌套向量中断控制器NVIC配置 */ T_NVIC_Configuration(); /* 使能串口接收中断 */ USART_ITConfig(DEBUG_T_USART, USART_IT_RXNE, ENABLE); /* 使能串口 */ USART_Cmd(DEBUG_T_USART, ENABLE); } 未解决:串口一和串口四都可以单独收发,但是我想要实现一个串口收,另外一个串口发的功能,,,,,,,,求助啊,,,,,,试了好多可能性了

51单片机模拟spi控制电力载波芯片MI200E,发送0xaa,接收有显示,但不是0xaa。

想测试发送0xaa,但接收不对,而且接收更像是乱码,改了很多地方都不对,不知道问题出在哪里,希望各位大神帮忙看看代码错在哪。我用的keil3编译环境,51单片机,电力线载波芯片是MI200E,测试接收0xaa是通过8个led灯(也用串口显示过,和led灯显示相匹配)第一次提问题,不知道怎么把MI200E的数据手册和应用手册贴出来,在代码后贴出了文档在百度文库上的网址,麻烦各位大神了,小弟这次是碰到棘手困难了,在这先谢了。代码如下: /********发送程序*********************/ #include <reg52.h> #include <intrins.h> #define uchar unsigned char #define uint unsigned int //sbit MOSI=P1^0; //主设备发送从设备接收线,master output subordinate input //sbit MISO=P1^1; //从设备发送主设备接收线 master input subordinate output sbit SDO=P1^2; //p1.3口模拟主机输出 主设备发送从设备接收 sbit SDI=P1^1; //p3.2口模拟主机输入,接到外部中断0 主设备接收从设备发送 sbit sck=P1^3; //SPI时钟 sbit cs=P1^4; //片选 p1.3 sbit MI200E_RST=P1^5; //复位 sbit ceshi1=P0^6; sbit ceshi2=P0^7; uchar num; uchar RDSR_command; //用来读0x82 uchar CRC_H,CRC_L; uchar step,i; void delay(uint z);//延时 void cudelay_50us(); void init_MI200E();//初始化 void Write_CommandReg(uchar add,uchar com);//写控制指令 uchar Read_CommandReg(uchar add);//读控制指令 void Write_DataReg(uchar add,uchar dat);//写数据,dat应是16位的 void Write_DataReg2(uchar add,uchar dat_H,uchar dat_L);//改进,将高低8位分开发送 uchar Read_DataReg(uchar add);//读数据 void send(); void delay(uint z) { uint x,y; for(x=z;x>0;x--) for(y=110;y>0;y--); } void cudelay_50us() { uchar i; for(i=0;i<5;i++); } void init_MI200E() //初始化 { MI200E_RST=0; delay(600); //要求延时超过500ms MI200E_RST=1; delay(60); //要求延时超过50ms Write_CommandReg(0x01,0xFF); Write_CommandReg(0x0C,0x58); Write_CommandReg(0x0D,0x01); //应用笔记这样写 // Write_CommandReg(0x0D,0x0A); //数据手册这样写 Write_CommandReg(0x10,0x66); Write_CommandReg(0x12,0x66); Write_CommandReg(0x14,0x66); Write_CommandReg(0x11,0x88); Write_CommandReg(0x13,0x88); Write_CommandReg(0x15,0x88); Write_CommandReg(0x07,0xFF); Write_CommandReg(0x0A,0x00); Write_CommandReg(0x0B,0x00); } void init() { TMOD=0x01;//设置定时器0工作方式1 TH0=(65536-2293)/256;//定时5ms TL0=(65536-2293)%256; EA=1; ET0=1;//开定时器0 TR0=1;//启动定时器0 } //写入控制寄存器 void Write_CommandReg(uchar add,uchar com) { uchar i; uchar mark; cs=0; mark=0x80; _nop_(); //_nop_();延时1us _nop_(); for(i=0;i<8;i++) { sck=0; _nop_(); if(add&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } mark=0x80; for(i=0;i<8;i++) { sck=0; _nop_(); if(com&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } _nop_(); sck=0; cs=1; } //读取控制寄存器 uchar Read_CommandReg(uchar add) //时序有问题,返回的readdata有三个高,目测是TI、carr和 { //Frame,但P2口值检测出Frame为高 uchar i; uchar mark; uchar readdata; cs=0; mark=0x80; _nop_(); _nop_(); for(i=0;i<8;i++) { sck=0; // _nop_(); if(add&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } _nop_(); _nop_(); for(i=0;i<8;i++) { //此处不能加延时 sck=0; _nop_(); readdata<<=1; if(SDI) { readdata|=1; } else { readdata&=0xFE; } sck=1; _nop_(); } _nop_(); sck=0; _nop_(); cs=1; return(readdata); } //写入数据寄存器 void Write_DataReg(uchar add,uchar dat) { uchar i; uchar mark; uchar marklong; cs=0; mark=0x80; marklong=0x8000; _nop_(); _nop_(); for(i=0;i<8;i++) { sck=0; _nop_(); if(add&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } for(i=0;i<16;i++) { sck=0; _nop_(); if(dat&marklong) { SDO=1; } else { SDO=0; } sck=1; _nop_(); marklong>>=1; } _nop_(); sck=0; cs=1; } void Write_DataReg2(uchar add,uchar dat_H,uchar dat_L) { uchar i; uchar mark; uint marklong; cs=0; mark=0x80; marklong=0x8000; _nop_(); _nop_(); for(i=0;i<8;i++) { sck=0; _nop_(); if(add&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } for(i=0;i<8;i++) { sck=0; _nop_(); if(dat_H&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } for(i=0;i<8;i++) { sck=0; _nop_(); if(dat_L&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } _nop_(); sck=0; cs=1; } //读取数据寄存器 uchar Read_DataReg(uchar add) { uchar i; uchar mark; uint readdata; cs=0; mark=0x80; readdata=0; _nop_(); _nop_(); for(i=0;i<8;i++) { sck=0; _nop_(); if(add&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } _nop_(); _nop_(); for(i=0;i<16;i++) { sck=0; _nop_(); readdata<<=1; if(SDI) { readdata|=1; } else { readdata&=0xFE; } sck=1; _nop_(); } _nop_(); sck=0; cs=1; return(readdata); } void send() { // Write_CommandReg(0x01,0x01); //bit6~4扩频码字,bit3~2波特率选择,bit1~0载波频率 //配置进入发送状态 switch(step) { case 0: { Write_CommandReg(0x01,0x0d);//将0x01的bit2、3至高,其余不变,以最低速率发送bit2、3 // Write_CommandReg(0x02,0x00);//将TI复位 Write_DataReg2(0x04,0xff,0xff); //发送0xff,0xff引导码 step=1; } break; case 1: { Write_CommandReg(0x02,0xfd);//将0x02的CRC清零 // Write_CommandReg(0x02,0x00);//将TI复位 Write_DataReg2(0x04,0x1a,0x0c);//发送bit3 0x1a和bit4 波特率和长度 step=2; } break; case 2: { Write_CommandReg(0x01,0x01);//将bit2、3恢复原设波特率1600和76.8kHZ // Write_CommandReg(0x02,0x00);//将TI复位 Write_DataReg(0x04,0xaa);//发送bit5,即使改成0xaaaa也不对 for(i=0;i<10;i++) //延时50us { _nop_(); _nop_(); _nop_(); _nop_(); _nop_(); } CRC_H=Read_CommandReg(0xa8); //读CRC CRC_L=Read_CommandReg(0xa9); step=3; } break; case 3: { // Write_CommandReg(0x02,0x00);//将TI复位 Write_DataReg2(0x04,CRC_H,CRC_L);//发送CRC step=0; } break; default: {delay(10);} break; } } void main() { init(); init_MI200E(); Write_CommandReg(0x02,0x80); Write_DataReg2(0x04,0xff,0xff); Write_CommandReg(0x01,0x01); //bit6~4扩频码字,bit3~2波特率选择,bit1~0载波频率 step=0; sck=0; SDI=1; while(1); } void timer0() interrupt 1//2.5ms { // P1|=1; TH0=(65536-2293)/256;// TL0=(65536-2293)%256;//重装初值 // Write_CommandReg(0x02,0x80); RDSR_command=Read_CommandReg(0x82); P2=RDSR_command; if((RDSR_command & 0x80)==0x80) //每隔2.5ms查询0x82,判断bit7 TI是否为1 { ceshi2=0; // P1&=0xFE; Write_CommandReg(0x02,0x00);//将TI复位 // delay(5); send(); //TI为1执行发送,TI为1往发送寄存器写入数据,之后TI需复位 // Write_CommandReg(0x01,0x0d);//将0x01的bit2、3至高,其余不变,以最低速率发送bit2、3 // Write_DataReg2(0x04,0xff,0xff); //发送0xff,0xff引导码 // P1|=1; // P0=0xaa; } // P1&=0xFE; } /*************接收程序************************/ #include <reg52.h> #include <intrins.h> #define uchar unsigned char #define uint unsigned int //sbit MOSI=P1^0; //主设备发送从设备接收线,master output subordinate input //sbit MISO=P1^1; //从设备发送主设备接收线 master input subordinate output sbit SDO=P1^2; //p1.3口模拟主机输出 主设备发送从设备接收 sbit SDI=P1^1; //p3.2口模拟主机输入,接到外部中断0 主设备接收从设备发送 sbit sck=P1^3; //SPI时钟 sbit cs=P1^4; //片选 p1.3 sbit MI200E_RST=P1^5; //复位 sbit ceshi1=P0^6; sbit ceshi2=P0^7; uchar num; uchar RDSR_command; //用来读0x82 uchar RDRR_command; //用来读0x83 uchar RDRB0_DataReg; //用来读取数据寄存器0x84 uchar CRC_H,CRC_L,CRC_flag; uchar step,i; void delay(uint z); void cudelay_50us(); void init_MI200E(); void Write_CommandReg(uchar add,uchar com); uchar Read_CommandReg(uchar add); void Write_DataReg(uchar add,uchar dat); void Write_DataReg2(uchar add,uchar dat_H,uchar dat_L); uchar Read_DataReg(uchar add); void send(); void delay(uint z) { uint x,y; for(x=z;x>0;x--) for(y=110;y>0;y--); } void cudelay_50us() { uchar i; for(i=0;i<5;i++); } void init_MI200E() //初始化 { MI200E_RST=0; delay(600); //要求延时超过500ms MI200E_RST=1; delay(60); //要求延时超过50ms Write_CommandReg(0x01,0xFF); Write_CommandReg(0x0C,0x58); Write_CommandReg(0x0D,0x01); //应用笔记这样写 // Write_CommandReg(0x0D,0x0A); //数据手册这样写 Write_CommandReg(0x10,0x66); Write_CommandReg(0x12,0x66); Write_CommandReg(0x14,0x66); Write_CommandReg(0x11,0x88); Write_CommandReg(0x13,0x88); Write_CommandReg(0x15,0x88); Write_CommandReg(0x07,0xFF); Write_CommandReg(0x0A,0x00); Write_CommandReg(0x0B,0x00); } void init() { TMOD=0x01;//设置定时器0工作方式1 TH0=(65536-2293)/256;//定时5ms TL0=(65536-2293)%256; EA=1; ET0=1;//开定时器0 TR0=1;//启动定时器0 } //写入控制寄存器 void Write_CommandReg(uchar add,uchar com) { uchar i; uchar mark; cs=0; mark=0x80; _nop_(); //_nop_();延时1us _nop_(); for(i=0;i<8;i++) { sck=0; _nop_(); if(add&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } mark=0x80; for(i=0;i<8;i++) { sck=0; _nop_(); if(com&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } _nop_(); sck=0; cs=1; } //读取控制寄存器 uchar Read_CommandReg(uchar add) { uchar i; uchar mark; uchar readdata; cs=0; mark=0x80; _nop_(); _nop_(); for(i=0;i<8;i++) { sck=0; // _nop_(); if(add&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } _nop_(); for(i=0;i<8;i++) { //此处不能加延时 sck=0; _nop_(); readdata<<=1; if(SDI) { readdata|=1; } else { readdata&=0xFE; } sck=1; // _nop_(); } _nop_(); sck=0; _nop_(); cs=1; return(readdata); } //写入数据寄存器 void Write_DataReg(uchar add,uchar dat) { uchar i; uchar mark; uchar marklong; cs=0; mark=0x80; marklong=0x8000; _nop_(); _nop_(); for(i=0;i<8;i++) { sck=0; _nop_(); if(add&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } for(i=0;i<16;i++) { sck=0; _nop_(); if(dat&marklong) { SDO=1; } else { SDO=0; } sck=1; _nop_(); marklong>>=1; } _nop_(); sck=0; cs=1; } void Write_DataReg2(uchar add,uchar dat_H,uchar dat_L) { uchar i; uchar mark; uint marklong; cs=0; mark=0x80; marklong=0x8000; _nop_(); _nop_(); for(i=0;i<8;i++) { sck=0; _nop_(); if(add&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } for(i=0;i<8;i++) { sck=0; _nop_(); if(dat_H&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } for(i=0;i<8;i++) { sck=0; _nop_(); if(dat_L&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } _nop_(); sck=0; cs=1; } //读取数据寄存器 uchar Read_DataReg(uchar add) { uchar i; uchar mark; uint readdata; cs=0; mark=0x80; readdata=0; _nop_(); _nop_(); for(i=0;i<8;i++) { sck=0; _nop_(); if(add&mark) { SDO=1; } else { SDO=0; } sck=1; _nop_(); mark>>=1; } _nop_(); _nop_(); for(i=0;i<16;i++) { sck=0; _nop_(); readdata<<=1; if(SDI) { readdata|=1; } else { readdata&=0xFE; } sck=1; _nop_(); } _nop_(); sck=0; cs=1; return(readdata); } void send() { // Write_CommandReg(0x01,0x01); //bit6~4扩频码字,bit3~2波特率选择,bit1~0载波频率 //配置进入发送状态 switch(step) { case 0: { Write_CommandReg(0x01,0x0d);//将0x01的bit2、3至高,其余不变,以最低速率发送bit2、3 Write_DataReg2(0x04,0xff,0xff); //发送0xff,0xff引导码 step=1; } break; case 1: { Write_CommandReg(0x02,0xfd);//将0x02的CRC清零 Write_DataReg2(0x04,0x1a,0x0c);//发送bit3 0x1a和bit4 波特率和长度 step=2; } break; case 2: { Write_CommandReg(0x01,0x01);//将bit2、3恢复原设波特率1600和76.8kHZ Write_DataReg(0x04,0xaa);//发送bit5 for(i=0;i<10;i++) //延时50us { _nop_(); _nop_(); _nop_(); _nop_(); _nop_(); } CRC_H=Read_CommandReg(0xa8); //读CRC CRC_L=Read_CommandReg(0xa9); step=3; } break; case 3: { Write_DataReg2(0x04,CRC_H,CRC_L);//发送CRC ceshi1=1; ceshi2=0; Write_CommandReg(0x02,0x00);//将TI复位 step=0; } break; default: {} break; } } void receive() { switch(step) { case 0: { RDRR_command=Read_CommandReg(0x83); if(RDRR_command!=0x00) { Write_CommandReg(0x01,0x81); step=1; } } break; case 1: { if((RDSR_command & 0x40)==0x40) { step=2; } else { step=1; } } break; case 2: { Write_CommandReg(0x02,0x7a);//将CRC标志位置1 RDRB0_DataReg=Read_DataReg(0x84);//读取0x84 Write_CommandReg(0x02,0x30);//将RI清零 P0=RDRB0_DataReg; step=3; } break; case 3: { CRC_flag=Read_DataReg(0x84);//读取CRC校验标志位 // P0=CRC_flag; if(CRC_flag==1) { Write_CommandReg(0x02,0x00);//将EPF和CRC标志位清零 } } break; default: {} break; } } void main() { init(); init_MI200E(); // Write_CommandReg(0x02,0x80); Write_CommandReg(0x02,0x00); Write_CommandReg(0x01,0x81);//bit6~4扩频码字,bit3~2波特率选择,bit1~0载波频率 Write_CommandReg(0x01,0x8d);//配置接收状态 step=0; sck=0; SDI=1; while(1); } void timer0() interrupt 1//2.5ms { // P1|=1; TH0=(65536-2293)/256;// TL0=(65536-2293)%256;//重装初值 RDSR_command=Read_CommandReg(0x82); P2=RDSR_command; if(((RDSR_command & 0x20)==0x20)&&((RDSR_command & 0x10)==0x10)) //每隔2.5ms查询0x82,判断carr和frame是否为1 { // P1&=0xFE; // Write_CommandReg(0x02,0x00);//将TI复位 // delay(2.5); receive(); //carr和frame为1执行接收 // cudelay_50us(); // ceshi2=0; // Write_CommandReg(0x02,0x30);//将RI清零 //Write_DataReg2(0x04,0xff,0xff); // P1|=1; // P0=0xaa; } // P1&=0xFE; } MI200E数据手册网址:[CSDN移动问答][1] MI200E应用笔记网址:[CSDN移动问答][2] [1]: http://wenku.baidu.com/link?url=stE_-LF4OcojG9xuouzs9Qbi54F6CmP96yoTdgtQ7VInQRp03tBh-A_P4TSIgvJ-vRZ7TaSg0UUNZNbUz36vnhU1QpT91omCDljRUAw8qY3 [2]: http://wenku.baidu.com/link?url=A-0hTe_YiFslr94yLvoqhliuPPIoGZaa98bp-va-Hvi1oO63lC3XW3kAIt4JuWfsAo7BUENnnvGjCWP4hmKFyxecv82QOixL-5ere1IAEYe

在中国程序员是青春饭吗?

今年,我也32了 ,为了不给大家误导,咨询了猎头、圈内好友,以及年过35岁的几位老程序员……舍了老脸去揭人家伤疤……希望能给大家以帮助,记得帮我点赞哦。 目录: 你以为的人生 一次又一次的伤害 猎头界的真相 如何应对互联网行业的「中年危机」 一、你以为的人生 刚入行时,拿着傲人的工资,想着好好干,以为我们的人生是这样的: 等真到了那一天,你会发现,你的人生很可能是这样的: ...

程序员请照顾好自己,周末病魔差点一套带走我。

程序员在一个周末的时间,得了重病,差点当场去世,还好及时挽救回来了。

和黑客斗争的 6 天!

互联网公司工作,很难避免不和黑客们打交道,我呆过的两家互联网公司,几乎每月每天每分钟都有黑客在公司网站上扫描。有的是寻找 Sql 注入的缺口,有的是寻找线上服务器可能存在的漏洞,大部分都...

点沙成金:英特尔芯片制造全过程揭密

“亚马逊丛林里的蝴蝶扇动几下翅膀就可能引起两周后美国德州的一次飓风……” 这句人人皆知的话最初用来描述非线性系统中微小参数的变化所引起的系统极大变化。 而在更长的时间尺度内,我们所生活的这个世界就是这样一个异常复杂的非线性系统…… 水泥、穹顶、透视——关于时间与技艺的蝴蝶效应 公元前3000年,古埃及人将尼罗河中挖出的泥浆与纳特龙盐湖中的矿物盐混合,再掺入煅烧石灰石制成的石灰,由此得来了人...

上班一个月,后悔当初着急入职的选择了

最近有个老铁,告诉我说,上班一个月,后悔当初着急入职现在公司了。他之前在美图做手机研发,今年美图那边今年也有一波组织优化调整,他是其中一个,在协商离职后,当时捉急找工作上班,因为有房贷供着,不能没有收入来源。所以匆忙选了一家公司,实际上是一个大型外包公司,主要派遣给其他手机厂商做外包项目。**当时承诺待遇还不错,所以就立马入职去上班了。但是后面入职后,发现薪酬待遇这块并不是HR所说那样,那个HR自...

女程序员,为什么比男程序员少???

昨天看到一档综艺节目,讨论了两个话题:(1)中国学生的数学成绩,平均下来看,会比国外好?为什么?(2)男生的数学成绩,平均下来看,会比女生好?为什么?同时,我又联想到了一个技术圈经常讨...

副业收入是我做程序媛的3倍,工作外的B面人生是怎样的?

提到“程序员”,多数人脑海里首先想到的大约是:为人木讷、薪水超高、工作枯燥…… 然而,当离开工作岗位,撕去层层标签,脱下“程序员”这身外套,有的人生动又有趣,马上展现出了完全不同的A/B面人生! 不论是简单的爱好,还是正经的副业,他们都干得同样出色。偶尔,还能和程序员的特质结合,产生奇妙的“化学反应”。 @Charlotte:平日素颜示人,周末美妆博主 大家都以为程序媛也个个不修边幅,但我们也许...

如果你是老板,你会不会踢了这样的员工?

有个好朋友ZS,是技术总监,昨天问我:“有一个老下属,跟了我很多年,做事勤勤恳恳,主动性也很好。但随着公司的发展,他的进步速度,跟不上团队的步伐了,有点...

我入职阿里后,才知道原来简历这么写

私下里,有不少读者问我:“二哥,如何才能写出一份专业的技术简历呢?我总感觉自己写的简历太烂了,所以投了无数份,都石沉大海了。”说实话,我自己好多年没有写过简历了,但我认识的一个同行,他在阿里,给我说了一些他当年写简历的方法论,我感觉太牛逼了,实在是忍不住,就分享了出来,希望能够帮助到你。 01、简历的本质 作为简历的撰写者,你必须要搞清楚一点,简历的本质是什么,它就是为了来销售你的价值主张的。往深...

外包程序员的幸福生活

今天给你们讲述一个外包程序员的幸福生活。男主是Z哥,不是在外包公司上班的那种,是一名自由职业者,接外包项目自己干。接下来讲的都是真人真事。 先给大家介绍一下男主,Z哥,老程序员,是我十多年前的老同事,技术大牛,当过CTO,也创过业。因为我俩都爱好喝酒、踢球,再加上住的距离不算远,所以一直也断断续续的联系着,我对Z哥的状况也有大概了解。 Z哥几年前创业失败,后来他开始干起了外包,利用自己的技术能...

C++11:一些微小的变化(新的数据类型、template表达式内的空格、nullptr、std::nullptr_t)

本文介绍一些C++的两个新特性,它们虽然微小,但对你的编程十分重要 一、Template表达式内的空格 C++11标准之前建议在“在两个template表达式的闭符之间放一个空格”的要求已经过时了 例如: vector&lt;list&lt;int&gt; &gt;; //C++11之前 vector&lt;list&lt;int&gt;&gt;; //C++11 二、nullptr ...

优雅的替换if-else语句

场景 日常开发,if-else语句写的不少吧??当逻辑分支非常多的时候,if-else套了一层又一层,虽然业务功能倒是实现了,但是看起来是真的很不优雅,尤其是对于我这种有强迫症的程序"猿",看到这么多if-else,脑袋瓜子就嗡嗡的,总想着解锁新姿势:干掉过多的if-else!!!本文将介绍三板斧手段: 优先判断条件,条件不满足的,逻辑及时中断返回; 采用策略模式+工厂模式; 结合注解,锦...

深入剖析Springboot启动原理的底层源码,再也不怕面试官问了!

大家现在应该都对Springboot很熟悉,但是你对他的启动原理了解吗?

离职半年了,老东家又发 offer,回不回?

有小伙伴问松哥这个问题,他在上海某公司,在离职了几个月后,前公司的领导联系到他,希望他能够返聘回去,他很纠结要不要回去? 俗话说好马不吃回头草,但是这个小伙伴既然感到纠结了,我觉得至少说明了两个问题:1.曾经的公司还不错;2.现在的日子也不是很如意。否则应该就不会纠结了。 老实说,松哥之前也有过类似的经历,今天就来和小伙伴们聊聊回头草到底吃不吃。 首先一个基本观点,就是离职了也没必要和老东家弄的苦...

为什么你不想学习?只想玩?人是如何一步一步废掉的

不知道是不是只有我这样子,还是你们也有过类似的经历。 上学的时候总有很多光辉历史,学年名列前茅,或者单科目大佬,但是虽然慢慢地长大了,你开始懈怠了,开始废掉了。。。 什么?你说不知道具体的情况是怎么样的? 我来告诉你: 你常常潜意识里或者心理觉得,自己真正的生活或者奋斗还没有开始。总是幻想着自己还拥有大把时间,还有无限的可能,自己还能逆风翻盘,只不是自己还没开始罢了,自己以后肯定会变得特别厉害...

为什么程序员做外包会被瞧不起?

二哥,有个事想询问下您的意见,您觉得应届生值得去外包吗?公司虽然挺大的,中xx,但待遇感觉挺低,马上要报到,挺纠结的。

当HR压你价,说你只值7K,你该怎么回答?

当HR压你价,说你只值7K时,你可以流畅地回答,记住,是流畅,不能犹豫。 礼貌地说:“7K是吗?了解了。嗯~其实我对贵司的面试官印象很好。只不过,现在我的手头上已经有一份11K的offer。来面试,主要也是自己对贵司挺有兴趣的,所以过来看看……”(未完) 这段话主要是陪HR互诈的同时,从公司兴趣,公司职员印象上,都给予对方正面的肯定,既能提升HR的好感度,又能让谈判气氛融洽,为后面的发挥留足空间。...

面试:第十六章:Java中级开发(16k)

HashMap底层实现原理,红黑树,B+树,B树的结构原理 Spring的AOP和IOC是什么?它们常见的使用场景有哪些?Spring事务,事务的属性,传播行为,数据库隔离级别 Spring和SpringMVC,MyBatis以及SpringBoot的注解分别有哪些?SpringMVC的工作原理,SpringBoot框架的优点,MyBatis框架的优点 SpringCould组件有哪些,他们...

面试阿里p7,被按在地上摩擦,鬼知道我经历了什么?

面试阿里p7被问到的问题(当时我只知道第一个):@Conditional是做什么的?@Conditional多个条件是什么逻辑关系?条件判断在什么时候执...

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

【阿里P6面经】二本,curd两年,疯狂复习,拿下阿里offer

二本的读者,在老东家不断学习,最后逆袭

大三实习生,字节跳动面经分享,已拿Offer

说实话,自己的算法,我一个不会,太难了吧

程序员垃圾简历长什么样?

已经连续五年参加大厂校招、社招的技术面试工作,简历看的不下于万份 这篇文章会用实例告诉你,什么是差的程序员简历! 疫情快要结束了,各个公司也都开始春招了,作为即将红遍大江南北的新晋UP主,那当然要为小伙伴们做点事(手动狗头)。 就在公众号里公开征简历,义务帮大家看,并一一点评。《启舰:春招在即,义务帮大家看看简历吧》 一石激起千层浪,三天收到两百多封简历。 花光了两个星期的所有空闲时...

《经典算法案例》01-08:如何使用质数设计扫雷(Minesweeper)游戏

我们都玩过Windows操作系统中的经典游戏扫雷(Minesweeper),如果把质数当作一颗雷,那么,表格中红色的数字哪些是雷(质数)?您能找出多少个呢?文中用列表的方式罗列了10000以内的自然数、质数(素数),6的倍数等,方便大家观察质数的分布规律及特性,以便对算法求解有指导意义。另外,判断质数是初学算法,理解算法重要性的一个非常好的案例。

《Oracle Java SE编程自学与面试指南》最佳学习路线图(2020最新版)

正确选择比瞎努力更重要!

面试官:你连SSO都不懂,就别来面试了

大厂竟然要考我SSO,卧槽。

微软为一人收购一公司?破解索尼程序、写黑客小说,看他彪悍的程序人生!...

作者 | 伍杏玲出品 | CSDN(ID:CSDNnews)格子衬衫、常掉发、双肩包、修电脑、加班多……这些似乎成了大众给程序员的固定标签。近几年流行的“跨界风”开始刷新人们对程序员的...

终于,月薪过5万了!

来看几个问题想不想月薪超过5万?想不想进入公司架构组?想不想成为项目组的负责人?想不想成为spring的高手,超越99%的对手?那么本文内容是你必须要掌握的。本文主要详解bean的生命...

我说我懂多线程,面试官立马给我发了offer

不小心拿了几个offer,有点烦

自从喜欢上了B站这12个UP主,我越来越觉得自己是个废柴了!

不怕告诉你,我自从喜欢上了这12个UP主,哔哩哔哩成为了我手机上最耗电的软件,几乎每天都会看,可是吧,看的越多,我就越觉得自己是个废柴,唉,老天不公啊,不信你看看…… 间接性踌躇满志,持续性混吃等死,都是因为你们……但是,自己的学习力在慢慢变强,这是不容忽视的,推荐给你们! 都说B站是个宝,可是有人不会挖啊,没事,今天咱挖好的送你一箩筐,首先啊,我在B站上最喜欢看这个家伙的视频了,为啥 ,咱撇...

代码注释如此沙雕,会玩还是你们程序员!

某站后端代码被“开源”,同时刷遍全网的,还有代码里的那些神注释。 我们这才知道,原来程序员个个都是段子手;这么多年来,我们也走过了他们的无数套路… 首先,产品经理,是永远永远吐槽不完的!网友的评论也非常扎心,说看这些代码就像在阅读程序员的日记,每一页都写满了对产品经理的恨。 然后,也要发出直击灵魂的质问:你是尊贵的付费大会员吗? 这不禁让人想起之前某音乐app的穷逼Vip,果然,穷逼在哪里都是...

2020春招面试了10多家大厂,我把问烂了的数据库事务知识点总结了一下

2020年截止目前,我面试了阿里巴巴、腾讯、美团、拼多多、京东、快手等互联网大厂。我发现数据库事务在面试中出现的次数非常多。

程序员如何与产品经理优雅的干架

早前,平安产险科技一名外包程序员和一名外包产品经理干架的视频几乎在互联网圈都传遍了,因为产品提了一个需求:要求用户App的主题颜色能根据手机壳自动调整。 首先说这个需求对于应用开发工程师来说,确实是有点奇葩,当然并非不能实现。这块涉及图形图像处理,用机器学习和人工智能来提取图像颜色,这是基本图像识别过程,对于采集图像,可以提示对着镜子自拍一张,上传图片,通过大量的训练数据,来识别手机体颜色。当然并...

爬虫(101)爬点重口味的

小弟最近在学校无聊的很哪,浏览网页突然看到一张图片,都快流鼻血。。。然后小弟冥思苦想,得干一点有趣的事情python 爬虫库安装https://s.taobao.com/api?_ks...

在拼多多上班,是一种什么样的体验?我心态崩了呀!

之前有很多读者咨询我:武哥,在拼多多上班是一种什么样的体验?由于一直很忙,没抽出时间来和大家分享。上周末特地花点时间来写了一篇文章,跟大家分享一下拼多多的日常。 1. 倒时差的作息 可能很多小伙伴都听说了,拼多多加班很严重。这怎么说呢?作息上确实和其他公司有点区别,大家知道 996,那么自然也就能理解拼多多的“11 11 6”了。 所以当很多小伙伴早上出门时,他们是这样的: 我们是这样的: 当...

立即提问
相关内容推荐