2012-09-28 10:44:25 +04:00
/*
2014-05-28 11:44:46 +04:00
* Driver for the Renesas RCar I2C unit
2012-09-28 10:44:25 +04:00
*
2014-05-28 11:44:46 +04:00
* Copyright ( C ) 2014 Wolfram Sang < wsa @ sang - engineering . com >
*
* Copyright ( C ) 2012 - 14 Renesas Solutions Corp .
2012-09-28 10:44:25 +04:00
* Kuninori Morimoto < kuninori . morimoto . gx @ renesas . com >
*
* This file is based on the drivers / i2c / busses / i2c - sh7760 . c
* ( c ) 2005 - 2008 MSC Vertriebsges . m . b . H , Manuel Lauss < mlau @ msc - ge . com >
*
* This file used out - of - tree driver i2c - rcar . c
* Copyright ( C ) 2011 - 2012 Renesas Electronics Corporation
*
* 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
2014-05-28 11:44:46 +04:00
* the Free Software Foundation ; version 2 of the License .
2012-09-28 10:44:25 +04:00
*
* 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 .
*/
# include <linux/clk.h>
# include <linux/delay.h>
# include <linux/err.h>
# include <linux/interrupt.h>
# include <linux/io.h>
# include <linux/i2c.h>
# include <linux/kernel.h>
# include <linux/module.h>
2013-09-12 16:36:46 +04:00
# include <linux/of_device.h>
2012-09-28 10:44:25 +04:00
# include <linux/platform_device.h>
# include <linux/pm_runtime.h>
# include <linux/slab.h>
/* register offsets */
# define ICSCR 0x00 /* slave ctrl */
# define ICMCR 0x04 /* master ctrl */
# define ICSSR 0x08 /* slave status */
# define ICMSR 0x0C /* master status */
# define ICSIER 0x10 /* slave irq enable */
# define ICMIER 0x14 /* master irq enable */
# define ICCCR 0x18 /* clock dividers */
# define ICSAR 0x1C /* slave address */
# define ICMAR 0x20 /* master address */
# define ICRXTX 0x24 /* data port */
2014-11-18 19:04:55 +03:00
/* ICSCR */
# define SDBS (1 << 3) /* slave data buffer select */
# define SIE (1 << 2) /* slave interface enable */
# define GCAE (1 << 1) /* general call address enable */
# define FNA (1 << 0) /* forced non acknowledgment */
2012-09-28 10:44:25 +04:00
/* ICMCR */
# define MDBS (1 << 7) /* non-fifo mode switch */
# define FSCL (1 << 6) /* override SCL pin */
# define FSDA (1 << 5) /* override SDA pin */
# define OBPC (1 << 4) /* override pins */
# define MIE (1 << 3) /* master if enable */
# define TSBE (1 << 2)
# define FSB (1 << 1) /* force stop bit */
# define ESG (1 << 0) /* en startbit gen */
2014-11-18 19:04:55 +03:00
/* ICSSR (also for ICSIER) */
# define GCAR (1 << 6) /* general call received */
# define STM (1 << 5) /* slave transmit mode */
# define SSR (1 << 4) /* stop received */
# define SDE (1 << 3) /* slave data empty */
# define SDT (1 << 2) /* slave data transmitted */
# define SDR (1 << 1) /* slave data received */
# define SAR (1 << 0) /* slave addr received */
2014-05-28 11:44:44 +04:00
/* ICMSR (also for ICMIE) */
2012-09-28 10:44:25 +04:00
# define MNR (1 << 6) /* nack received */
# define MAL (1 << 5) /* arbitration lost */
# define MST (1 << 4) /* sent a stop */
# define MDE (1 << 3)
# define MDT (1 << 2)
# define MDR (1 << 1)
# define MAT (1 << 0) /* slave addr xfer done */
2014-05-28 11:44:38 +04:00
# define RCAR_BUS_PHASE_START (MDBS | MIE | ESG)
# define RCAR_BUS_PHASE_DATA (MDBS | MIE)
# define RCAR_BUS_PHASE_STOP (MDBS | MIE | FSB)
2012-09-28 10:44:25 +04:00
2014-05-28 11:44:44 +04:00
# define RCAR_IRQ_SEND (MNR | MAL | MST | MAT | MDE)
# define RCAR_IRQ_RECV (MNR | MAL | MST | MAT | MDR)
# define RCAR_IRQ_STOP (MST)
2012-09-28 10:44:25 +04:00
2014-09-06 03:34:32 +04:00
# define RCAR_IRQ_ACK_SEND (~(MAT | MDE) & 0xFF)
# define RCAR_IRQ_ACK_RECV (~(MAT | MDR) & 0xFF)
2014-05-28 11:44:42 +04:00
2012-09-28 10:44:25 +04:00
# define ID_LAST_MSG (1 << 0)
# define ID_DONE (1 << 2)
# define ID_ARBLOST (1 << 3)
# define ID_NACK (1 << 4)
2013-09-03 04:09:25 +04:00
enum rcar_i2c_type {
2013-10-21 12:04:32 +04:00
I2C_RCAR_GEN1 ,
I2C_RCAR_GEN2 ,
2015-08-05 16:18:25 +03:00
I2C_RCAR_GEN3 ,
2013-09-03 04:09:25 +04:00
} ;
2012-09-28 10:44:25 +04:00
struct rcar_i2c_priv {
void __iomem * io ;
struct i2c_adapter adap ;
2015-11-19 18:56:45 +03:00
struct i2c_msg * msg ;
int msgs_left ;
2014-01-26 20:05:35 +04:00
struct clk * clk ;
2012-09-28 10:44:25 +04:00
wait_queue_head_t wait ;
int pos ;
u32 icccr ;
u32 flags ;
2014-05-28 11:44:45 +04:00
enum rcar_i2c_type devtype ;
2014-11-18 19:04:55 +03:00
struct i2c_client * slave ;
2012-09-28 10:44:25 +04:00
} ;
# define rcar_i2c_priv_to_dev(p) ((p)->adap.dev.parent)
# define rcar_i2c_is_recv(p) ((p)->msg->flags & I2C_M_RD)
# define rcar_i2c_flags_set(p, f) ((p)->flags |= (f))
# define rcar_i2c_flags_has(p, f) ((p)->flags & (f))
# define LOOP_TIMEOUT 1024
2014-05-28 11:44:45 +04:00
2012-09-28 10:44:25 +04:00
static void rcar_i2c_write ( struct rcar_i2c_priv * priv , int reg , u32 val )
{
writel ( val , priv - > io + reg ) ;
}
static u32 rcar_i2c_read ( struct rcar_i2c_priv * priv , int reg )
{
return readl ( priv - > io + reg ) ;
}
static void rcar_i2c_init ( struct rcar_i2c_priv * priv )
{
/* reset master mode */
rcar_i2c_write ( priv , ICMIER , 0 ) ;
2015-11-19 18:56:42 +03:00
rcar_i2c_write ( priv , ICMCR , MDBS ) ;
2012-09-28 10:44:25 +04:00
rcar_i2c_write ( priv , ICMSR , 0 ) ;
2015-11-19 18:56:42 +03:00
/* start clock */
rcar_i2c_write ( priv , ICCCR , priv - > icccr ) ;
2012-09-28 10:44:25 +04:00
}
static int rcar_i2c_bus_barrier ( struct rcar_i2c_priv * priv )
{
int i ;
for ( i = 0 ; i < LOOP_TIMEOUT ; i + + ) {
/* make sure that bus is not busy */
if ( ! ( rcar_i2c_read ( priv , ICMCR ) & FSDA ) )
return 0 ;
udelay ( 1 ) ;
}
return - EBUSY ;
}
static int rcar_i2c_clock_calculate ( struct rcar_i2c_priv * priv ,
u32 bus_speed ,
struct device * dev )
{
u32 scgd , cdf ;
u32 round , ick ;
u32 scl ;
2013-09-03 04:09:25 +04:00
u32 cdf_width ;
2013-09-12 16:36:45 +04:00
unsigned long rate ;
2012-09-28 10:44:25 +04:00
2013-09-03 04:09:25 +04:00
switch ( priv - > devtype ) {
2013-10-21 12:04:32 +04:00
case I2C_RCAR_GEN1 :
2013-09-03 04:09:25 +04:00
cdf_width = 2 ;
break ;
2013-10-21 12:04:32 +04:00
case I2C_RCAR_GEN2 :
2015-08-05 16:18:25 +03:00
case I2C_RCAR_GEN3 :
2013-09-03 04:09:25 +04:00
cdf_width = 3 ;
break ;
default :
dev_err ( dev , " device type error \n " ) ;
return - EIO ;
}
2012-09-28 10:44:25 +04:00
/*
* calculate SCL clock
* see
* ICCCR
*
* ick = clkp / ( 1 + CDF )
* SCL = ick / ( 20 + SCGD * 8 + F [ ( ticf + tr + intd ) * ick ] )
*
* ick : I2C internal clock < 20 MHz
* ticf : I2C SCL falling time = 35 ns here
* tr : I2C SCL rising time = 200 ns here
* intd : LSI internal delay = 50 ns here
* clkp : peripheral_clk
* F [ ] : integer up - valuation
*/
2014-01-26 20:05:35 +04:00
rate = clk_get_rate ( priv - > clk ) ;
2013-09-12 16:36:45 +04:00
cdf = rate / 20000000 ;
2014-09-20 14:07:37 +04:00
if ( cdf > = 1U < < cdf_width ) {
2013-09-12 16:36:45 +04:00
dev_err ( dev , " Input clock %lu too high \n " , rate ) ;
return - EIO ;
2012-09-28 10:44:25 +04:00
}
2013-09-12 16:36:45 +04:00
ick = rate / ( cdf + 1 ) ;
2012-09-28 10:44:25 +04:00
/*
* it is impossible to calculate large scale
* number on u32 . separate it
*
* F [ ( ticf + tr + intd ) * ick ]
* = F [ ( 35 + 200 + 50 ) ns * ick ]
* = F [ 285 * ick / 1000000000 ]
* = F [ ( ick / 1000000 ) * 285 / 1000 ]
*/
round = ( ick + 500000 ) / 1000000 * 285 ;
round = ( round + 500 ) / 1000 ;
/*
* SCL = ick / ( 20 + SCGD * 8 + F [ ( ticf + tr + intd ) * ick ] )
*
* Calculation result ( = SCL ) should be less than
* bus_speed for hardware safety
2013-09-12 16:36:45 +04:00
*
* We could use something along the lines of
* div = ick / ( bus_speed + 1 ) + 1 ;
* scgd = ( div - 20 - round + 7 ) / 8 ;
* scl = ick / ( 20 + ( scgd * 8 ) + round ) ;
* ( not fully verified ) but that would get pretty involved
2012-09-28 10:44:25 +04:00
*/
for ( scgd = 0 ; scgd < 0x40 ; scgd + + ) {
scl = ick / ( 20 + ( scgd * 8 ) + round ) ;
if ( scl < = bus_speed )
goto scgd_find ;
}
dev_err ( dev , " it is impossible to calculate best SCL \n " ) ;
return - EIO ;
scgd_find :
dev_dbg ( dev , " clk %d/%d(%lu), round %u, CDF:0x%x, SCGD: 0x%x \n " ,
2014-01-26 20:05:35 +04:00
scl , bus_speed , clk_get_rate ( priv - > clk ) , round , cdf , scgd ) ;
2012-09-28 10:44:25 +04:00
/*
* keep icccr value
*/
2013-09-12 16:36:44 +04:00
priv - > icccr = scgd < < cdf_width | cdf ;
2012-09-28 10:44:25 +04:00
return 0 ;
}
2014-09-15 00:15:46 +04:00
static void rcar_i2c_prepare_msg ( struct rcar_i2c_priv * priv )
2012-09-28 10:44:25 +04:00
{
2014-05-28 11:44:41 +04:00
int read = ! ! rcar_i2c_is_recv ( priv ) ;
2012-09-28 10:44:25 +04:00
2015-11-19 18:56:45 +03:00
priv - > pos = 0 ;
priv - > flags = 0 ;
if ( priv - > msgs_left = = 1 )
rcar_i2c_flags_set ( priv , ID_LAST_MSG ) ;
2014-05-28 11:44:41 +04:00
rcar_i2c_write ( priv , ICMAR , ( priv - > msg - > addr < < 1 ) | read ) ;
2014-05-28 11:44:42 +04:00
rcar_i2c_write ( priv , ICMSR , 0 ) ;
2014-05-28 11:44:38 +04:00
rcar_i2c_write ( priv , ICMCR , RCAR_BUS_PHASE_START ) ;
2014-05-28 11:44:41 +04:00
rcar_i2c_write ( priv , ICMIER , read ? RCAR_IRQ_RECV : RCAR_IRQ_SEND ) ;
2012-09-28 10:44:25 +04:00
}
2015-11-19 18:56:46 +03:00
static void rcar_i2c_next_msg ( struct rcar_i2c_priv * priv )
{
priv - > msg + + ;
priv - > msgs_left - - ;
rcar_i2c_prepare_msg ( priv ) ;
}
2012-09-28 10:44:25 +04:00
/*
* interrupt functions
*/
2015-11-19 18:56:46 +03:00
static void rcar_i2c_irq_send ( struct rcar_i2c_priv * priv , u32 msr )
2012-09-28 10:44:25 +04:00
{
struct i2c_msg * msg = priv - > msg ;
/*
* FIXME
* sometimes , unknown interrupt happened .
* Do nothing
*/
if ( ! ( msr & MDE ) )
2015-11-19 18:56:46 +03:00
return ;
2012-09-28 10:44:25 +04:00
/*
* If address transfer phase finished ,
* goto data phase .
*/
if ( msr & MAT )
2014-05-28 11:44:38 +04:00
rcar_i2c_write ( priv , ICMCR , RCAR_BUS_PHASE_DATA ) ;
2012-09-28 10:44:25 +04:00
if ( priv - > pos < msg - > len ) {
/*
* Prepare next data to ICRXTX register .
* This data will go to _SHIFT_ register .
*
* *
* [ ICRXTX ] - > [ SHIFT ] - > [ I2C bus ]
*/
rcar_i2c_write ( priv , ICRXTX , msg - > buf [ priv - > pos ] ) ;
priv - > pos + + ;
} else {
/*
* The last data was pushed to ICRXTX on _PREV_ empty irq .
* It is on _SHIFT_ register , and will sent to I2C bus .
*
* *
* [ ICRXTX ] - > [ SHIFT ] - > [ I2C bus ]
*/
2015-11-19 18:56:46 +03:00
if ( priv - > flags & ID_LAST_MSG ) {
2012-09-28 10:44:25 +04:00
/*
* If current msg is the _LAST_ msg ,
* prepare stop condition here .
* ID_DONE will be set on STOP irq .
*/
2014-05-28 11:44:38 +04:00
rcar_i2c_write ( priv , ICMCR , RCAR_BUS_PHASE_STOP ) ;
2015-11-19 18:56:46 +03:00
} else {
rcar_i2c_next_msg ( priv ) ;
return ;
}
2012-09-28 10:44:25 +04:00
}
2014-05-28 11:44:42 +04:00
rcar_i2c_write ( priv , ICMSR , RCAR_IRQ_ACK_SEND ) ;
2012-09-28 10:44:25 +04:00
}
2015-11-19 18:56:46 +03:00
static void rcar_i2c_irq_recv ( struct rcar_i2c_priv * priv , u32 msr )
2012-09-28 10:44:25 +04:00
{
struct i2c_msg * msg = priv - > msg ;
/*
* FIXME
* sometimes , unknown interrupt happened .
* Do nothing
*/
if ( ! ( msr & MDR ) )
2015-11-19 18:56:46 +03:00
return ;
2012-09-28 10:44:25 +04:00
if ( msr & MAT ) {
/*
* Address transfer phase finished ,
* but , there is no data at this point .
* Do nothing .
*/
} else if ( priv - > pos < msg - > len ) {
/*
* get received data
*/
msg - > buf [ priv - > pos ] = rcar_i2c_read ( priv , ICRXTX ) ;
priv - > pos + + ;
}
/*
* If next received data is the _LAST_ ,
* go to STOP phase ,
* otherwise , go to DATA phase .
*/
if ( priv - > pos + 1 > = msg - > len )
2014-05-28 11:44:38 +04:00
rcar_i2c_write ( priv , ICMCR , RCAR_BUS_PHASE_STOP ) ;
2012-09-28 10:44:25 +04:00
else
2014-05-28 11:44:38 +04:00
rcar_i2c_write ( priv , ICMCR , RCAR_BUS_PHASE_DATA ) ;
2012-09-28 10:44:25 +04:00
2015-11-19 18:56:46 +03:00
if ( priv - > pos = = msg - > len & & ! ( priv - > flags & ID_LAST_MSG ) )
rcar_i2c_next_msg ( priv ) ;
else
rcar_i2c_write ( priv , ICMSR , RCAR_IRQ_ACK_RECV ) ;
2012-09-28 10:44:25 +04:00
}
2014-11-18 19:04:55 +03:00
static bool rcar_i2c_slave_irq ( struct rcar_i2c_priv * priv )
{
u32 ssr_raw , ssr_filtered ;
u8 value ;
ssr_raw = rcar_i2c_read ( priv , ICSSR ) & 0xff ;
ssr_filtered = ssr_raw & rcar_i2c_read ( priv , ICSIER ) ;
if ( ! ssr_filtered )
return false ;
/* address detected */
if ( ssr_filtered & SAR ) {
/* read or write request */
if ( ssr_raw & STM ) {
2015-03-23 11:26:36 +03:00
i2c_slave_event ( priv - > slave , I2C_SLAVE_READ_REQUESTED , & value ) ;
2014-11-18 19:04:55 +03:00
rcar_i2c_write ( priv , ICRXTX , value ) ;
rcar_i2c_write ( priv , ICSIER , SDE | SSR | SAR ) ;
} else {
2015-03-23 11:26:36 +03:00
i2c_slave_event ( priv - > slave , I2C_SLAVE_WRITE_REQUESTED , & value ) ;
2014-11-18 19:04:55 +03:00
rcar_i2c_read ( priv , ICRXTX ) ; /* dummy read */
rcar_i2c_write ( priv , ICSIER , SDR | SSR | SAR ) ;
}
rcar_i2c_write ( priv , ICSSR , ~ SAR & 0xff ) ;
}
/* master sent stop */
if ( ssr_filtered & SSR ) {
i2c_slave_event ( priv - > slave , I2C_SLAVE_STOP , & value ) ;
rcar_i2c_write ( priv , ICSIER , SAR | SSR ) ;
rcar_i2c_write ( priv , ICSSR , ~ SSR & 0xff ) ;
}
/* master wants to write to us */
if ( ssr_filtered & SDR ) {
int ret ;
value = rcar_i2c_read ( priv , ICRXTX ) ;
2015-03-23 11:26:36 +03:00
ret = i2c_slave_event ( priv - > slave , I2C_SLAVE_WRITE_RECEIVED , & value ) ;
2014-11-18 19:04:55 +03:00
/* Send NACK in case of error */
rcar_i2c_write ( priv , ICSCR , SIE | SDBS | ( ret < 0 ? FNA : 0 ) ) ;
rcar_i2c_write ( priv , ICSSR , ~ SDR & 0xff ) ;
}
/* master wants to read from us */
if ( ssr_filtered & SDE ) {
2015-03-23 11:26:36 +03:00
i2c_slave_event ( priv - > slave , I2C_SLAVE_READ_PROCESSED , & value ) ;
2014-11-18 19:04:55 +03:00
rcar_i2c_write ( priv , ICRXTX , value ) ;
rcar_i2c_write ( priv , ICSSR , ~ SDE & 0xff ) ;
}
return true ;
}
2012-09-28 10:44:25 +04:00
static irqreturn_t rcar_i2c_irq ( int irq , void * ptr )
{
struct rcar_i2c_priv * priv = ptr ;
u32 msr ;
2014-05-28 11:44:36 +04:00
msr = rcar_i2c_read ( priv , ICMSR ) ;
2012-09-28 10:44:25 +04:00
2014-09-02 01:15:26 +04:00
/* Only handle interrupts that are currently enabled */
msr & = rcar_i2c_read ( priv , ICMIER ) ;
2014-09-15 00:20:19 +04:00
if ( ! msr ) {
2015-11-19 18:56:48 +03:00
if ( rcar_i2c_slave_irq ( priv ) )
return IRQ_HANDLED ;
return IRQ_NONE ;
2014-09-15 00:20:19 +04:00
}
2014-09-02 01:15:26 +04:00
2014-05-28 11:44:45 +04:00
/* Arbitration lost */
2012-09-28 10:44:25 +04:00
if ( msr & MAL ) {
rcar_i2c_flags_set ( priv , ( ID_DONE | ID_ARBLOST ) ) ;
goto out ;
}
2014-05-28 11:44:45 +04:00
/* Nack */
2012-09-28 10:44:25 +04:00
if ( msr & MNR ) {
2015-11-19 18:56:47 +03:00
/* HW automatically sends STOP after received NACK */
rcar_i2c_write ( priv , ICMCR , RCAR_BUS_PHASE_DATA ) ;
2014-05-28 11:44:39 +04:00
rcar_i2c_write ( priv , ICMIER , RCAR_IRQ_STOP ) ;
2012-09-28 10:44:25 +04:00
rcar_i2c_flags_set ( priv , ID_NACK ) ;
goto out ;
}
2014-09-02 01:15:26 +04:00
/* Stop */
if ( msr & MST ) {
2015-11-19 18:56:46 +03:00
priv - > msgs_left - - ; /* The last message also made it */
2014-09-02 01:15:26 +04:00
rcar_i2c_flags_set ( priv , ID_DONE ) ;
goto out ;
}
2012-09-28 10:44:25 +04:00
if ( rcar_i2c_is_recv ( priv ) )
2015-11-19 18:56:46 +03:00
rcar_i2c_irq_recv ( priv , msr ) ;
2012-09-28 10:44:25 +04:00
else
2015-11-19 18:56:46 +03:00
rcar_i2c_irq_send ( priv , msr ) ;
2012-09-28 10:44:25 +04:00
out :
if ( rcar_i2c_flags_has ( priv , ID_DONE ) ) {
2014-05-28 11:44:39 +04:00
rcar_i2c_write ( priv , ICMIER , 0 ) ;
2014-05-28 11:44:42 +04:00
rcar_i2c_write ( priv , ICMSR , 0 ) ;
2012-09-28 10:44:25 +04:00
wake_up ( & priv - > wait ) ;
}
2015-11-19 18:56:48 +03:00
return IRQ_HANDLED ;
2012-09-28 10:44:25 +04:00
}
static int rcar_i2c_master_xfer ( struct i2c_adapter * adap ,
struct i2c_msg * msgs ,
int num )
{
struct rcar_i2c_priv * priv = i2c_get_adapdata ( adap ) ;
struct device * dev = rcar_i2c_priv_to_dev ( priv ) ;
2015-06-20 22:03:20 +03:00
int i , ret ;
2015-11-19 18:56:44 +03:00
long time_left ;
2012-09-28 10:44:25 +04:00
pm_runtime_get_sync ( dev ) ;
2014-05-28 11:44:40 +04:00
ret = rcar_i2c_bus_barrier ( priv ) ;
if ( ret < 0 )
goto out ;
2012-09-28 10:44:25 +04:00
for ( i = 0 ; i < num ; i + + ) {
2014-05-05 20:36:21 +04:00
/* This HW can't send STOP after address phase */
if ( msgs [ i ] . len = = 0 ) {
ret = - EOPNOTSUPP ;
2015-11-19 18:56:46 +03:00
goto out ;
2012-09-28 10:44:25 +04:00
}
2015-11-19 18:56:46 +03:00
}
2012-09-28 10:44:25 +04:00
2015-11-19 18:56:46 +03:00
/* init data */
priv - > msg = msgs ;
priv - > msgs_left = num ;
rcar_i2c_prepare_msg ( priv ) ;
time_left = wait_event_timeout ( priv - > wait ,
rcar_i2c_flags_has ( priv , ID_DONE ) ,
num * adap - > timeout ) ;
if ( ! time_left ) {
rcar_i2c_init ( priv ) ;
ret = - ETIMEDOUT ;
} else if ( rcar_i2c_flags_has ( priv , ID_NACK ) ) {
ret = - ENXIO ;
} else if ( rcar_i2c_flags_has ( priv , ID_ARBLOST ) ) {
ret = - EAGAIN ;
} else {
ret = num - priv - > msgs_left ; /* The number of transfer */
2012-09-28 10:44:25 +04:00
}
2014-05-28 11:44:40 +04:00
out :
2012-09-28 10:44:25 +04:00
pm_runtime_put ( dev ) ;
2014-01-26 20:05:37 +04:00
if ( ret < 0 & & ret ! = - ENXIO )
2012-09-28 10:44:25 +04:00
dev_err ( dev , " error %d : %x \n " , ret , priv - > flags ) ;
return ret ;
}
2014-11-18 19:04:55 +03:00
static int rcar_reg_slave ( struct i2c_client * slave )
{
struct rcar_i2c_priv * priv = i2c_get_adapdata ( slave - > adapter ) ;
if ( priv - > slave )
return - EBUSY ;
if ( slave - > flags & I2C_CLIENT_TEN )
return - EAFNOSUPPORT ;
pm_runtime_forbid ( rcar_i2c_priv_to_dev ( priv ) ) ;
priv - > slave = slave ;
rcar_i2c_write ( priv , ICSAR , slave - > addr ) ;
rcar_i2c_write ( priv , ICSSR , 0 ) ;
rcar_i2c_write ( priv , ICSIER , SAR | SSR ) ;
rcar_i2c_write ( priv , ICSCR , SIE | SDBS ) ;
return 0 ;
}
static int rcar_unreg_slave ( struct i2c_client * slave )
{
struct rcar_i2c_priv * priv = i2c_get_adapdata ( slave - > adapter ) ;
WARN_ON ( ! priv - > slave ) ;
rcar_i2c_write ( priv , ICSIER , 0 ) ;
rcar_i2c_write ( priv , ICSCR , 0 ) ;
priv - > slave = NULL ;
pm_runtime_allow ( rcar_i2c_priv_to_dev ( priv ) ) ;
return 0 ;
}
2012-09-28 10:44:25 +04:00
static u32 rcar_i2c_func ( struct i2c_adapter * adap )
{
2014-05-05 20:36:21 +04:00
/* This HW can't do SMBUS_QUICK and NOSTART */
2015-05-14 15:40:03 +03:00
return I2C_FUNC_I2C | I2C_FUNC_SLAVE |
( I2C_FUNC_SMBUS_EMUL & ~ I2C_FUNC_SMBUS_QUICK ) ;
2012-09-28 10:44:25 +04:00
}
static const struct i2c_algorithm rcar_i2c_algo = {
. master_xfer = rcar_i2c_master_xfer ,
. functionality = rcar_i2c_func ,
2014-11-18 19:04:55 +03:00
. reg_slave = rcar_reg_slave ,
. unreg_slave = rcar_unreg_slave ,
2012-09-28 10:44:25 +04:00
} ;
2013-09-12 16:36:46 +04:00
static const struct of_device_id rcar_i2c_dt_ids [ ] = {
2013-10-21 12:04:32 +04:00
{ . compatible = " renesas,i2c-rcar " , . data = ( void * ) I2C_RCAR_GEN1 } ,
{ . compatible = " renesas,i2c-r8a7778 " , . data = ( void * ) I2C_RCAR_GEN1 } ,
{ . compatible = " renesas,i2c-r8a7779 " , . data = ( void * ) I2C_RCAR_GEN1 } ,
{ . compatible = " renesas,i2c-r8a7790 " , . data = ( void * ) I2C_RCAR_GEN2 } ,
2014-02-20 12:03:20 +04:00
{ . compatible = " renesas,i2c-r8a7791 " , . data = ( void * ) I2C_RCAR_GEN2 } ,
2014-05-27 16:06:28 +04:00
{ . compatible = " renesas,i2c-r8a7792 " , . data = ( void * ) I2C_RCAR_GEN2 } ,
{ . compatible = " renesas,i2c-r8a7793 " , . data = ( void * ) I2C_RCAR_GEN2 } ,
{ . compatible = " renesas,i2c-r8a7794 " , . data = ( void * ) I2C_RCAR_GEN2 } ,
2015-08-05 16:18:25 +03:00
{ . compatible = " renesas,i2c-r8a7795 " , . data = ( void * ) I2C_RCAR_GEN3 } ,
2013-09-12 16:36:46 +04:00
{ } ,
} ;
MODULE_DEVICE_TABLE ( of , rcar_i2c_dt_ids ) ;
2012-11-28 00:59:38 +04:00
static int rcar_i2c_probe ( struct platform_device * pdev )
2012-09-28 10:44:25 +04:00
{
struct rcar_i2c_priv * priv ;
struct i2c_adapter * adap ;
struct resource * res ;
struct device * dev = & pdev - > dev ;
u32 bus_speed ;
2014-05-28 11:44:37 +04:00
int irq , ret ;
2012-09-28 10:44:25 +04:00
priv = devm_kzalloc ( dev , sizeof ( struct rcar_i2c_priv ) , GFP_KERNEL ) ;
2014-05-13 05:51:58 +04:00
if ( ! priv )
2012-09-28 10:44:25 +04:00
return - ENOMEM ;
2014-01-26 20:05:35 +04:00
priv - > clk = devm_clk_get ( dev , NULL ) ;
if ( IS_ERR ( priv - > clk ) ) {
dev_err ( dev , " cannot get clock \n " ) ;
return PTR_ERR ( priv - > clk ) ;
}
2015-11-19 18:56:41 +03:00
res = platform_get_resource ( pdev , IORESOURCE_MEM , 0 ) ;
priv - > io = devm_ioremap_resource ( dev , res ) ;
if ( IS_ERR ( priv - > io ) )
return PTR_ERR ( priv - > io ) ;
2012-09-28 10:44:25 +04:00
bus_speed = 100000 ; /* default 100 kHz */
2015-10-07 11:16:31 +03:00
of_property_read_u32 ( dev - > of_node , " clock-frequency " , & bus_speed ) ;
2013-09-03 04:09:25 +04:00
2015-10-07 11:16:31 +03:00
priv - > devtype = ( enum rcar_i2c_type ) of_match_device ( rcar_i2c_dt_ids , dev ) - > data ;
2013-09-03 04:09:25 +04:00
2015-11-19 18:56:41 +03:00
pm_runtime_enable ( dev ) ;
pm_runtime_get_sync ( dev ) ;
2012-09-28 10:44:25 +04:00
ret = rcar_i2c_clock_calculate ( priv , bus_speed , dev ) ;
if ( ret < 0 )
2015-11-19 18:56:41 +03:00
goto out_pm_put ;
2012-09-28 10:44:25 +04:00
2015-11-19 18:56:42 +03:00
rcar_i2c_init ( priv ) ;
2015-11-19 18:56:41 +03:00
pm_runtime_put ( dev ) ;
2012-09-28 10:44:25 +04:00
2014-05-28 11:44:37 +04:00
irq = platform_get_irq ( pdev , 0 ) ;
2012-09-28 10:44:25 +04:00
init_waitqueue_head ( & priv - > wait ) ;
2014-07-10 15:46:31 +04:00
adap = & priv - > adap ;
adap - > nr = pdev - > id ;
adap - > algo = & rcar_i2c_algo ;
adap - > class = I2C_CLASS_DEPRECATED ;
adap - > retries = 3 ;
adap - > dev . parent = dev ;
adap - > dev . of_node = dev - > of_node ;
2012-09-28 10:44:25 +04:00
i2c_set_adapdata ( adap , priv ) ;
strlcpy ( adap - > name , pdev - > name , sizeof ( adap - > name ) ) ;
2014-05-28 11:44:37 +04:00
ret = devm_request_irq ( dev , irq , rcar_i2c_irq , 0 ,
2012-09-28 10:44:25 +04:00
dev_name ( dev ) , priv ) ;
if ( ret < 0 ) {
2014-05-28 11:44:37 +04:00
dev_err ( dev , " cannot get irq %d \n " , irq ) ;
2015-11-19 18:56:41 +03:00
goto out_pm_disable ;
2012-09-28 10:44:25 +04:00
}
2015-10-09 12:39:25 +03:00
platform_set_drvdata ( pdev , priv ) ;
2012-09-28 10:44:25 +04:00
ret = i2c_add_numbered_adapter ( adap ) ;
if ( ret < 0 ) {
dev_err ( dev , " reg adap failed: %d \n " , ret ) ;
2015-11-19 18:56:41 +03:00
goto out_pm_disable ;
2012-09-28 10:44:25 +04:00
}
dev_info ( dev , " probed \n " ) ;
return 0 ;
2015-11-19 18:56:41 +03:00
out_pm_put :
pm_runtime_put ( dev ) ;
out_pm_disable :
pm_runtime_disable ( dev ) ;
return ret ;
2012-09-28 10:44:25 +04:00
}
2012-11-28 00:59:38 +04:00
static int rcar_i2c_remove ( struct platform_device * pdev )
2012-09-28 10:44:25 +04:00
{
struct rcar_i2c_priv * priv = platform_get_drvdata ( pdev ) ;
struct device * dev = & pdev - > dev ;
i2c_del_adapter ( & priv - > adap ) ;
pm_runtime_disable ( dev ) ;
return 0 ;
}
2012-11-13 14:24:15 +04:00
static struct platform_driver rcar_i2c_driver = {
2012-09-28 10:44:25 +04:00
. driver = {
. name = " i2c-rcar " ,
2013-09-12 16:36:46 +04:00
. of_match_table = rcar_i2c_dt_ids ,
2012-09-28 10:44:25 +04:00
} ,
. probe = rcar_i2c_probe ,
2012-11-28 00:59:38 +04:00
. remove = rcar_i2c_remove ,
2012-09-28 10:44:25 +04:00
} ;
2012-11-13 14:24:15 +04:00
module_platform_driver ( rcar_i2c_driver ) ;
2012-09-28 10:44:25 +04:00
2014-05-28 11:44:46 +04:00
MODULE_LICENSE ( " GPL v2 " ) ;
2012-09-28 10:44:25 +04:00
MODULE_DESCRIPTION ( " Renesas R-Car I2C bus driver " ) ;
MODULE_AUTHOR ( " Kuninori Morimoto <kuninori.morimoto.gx@renesas.com> " ) ;