⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 serial.c

📁 UBOOT 源码
💻 C
字号:
/* * U-boot - serial.c Serial driver for BF533 * * Copyright (c) 2005 blackfin.uclinux.org * * This file is based on * bf533_serial.c: Serial driver for BlackFin BF533 DSP internal UART. * Copyright (c) 2003	Bas Vermeulen <bas@buyways.nl>, * 			BuyWays B.V. (www.buyways.nl) * * Based heavily on blkfinserial.c * blkfinserial.c: Serial driver for BlackFin DSP internal USRTs. * Copyright(c) 2003	Metrowerks	<mwaddel@metrowerks.com> * Copyright(c)	2001	Tony Z. Kou	<tonyko@arcturusnetworks.com> * Copyright(c)	2001-2002 Arcturus Networks Inc. <www.arcturusnetworks.com> * * Based on code from 68328 version serial driver imlpementation which was: * Copyright (C) 1995       David S. Miller    <davem@caip.rutgers.edu> * Copyright (C) 1998       Kenneth Albanowski <kjahds@kjahds.com> * Copyright (C) 1998, 1999 D. Jeff Dionne     <jeff@uclinux.org> * Copyright (C) 1999       Vladimir Gurevich  <vgurevic@cisco.com> * * (C) Copyright 2000-2004 * Wolfgang Denk, DENX Software Engineering, wd@denx.de. * * See file CREDITS for list of people who contributed to this * project. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License as * published by the Free Software Foundation; either version 2 of * the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * MA 02111-1307 USA */#include <common.h>#include <asm/irq.h>#include <asm/system.h>#include <asm/segment.h>#include <asm/bitops.h>#include <asm/delay.h>#include <asm/uaccess.h>#include "bf533_serial.h"DECLARE_GLOBAL_DATA_PTR;unsigned long pll_div_fact;void calc_baud(void){	unsigned char i;	int	temp;	for(i = 0; i < sizeof(baud_table)/sizeof(int); i++) {		temp =  CONFIG_SCLK_HZ/(baud_table[i]*8);		if ( temp && 0x1 == 1 ) {			temp++;		}		temp = temp/2;		hw_baud_table[i].dl_high = (temp >> 8)& 0xFF;		hw_baud_table[i].dl_low = (temp) & 0xFF;	}}void serial_setbrg(void){	int i;	calc_baud();	for (i = 0; i < sizeof(baud_table) / sizeof(int); i++) {		if (gd->baudrate == baud_table[i])			break;	}	/* Enable UART */	*pUART_GCTL |= UART_GCTL_UCEN;	asm("ssync;");	/* Set DLAB in LCR to Access DLL and DLH */	ACCESS_LATCH;	asm("ssync;");	*pUART_DLL = hw_baud_table[i].dl_low;	asm("ssync;");	*pUART_DLH = hw_baud_table[i].dl_high;	asm("ssync;");	/* Clear DLAB in LCR to Access THR RBR IER */	ACCESS_PORT_IER;	asm("ssync;");	/* Enable  ERBFI and ELSI interrupts	* to poll SIC_ISR register*/	*pUART_IER = UART_IER_ELSI | UART_IER_ERBFI | UART_IER_ETBEI;	asm("ssync;");	/* Set LCR to Word Lengh 8-bit word select */	*pUART_LCR = UART_LCR_WLS8;	asm("ssync;");	return;}int serial_init(void){	serial_setbrg();	return (0);}void serial_putc(const char c){	if ((*pUART_LSR) & UART_LSR_TEMT)	{		if (c == '\n')			serial_putc('\r');		local_put_char(c);	}	while (!((*pUART_LSR) & UART_LSR_TEMT))		SYNC_ALL;	return;}int serial_tstc(void){	if (*pUART_LSR & UART_LSR_DR)		return 1;	else		return 0;}int serial_getc(void){	unsigned short uart_lsr_val, uart_rbr_val;	unsigned long isr_val;	int ret;	/* Poll for RX Interrupt */	while (!((isr_val = *(volatile unsigned long *)SIC_ISR) & IRQ_UART_RX_BIT));	asm("csync;");	uart_lsr_val = *pUART_LSR;	/* Clear status bit */	uart_rbr_val = *pUART_RBR;	/* getc() */	if (isr_val & IRQ_UART_ERROR_BIT) {		ret =  -1;	}	else	{		ret = uart_rbr_val & 0xff;	}	return ret;}void serial_puts(const char *s){	while (*s) {		serial_putc(*s++);	}}static void local_put_char(char ch){	int flags = 0;	unsigned long isr_val;	save_and_cli(flags);	/* Poll for TX Interruput */	while (!((isr_val = *pSIC_ISR) & IRQ_UART_TX_BIT));	asm("csync;");	*pUART_THR = ch;			/* putc() */	if (isr_val & IRQ_UART_ERROR_BIT) {		printf("?");	}	restore_flags(flags);	return ;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -