利用iMCU7100EVB实现HTTP服务器(二)

利用iMCU7100EVB实现HTTP服务器(二),第1张

大家好, 我们昨天为大家分享了如何实现W7100A中的UART。今天继续为大家分享第二部分,明天将会继续为大家分享最后一部分。

如何实现W7100A中的UART第一部分请参考:

4.  2, 9位UART,固定波特率

void Init_iMCU(void)

{

SCON = 0x90;       // 串行模式2, SM00 = 1, SM01 = 0, REN=1

PCON &= 0x7F;         // fosc/64(SMOD = 0), fosc/32(SMOD = 1)

}

void PutByte(unsigned char byData)

{

SBUF = byData;    // 向串行缓存器中写入数据

while(!TI);        // 等待所有的数据记录完成

TI = 0;            // 清除传输中断

}

unsigned char GetByte(void)   

{

unsigned char byData;     // 等待数据接收

while(!RI);

RI = 0;                 //清除RI

byData = SBUF;                 //读取数据

return byData;

}

void main()

{

Init_iMCU();                     //调用Init_iMCU函数

while(1)  PutByte(GetByte());    //回送(Echo-back)接收到的数据

}

波特率的UART模式2是固定内部时钟的fosc/32或fosc/64。具体选择fosc/32还是fosc/64要根据SMOD0的位来确定。考虑到W7100A的内部时钟,产生的高速波特率时钟的范围为2.7 ~ 1.4MHz。如同模式0的情况,一般不使用模式3,因为波特率是固定的且时钟频率过快。

在这些示例程序中,将SCON寄存器设定为0x90。为了设置波特率,还要设置SMOD0,

PCON寄存器的最高位(波特率 = fosc/32)。其它实现输出信息的代码也和第2章中介绍的接收过程的程序类似。

5.  3, 9位UART,可变波特率

5.1 定时器1(TImer 1)时钟源

void Init_iMCU(void)

{

SCON = 0xD0;             // 串行模式3, SM00 = 1, SM01 =1, REN=1

TMOD |= 0x20;         // 定时器1(TImer1)模式2

PCON |= 0x80;         // SMOD0 = 1

TL1 = 0xFC;           // 波特率115200bps

TH1 = 0xFC;           //请参考W7100A数据手册

TR1 = 1;               // 启动定时器1(Timer1)

}

void PutByte(unsigned char byData)

{

SBUF = byData;    // 向串行缓存器中写入数据

while(!TI);        // 等待数据记录完成

TI = 0;            // 清除传输中断

}

unsigned char GetByte(void)   

{

unsigned char byData;     //等待数据接收

while(!RI);

RI = 0;                 //清除RI

byData = SBUF;         // 读取数据

return byData;

}

void main()

{

Init_iMCU();                     //调用Init_iMCU函数

while(1)  PutByte(GetByte());    //回送(Echo-back)接收到的数据

}

UART在模式3下,可以交换使用定时器1(Timer1)和定时器2(Timer2)来设定波特率的值。在这一章节,我们使用定时器1(Timer1)来设置波特率的值,信息请参考W7100A数据手册。与模式1不同的是,停止位之前多了1位。这一增加位可以用作奇偶校验或者多重处理器通信,详情请参考W7100A数据手册。

在示例程序中,将SCON寄存器设置为0xD0,定时器1(Timer1)工作在模式2下。为了能设置波特率,需要设置PCON寄存器的SMOD位,同时TH1寄存器的值设为0xFC。这样设置完成后,波特率的值为115200bps。其它实现输出信息的代码也和第2章中介绍的接收过程的程序类似。

5.2 定时器2(timer 2)时钟源

void Init_iMCU(void)

{

SCON = 0xD0;           //串行模式3, SM00 = 1, SM01 =1, REN=1

T2CON = 0x30;         //定时器2(Timer2)波特率发生器模式

TH2 = 0xFF;            //波特率设定为115200bps

TL2 = 0xE8;            // 请参考W7100A数据手册

RLDH = 0xFF;          // 波特率重载值设为115200bps

RLDL = 0xE8;           // 波特率重载值设为115200bps

TR2 = 1;               // 启动定时器2(Timer2)

}

void PutByte(unsigned char byData)

{

SBUF = byData;    // 向串行缓存器中写入数据

while(!TI);        // 等待数据记录完成

TI = 0;            // 清除传输中断

}

unsigned char GetByte(void)   

{

unsigned char byData;     //等待数据接收

while(!RI);

RI = 0;                     //清除RI

byData = SBUF;          //读取数据

return byData;

}

void main()

{

Init_iMCU();                     //调用Init_iMCU函数

while(1)  PutByte(GetByte());    //回送(Echo-back)接收到的数据

}

UART在模式3可以交换使用定时器1(Timer1)和定时器2(Timer2)来设置波特率。在这一章节,利用定时器2(Timer2)来设置波特率。更多的详细信息请参考W7100A数据手册。与模式1不同的是,在停止位之前多了1位,此位可以用于奇偶校验或者多重处理器通信。具体的细节可以参考W7100A数据手册。

在上面的程序中,将SCON寄存器设为0xD0,定时器2(Timer2)设定为波特率发生器模式。为了能够设定波特率,还需要将TH2和TL2的值分别设为0xFF和0xE8。都设置完成后,波特率的值就变成115200bps。重载值RLDH和RLDL也必须相应的设置为0xFF和0xE8。其它实现输出信息的代码也和第2章中介绍的接收过程的程序类似。

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

原文地址: http://outofmemory.cn/dianzi/2640717.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-08-12
下一篇 2022-08-12

发表评论

登录后才能评论

评论列表(0条)

保存