2014-05-20 14:05:50 -07:00
# ifndef __SAMSUNG_H
# define __SAMSUNG_H
2011-03-30 05:30:41 -04:00
/*
2008-07-03 12:32:51 +01:00
* Driver for Samsung SoC onboard UARTs .
*
2009-11-13 22:54:14 +00:00
* Ben Dooks , Copyright ( c ) 2003 - 2008 Simtec Electronics
2008-07-03 12:32:51 +01:00
* http : //armlinux.simtec.co.uk/
*
* 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 .
*/
2014-12-10 12:49:22 +01:00
# include <linux/dmaengine.h>
2008-07-03 12:32:51 +01:00
struct s3c24xx_uart_info {
char * name ;
unsigned int type ;
unsigned int fifosize ;
unsigned long rx_fifomask ;
unsigned long rx_fifoshift ;
unsigned long rx_fifofull ;
unsigned long tx_fifomask ;
unsigned long tx_fifoshift ;
unsigned long tx_fifofull ;
2011-10-24 11:47:46 +02:00
unsigned int def_clk_sel ;
unsigned long num_clks ;
unsigned long clksel_mask ;
unsigned long clksel_shift ;
2008-07-03 12:32:51 +01:00
2008-12-12 00:24:21 +00:00
/* uart port features */
unsigned int has_divslot : 1 ;
2008-07-03 12:32:51 +01:00
/* uart controls */
int ( * reset_port ) ( struct uart_port * , struct s3c2410_uartcfg * ) ;
} ;
2011-11-02 19:23:25 +09:00
struct s3c24xx_serial_drv_data {
struct s3c24xx_uart_info * info ;
struct s3c2410_uartcfg * def_cfg ;
unsigned int fifosize [ CONFIG_SERIAL_SAMSUNG_UARTS ] ;
} ;
2014-12-10 12:49:22 +01:00
struct s3c24xx_uart_dma {
unsigned int rx_chan_id ;
unsigned int tx_chan_id ;
struct dma_slave_config rx_conf ;
struct dma_slave_config tx_conf ;
struct dma_chan * rx_chan ;
struct dma_chan * tx_chan ;
dma_addr_t rx_addr ;
dma_addr_t tx_addr ;
dma_cookie_t rx_cookie ;
dma_cookie_t tx_cookie ;
char * rx_buf ;
dma_addr_t tx_transfer_addr ;
size_t rx_size ;
size_t tx_size ;
struct dma_async_tx_descriptor * tx_desc ;
struct dma_async_tx_descriptor * rx_desc ;
int tx_bytes_requested ;
int rx_bytes_requested ;
} ;
2008-07-03 12:32:51 +01:00
struct s3c24xx_uart_port {
unsigned char rx_claimed ;
unsigned char tx_claimed ;
2008-10-21 14:06:36 +01:00
unsigned int pm_level ;
unsigned long baudclk_rate ;
2015-07-31 10:58:27 +02:00
unsigned int min_dma_size ;
2008-07-03 12:32:51 +01:00
2008-10-21 14:07:04 +01:00
unsigned int rx_irq ;
unsigned int tx_irq ;
2014-12-10 12:49:26 +01:00
unsigned int tx_in_progress ;
unsigned int tx_mode ;
2014-12-10 12:49:27 +01:00
unsigned int rx_mode ;
2014-12-10 12:49:26 +01:00
2008-07-03 12:32:51 +01:00
struct s3c24xx_uart_info * info ;
struct clk * clk ;
struct clk * baudclk ;
struct uart_port port ;
2011-11-02 19:23:25 +09:00
struct s3c24xx_serial_drv_data * drv_data ;
2008-10-21 14:06:36 +01:00
2011-10-24 11:47:25 +02:00
/* reference to platform data */
struct s3c2410_uartcfg * cfg ;
2014-12-10 12:49:22 +01:00
struct s3c24xx_uart_dma * dma ;
2016-06-27 13:59:08 +02:00
# ifdef CONFIG_ARM_S3C24XX_CPUFREQ
2008-10-21 14:06:36 +01:00
struct notifier_block freq_transition ;
# endif
2008-07-03 12:32:51 +01:00
} ;
/* conversion functions */
2013-09-09 14:10:30 +09:00
# define s3c24xx_dev_to_port(__dev) dev_get_drvdata(__dev)
2008-07-03 12:32:51 +01:00
/* register access controls */
# define portaddr(port, reg) ((port)->membase + (reg))
2013-08-08 17:29:48 +09:00
# define portaddrl(port, reg) \
( ( unsigned long * ) ( unsigned long ) ( ( port ) - > membase + ( reg ) ) )
2008-07-03 12:32:51 +01:00
2016-06-22 17:57:02 +01:00
# define rd_regb(port, reg) (readb_relaxed(portaddr(port, reg)))
# define rd_regl(port, reg) (readl_relaxed(portaddr(port, reg)))
2008-07-03 12:32:51 +01:00
2016-06-22 17:57:02 +01:00
# define wr_regb(port, reg, val) writeb_relaxed(val, portaddr(port, reg))
# define wr_regl(port, reg, val) writel_relaxed(val, portaddr(port, reg))
2008-07-03 12:32:51 +01:00
2016-06-22 17:57:03 +01:00
/* Byte-order aware bit setting/clearing functions. */
static inline void s3c24xx_set_bit ( struct uart_port * port , int idx ,
unsigned int reg )
{
unsigned long flags ;
u32 val ;
local_irq_save ( flags ) ;
val = rd_regl ( port , reg ) ;
val | = ( 1 < < idx ) ;
wr_regl ( port , reg , val ) ;
local_irq_restore ( flags ) ;
}
static inline void s3c24xx_clear_bit ( struct uart_port * port , int idx ,
unsigned int reg )
{
unsigned long flags ;
u32 val ;
local_irq_save ( flags ) ;
val = rd_regl ( port , reg ) ;
val & = ~ ( 1 < < idx ) ;
wr_regl ( port , reg , val ) ;
local_irq_restore ( flags ) ;
}
2008-07-03 12:32:51 +01:00
# endif