2011-03-30 13:30:41 +04:00
/*
2008-07-03 15:32:51 +04:00
* Driver for Samsung S3C2410 SoC onboard UARTs .
2005-04-17 02:20:36 +04:00
*
2009-11-14 01:54:14 +03:00
* Ben Dooks , Copyright ( c ) 2003 - 2008 Simtec Electronics
2008-05-22 19:36:45 +04:00
* http : //armlinux.simtec.co.uk/
2008-05-23 14:48:00 +04:00
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation .
2005-04-17 02:20:36 +04:00
*/
2008-07-03 15:32:51 +04:00
# include <linux/module.h>
# include <linux/ioport.h>
# include <linux/io.h>
# include <linux/platform_device.h>
# include <linux/init.h>
# include <linux/serial_core.h>
# include <linux/serial.h>
2005-04-17 02:20:36 +04:00
2008-07-03 15:32:51 +04:00
# include <asm/irq.h>
2008-08-05 19:14:15 +04:00
# include <mach/hardware.h>
2005-04-17 02:20:36 +04:00
2008-10-08 01:26:09 +04:00
# include <plat/regs-serial.h>
2008-08-05 19:14:15 +04:00
# include <mach/regs-gpio.h>
2005-04-17 02:20:36 +04:00
2008-07-03 15:32:51 +04:00
# include "samsung.h"
2005-04-17 02:20:36 +04:00
static int s3c2410_serial_setsource ( struct uart_port * port ,
struct s3c24xx_uart_clksrc * clk )
{
unsigned long ucon = rd_regl ( port , S3C2410_UCON ) ;
if ( strcmp ( clk - > name , " uclk " ) = = 0 )
ucon | = S3C2410_UCON_UCLK ;
else
ucon & = ~ S3C2410_UCON_UCLK ;
wr_regl ( port , S3C2410_UCON , ucon ) ;
return 0 ;
}
static int s3c2410_serial_getsource ( struct uart_port * port ,
struct s3c24xx_uart_clksrc * clk )
{
unsigned long ucon = rd_regl ( port , S3C2410_UCON ) ;
clk - > divisor = 1 ;
clk - > name = ( ucon & S3C2410_UCON_UCLK ) ? " uclk " : " pclk " ;
return 0 ;
}
static int s3c2410_serial_resetport ( struct uart_port * port ,
struct s3c2410_uartcfg * cfg )
{
dbg ( " s3c2410_serial_resetport: port=%p (%08lx), cfg=%p \n " ,
port , port - > mapbase , cfg ) ;
wr_regl ( port , S3C2410_UCON , cfg - > ucon ) ;
wr_regl ( port , S3C2410_ULCON , cfg - > ulcon ) ;
/* reset both fifos */
wr_regl ( port , S3C2410_UFCON , cfg - > ufcon | S3C2410_UFCON_RESETBOTH ) ;
wr_regl ( port , S3C2410_UFCON , cfg - > ufcon ) ;
return 0 ;
}
static struct s3c24xx_uart_info s3c2410_uart_inf = {
. name = " Samsung S3C2410 UART " ,
. type = PORT_S3C2410 ,
. fifosize = 16 ,
. rx_fifomask = S3C2410_UFSTAT_RXMASK ,
. rx_fifoshift = S3C2410_UFSTAT_RXSHIFT ,
. rx_fifofull = S3C2410_UFSTAT_RXFULL ,
. tx_fifofull = S3C2410_UFSTAT_TXFULL ,
. tx_fifomask = S3C2410_UFSTAT_TXMASK ,
. tx_fifoshift = S3C2410_UFSTAT_TXSHIFT ,
. get_clksrc = s3c2410_serial_getsource ,
. set_clksrc = s3c2410_serial_setsource ,
. reset_port = s3c2410_serial_resetport ,
} ;
2005-11-10 01:32:44 +03:00
static int s3c2410_serial_probe ( struct platform_device * dev )
2005-04-17 02:20:36 +04:00
{
return s3c24xx_serial_probe ( dev , & s3c2410_uart_inf ) ;
}
2009-07-09 12:28:33 +04:00
static struct platform_driver s3c2410_serial_driver = {
2005-04-17 02:20:36 +04:00
. probe = s3c2410_serial_probe ,
2009-06-22 21:42:49 +04:00
. remove = __devexit_p ( s3c24xx_serial_remove ) ,
2005-11-10 01:32:44 +03:00
. driver = {
. name = " s3c2410-uart " ,
. owner = THIS_MODULE ,
} ,
2005-04-17 02:20:36 +04:00
} ;
2008-07-03 15:32:51 +04:00
static int __init s3c2410_serial_init ( void )
2005-04-17 02:20:36 +04:00
{
2009-07-09 12:28:33 +04:00
return s3c24xx_serial_init ( & s3c2410_serial_driver , & s3c2410_uart_inf ) ;
2005-04-17 02:20:36 +04:00
}
2008-07-03 15:32:51 +04:00
static void __exit s3c2410_serial_exit ( void )
2005-04-17 02:20:36 +04:00
{
2009-07-09 12:28:33 +04:00
platform_driver_unregister ( & s3c2410_serial_driver ) ;
2005-04-17 02:20:36 +04:00
}
2008-07-03 15:32:51 +04:00
module_init ( s3c2410_serial_init ) ;
module_exit ( s3c2410_serial_exit ) ;
2005-04-17 02:20:36 +04:00
2008-05-23 14:48:00 +04:00
MODULE_LICENSE ( " GPL v2 " ) ;
2005-04-17 02:20:36 +04:00
MODULE_AUTHOR ( " Ben Dooks <ben@simtec.co.uk> " ) ;
2008-07-03 15:32:51 +04:00
MODULE_DESCRIPTION ( " Samsung S3C2410 SoC Serial port driver " ) ;
2008-04-16 01:34:35 +04:00
MODULE_ALIAS ( " platform:s3c2410-uart " ) ;