ds1320读不到

ds1320读不到,第1张

这种情况一般是由于你的"DS1320 初始化程序"初始化程序不太好.单线总线上的所有 *** 作均从初始化开始.过程如下:主机通过拉低单线至少480uS以上,产生复位脉冲,然后释放该总线.释放总线时,会产生一个上升沿,即命令DQ=1.DS1320检测到该上升沿后,延迟15--60uS,通过拉低总线60--240uS来产生应答脉冲(DS1320自己发出的).主机接收到该信号后,说明有单线器件在线.于是开始执行ROM *** 作-->存储器 *** 作-->数据传输-->结束

暂不讨论LZ的驱动程序对与否,也不说 DS1302 时钟 是否启动(可能暂停中),单单就说最后的读取 *** 作:

1、读出来的 秒 格式:(CH) XXX XXXX,最高位CH 为系统时钟状态,1-停止,0-启动;

2、读出来的 分 格式:0 XXX XXXX,这个你算对了,没啥好说的;

3、读出来的 时 格式:H 0 (AP) X XXXX,最高位H 为小时制度,1-12小时制,0-24小时制;AP 位为 12小时制 下的上下午符号AM/PM,1-PM,0-AM;

综上,LZ 的计算内容,考虑太少。

要求用什么语言?

------------------------------

网友“星心晨梦”的回答,是可以满足题目要求的。

我实验了,是成功的,没有任何错误。

楼主应该检查自己的电路、串口设置等等。

------------------------------

网友“星心晨梦”的回答,篇幅稍稍长了一些。

缩减一半就可以正常工作了,可读性更好一些。

建议看看下面的。

------------------------------

#include <AT89X51.h>

#include <intrins.h>

#define uchar unsigned char

#define uint unsigned int

//---------------------------------------------------

uchar idata trdata1[] = {

'W','E','L','C','O','M','E',' ','T','O',' ','C','H','I','N','A','!',0x0d,0x0a,0x00}

uchar idata trdata2[] = {

'M','Y',' ','N','A','M','E',' ','I','S',' ','L','I','M','I','N','G',0x0d,0x0a,0x00}

uchar idata trdata3[] = {

'Y','I','N','G','Y','O','N','G','K','E','X','U','E','X','U','E','Y','U','A','N',0x0d,0x0a,0x00}

uchar RxBuf[5], Rx_p, Rx_i, TX_p, Tx_i

//---------------------------------------------------

void UART_Init(void) //串口初始化

{

PCON = 0x00

SCON = 0x50//串口工作方式为1,允许接收.

TMOD = 0x20// T1 定时方式2

TH1 = 0xfd //波特率 9600bps @ fosc = 11.0592MHz

TL1 = 0xfd

TR1 = 1//启动T1

ES = 1 //开串口中断.

EA = 1 //开总中断.

}

//---------------------------------------------------

void main()

{

UART_Init()

Rx_p = 0

Rx_p = 2

while(1) {

if (Rx_p != 0) {

TX_p = Rx_p//字符串1 2 3

Tx_i = 0 //字符指针.

Rx_p = 0 //清零.

Rx_i = 0

TI = 1//启动发送中断.

} }

}

//---------------------------------------------------

void Uart_INT(void) interrupt 4 //串口中断函数

{

uchar Tcv = 0

if(RI) { //接收?.

RI = 0 //标志位清零.

RxBuf[Rx_i] = SBUF

if((RxBuf[Rx_i - 1] == 'g') &&(RxBuf[Rx_i] == 'o')) Rx_p = 1

if((RxBuf[Rx_i - 2] == 'w') &&(RxBuf[Rx_i - 1] == 'h') &&(RxBuf[Rx_i] == 'o')) Rx_p = 2

if((RxBuf[Rx_i - 3] == 'h') &&(RxBuf[Rx_i - 2] == 'o') &&(RxBuf[Rx_i - 1] == 'm') &&(RxBuf[Rx_i] == 'e')) Rx_p = 3

P1 = Rx_p //在P1显示收到的信息.

Rx_i++

Rx_i %= 5

}

else {

TI = 0

if (TX_p == 1) Tcv = trdata1[Tx_i] //取来待发字符.

if (TX_p == 2) Tcv = trdata2[Tx_i]

if (TX_p == 3) Tcv = trdata3[Tx_i]

if (Tcv != 0) {SBUF = Tcv Tx_i++} //不是0就发送.

}

}

//---------------------------------------------------


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

原文地址: https://outofmemory.cn/yw/8084527.html

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

发表评论

登录后才能评论

评论列表(0条)

保存