S3C6410裸機UART驅(qū)動(將printf重定義到串口)
要確保S3C6410已經(jīng)初始化,一般是使用UBOOT初始化
?
//串口寄存器
//UART0
#defineULCON0????????????????*((vu32*)0x7F005000)????????????????//UART通道0 行控制寄存器
#defineUCON0????????????????*((vu32*)0x7F005004)????????????????//UART通道0 控制寄存器
#defineUFCON0????????????????*((vu32*)0x7F005008)????????????????//UART通道0 FIFO 控制寄存器
#defineUMCON0????????????????*((vu32*)0x7F00500C)????????????????//UART通道0 調(diào)制解調(diào)器(Modem)控制寄存器
#defineUTRSTAT0????????*((vu32*)0x7F005010)????????????????//UART通道0 發(fā)送/接收狀態(tài)寄存器
#defineUERSTAT0????????*((vu32*)0x7F005014)????????????????//UART通道0 接收錯誤狀態(tài)寄存器
#defineUFSTAT0????????????????*((vu32*)0x7F005018)????????????????//UART通道0 FIFO 狀態(tài)寄存器
#defineUMSTAT0????????????????*((vu32*)0x7F00501C)????????????????//UART通道0 調(diào)制解調(diào)器(Modem)狀態(tài)寄存器
#defineUTXH0????????????????*((vu32*)0x7F005020)????????????????//UART通道0 發(fā)送緩沖寄存器
#defineURXH0????????????????*((vu32*)0x7F005024)????????????????//UART通道0 接收緩沖寄存器
#defineUBRDIV0????????????????*((vu32*)0x7F005028)????????????????//通道0波特率分頻寄存器
#defineUDIVSLOT0????????*((vu32*)0x7F00502C)????????????????//UART通道0 分頻插槽寄存器
#defineUINTP0????????????????*((vu32*)0x7F005030)????????????????//通道0中斷處理寄存器
#defineUINTSP0????????????????*((vu32*)0x7F005034)????????????????//UART通道0 中斷源處理寄存器
#defineUINTM0????????????????*((vu32*)0x7F005038)????????????????//UART通道0 中斷屏蔽寄存器
?
?
?
?
?
//作者:陳
//創(chuàng)建時間:20120220
//最后修改時間:20120220
//說明:S3C6410串口相關(guān)
?
#include"system.h"
#include"uart.h"
#include"s3c6410_map.h"
?
?
?
?
//////////////////////////////////////////////////////////////////
//加入以下代碼,支持printf函數(shù),
#if 1
?
#include"stdio.h"????????
//標(biāo)準(zhǔn)庫需要的支持函數(shù)????????????????
struct __FILE
{
inthandle;
};
/* FILE is typedef’d in stdio.h. */
FILE __stdout;??????
//定義_sys_exit()以避免使用半主機模式???
_sys_exit(int x)
{
x= x;
}
//重定義fputc函數(shù)
int fputc(int ch,FILE *f)
{?????
Uart0_SendByte((u8)ch);?????
returnch;
}
#endif
?
?
?
static const u16UART_SPEED[13][2] ={{1717,0x4924},{858,0x4924},{428,0x4924},{285,0x4924},{213,0x4924},{142,0x4924},{106,0x4924},{72,0x4924},{70,0x4924},{34,0x4924},{16,0x4924},{7,0x4924},{3,0x4924}};
?
?
?
?
/*************************************************************************************************************************
*函數(shù)????????:????????voidUart0_Init(void)
*功能????????:????????串口0初始化
*參數(shù)????????:????????無
*返回????????:????????無
*依賴????????:????????底層宏定義
*作者????????:????????陳
*時間????????:????????20120220
* 最后修改時間 : 20120220
*說明????????:????????初始化串口0
*************************************************************************************************************************/
void Uart0_Init(u8UART_Speed)
{
PCLK_GATE|= 1 << 1;//UART0選通PCLK時鐘,66mhz
GPIOA->CON&=~(0xff);????????//清除之前的設(shè)置,GPIOA0,GPIOA1
GPIOA->CON|= (HOST | (HOST <<4));????????//設(shè)置GPIOA0,GPIOA1為uart模式
ULCON0=0x3;????????//每幀8位????????//清除設(shè)置//普通模式,無校驗,1個停止位
UCON0= (0x1 << 2) | 0x1 | (2 <<10);????????????????//清除控制寄存器//設(shè)置(PCLK=66MHz)為波特率時鐘
UFCON0=0;????????????????//禁止FIFO
UMCON0=0;????????????????//禁止AFC,nRTS高電平無效
UBRDIV0????????=UART_SPEED[UART_Speed][0];//設(shè)置波特率整數(shù)部分
UDIVSLOT0= UART_SPEED[UART_Speed][1];//設(shè)置波特率小數(shù)部分
UINTP0= 0;????????//關(guān)閉UART0中斷
UINTSP0= 0;//設(shè)置中斷源
UINTM0= 0;????????//關(guān)閉中斷屏蔽
?
}
?
/*************************************************************************************************************************
*函數(shù)????????:????????voidUart0_SendByte(u8 data)
*功能????????:????????串口0發(fā)送一個字節(jié)
*參數(shù)????????:????????發(fā)送的數(shù)據(jù)
*返回????????:????????無
*依賴????????:????????底層宏定義
*作者????????:????????陳
*時間????????:????????20120220
* 最后修改時間 : 20120220
*說明????????:????????使用串口0發(fā)送一個字節(jié)
*************************************************************************************************************************/
voidUart0_SendByte(u8 data)
{
while(!(UTRSTAT0& (1 <<2)));????????//等待發(fā)送緩沖器為空
UTXH0= data;????????//將數(shù)據(jù)寫入發(fā)送緩沖器
}
現(xiàn)在可以直接使用printf將數(shù)據(jù)發(fā)送到串口了.