1.S3C2440串口概述
串口通讯一般要增加电平转换电路,原因是TTL/CMOS电平与RS232电平不一致:
TTL/CMOS电平:
CMOS电平:
常用的电平转换芯片是MAX3232。
S3C2440有3个独立的异步串口,可以选择工作在中断或DMA方式下。每个UART包括一个波特率发生器、发送器、接收器和一个控制单元。
UART有FIFO模式和非FIFO模式。FIFO模式下可以利用64字节的发送/接收缓冲寄存器,非FIFO模式下只使用了发送/接收缓冲寄存器中的1个字节。本篇入门级以非FIFO为例。
2.串口设置及相关寄存器
串口引脚是GPIO复用的。本篇UART只用3根引脚:TXD、RXD、GND。
TXD0 – GPH2 , RXD0 – GPH3
需要初始化以下6个寄存器:
ULCONn (UART LINE CONTROLREGISTER) – 设置数据位信息
UCONn(UART CONTROL REGISTER) – 设置发送和接收模式,及时钟源。
UBRDIVn– 设置UART波特率
波特率计算公式:
例子:
UTRSTATn(UARTTX/RX REGISTER) – 状态位
使用while(!UTRSTAT0&(1<<2)); 等待发送完成(while(!UTRSTAT0&(1<<1)); 也可以)
使用while(!UTRSTAT0&(1<<0)); 等待接收数据。
UTXHn(HOLDINGREGISTER) – 发送缓冲寄存器(Transmit)
URXHn(HOLDINGREGISTER) – 接收缓冲寄存器(Receive)
3.串口UART0应用
串口UART0接收到数据后再将其发出去。波特率为115200。
uart.h
#ifndef __UART_H__
#define __UART_H__
extern void Uart0_Init(unsigned int baudrate);
extern void putc(unsigned char c);
extern unsigned char getc(void);
#endif
uart.c
#include "2440addr.h"
#define PCLK 50000000
void Uart0_Init(unsigned int baudrate)
{
rGPHCON &= ~((3<<4)|(3<<6));
rGPHCON |= (2<<4)|(2<<6); //GPH2-TXD, GPH3-RXD
rGPHUP &= ~((1<<2)|(1<<3)); //GPH2,GPH3 enable pull-up
rULCON0 = 0x03; //8-bits 1-stop bit
rUCON0 = 0x05;
rUBRDIV0 = (int)(PCLK/baudrate/16)-1;
rURXH0 = 0;
}
void putc(unsigned char c)
{
rUTXH0 = c;
// while(!(rUTRSTAT0 & (1<<2)));
while(!(rUTRSTAT0 & (1<<1))); //ok
}
unsigned char getc(void)
{
while(!(rUTRSTAT0 & (1<<0)));
return rURXH0;
}
Main.c
#include "common.h"
#include "uart.h"
int Main()
{
unsigned char a;
Uart0_Init(115200);
while(1)
{
a=getc();
putc(a);
}
return 0;
}
上一篇:S3C2440芯片时钟(2)
下一篇:s3c2440A开发板UART总结以及UART代码详解
推荐阅读最新更新时间:2024-11-09 15:48
设计资源 培训 开发板 精华推荐
- ADP2119 1.2V、2A降压稳压器的典型应用,强制连续导通模式
- CW_TAP: CodeWarrior® TAP
- LT1021CIN8-10 精密 DAC 电压基准的典型应用
- AM6TW-2418SH35Z 18V 6 瓦单路输出 DC/DC 转换器的典型应用
- 具有延迟启动的 TS2596SCS50 RL 2A、5V、150KHz 降压 DC-DC 转换器的反相 -5V 稳压器的典型应用
- 用于 PLC/DCS 应用的通道间隔离温度输入(热电偶/RTD)
- 16 位、40KSPS、1CH 用于工业控制
- MIC4576WT、3A降压稳压器的典型应用电路
- AT91SAM9G15-EK,基于 AT91SAM9G15 SAM9G15 MCU ARM9 系列的评估套件
- 使用 Analog Devices 的 LT3467AES67 的参考设计