2010-05-19 11:39:02 +02:00
/*
* Copyright ( C ) ST - Ericsson SA 2010
*
* License Terms : GNU General Public License v2
* Author : Srinidhi Kasagar < srinidhi . kasagar @ stericsson . com >
* Author : Rabin Vincent < rabin . vincent @ stericsson . com >
2011-03-02 11:51:11 +01:00
* Author : Mattias Wallin < mattias . wallin @ stericsson . com >
2010-05-19 11:39:02 +02:00
*/
# include <linux/kernel.h>
# include <linux/slab.h>
# include <linux/init.h>
# include <linux/irq.h>
2012-06-20 13:56:37 +01:00
# include <linux/irqdomain.h>
2010-05-19 11:39:02 +02:00
# include <linux/delay.h>
# include <linux/interrupt.h>
2016-10-29 21:24:36 -04:00
# include <linux/moduleparam.h>
2010-05-19 11:39:02 +02:00
# include <linux/platform_device.h>
# include <linux/mfd/core.h>
2010-09-10 17:47:56 +02:00
# include <linux/mfd/abx500.h>
2011-12-02 14:16:33 +01:00
# include <linux/mfd/abx500/ab8500.h>
2013-01-09 10:06:03 +00:00
# include <linux/mfd/abx500/ab8500-bm.h>
2012-05-19 17:21:37 +02:00
# include <linux/mfd/dbx500-prcmu.h>
2010-07-13 11:51:28 +05:30
# include <linux/regulator/ab8500.h>
2012-05-17 14:45:13 +01:00
# include <linux/of.h>
# include <linux/of_device.h>
2010-05-19 11:39:02 +02:00
/*
* Interrupt register offsets
* Bank : 0x0E
*/
2010-09-10 17:47:56 +02:00
# define AB8500_IT_SOURCE1_REG 0x00
# define AB8500_IT_SOURCE2_REG 0x01
# define AB8500_IT_SOURCE3_REG 0x02
# define AB8500_IT_SOURCE4_REG 0x03
# define AB8500_IT_SOURCE5_REG 0x04
# define AB8500_IT_SOURCE6_REG 0x05
# define AB8500_IT_SOURCE7_REG 0x06
# define AB8500_IT_SOURCE8_REG 0x07
2012-02-20 21:42:24 +01:00
# define AB9540_IT_SOURCE13_REG 0x0C
2010-09-10 17:47:56 +02:00
# define AB8500_IT_SOURCE19_REG 0x12
# define AB8500_IT_SOURCE20_REG 0x13
# define AB8500_IT_SOURCE21_REG 0x14
# define AB8500_IT_SOURCE22_REG 0x15
# define AB8500_IT_SOURCE23_REG 0x16
# define AB8500_IT_SOURCE24_REG 0x17
2010-05-19 11:39:02 +02:00
/*
* latch registers
*/
2010-09-10 17:47:56 +02:00
# define AB8500_IT_LATCH1_REG 0x20
# define AB8500_IT_LATCH2_REG 0x21
# define AB8500_IT_LATCH3_REG 0x22
# define AB8500_IT_LATCH4_REG 0x23
# define AB8500_IT_LATCH5_REG 0x24
# define AB8500_IT_LATCH6_REG 0x25
# define AB8500_IT_LATCH7_REG 0x26
# define AB8500_IT_LATCH8_REG 0x27
# define AB8500_IT_LATCH9_REG 0x28
# define AB8500_IT_LATCH10_REG 0x29
2010-12-07 11:20:47 +01:00
# define AB8500_IT_LATCH12_REG 0x2B
2012-02-20 21:42:24 +01:00
# define AB9540_IT_LATCH13_REG 0x2C
2010-09-10 17:47:56 +02:00
# define AB8500_IT_LATCH19_REG 0x32
# define AB8500_IT_LATCH20_REG 0x33
# define AB8500_IT_LATCH21_REG 0x34
# define AB8500_IT_LATCH22_REG 0x35
# define AB8500_IT_LATCH23_REG 0x36
# define AB8500_IT_LATCH24_REG 0x37
2010-05-19 11:39:02 +02:00
/*
* mask registers
*/
2010-09-10 17:47:56 +02:00
# define AB8500_IT_MASK1_REG 0x40
# define AB8500_IT_MASK2_REG 0x41
# define AB8500_IT_MASK3_REG 0x42
# define AB8500_IT_MASK4_REG 0x43
# define AB8500_IT_MASK5_REG 0x44
# define AB8500_IT_MASK6_REG 0x45
# define AB8500_IT_MASK7_REG 0x46
# define AB8500_IT_MASK8_REG 0x47
# define AB8500_IT_MASK9_REG 0x48
# define AB8500_IT_MASK10_REG 0x49
# define AB8500_IT_MASK11_REG 0x4A
# define AB8500_IT_MASK12_REG 0x4B
# define AB8500_IT_MASK13_REG 0x4C
# define AB8500_IT_MASK14_REG 0x4D
# define AB8500_IT_MASK15_REG 0x4E
# define AB8500_IT_MASK16_REG 0x4F
# define AB8500_IT_MASK17_REG 0x50
# define AB8500_IT_MASK18_REG 0x51
# define AB8500_IT_MASK19_REG 0x52
# define AB8500_IT_MASK20_REG 0x53
# define AB8500_IT_MASK21_REG 0x54
# define AB8500_IT_MASK22_REG 0x55
# define AB8500_IT_MASK23_REG 0x56
# define AB8500_IT_MASK24_REG 0x57
2013-02-25 14:34:26 +00:00
# define AB8500_IT_MASK25_REG 0x58
2010-09-10 17:47:56 +02:00
2012-05-07 15:02:03 +02:00
/*
* latch hierarchy registers
*/
# define AB8500_IT_LATCHHIER1_REG 0x60
# define AB8500_IT_LATCHHIER2_REG 0x61
# define AB8500_IT_LATCHHIER3_REG 0x62
2013-02-25 14:57:35 +00:00
# define AB8540_IT_LATCHHIER4_REG 0x63
2012-05-07 15:02:03 +02:00
# define AB8500_IT_LATCHHIER_NUM 3
2013-02-25 14:57:35 +00:00
# define AB8540_IT_LATCHHIER_NUM 4
2012-05-07 15:02:03 +02:00
2010-09-10 17:47:56 +02:00
# define AB8500_REV_REG 0x80
2012-02-20 21:42:10 +01:00
# define AB8500_IC_NAME_REG 0x82
2011-03-02 11:52:36 +01:00
# define AB8500_SWITCH_OFF_STATUS 0x00
2010-05-19 11:39:02 +02:00
2011-10-11 10:49:47 +02:00
# define AB8500_TURN_ON_STATUS 0x00
2015-10-28 09:15:02 +00:00
# define AB8505_TURN_ON_STATUS_2 0x04
2011-10-11 10:49:47 +02:00
2012-05-30 16:32:37 +05:30
# define AB8500_CH_USBCH_STAT1_REG 0x02
# define VBUS_DET_DBNC100 0x02
# define VBUS_DET_DBNC1 0x01
static DEFINE_SPINLOCK ( on_stat_lock ) ;
static u8 turn_on_stat_mask = 0xFF ;
static u8 turn_on_stat_set ;
2012-04-17 09:30:57 +02:00
static bool no_bm ; /* No battery management */
2016-10-29 21:24:36 -04:00
/*
* not really modular , but the easiest way to keep compat with existing
* bootargs behaviour is to continue using module_param here .
*/
2012-04-17 09:30:57 +02:00
module_param ( no_bm , bool , S_IRUGO ) ;
2012-02-20 21:42:24 +01:00
# define AB9540_MODEM_CTRL2_REG 0x23
# define AB9540_MODEM_CTRL2_SWDBBRSTN_BIT BIT(2)
2010-05-19 11:39:02 +02:00
/*
* Map interrupt numbers to the LATCH and MASK register offsets , Interrupt
2012-02-20 21:42:17 +01:00
* numbers are indexed into this array with ( num / 8 ) . The interupts are
* defined in linux / mfd / ab8500 . h
2010-05-19 11:39:02 +02:00
*
* This is one off from the register names , i . e . AB8500_IT_MASK1_REG is at
* offset 0.
*/
2012-02-20 21:42:17 +01:00
/* AB8500 support */
2010-05-19 11:39:02 +02:00
static const int ab8500_irq_regoffset [ AB8500_NUM_IRQ_REGS ] = {
2010-12-07 11:20:47 +01:00
0 , 1 , 2 , 3 , 4 , 6 , 7 , 8 , 9 , 11 , 18 , 19 , 20 , 21 ,
2010-05-19 11:39:02 +02:00
} ;
2013-02-25 14:34:26 +00:00
/* AB9540 / AB8505 support */
2012-02-20 21:42:24 +01:00
static const int ab9540_irq_regoffset [ AB9540_NUM_IRQ_REGS ] = {
2013-02-25 14:34:26 +00:00
0 , 1 , 2 , 3 , 4 , 6 , 7 , 8 , 9 , 11 , 18 , 19 , 20 , 21 , 12 , 13 , 24 , 5 , 22 , 23
2012-02-20 21:42:24 +01:00
} ;
2013-02-25 14:57:35 +00:00
/* AB8540 support */
static const int ab8540_irq_regoffset [ AB8540_NUM_IRQ_REGS ] = {
mfd: ab8500-core: Resolve code style issues
Soothes the following checkpatch warnings:
WARNING: line over 80 characters
#151: FILE: drivers/mfd/ab8500-core.c:151:
+ 0, 1, 2, 3, 4, -1, -1, -1, -1, 11, 18, 19, 20, 21, 12, 13, 24, 5, 22, 23,
ERROR: spaces required around that '=' (ctx:VxW)
#325: FILE: drivers/mfd/ab8500-core.c:325:
+ ret= mask_and_set_register_interruptible(ab8500, bank, reg,
^
WARNING: line over 80 characters
#418: FILE: drivers/mfd/ab8500-core.c:418:
+ else if (offset >= AB9540_INT_GPIO50R && offset <= AB9540_INT_GPIO54R)
WARNING: line over 80 characters
#420: FILE: drivers/mfd/ab8500-core.c:420:
+ else if (offset == AB8540_INT_GPIO43R || offset == AB8540_INT_GPIO44R)
ERROR: spaces required around that '==' (ctx:VxV)
#454: FILE: drivers/mfd/ab8500-core.c:454:
+ if ((i==3) && (*offset >= 24))
^
ERROR: code indent should use tabs where possible
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
WARNING: please, no spaces at the start of a line
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
ERROR: code indent should use tabs where possible
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: please, no spaces at the start of a line
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: char * array declaration might be better as static const
#1554: FILE: drivers/mfd/ab8500-core.c:1554:
+ static char *switch_off_status[] = {
WARNING: char * array declaration might be better as static const
#1563: FILE: drivers/mfd/ab8500-core.c:1563:
+ static char *turn_on_status[] = {
WARNING: sizeof *ab8500 should be sizeof(*ab8500)
#1582: FILE: drivers/mfd/ab8500-core.c:1582:
+ ab8500 = devm_kzalloc(&pdev->dev, sizeof *ab8500, GFP_KERNEL);
ERROR: space required after that close brace '}'
#1639: FILE: drivers/mfd/ab8500-core.c:1639:
+ }/* Configure AB8500 or AB9540 IRQ */
WARNING: line over 80 characters
#1652: FILE: drivers/mfd/ab8500-core.c:1652:
+ ab8500->oldmask = devm_kzalloc(&pdev->dev, ab8500->mask_size, GFP_KERNEL);
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1677: FILE: drivers/mfd/ab8500-core.c:1677:
+ printk(KERN_CONT " \"%s\"",
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1682: FILE: drivers/mfd/ab8500-core.c:1682:
+ printk(KERN_CONT "\n");
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1684: FILE: drivers/mfd/ab8500-core.c:1684:
+ printk(KERN_CONT " None\n");
WARNING: printk() should include KERN_ facility level
#1695: FILE: drivers/mfd/ab8500-core.c:1695:
+ printk("\"%s\" ", turn_on_status[i]);
WARNING: printk() should include KERN_ facility level
#1700: FILE: drivers/mfd/ab8500-core.c:1700:
+ printk("None\n");
total: 5 errors, 14 warnings, 1869 lines checked
Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Lee Jones <lee.jones@linaro.org>
2014-05-08 14:11:37 +01:00
0 , 1 , 2 , 3 , 4 , - 1 , - 1 , - 1 , - 1 , 11 , 18 , 19 , 20 , 21 , 12 , 13 , 24 , 5 , 22 ,
23 , 25 , 26 , 27 , 28 , 29 , 30 , 31 ,
2013-02-25 14:57:35 +00:00
} ;
2012-02-20 21:42:10 +01:00
static const char ab8500_version_str [ ] [ 7 ] = {
[ AB8500_VERSION_AB8500 ] = " AB8500 " ,
[ AB8500_VERSION_AB8505 ] = " AB8505 " ,
[ AB8500_VERSION_AB9540 ] = " AB9540 " ,
[ AB8500_VERSION_AB8540 ] = " AB8540 " ,
} ;
2012-06-20 13:56:38 +01:00
static int ab8500_prcmu_write ( struct ab8500 * ab8500 , u16 addr , u8 data )
2012-05-19 17:21:37 +02:00
{
int ret ;
ret = prcmu_abb_write ( ( u8 ) ( addr > > 8 ) , ( u8 ) ( addr & 0xFF ) , & data , 1 ) ;
if ( ret < 0 )
dev_err ( ab8500 - > dev , " prcmu i2c error %d \n " , ret ) ;
return ret ;
}
2012-06-20 13:56:38 +01:00
static int ab8500_prcmu_write_masked ( struct ab8500 * ab8500 , u16 addr , u8 mask ,
2012-05-19 17:21:37 +02:00
u8 data )
{
int ret ;
ret = prcmu_abb_write_masked ( ( u8 ) ( addr > > 8 ) , ( u8 ) ( addr & 0xFF ) , & data ,
& mask , 1 ) ;
if ( ret < 0 )
dev_err ( ab8500 - > dev , " prcmu i2c error %d \n " , ret ) ;
return ret ;
}
2012-06-20 13:56:38 +01:00
static int ab8500_prcmu_read ( struct ab8500 * ab8500 , u16 addr )
2012-05-19 17:21:37 +02:00
{
int ret ;
u8 data ;
ret = prcmu_abb_read ( ( u8 ) ( addr > > 8 ) , ( u8 ) ( addr & 0xFF ) , & data , 1 ) ;
if ( ret < 0 ) {
dev_err ( ab8500 - > dev , " prcmu i2c error %d \n " , ret ) ;
return ret ;
}
return ( int ) data ;
}
2010-09-10 17:47:56 +02:00
static int ab8500_get_chip_id ( struct device * dev )
{
2010-12-02 15:08:32 +01:00
struct ab8500 * ab8500 ;
if ( ! dev )
return - EINVAL ;
ab8500 = dev_get_drvdata ( dev - > parent ) ;
return ab8500 ? ( int ) ab8500 - > chip_id : - EINVAL ;
2010-09-10 17:47:56 +02:00
}
static int set_register_interruptible ( struct ab8500 * ab8500 , u8 bank ,
u8 reg , u8 data )
2010-05-19 11:39:02 +02:00
{
int ret ;
2010-09-10 17:47:56 +02:00
/*
* Put the u8 bank and u8 register together into a an u16 .
* The bank on higher 8 bits and register in lower 8 bits .
2015-10-28 09:15:02 +00:00
*/
2010-09-10 17:47:56 +02:00
u16 addr = ( ( u16 ) bank ) < < 8 | reg ;
2010-05-19 11:39:02 +02:00
dev_vdbg ( ab8500 - > dev , " wr: addr %#x <= %#x \n " , addr , data ) ;
2012-03-08 14:01:46 +01:00
mutex_lock ( & ab8500 - > lock ) ;
2010-09-10 17:47:56 +02:00
2010-05-19 11:39:02 +02:00
ret = ab8500 - > write ( ab8500 , addr , data ) ;
if ( ret < 0 )
dev_err ( ab8500 - > dev , " failed to write reg %#x: %d \n " ,
addr , ret ) ;
2010-09-10 17:47:56 +02:00
mutex_unlock ( & ab8500 - > lock ) ;
2010-05-19 11:39:02 +02:00
return ret ;
}
2010-09-10 17:47:56 +02:00
static int ab8500_set_register ( struct device * dev , u8 bank ,
u8 reg , u8 value )
2010-05-19 11:39:02 +02:00
{
2012-04-17 09:30:33 +02:00
int ret ;
2010-09-10 17:47:56 +02:00
struct ab8500 * ab8500 = dev_get_drvdata ( dev - > parent ) ;
2010-05-19 11:39:02 +02:00
2012-04-17 09:30:33 +02:00
atomic_inc ( & ab8500 - > transfer_ongoing ) ;
ret = set_register_interruptible ( ab8500 , bank , reg , value ) ;
atomic_dec ( & ab8500 - > transfer_ongoing ) ;
return ret ;
2010-05-19 11:39:02 +02:00
}
2010-09-10 17:47:56 +02:00
static int get_register_interruptible ( struct ab8500 * ab8500 , u8 bank ,
u8 reg , u8 * value )
2010-05-19 11:39:02 +02:00
{
int ret ;
2010-09-10 17:47:56 +02:00
u16 addr = ( ( u16 ) bank ) < < 8 | reg ;
2012-03-08 14:01:46 +01:00
mutex_lock ( & ab8500 - > lock ) ;
2010-05-19 11:39:02 +02:00
ret = ab8500 - > read ( ab8500 , addr ) ;
if ( ret < 0 )
dev_err ( ab8500 - > dev , " failed to read reg %#x: %d \n " ,
addr , ret ) ;
2010-09-10 17:47:56 +02:00
else
* value = ret ;
2010-05-19 11:39:02 +02:00
2010-09-10 17:47:56 +02:00
mutex_unlock ( & ab8500 - > lock ) ;
2010-05-19 11:39:02 +02:00
dev_vdbg ( ab8500 - > dev , " rd: addr %#x => data %#x \n " , addr , ret ) ;
return ret ;
}
2010-09-10 17:47:56 +02:00
static int ab8500_get_register ( struct device * dev , u8 bank ,
u8 reg , u8 * value )
2010-05-19 11:39:02 +02:00
{
2012-04-17 09:30:33 +02:00
int ret ;
2010-09-10 17:47:56 +02:00
struct ab8500 * ab8500 = dev_get_drvdata ( dev - > parent ) ;
2010-05-19 11:39:02 +02:00
2012-04-17 09:30:33 +02:00
atomic_inc ( & ab8500 - > transfer_ongoing ) ;
ret = get_register_interruptible ( ab8500 , bank , reg , value ) ;
atomic_dec ( & ab8500 - > transfer_ongoing ) ;
return ret ;
2010-05-19 11:39:02 +02:00
}
2010-09-10 17:47:56 +02:00
static int mask_and_set_register_interruptible ( struct ab8500 * ab8500 , u8 bank ,
u8 reg , u8 bitmask , u8 bitvalues )
2010-05-19 11:39:02 +02:00
{
int ret ;
2010-09-10 17:47:56 +02:00
u16 addr = ( ( u16 ) bank ) < < 8 | reg ;
2010-05-19 11:39:02 +02:00
2012-03-08 14:01:46 +01:00
mutex_lock ( & ab8500 - > lock ) ;
2010-05-19 11:39:02 +02:00
2012-03-08 14:02:20 +01:00
if ( ab8500 - > write_masked = = NULL ) {
u8 data ;
2010-05-19 11:39:02 +02:00
2012-03-08 14:02:20 +01:00
ret = ab8500 - > read ( ab8500 , addr ) ;
if ( ret < 0 ) {
dev_err ( ab8500 - > dev , " failed to read reg %#x: %d \n " ,
addr , ret ) ;
goto out ;
}
2010-05-19 11:39:02 +02:00
2012-03-08 14:02:20 +01:00
data = ( u8 ) ret ;
data = ( ~ bitmask & data ) | ( bitmask & bitvalues ) ;
ret = ab8500 - > write ( ab8500 , addr , data ) ;
if ( ret < 0 )
dev_err ( ab8500 - > dev , " failed to write reg %#x: %d \n " ,
addr , ret ) ;
2010-05-19 11:39:02 +02:00
2012-03-08 14:02:20 +01:00
dev_vdbg ( ab8500 - > dev , " mask: addr %#x => data %#x \n " , addr ,
data ) ;
goto out ;
}
ret = ab8500 - > write_masked ( ab8500 , addr , bitmask , bitvalues ) ;
if ( ret < 0 )
dev_err ( ab8500 - > dev , " failed to modify reg %#x: %d \n " , addr ,
ret ) ;
2010-05-19 11:39:02 +02:00
out :
mutex_unlock ( & ab8500 - > lock ) ;
return ret ;
}
2010-09-10 17:47:56 +02:00
static int ab8500_mask_and_set_register ( struct device * dev ,
u8 bank , u8 reg , u8 bitmask , u8 bitvalues )
{
2012-04-17 09:30:33 +02:00
int ret ;
2010-09-10 17:47:56 +02:00
struct ab8500 * ab8500 = dev_get_drvdata ( dev - > parent ) ;
2012-04-17 09:30:33 +02:00
atomic_inc ( & ab8500 - > transfer_ongoing ) ;
mfd: ab8500-core: Resolve code style issues
Soothes the following checkpatch warnings:
WARNING: line over 80 characters
#151: FILE: drivers/mfd/ab8500-core.c:151:
+ 0, 1, 2, 3, 4, -1, -1, -1, -1, 11, 18, 19, 20, 21, 12, 13, 24, 5, 22, 23,
ERROR: spaces required around that '=' (ctx:VxW)
#325: FILE: drivers/mfd/ab8500-core.c:325:
+ ret= mask_and_set_register_interruptible(ab8500, bank, reg,
^
WARNING: line over 80 characters
#418: FILE: drivers/mfd/ab8500-core.c:418:
+ else if (offset >= AB9540_INT_GPIO50R && offset <= AB9540_INT_GPIO54R)
WARNING: line over 80 characters
#420: FILE: drivers/mfd/ab8500-core.c:420:
+ else if (offset == AB8540_INT_GPIO43R || offset == AB8540_INT_GPIO44R)
ERROR: spaces required around that '==' (ctx:VxV)
#454: FILE: drivers/mfd/ab8500-core.c:454:
+ if ((i==3) && (*offset >= 24))
^
ERROR: code indent should use tabs where possible
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
WARNING: please, no spaces at the start of a line
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
ERROR: code indent should use tabs where possible
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: please, no spaces at the start of a line
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: char * array declaration might be better as static const
#1554: FILE: drivers/mfd/ab8500-core.c:1554:
+ static char *switch_off_status[] = {
WARNING: char * array declaration might be better as static const
#1563: FILE: drivers/mfd/ab8500-core.c:1563:
+ static char *turn_on_status[] = {
WARNING: sizeof *ab8500 should be sizeof(*ab8500)
#1582: FILE: drivers/mfd/ab8500-core.c:1582:
+ ab8500 = devm_kzalloc(&pdev->dev, sizeof *ab8500, GFP_KERNEL);
ERROR: space required after that close brace '}'
#1639: FILE: drivers/mfd/ab8500-core.c:1639:
+ }/* Configure AB8500 or AB9540 IRQ */
WARNING: line over 80 characters
#1652: FILE: drivers/mfd/ab8500-core.c:1652:
+ ab8500->oldmask = devm_kzalloc(&pdev->dev, ab8500->mask_size, GFP_KERNEL);
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1677: FILE: drivers/mfd/ab8500-core.c:1677:
+ printk(KERN_CONT " \"%s\"",
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1682: FILE: drivers/mfd/ab8500-core.c:1682:
+ printk(KERN_CONT "\n");
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1684: FILE: drivers/mfd/ab8500-core.c:1684:
+ printk(KERN_CONT " None\n");
WARNING: printk() should include KERN_ facility level
#1695: FILE: drivers/mfd/ab8500-core.c:1695:
+ printk("\"%s\" ", turn_on_status[i]);
WARNING: printk() should include KERN_ facility level
#1700: FILE: drivers/mfd/ab8500-core.c:1700:
+ printk("None\n");
total: 5 errors, 14 warnings, 1869 lines checked
Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Lee Jones <lee.jones@linaro.org>
2014-05-08 14:11:37 +01:00
ret = mask_and_set_register_interruptible ( ab8500 , bank , reg ,
2012-04-17 09:30:33 +02:00
bitmask , bitvalues ) ;
atomic_dec ( & ab8500 - > transfer_ongoing ) ;
return ret ;
2010-09-10 17:47:56 +02:00
}
static struct abx500_ops ab8500_ops = {
. get_chip_id = ab8500_get_chip_id ,
. get_register = ab8500_get_register ,
. set_register = ab8500_set_register ,
. get_register_page = NULL ,
. set_register_page = NULL ,
. mask_and_set_register = ab8500_mask_and_set_register ,
. event_registers_startup_state_get = NULL ,
. startup_irq_enabled = NULL ,
2012-01-27 11:35:41 +01:00
. dump_all_banks = ab8500_dump_all_banks ,
2010-09-10 17:47:56 +02:00
} ;
2010-05-19 11:39:02 +02:00
2010-12-11 13:16:08 +00:00
static void ab8500_irq_lock ( struct irq_data * data )
2010-05-19 11:39:02 +02:00
{
2010-12-11 13:16:08 +00:00
struct ab8500 * ab8500 = irq_data_get_irq_chip_data ( data ) ;
2010-05-19 11:39:02 +02:00
mutex_lock ( & ab8500 - > irq_lock ) ;
2012-04-17 09:30:33 +02:00
atomic_inc ( & ab8500 - > transfer_ongoing ) ;
2010-05-19 11:39:02 +02:00
}
2010-12-11 13:16:08 +00:00
static void ab8500_irq_sync_unlock ( struct irq_data * data )
2010-05-19 11:39:02 +02:00
{
2010-12-11 13:16:08 +00:00
struct ab8500 * ab8500 = irq_data_get_irq_chip_data ( data ) ;
2010-05-19 11:39:02 +02:00
int i ;
2012-02-20 21:42:17 +01:00
for ( i = 0 ; i < ab8500 - > mask_size ; i + + ) {
2010-05-19 11:39:02 +02:00
u8 old = ab8500 - > oldmask [ i ] ;
u8 new = ab8500 - > mask [ i ] ;
int reg ;
if ( new = = old )
continue ;
2012-02-20 21:42:10 +01:00
/*
* Interrupt register 12 doesn ' t exist prior to AB8500 version
* 2.0
*/
if ( ab8500 - > irq_reg_offset [ i ] = = 11 & &
is_ab8500_1p1_or_earlier ( ab8500 ) )
2010-12-07 11:20:47 +01:00
continue ;
2013-02-25 14:57:35 +00:00
if ( ab8500 - > irq_reg_offset [ i ] < 0 )
continue ;
2010-05-19 11:39:02 +02:00
ab8500 - > oldmask [ i ] = new ;
2012-02-20 21:42:17 +01:00
reg = AB8500_IT_MASK1_REG + ab8500 - > irq_reg_offset [ i ] ;
2010-09-10 17:47:56 +02:00
set_register_interruptible ( ab8500 , AB8500_INTERRUPT , reg , new ) ;
2010-05-19 11:39:02 +02:00
}
2012-04-17 09:30:33 +02:00
atomic_dec ( & ab8500 - > transfer_ongoing ) ;
2010-05-19 11:39:02 +02:00
mutex_unlock ( & ab8500 - > irq_lock ) ;
}
2010-12-11 13:16:08 +00:00
static void ab8500_irq_mask ( struct irq_data * data )
2010-05-19 11:39:02 +02:00
{
2010-12-11 13:16:08 +00:00
struct ab8500 * ab8500 = irq_data_get_irq_chip_data ( data ) ;
2012-06-20 13:56:37 +01:00
int offset = data - > hwirq ;
2010-05-19 11:39:02 +02:00
int index = offset / 8 ;
int mask = 1 < < ( offset % 8 ) ;
ab8500 - > mask [ index ] | = mask ;
2012-12-20 11:23:42 +00:00
/* The AB8500 GPIOs have two interrupts each (rising & falling). */
if ( offset > = AB8500_INT_GPIO6R & & offset < = AB8500_INT_GPIO41R )
ab8500 - > mask [ index + 2 ] | = mask ;
if ( offset > = AB9540_INT_GPIO50R & & offset < = AB9540_INT_GPIO54R )
ab8500 - > mask [ index + 1 ] | = mask ;
if ( offset = = AB8540_INT_GPIO43R | | offset = = AB8540_INT_GPIO44R )
2013-02-06 21:54:34 +01:00
/* Here the falling IRQ is one bit lower */
ab8500 - > mask [ index ] | = ( mask < < 1 ) ;
2010-05-19 11:39:02 +02:00
}
2010-12-11 13:16:08 +00:00
static void ab8500_irq_unmask ( struct irq_data * data )
2010-05-19 11:39:02 +02:00
{
2010-12-11 13:16:08 +00:00
struct ab8500 * ab8500 = irq_data_get_irq_chip_data ( data ) ;
2012-12-20 11:23:42 +00:00
unsigned int type = irqd_get_trigger_type ( data ) ;
2012-06-20 13:56:37 +01:00
int offset = data - > hwirq ;
2010-05-19 11:39:02 +02:00
int index = offset / 8 ;
int mask = 1 < < ( offset % 8 ) ;
2012-12-20 11:23:42 +00:00
if ( type & IRQ_TYPE_EDGE_RISING )
ab8500 - > mask [ index ] & = ~ mask ;
/* The AB8500 GPIOs have two interrupts each (rising & falling). */
if ( type & IRQ_TYPE_EDGE_FALLING ) {
if ( offset > = AB8500_INT_GPIO6R & & offset < = AB8500_INT_GPIO41R )
ab8500 - > mask [ index + 2 ] & = ~ mask ;
mfd: ab8500-core: Resolve code style issues
Soothes the following checkpatch warnings:
WARNING: line over 80 characters
#151: FILE: drivers/mfd/ab8500-core.c:151:
+ 0, 1, 2, 3, 4, -1, -1, -1, -1, 11, 18, 19, 20, 21, 12, 13, 24, 5, 22, 23,
ERROR: spaces required around that '=' (ctx:VxW)
#325: FILE: drivers/mfd/ab8500-core.c:325:
+ ret= mask_and_set_register_interruptible(ab8500, bank, reg,
^
WARNING: line over 80 characters
#418: FILE: drivers/mfd/ab8500-core.c:418:
+ else if (offset >= AB9540_INT_GPIO50R && offset <= AB9540_INT_GPIO54R)
WARNING: line over 80 characters
#420: FILE: drivers/mfd/ab8500-core.c:420:
+ else if (offset == AB8540_INT_GPIO43R || offset == AB8540_INT_GPIO44R)
ERROR: spaces required around that '==' (ctx:VxV)
#454: FILE: drivers/mfd/ab8500-core.c:454:
+ if ((i==3) && (*offset >= 24))
^
ERROR: code indent should use tabs where possible
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
WARNING: please, no spaces at the start of a line
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
ERROR: code indent should use tabs where possible
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: please, no spaces at the start of a line
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: char * array declaration might be better as static const
#1554: FILE: drivers/mfd/ab8500-core.c:1554:
+ static char *switch_off_status[] = {
WARNING: char * array declaration might be better as static const
#1563: FILE: drivers/mfd/ab8500-core.c:1563:
+ static char *turn_on_status[] = {
WARNING: sizeof *ab8500 should be sizeof(*ab8500)
#1582: FILE: drivers/mfd/ab8500-core.c:1582:
+ ab8500 = devm_kzalloc(&pdev->dev, sizeof *ab8500, GFP_KERNEL);
ERROR: space required after that close brace '}'
#1639: FILE: drivers/mfd/ab8500-core.c:1639:
+ }/* Configure AB8500 or AB9540 IRQ */
WARNING: line over 80 characters
#1652: FILE: drivers/mfd/ab8500-core.c:1652:
+ ab8500->oldmask = devm_kzalloc(&pdev->dev, ab8500->mask_size, GFP_KERNEL);
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1677: FILE: drivers/mfd/ab8500-core.c:1677:
+ printk(KERN_CONT " \"%s\"",
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1682: FILE: drivers/mfd/ab8500-core.c:1682:
+ printk(KERN_CONT "\n");
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1684: FILE: drivers/mfd/ab8500-core.c:1684:
+ printk(KERN_CONT " None\n");
WARNING: printk() should include KERN_ facility level
#1695: FILE: drivers/mfd/ab8500-core.c:1695:
+ printk("\"%s\" ", turn_on_status[i]);
WARNING: printk() should include KERN_ facility level
#1700: FILE: drivers/mfd/ab8500-core.c:1700:
+ printk("None\n");
total: 5 errors, 14 warnings, 1869 lines checked
Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Lee Jones <lee.jones@linaro.org>
2014-05-08 14:11:37 +01:00
else if ( offset > = AB9540_INT_GPIO50R & &
offset < = AB9540_INT_GPIO54R )
2012-12-20 11:23:42 +00:00
ab8500 - > mask [ index + 1 ] & = ~ mask ;
mfd: ab8500-core: Resolve code style issues
Soothes the following checkpatch warnings:
WARNING: line over 80 characters
#151: FILE: drivers/mfd/ab8500-core.c:151:
+ 0, 1, 2, 3, 4, -1, -1, -1, -1, 11, 18, 19, 20, 21, 12, 13, 24, 5, 22, 23,
ERROR: spaces required around that '=' (ctx:VxW)
#325: FILE: drivers/mfd/ab8500-core.c:325:
+ ret= mask_and_set_register_interruptible(ab8500, bank, reg,
^
WARNING: line over 80 characters
#418: FILE: drivers/mfd/ab8500-core.c:418:
+ else if (offset >= AB9540_INT_GPIO50R && offset <= AB9540_INT_GPIO54R)
WARNING: line over 80 characters
#420: FILE: drivers/mfd/ab8500-core.c:420:
+ else if (offset == AB8540_INT_GPIO43R || offset == AB8540_INT_GPIO44R)
ERROR: spaces required around that '==' (ctx:VxV)
#454: FILE: drivers/mfd/ab8500-core.c:454:
+ if ((i==3) && (*offset >= 24))
^
ERROR: code indent should use tabs where possible
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
WARNING: please, no spaces at the start of a line
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
ERROR: code indent should use tabs where possible
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: please, no spaces at the start of a line
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: char * array declaration might be better as static const
#1554: FILE: drivers/mfd/ab8500-core.c:1554:
+ static char *switch_off_status[] = {
WARNING: char * array declaration might be better as static const
#1563: FILE: drivers/mfd/ab8500-core.c:1563:
+ static char *turn_on_status[] = {
WARNING: sizeof *ab8500 should be sizeof(*ab8500)
#1582: FILE: drivers/mfd/ab8500-core.c:1582:
+ ab8500 = devm_kzalloc(&pdev->dev, sizeof *ab8500, GFP_KERNEL);
ERROR: space required after that close brace '}'
#1639: FILE: drivers/mfd/ab8500-core.c:1639:
+ }/* Configure AB8500 or AB9540 IRQ */
WARNING: line over 80 characters
#1652: FILE: drivers/mfd/ab8500-core.c:1652:
+ ab8500->oldmask = devm_kzalloc(&pdev->dev, ab8500->mask_size, GFP_KERNEL);
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1677: FILE: drivers/mfd/ab8500-core.c:1677:
+ printk(KERN_CONT " \"%s\"",
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1682: FILE: drivers/mfd/ab8500-core.c:1682:
+ printk(KERN_CONT "\n");
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1684: FILE: drivers/mfd/ab8500-core.c:1684:
+ printk(KERN_CONT " None\n");
WARNING: printk() should include KERN_ facility level
#1695: FILE: drivers/mfd/ab8500-core.c:1695:
+ printk("\"%s\" ", turn_on_status[i]);
WARNING: printk() should include KERN_ facility level
#1700: FILE: drivers/mfd/ab8500-core.c:1700:
+ printk("None\n");
total: 5 errors, 14 warnings, 1869 lines checked
Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Lee Jones <lee.jones@linaro.org>
2014-05-08 14:11:37 +01:00
else if ( offset = = AB8540_INT_GPIO43R | |
offset = = AB8540_INT_GPIO44R )
2013-02-06 21:54:34 +01:00
/* Here the falling IRQ is one bit lower */
ab8500 - > mask [ index ] & = ~ ( mask < < 1 ) ;
2012-12-20 11:23:42 +00:00
else
ab8500 - > mask [ index ] & = ~ mask ;
2013-02-06 21:54:34 +01:00
} else {
2012-12-20 11:23:42 +00:00
/* Satisfies the case where type is not set. */
ab8500 - > mask [ index ] & = ~ mask ;
2013-02-06 21:54:34 +01:00
}
2010-05-19 11:39:02 +02:00
}
2013-01-07 12:23:48 +00:00
static int ab8500_irq_set_type ( struct irq_data * data , unsigned int type )
{
return 0 ;
2010-05-19 11:39:02 +02:00
}
static struct irq_chip ab8500_irq_chip = {
. name = " ab8500 " ,
2010-12-11 13:16:08 +00:00
. irq_bus_lock = ab8500_irq_lock ,
. irq_bus_sync_unlock = ab8500_irq_sync_unlock ,
. irq_mask = ab8500_irq_mask ,
2011-10-11 10:49:17 +02:00
. irq_disable = ab8500_irq_mask ,
2010-12-11 13:16:08 +00:00
. irq_unmask = ab8500_irq_unmask ,
2013-01-07 12:23:48 +00:00
. irq_set_type = ab8500_irq_set_type ,
2010-05-19 11:39:02 +02:00
} ;
2013-02-25 14:57:35 +00:00
static void update_latch_offset ( u8 * offset , int i )
{
/* Fix inconsistent ITFromLatch25 bit mapping... */
if ( unlikely ( * offset = = 17 ) )
2015-10-28 09:15:02 +00:00
* offset = 24 ;
2013-02-25 14:57:35 +00:00
/* Fix inconsistent ab8540 bit mapping... */
if ( unlikely ( * offset = = 16 ) )
2015-10-28 09:15:02 +00:00
* offset = 25 ;
mfd: ab8500-core: Resolve code style issues
Soothes the following checkpatch warnings:
WARNING: line over 80 characters
#151: FILE: drivers/mfd/ab8500-core.c:151:
+ 0, 1, 2, 3, 4, -1, -1, -1, -1, 11, 18, 19, 20, 21, 12, 13, 24, 5, 22, 23,
ERROR: spaces required around that '=' (ctx:VxW)
#325: FILE: drivers/mfd/ab8500-core.c:325:
+ ret= mask_and_set_register_interruptible(ab8500, bank, reg,
^
WARNING: line over 80 characters
#418: FILE: drivers/mfd/ab8500-core.c:418:
+ else if (offset >= AB9540_INT_GPIO50R && offset <= AB9540_INT_GPIO54R)
WARNING: line over 80 characters
#420: FILE: drivers/mfd/ab8500-core.c:420:
+ else if (offset == AB8540_INT_GPIO43R || offset == AB8540_INT_GPIO44R)
ERROR: spaces required around that '==' (ctx:VxV)
#454: FILE: drivers/mfd/ab8500-core.c:454:
+ if ((i==3) && (*offset >= 24))
^
ERROR: code indent should use tabs where possible
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
WARNING: please, no spaces at the start of a line
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
ERROR: code indent should use tabs where possible
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: please, no spaces at the start of a line
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: char * array declaration might be better as static const
#1554: FILE: drivers/mfd/ab8500-core.c:1554:
+ static char *switch_off_status[] = {
WARNING: char * array declaration might be better as static const
#1563: FILE: drivers/mfd/ab8500-core.c:1563:
+ static char *turn_on_status[] = {
WARNING: sizeof *ab8500 should be sizeof(*ab8500)
#1582: FILE: drivers/mfd/ab8500-core.c:1582:
+ ab8500 = devm_kzalloc(&pdev->dev, sizeof *ab8500, GFP_KERNEL);
ERROR: space required after that close brace '}'
#1639: FILE: drivers/mfd/ab8500-core.c:1639:
+ }/* Configure AB8500 or AB9540 IRQ */
WARNING: line over 80 characters
#1652: FILE: drivers/mfd/ab8500-core.c:1652:
+ ab8500->oldmask = devm_kzalloc(&pdev->dev, ab8500->mask_size, GFP_KERNEL);
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1677: FILE: drivers/mfd/ab8500-core.c:1677:
+ printk(KERN_CONT " \"%s\"",
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1682: FILE: drivers/mfd/ab8500-core.c:1682:
+ printk(KERN_CONT "\n");
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1684: FILE: drivers/mfd/ab8500-core.c:1684:
+ printk(KERN_CONT " None\n");
WARNING: printk() should include KERN_ facility level
#1695: FILE: drivers/mfd/ab8500-core.c:1695:
+ printk("\"%s\" ", turn_on_status[i]);
WARNING: printk() should include KERN_ facility level
#1700: FILE: drivers/mfd/ab8500-core.c:1700:
+ printk("None\n");
total: 5 errors, 14 warnings, 1869 lines checked
Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Lee Jones <lee.jones@linaro.org>
2014-05-08 14:11:37 +01:00
if ( ( i = = 3 ) & & ( * offset > = 24 ) )
2015-10-28 09:15:02 +00:00
* offset + = 2 ;
2013-02-25 14:57:35 +00:00
}
2012-05-07 15:02:03 +02:00
static int ab8500_handle_hierarchical_line ( struct ab8500 * ab8500 ,
int latch_offset , u8 latch_val )
{
2013-03-21 14:49:44 +01:00
int int_bit , line , i ;
2012-05-07 15:02:03 +02:00
2013-03-21 14:49:44 +01:00
for ( i = 0 ; i < ab8500 - > mask_size ; i + + )
if ( ab8500 - > irq_reg_offset [ i ] = = latch_offset )
break ;
2012-05-07 15:02:03 +02:00
2013-03-21 14:49:44 +01:00
if ( i > = ab8500 - > mask_size ) {
dev_err ( ab8500 - > dev , " Register offset 0x%2x not declared \n " ,
latch_offset ) ;
return - ENXIO ;
}
2012-05-07 15:02:03 +02:00
2013-03-21 14:49:44 +01:00
/* ignore masked out interrupts */
latch_val & = ~ ab8500 - > mask [ i ] ;
2012-05-07 15:02:03 +02:00
2013-03-21 14:49:44 +01:00
while ( latch_val ) {
int_bit = __ffs ( latch_val ) ;
2012-05-07 15:02:03 +02:00
line = ( i < < 3 ) + int_bit ;
latch_val & = ~ ( 1 < < int_bit ) ;
2013-02-06 21:54:34 +01:00
/*
* This handles the falling edge hwirqs from the GPIO
* lines . Route them back to the line registered for the
* rising IRQ , as this is merely a flag for the same IRQ
* in linux terms .
*/
if ( line > = AB8500_INT_GPIO6F & & line < = AB8500_INT_GPIO41F )
line - = 16 ;
if ( line > = AB9540_INT_GPIO50F & & line < = AB9540_INT_GPIO54F )
line - = 8 ;
if ( line = = AB8540_INT_GPIO43F | | line = = AB8540_INT_GPIO44F )
line + = 1 ;
2013-12-03 15:11:54 +01:00
handle_nested_irq ( irq_create_mapping ( ab8500 - > domain , line ) ) ;
2013-03-21 14:49:44 +01:00
}
2012-05-07 15:02:03 +02:00
return 0 ;
}
static int ab8500_handle_hierarchical_latch ( struct ab8500 * ab8500 ,
int hier_offset , u8 hier_val )
{
int latch_bit , status ;
u8 latch_offset , latch_val ;
do {
latch_bit = __ffs ( hier_val ) ;
latch_offset = ( hier_offset < < 3 ) + latch_bit ;
2013-02-25 14:57:35 +00:00
update_latch_offset ( & latch_offset , hier_offset ) ;
2012-05-07 15:02:03 +02:00
status = get_register_interruptible ( ab8500 ,
AB8500_INTERRUPT ,
AB8500_IT_LATCH1_REG + latch_offset ,
& latch_val ) ;
if ( status < 0 | | latch_val = = 0 )
goto discard ;
status = ab8500_handle_hierarchical_line ( ab8500 ,
latch_offset , latch_val ) ;
if ( status < 0 )
return status ;
discard :
hier_val & = ~ ( 1 < < latch_bit ) ;
} while ( hier_val ) ;
return 0 ;
}
static irqreturn_t ab8500_hierarchical_irq ( int irq , void * dev )
{
struct ab8500 * ab8500 = dev ;
u8 i ;
dev_vdbg ( ab8500 - > dev , " interrupt \n " ) ;
/* Hierarchical interrupt version */
2013-02-25 14:57:35 +00:00
for ( i = 0 ; i < ( ab8500 - > it_latchhier_num ) ; i + + ) {
2012-05-07 15:02:03 +02:00
int status ;
u8 hier_val ;
status = get_register_interruptible ( ab8500 , AB8500_INTERRUPT ,
AB8500_IT_LATCHHIER1_REG + i , & hier_val ) ;
if ( status < 0 | | hier_val = = 0 )
continue ;
status = ab8500_handle_hierarchical_latch ( ab8500 , i , hier_val ) ;
if ( status < 0 )
break ;
}
return IRQ_HANDLED ;
}
2012-06-20 13:56:37 +01:00
static int ab8500_irq_map ( struct irq_domain * d , unsigned int virq ,
irq_hw_number_t hwirq )
{
struct ab8500 * ab8500 = d - > host_data ;
if ( ! ab8500 )
return - EINVAL ;
irq_set_chip_data ( virq , ab8500 ) ;
irq_set_chip_and_handler ( virq , & ab8500_irq_chip ,
handle_simple_irq ) ;
irq_set_nested_thread ( virq , 1 ) ;
irq_set_noprobe ( virq ) ;
2010-05-19 11:39:02 +02:00
return 0 ;
}
2015-04-27 21:54:13 +09:00
static const struct irq_domain_ops ab8500_irq_ops = {
mfd: ab8500-core: Resolve code style issues
Soothes the following checkpatch warnings:
WARNING: line over 80 characters
#151: FILE: drivers/mfd/ab8500-core.c:151:
+ 0, 1, 2, 3, 4, -1, -1, -1, -1, 11, 18, 19, 20, 21, 12, 13, 24, 5, 22, 23,
ERROR: spaces required around that '=' (ctx:VxW)
#325: FILE: drivers/mfd/ab8500-core.c:325:
+ ret= mask_and_set_register_interruptible(ab8500, bank, reg,
^
WARNING: line over 80 characters
#418: FILE: drivers/mfd/ab8500-core.c:418:
+ else if (offset >= AB9540_INT_GPIO50R && offset <= AB9540_INT_GPIO54R)
WARNING: line over 80 characters
#420: FILE: drivers/mfd/ab8500-core.c:420:
+ else if (offset == AB8540_INT_GPIO43R || offset == AB8540_INT_GPIO44R)
ERROR: spaces required around that '==' (ctx:VxV)
#454: FILE: drivers/mfd/ab8500-core.c:454:
+ if ((i==3) && (*offset >= 24))
^
ERROR: code indent should use tabs where possible
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
WARNING: please, no spaces at the start of a line
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
ERROR: code indent should use tabs where possible
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: please, no spaces at the start of a line
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: char * array declaration might be better as static const
#1554: FILE: drivers/mfd/ab8500-core.c:1554:
+ static char *switch_off_status[] = {
WARNING: char * array declaration might be better as static const
#1563: FILE: drivers/mfd/ab8500-core.c:1563:
+ static char *turn_on_status[] = {
WARNING: sizeof *ab8500 should be sizeof(*ab8500)
#1582: FILE: drivers/mfd/ab8500-core.c:1582:
+ ab8500 = devm_kzalloc(&pdev->dev, sizeof *ab8500, GFP_KERNEL);
ERROR: space required after that close brace '}'
#1639: FILE: drivers/mfd/ab8500-core.c:1639:
+ }/* Configure AB8500 or AB9540 IRQ */
WARNING: line over 80 characters
#1652: FILE: drivers/mfd/ab8500-core.c:1652:
+ ab8500->oldmask = devm_kzalloc(&pdev->dev, ab8500->mask_size, GFP_KERNEL);
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1677: FILE: drivers/mfd/ab8500-core.c:1677:
+ printk(KERN_CONT " \"%s\"",
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1682: FILE: drivers/mfd/ab8500-core.c:1682:
+ printk(KERN_CONT "\n");
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1684: FILE: drivers/mfd/ab8500-core.c:1684:
+ printk(KERN_CONT " None\n");
WARNING: printk() should include KERN_ facility level
#1695: FILE: drivers/mfd/ab8500-core.c:1695:
+ printk("\"%s\" ", turn_on_status[i]);
WARNING: printk() should include KERN_ facility level
#1700: FILE: drivers/mfd/ab8500-core.c:1700:
+ printk("None\n");
total: 5 errors, 14 warnings, 1869 lines checked
Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Lee Jones <lee.jones@linaro.org>
2014-05-08 14:11:37 +01:00
. map = ab8500_irq_map ,
. xlate = irq_domain_xlate_twocell ,
2012-06-20 13:56:37 +01:00
} ;
static int ab8500_irq_init ( struct ab8500 * ab8500 , struct device_node * np )
2010-05-19 11:39:02 +02:00
{
2012-02-20 21:42:17 +01:00
int num_irqs ;
2013-02-25 14:57:35 +00:00
if ( is_ab8540 ( ab8500 ) )
num_irqs = AB8540_NR_IRQS ;
else if ( is_ab9540 ( ab8500 ) )
2012-02-20 21:42:24 +01:00
num_irqs = AB9540_NR_IRQS ;
2012-03-08 14:01:57 +01:00
else if ( is_ab8505 ( ab8500 ) )
num_irqs = AB8505_NR_IRQS ;
2012-02-20 21:42:24 +01:00
else
num_irqs = AB8500_NR_IRQS ;
2010-05-19 11:39:02 +02:00
2012-10-18 18:18:44 +02:00
/* If ->irq_base is zero this will give a linear mapping */
2014-06-02 19:27:58 +03:00
ab8500 - > domain = irq_domain_add_simple ( ab8500 - > dev - > of_node ,
2015-10-28 09:15:02 +00:00
num_irqs , 0 ,
& ab8500_irq_ops , ab8500 ) ;
2012-06-20 13:56:37 +01:00
if ( ! ab8500 - > domain ) {
dev_err ( ab8500 - > dev , " Failed to create irqdomain \n " ) ;
2015-10-28 09:15:02 +00:00
return - ENODEV ;
2012-06-20 13:56:37 +01:00
}
return 0 ;
2010-05-19 11:39:02 +02:00
}
2012-04-17 09:30:33 +02:00
int ab8500_suspend ( struct ab8500 * ab8500 )
{
if ( atomic_read ( & ab8500 - > transfer_ongoing ) )
return - EINVAL ;
2014-07-02 11:13:42 +01:00
return 0 ;
2012-04-17 09:30:33 +02:00
}
2013-11-18 14:33:06 +01:00
static const struct mfd_cell ab8500_bm_devs [ ] = {
2013-02-25 14:42:00 +00:00
{
. name = " ab8500-charger " ,
. of_compatible = " stericsson,ab8500-charger " ,
. platform_data = & ab8500_bm_data ,
. pdata_size = sizeof ( ab8500_bm_data ) ,
} ,
{
. name = " ab8500-btemp " ,
. of_compatible = " stericsson,ab8500-btemp " ,
. platform_data = & ab8500_bm_data ,
. pdata_size = sizeof ( ab8500_bm_data ) ,
} ,
{
. name = " ab8500-fg " ,
. of_compatible = " stericsson,ab8500-fg " ,
. platform_data = & ab8500_bm_data ,
. pdata_size = sizeof ( ab8500_bm_data ) ,
} ,
{
. name = " ab8500-chargalg " ,
. of_compatible = " stericsson,ab8500-chargalg " ,
. platform_data = & ab8500_bm_data ,
. pdata_size = sizeof ( ab8500_bm_data ) ,
} ,
} ;
2013-11-18 14:33:06 +01:00
static const struct mfd_cell ab8500_devs [ ] = {
2010-09-13 16:05:04 +02:00
# ifdef CONFIG_DEBUG_FS
{
. name = " ab8500-debug " ,
2012-07-02 17:10:56 +02:00
. of_compatible = " stericsson,ab8500-debug " ,
2010-09-13 16:05:04 +02:00
} ,
# endif
2010-12-02 15:40:31 +01:00
{
. name = " ab8500-sysctrl " ,
2012-07-02 17:10:56 +02:00
. of_compatible = " stericsson,ab8500-sysctrl " ,
2010-12-02 15:40:31 +01:00
} ,
2013-06-07 16:07:47 +01:00
{
. name = " ab8500-ext-regulator " ,
. of_compatible = " stericsson,ab8500-ext-regulator " ,
} ,
2010-12-02 15:40:31 +01:00
{
. name = " ab8500-regulator " ,
2012-07-02 17:10:56 +02:00
. of_compatible = " stericsson,ab8500-regulator " ,
2010-12-02 15:40:31 +01:00
} ,
2012-11-22 11:35:40 +01:00
{
2017-01-13 16:10:20 +01:00
. name = " ab8500-clk " ,
. of_compatible = " stericsson,ab8500-clk " ,
2012-11-22 11:35:40 +01:00
} ,
2013-02-25 14:42:00 +00:00
{
. name = " ab8500-gpadc " ,
2013-05-08 14:29:09 +01:00
. of_compatible = " stericsson,ab8500-gpadc " ,
2013-02-25 14:42:00 +00:00
} ,
2010-05-19 11:39:02 +02:00
{
. name = " ab8500-rtc " ,
2012-07-02 17:10:56 +02:00
. of_compatible = " stericsson,ab8500-rtc " ,
2010-05-19 11:39:02 +02:00
} ,
2011-06-09 23:57:45 +02:00
{
. name = " ab8500-acc-det " ,
2012-07-02 17:10:56 +02:00
. of_compatible = " stericsson,ab8500-acc-det " ,
2011-06-09 23:57:45 +02:00
} ,
2010-12-02 15:40:31 +01:00
{
2013-02-25 14:42:00 +00:00
2010-12-02 15:40:31 +01:00
. name = " ab8500-poweron-key " ,
2012-07-02 17:10:56 +02:00
. of_compatible = " stericsson,ab8500-poweron-key " ,
2010-12-02 15:40:31 +01:00
} ,
2010-09-06 12:24:52 +05:30
{
. name = " ab8500-pwm " ,
2012-07-02 17:10:56 +02:00
. of_compatible = " stericsson,ab8500-pwm " ,
2010-09-06 12:24:52 +05:30
. id = 1 ,
} ,
{
. name = " ab8500-pwm " ,
2012-07-02 17:10:56 +02:00
. of_compatible = " stericsson,ab8500-pwm " ,
2010-09-06 12:24:52 +05:30
. id = 2 ,
} ,
{
. name = " ab8500-pwm " ,
2012-07-02 17:10:56 +02:00
. of_compatible = " stericsson,ab8500-pwm " ,
2010-09-06 12:24:52 +05:30
. id = 3 ,
} ,
2010-09-05 12:18:47 -07:00
{
2010-12-02 15:40:31 +01:00
. name = " ab8500-denc " ,
2012-07-02 17:10:56 +02:00
. of_compatible = " stericsson,ab8500-denc " ,
2010-12-02 15:40:31 +01:00
} ,
2013-02-25 14:42:00 +00:00
{
2013-05-07 11:29:55 +01:00
. name = " pinctrl-ab8500 " ,
2013-02-25 14:42:00 +00:00
. of_compatible = " stericsson,ab8500-gpio " ,
} ,
2010-12-02 15:40:31 +01:00
{
2013-01-30 18:21:27 +08:00
. name = " abx500-temp " ,
. of_compatible = " stericsson,abx500-temp " ,
2010-09-05 12:18:47 -07:00
} ,
2012-04-17 09:30:57 +02:00
{
2013-02-25 14:42:00 +00:00
. name = " ab8500-usb " ,
2013-04-09 10:57:21 +02:00
. of_compatible = " stericsson,ab8500-usb " ,
2012-04-17 09:30:57 +02:00
} ,
{
2013-02-25 14:42:00 +00:00
. name = " ab8500-codec " ,
2013-05-30 15:27:45 +02:00
. of_compatible = " stericsson,ab8500-codec " ,
2012-04-17 09:30:57 +02:00
} ,
} ;
2013-11-18 14:33:06 +01:00
static const struct mfd_cell ab9540_devs [ ] = {
2013-02-25 14:42:00 +00:00
# ifdef CONFIG_DEBUG_FS
2012-02-20 21:42:24 +01:00
{
2013-02-25 14:42:00 +00:00
. name = " ab8500-debug " ,
2012-02-20 21:42:24 +01:00
} ,
2013-02-25 14:42:00 +00:00
# endif
2012-02-20 21:42:24 +01:00
{
2013-02-25 14:42:00 +00:00
. name = " ab8500-sysctrl " ,
2012-02-20 21:42:24 +01:00
} ,
2013-06-07 16:07:47 +01:00
{
. name = " ab8500-ext-regulator " ,
} ,
2012-04-17 09:30:14 +02:00
{
2013-02-25 14:42:00 +00:00
. name = " ab8500-regulator " ,
2012-04-17 09:30:14 +02:00
} ,
2012-11-20 14:57:25 +01:00
{
. name = " abx500-clk " ,
. of_compatible = " stericsson,abx500-clk " ,
} ,
2013-02-12 15:04:09 +00:00
{
. name = " ab8500-gpadc " ,
. of_compatible = " stericsson,ab8500-gpadc " ,
} ,
2013-02-25 14:42:00 +00:00
{
. name = " ab8500-rtc " ,
} ,
{
. name = " ab8500-acc-det " ,
} ,
{
. name = " ab8500-poweron-key " ,
} ,
{
. name = " ab8500-pwm " ,
. id = 1 ,
} ,
{
. name = " abx500-temp " ,
} ,
2012-02-20 21:42:24 +01:00
{
2013-01-16 15:09:36 +00:00
. name = " pinctrl-ab9540 " ,
. of_compatible = " stericsson,ab9540-gpio " ,
2012-02-20 21:42:24 +01:00
} ,
{
. name = " ab9540-usb " ,
} ,
2012-04-17 09:30:14 +02:00
{
. name = " ab9540-codec " ,
} ,
2013-02-12 15:04:09 +00:00
{
. name = " ab-iddet " ,
} ,
2012-04-17 09:30:14 +02:00
} ;
2013-02-12 15:04:09 +00:00
/* Device list for ab8505 */
2013-11-18 14:33:06 +01:00
static const struct mfd_cell ab8505_devs [ ] = {
2013-02-25 14:42:00 +00:00
# ifdef CONFIG_DEBUG_FS
{
. name = " ab8500-debug " ,
} ,
# endif
{
. name = " ab8500-sysctrl " ,
} ,
{
. name = " ab8500-regulator " ,
} ,
2012-11-20 14:57:25 +01:00
{
. name = " abx500-clk " ,
. of_compatible = " stericsson,abx500-clk " ,
} ,
2013-02-25 14:42:00 +00:00
{
. name = " ab8500-gpadc " ,
2013-05-08 14:29:09 +01:00
. of_compatible = " stericsson,ab8500-gpadc " ,
2013-02-25 14:42:00 +00:00
} ,
{
. name = " ab8500-rtc " ,
} ,
{
. name = " ab8500-acc-det " ,
} ,
{
. name = " ab8500-poweron-key " ,
} ,
{
. name = " ab8500-pwm " ,
. id = 1 ,
} ,
{
2013-05-07 11:29:55 +01:00
. name = " pinctrl-ab8505 " ,
2013-02-25 14:42:00 +00:00
} ,
{
. name = " ab8500-usb " ,
} ,
{
. name = " ab8500-codec " ,
} ,
2013-02-12 15:04:09 +00:00
{
. name = " ab-iddet " ,
} ,
} ;
2013-11-18 14:33:06 +01:00
static const struct mfd_cell ab8540_devs [ ] = {
2013-02-25 14:42:00 +00:00
# ifdef CONFIG_DEBUG_FS
{
. name = " ab8500-debug " ,
} ,
# endif
{
. name = " ab8500-sysctrl " ,
} ,
2013-06-07 16:07:47 +01:00
{
. name = " ab8500-ext-regulator " ,
} ,
2013-02-25 14:42:00 +00:00
{
. name = " ab8500-regulator " ,
} ,
2012-11-20 14:57:25 +01:00
{
. name = " abx500-clk " ,
. of_compatible = " stericsson,abx500-clk " ,
} ,
2013-02-25 14:42:00 +00:00
{
. name = " ab8500-gpadc " ,
2013-05-08 14:29:09 +01:00
. of_compatible = " stericsson,ab8500-gpadc " ,
2013-02-25 14:42:00 +00:00
} ,
{
. name = " ab8500-acc-det " ,
} ,
{
. name = " ab8500-poweron-key " ,
} ,
{
. name = " ab8500-pwm " ,
. id = 1 ,
} ,
{
. name = " abx500-temp " ,
} ,
2013-02-12 15:04:09 +00:00
{
2013-05-07 11:29:55 +01:00
. name = " pinctrl-ab8540 " ,
2013-02-12 15:04:09 +00:00
} ,
{
. name = " ab8540-usb " ,
} ,
{
. name = " ab8540-codec " ,
} ,
2012-04-17 09:30:14 +02:00
{
. name = " ab-iddet " ,
} ,
2012-02-20 21:42:24 +01:00
} ;
2013-11-18 14:33:06 +01:00
static const struct mfd_cell ab8540_cut1_devs [ ] = {
2013-05-24 11:59:47 +02:00
{
. name = " ab8500-rtc " ,
. of_compatible = " stericsson,ab8500-rtc " ,
} ,
} ;
2013-11-18 14:33:06 +01:00
static const struct mfd_cell ab8540_cut2_devs [ ] = {
2013-05-24 11:59:47 +02:00
{
. name = " ab8540-rtc " ,
. of_compatible = " stericsson,ab8540-rtc " ,
} ,
} ;
2010-12-02 15:09:36 +01:00
static ssize_t show_chip_id ( struct device * dev ,
struct device_attribute * attr , char * buf )
{
struct ab8500 * ab8500 ;
ab8500 = dev_get_drvdata ( dev ) ;
2013-02-26 10:09:41 +00:00
2010-12-02 15:09:36 +01:00
return sprintf ( buf , " %#x \n " , ab8500 ? ab8500 - > chip_id : - EINVAL ) ;
}
2011-03-02 11:52:36 +01:00
/*
* ab8500 has switched off due to ( SWITCH_OFF_STATUS ) :
* 0x01 Swoff bit programming
* 0x02 Thermal protection activation
* 0x04 Vbat lower then BattOk falling threshold
* 0x08 Watchdog expired
* 0x10 Non presence of 32 kHz clock
* 0x20 Battery level lower than power on reset threshold
* 0x40 Power on key 1 pressed longer than 10 seconds
* 0x80 DB8500 thermal shutdown
*/
static ssize_t show_switch_off_status ( struct device * dev ,
struct device_attribute * attr , char * buf )
{
int ret ;
u8 value ;
struct ab8500 * ab8500 ;
ab8500 = dev_get_drvdata ( dev ) ;
ret = get_register_interruptible ( ab8500 , AB8500_RTC ,
AB8500_SWITCH_OFF_STATUS , & value ) ;
if ( ret < 0 )
return ret ;
return sprintf ( buf , " %#x \n " , value ) ;
}
2012-05-30 16:32:37 +05:30
/* use mask and set to override the register turn_on_stat value */
void ab8500_override_turn_on_stat ( u8 mask , u8 set )
{
spin_lock ( & on_stat_lock ) ;
turn_on_stat_mask = mask ;
turn_on_stat_set = set ;
spin_unlock ( & on_stat_lock ) ;
}
2011-10-11 10:49:47 +02:00
/*
* ab8500 has turned on due to ( TURN_ON_STATUS ) :
* 0x01 PORnVbat
* 0x02 PonKey1dbF
* 0x04 PonKey2dbF
* 0x08 RTCAlarm
* 0x10 MainChDet
* 0x20 VbusDet
* 0x40 UsbIDDetect
* 0x80 Reserved
*/
static ssize_t show_turn_on_status ( struct device * dev ,
struct device_attribute * attr , char * buf )
{
int ret ;
u8 value ;
struct ab8500 * ab8500 ;
ab8500 = dev_get_drvdata ( dev ) ;
ret = get_register_interruptible ( ab8500 , AB8500_SYS_CTRL1_BLOCK ,
AB8500_TURN_ON_STATUS , & value ) ;
if ( ret < 0 )
return ret ;
2012-05-30 16:32:37 +05:30
/*
* In L9540 , turn_on_status register is not updated correctly if
* the device is rebooted with AC / USB charger connected . Due to
* this , the device boots android instead of entering into charge
* only mode . Read the AC / USB status register to detect the charger
* presence and update the turn on status manually .
*/
if ( is_ab9540 ( ab8500 ) ) {
spin_lock ( & on_stat_lock ) ;
value = ( value & turn_on_stat_mask ) | turn_on_stat_set ;
spin_unlock ( & on_stat_lock ) ;
}
2011-10-11 10:49:47 +02:00
return sprintf ( buf , " %#x \n " , value ) ;
}
2012-05-31 16:16:36 +02:00
static ssize_t show_turn_on_status_2 ( struct device * dev ,
struct device_attribute * attr , char * buf )
{
int ret ;
u8 value ;
struct ab8500 * ab8500 ;
ab8500 = dev_get_drvdata ( dev ) ;
ret = get_register_interruptible ( ab8500 , AB8500_SYS_CTRL1_BLOCK ,
AB8505_TURN_ON_STATUS_2 , & value ) ;
if ( ret < 0 )
return ret ;
return sprintf ( buf , " %#x \n " , ( value & 0x1 ) ) ;
}
2012-02-20 21:42:24 +01:00
static ssize_t show_ab9540_dbbrstn ( struct device * dev ,
struct device_attribute * attr , char * buf )
{
struct ab8500 * ab8500 ;
int ret ;
u8 value ;
ab8500 = dev_get_drvdata ( dev ) ;
ret = get_register_interruptible ( ab8500 , AB8500_REGU_CTRL2 ,
AB9540_MODEM_CTRL2_REG , & value ) ;
if ( ret < 0 )
return ret ;
return sprintf ( buf , " %d \n " ,
( value & AB9540_MODEM_CTRL2_SWDBBRSTN_BIT ) ? 1 : 0 ) ;
}
static ssize_t store_ab9540_dbbrstn ( struct device * dev ,
struct device_attribute * attr , const char * buf , size_t count )
{
struct ab8500 * ab8500 ;
int ret = count ;
int err ;
u8 bitvalues ;
ab8500 = dev_get_drvdata ( dev ) ;
if ( count > 0 ) {
switch ( buf [ 0 ] ) {
case ' 0 ' :
bitvalues = 0 ;
break ;
case ' 1 ' :
bitvalues = AB9540_MODEM_CTRL2_SWDBBRSTN_BIT ;
break ;
default :
goto exit ;
}
err = mask_and_set_register_interruptible ( ab8500 ,
AB8500_REGU_CTRL2 , AB9540_MODEM_CTRL2_REG ,
AB9540_MODEM_CTRL2_SWDBBRSTN_BIT , bitvalues ) ;
if ( err )
dev_info ( ab8500 - > dev ,
" Failed to set DBBRSTN %c, err %#x \n " ,
buf [ 0 ] , err ) ;
}
exit :
return ret ;
}
2010-12-02 15:09:36 +01:00
static DEVICE_ATTR ( chip_id , S_IRUGO , show_chip_id , NULL ) ;
2011-03-02 11:52:36 +01:00
static DEVICE_ATTR ( switch_off_status , S_IRUGO , show_switch_off_status , NULL ) ;
2011-10-11 10:49:47 +02:00
static DEVICE_ATTR ( turn_on_status , S_IRUGO , show_turn_on_status , NULL ) ;
2012-05-31 16:16:36 +02:00
static DEVICE_ATTR ( turn_on_status_2 , S_IRUGO , show_turn_on_status_2 , NULL ) ;
2012-02-20 21:42:24 +01:00
static DEVICE_ATTR ( dbbrstn , S_IRUGO | S_IWUSR ,
show_ab9540_dbbrstn , store_ab9540_dbbrstn ) ;
2010-12-02 15:09:36 +01:00
static struct attribute * ab8500_sysfs_entries [ ] = {
& dev_attr_chip_id . attr ,
2011-03-02 11:52:36 +01:00
& dev_attr_switch_off_status . attr ,
2011-10-11 10:49:47 +02:00
& dev_attr_turn_on_status . attr ,
2010-12-02 15:09:36 +01:00
NULL ,
} ;
2012-05-31 16:16:36 +02:00
static struct attribute * ab8505_sysfs_entries [ ] = {
& dev_attr_turn_on_status_2 . attr ,
NULL ,
} ;
2012-02-20 21:42:24 +01:00
static struct attribute * ab9540_sysfs_entries [ ] = {
& dev_attr_chip_id . attr ,
& dev_attr_switch_off_status . attr ,
& dev_attr_turn_on_status . attr ,
& dev_attr_dbbrstn . attr ,
NULL ,
} ;
2017-07-10 11:07:22 +05:30
static const struct attribute_group ab8500_attr_group = {
2010-12-02 15:09:36 +01:00
. attrs = ab8500_sysfs_entries ,
} ;
2017-07-10 11:07:22 +05:30
static const struct attribute_group ab8505_attr_group = {
2012-05-31 16:16:36 +02:00
. attrs = ab8505_sysfs_entries ,
} ;
2017-07-10 11:07:22 +05:30
static const struct attribute_group ab9540_attr_group = {
2012-02-20 21:42:24 +01:00
. attrs = ab9540_sysfs_entries ,
} ;
2012-11-19 13:23:04 -05:00
static int ab8500_probe ( struct platform_device * pdev )
2010-05-19 11:39:02 +02:00
{
2015-10-28 09:15:02 +00:00
static const char * const switch_off_status [ ] = {
2012-06-29 17:46:12 +02:00
" Swoff bit programming " ,
" Thermal protection activation " ,
" Vbat lower then BattOk falling threshold " ,
" Watchdog expired " ,
" Non presence of 32kHz clock " ,
" Battery level lower than power on reset threshold " ,
" Power on key 1 pressed longer than 10 seconds " ,
" DB8500 thermal shutdown " } ;
2015-10-28 09:15:02 +00:00
static const char * const turn_on_status [ ] = {
2012-09-28 09:34:24 +02:00
" Battery rising (Vbat) " ,
" Power On Key 1 dbF " ,
" Power On Key 2 dbF " ,
" RTC Alarm " ,
" Main Charger Detect " ,
" Vbus Detect (USB) " ,
" USB ID Detect " ,
" UART Factory Mode Detect " } ;
2012-05-19 17:21:37 +02:00
const struct platform_device_id * platid = platform_get_device_id ( pdev ) ;
2012-05-17 14:45:13 +01:00
enum ab8500_version version = AB8500_VERSION_UNDEFINED ;
struct device_node * np = pdev - > dev . of_node ;
2012-05-19 17:21:37 +02:00
struct ab8500 * ab8500 ;
struct resource * resource ;
2010-05-19 11:39:02 +02:00
int ret ;
int i ;
2010-09-10 17:47:56 +02:00
u8 value ;
2010-05-19 11:39:02 +02:00
mfd: ab8500-core: Resolve code style issues
Soothes the following checkpatch warnings:
WARNING: line over 80 characters
#151: FILE: drivers/mfd/ab8500-core.c:151:
+ 0, 1, 2, 3, 4, -1, -1, -1, -1, 11, 18, 19, 20, 21, 12, 13, 24, 5, 22, 23,
ERROR: spaces required around that '=' (ctx:VxW)
#325: FILE: drivers/mfd/ab8500-core.c:325:
+ ret= mask_and_set_register_interruptible(ab8500, bank, reg,
^
WARNING: line over 80 characters
#418: FILE: drivers/mfd/ab8500-core.c:418:
+ else if (offset >= AB9540_INT_GPIO50R && offset <= AB9540_INT_GPIO54R)
WARNING: line over 80 characters
#420: FILE: drivers/mfd/ab8500-core.c:420:
+ else if (offset == AB8540_INT_GPIO43R || offset == AB8540_INT_GPIO44R)
ERROR: spaces required around that '==' (ctx:VxV)
#454: FILE: drivers/mfd/ab8500-core.c:454:
+ if ((i==3) && (*offset >= 24))
^
ERROR: code indent should use tabs where possible
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
WARNING: please, no spaces at the start of a line
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
ERROR: code indent should use tabs where possible
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: please, no spaces at the start of a line
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: char * array declaration might be better as static const
#1554: FILE: drivers/mfd/ab8500-core.c:1554:
+ static char *switch_off_status[] = {
WARNING: char * array declaration might be better as static const
#1563: FILE: drivers/mfd/ab8500-core.c:1563:
+ static char *turn_on_status[] = {
WARNING: sizeof *ab8500 should be sizeof(*ab8500)
#1582: FILE: drivers/mfd/ab8500-core.c:1582:
+ ab8500 = devm_kzalloc(&pdev->dev, sizeof *ab8500, GFP_KERNEL);
ERROR: space required after that close brace '}'
#1639: FILE: drivers/mfd/ab8500-core.c:1639:
+ }/* Configure AB8500 or AB9540 IRQ */
WARNING: line over 80 characters
#1652: FILE: drivers/mfd/ab8500-core.c:1652:
+ ab8500->oldmask = devm_kzalloc(&pdev->dev, ab8500->mask_size, GFP_KERNEL);
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1677: FILE: drivers/mfd/ab8500-core.c:1677:
+ printk(KERN_CONT " \"%s\"",
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1682: FILE: drivers/mfd/ab8500-core.c:1682:
+ printk(KERN_CONT "\n");
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1684: FILE: drivers/mfd/ab8500-core.c:1684:
+ printk(KERN_CONT " None\n");
WARNING: printk() should include KERN_ facility level
#1695: FILE: drivers/mfd/ab8500-core.c:1695:
+ printk("\"%s\" ", turn_on_status[i]);
WARNING: printk() should include KERN_ facility level
#1700: FILE: drivers/mfd/ab8500-core.c:1700:
+ printk("None\n");
total: 5 errors, 14 warnings, 1869 lines checked
Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Lee Jones <lee.jones@linaro.org>
2014-05-08 14:11:37 +01:00
ab8500 = devm_kzalloc ( & pdev - > dev , sizeof ( * ab8500 ) , GFP_KERNEL ) ;
2012-05-19 17:21:37 +02:00
if ( ! ab8500 )
return - ENOMEM ;
ab8500 - > dev = & pdev - > dev ;
resource = platform_get_resource ( pdev , IORESOURCE_IRQ , 0 ) ;
2014-02-04 00:35:56 +01:00
if ( ! resource ) {
dev_err ( & pdev - > dev , " no IRQ resource \n " ) ;
2012-11-05 16:10:35 +01:00
return - ENODEV ;
2014-02-04 00:35:56 +01:00
}
2012-05-19 17:21:37 +02:00
ab8500 - > irq = resource - > start ;
2012-06-20 13:56:38 +01:00
ab8500 - > read = ab8500_prcmu_read ;
ab8500 - > write = ab8500_prcmu_write ;
ab8500 - > write_masked = ab8500_prcmu_write_masked ;
2012-05-19 17:21:37 +02:00
2010-05-19 11:39:02 +02:00
mutex_init ( & ab8500 - > lock ) ;
mutex_init ( & ab8500 - > irq_lock ) ;
2012-04-17 09:30:33 +02:00
atomic_set ( & ab8500 - > transfer_ongoing , 0 ) ;
2010-05-19 11:39:02 +02:00
2012-05-19 17:21:37 +02:00
platform_set_drvdata ( pdev , ab8500 ) ;
2012-05-17 14:45:13 +01:00
if ( platid )
version = platid - > driver_data ;
2012-02-20 21:42:10 +01:00
if ( version ! = AB8500_VERSION_UNDEFINED )
ab8500 - > version = version ;
else {
ret = get_register_interruptible ( ab8500 , AB8500_MISC ,
AB8500_IC_NAME_REG , & value ) ;
2014-02-04 00:35:56 +01:00
if ( ret < 0 ) {
dev_err ( & pdev - > dev , " could not probe HW \n " ) ;
2012-11-05 16:10:35 +01:00
return ret ;
2014-02-04 00:35:56 +01:00
}
2012-02-20 21:42:10 +01:00
ab8500 - > version = value ;
}
2010-09-10 17:47:56 +02:00
ret = get_register_interruptible ( ab8500 , AB8500_MISC ,
AB8500_REV_REG , & value ) ;
2010-05-19 11:39:02 +02:00
if ( ret < 0 )
2012-11-05 16:10:35 +01:00
return ret ;
2010-05-19 11:39:02 +02:00
2010-09-10 17:47:56 +02:00
ab8500 - > chip_id = value ;
2010-05-19 11:39:02 +02:00
2012-02-20 21:42:10 +01:00
dev_info ( ab8500 - > dev , " detected chip, %s rev. %1x.%1x \n " ,
ab8500_version_str [ ab8500 - > version ] ,
ab8500 - > chip_id > > 4 ,
ab8500 - > chip_id & 0x0F ) ;
2013-02-25 14:57:35 +00:00
/* Configure AB8540 */
if ( is_ab8540 ( ab8500 ) ) {
ab8500 - > mask_size = AB8540_NUM_IRQ_REGS ;
ab8500 - > irq_reg_offset = ab8540_irq_regoffset ;
ab8500 - > it_latchhier_num = AB8540_IT_LATCHHIER_NUM ;
mfd: ab8500-core: Resolve code style issues
Soothes the following checkpatch warnings:
WARNING: line over 80 characters
#151: FILE: drivers/mfd/ab8500-core.c:151:
+ 0, 1, 2, 3, 4, -1, -1, -1, -1, 11, 18, 19, 20, 21, 12, 13, 24, 5, 22, 23,
ERROR: spaces required around that '=' (ctx:VxW)
#325: FILE: drivers/mfd/ab8500-core.c:325:
+ ret= mask_and_set_register_interruptible(ab8500, bank, reg,
^
WARNING: line over 80 characters
#418: FILE: drivers/mfd/ab8500-core.c:418:
+ else if (offset >= AB9540_INT_GPIO50R && offset <= AB9540_INT_GPIO54R)
WARNING: line over 80 characters
#420: FILE: drivers/mfd/ab8500-core.c:420:
+ else if (offset == AB8540_INT_GPIO43R || offset == AB8540_INT_GPIO44R)
ERROR: spaces required around that '==' (ctx:VxV)
#454: FILE: drivers/mfd/ab8500-core.c:454:
+ if ((i==3) && (*offset >= 24))
^
ERROR: code indent should use tabs where possible
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
WARNING: please, no spaces at the start of a line
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
ERROR: code indent should use tabs where possible
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: please, no spaces at the start of a line
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: char * array declaration might be better as static const
#1554: FILE: drivers/mfd/ab8500-core.c:1554:
+ static char *switch_off_status[] = {
WARNING: char * array declaration might be better as static const
#1563: FILE: drivers/mfd/ab8500-core.c:1563:
+ static char *turn_on_status[] = {
WARNING: sizeof *ab8500 should be sizeof(*ab8500)
#1582: FILE: drivers/mfd/ab8500-core.c:1582:
+ ab8500 = devm_kzalloc(&pdev->dev, sizeof *ab8500, GFP_KERNEL);
ERROR: space required after that close brace '}'
#1639: FILE: drivers/mfd/ab8500-core.c:1639:
+ }/* Configure AB8500 or AB9540 IRQ */
WARNING: line over 80 characters
#1652: FILE: drivers/mfd/ab8500-core.c:1652:
+ ab8500->oldmask = devm_kzalloc(&pdev->dev, ab8500->mask_size, GFP_KERNEL);
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1677: FILE: drivers/mfd/ab8500-core.c:1677:
+ printk(KERN_CONT " \"%s\"",
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1682: FILE: drivers/mfd/ab8500-core.c:1682:
+ printk(KERN_CONT "\n");
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1684: FILE: drivers/mfd/ab8500-core.c:1684:
+ printk(KERN_CONT " None\n");
WARNING: printk() should include KERN_ facility level
#1695: FILE: drivers/mfd/ab8500-core.c:1695:
+ printk("\"%s\" ", turn_on_status[i]);
WARNING: printk() should include KERN_ facility level
#1700: FILE: drivers/mfd/ab8500-core.c:1700:
+ printk("None\n");
total: 5 errors, 14 warnings, 1869 lines checked
Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Lee Jones <lee.jones@linaro.org>
2014-05-08 14:11:37 +01:00
} /* Configure AB8500 or AB9540 IRQ */
2013-02-25 14:57:35 +00:00
else if ( is_ab9540 ( ab8500 ) | | is_ab8505 ( ab8500 ) ) {
2012-02-20 21:42:24 +01:00
ab8500 - > mask_size = AB9540_NUM_IRQ_REGS ;
ab8500 - > irq_reg_offset = ab9540_irq_regoffset ;
2013-02-25 14:57:35 +00:00
ab8500 - > it_latchhier_num = AB8500_IT_LATCHHIER_NUM ;
2012-02-20 21:42:24 +01:00
} else {
ab8500 - > mask_size = AB8500_NUM_IRQ_REGS ;
ab8500 - > irq_reg_offset = ab8500_irq_regoffset ;
2013-02-25 14:57:35 +00:00
ab8500 - > it_latchhier_num = AB8500_IT_LATCHHIER_NUM ;
2012-02-20 21:42:24 +01:00
}
mfd: ab8500-core: Resolve code style issues
Soothes the following checkpatch warnings:
WARNING: line over 80 characters
#151: FILE: drivers/mfd/ab8500-core.c:151:
+ 0, 1, 2, 3, 4, -1, -1, -1, -1, 11, 18, 19, 20, 21, 12, 13, 24, 5, 22, 23,
ERROR: spaces required around that '=' (ctx:VxW)
#325: FILE: drivers/mfd/ab8500-core.c:325:
+ ret= mask_and_set_register_interruptible(ab8500, bank, reg,
^
WARNING: line over 80 characters
#418: FILE: drivers/mfd/ab8500-core.c:418:
+ else if (offset >= AB9540_INT_GPIO50R && offset <= AB9540_INT_GPIO54R)
WARNING: line over 80 characters
#420: FILE: drivers/mfd/ab8500-core.c:420:
+ else if (offset == AB8540_INT_GPIO43R || offset == AB8540_INT_GPIO44R)
ERROR: spaces required around that '==' (ctx:VxV)
#454: FILE: drivers/mfd/ab8500-core.c:454:
+ if ((i==3) && (*offset >= 24))
^
ERROR: code indent should use tabs where possible
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
WARNING: please, no spaces at the start of a line
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
ERROR: code indent should use tabs where possible
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: please, no spaces at the start of a line
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: char * array declaration might be better as static const
#1554: FILE: drivers/mfd/ab8500-core.c:1554:
+ static char *switch_off_status[] = {
WARNING: char * array declaration might be better as static const
#1563: FILE: drivers/mfd/ab8500-core.c:1563:
+ static char *turn_on_status[] = {
WARNING: sizeof *ab8500 should be sizeof(*ab8500)
#1582: FILE: drivers/mfd/ab8500-core.c:1582:
+ ab8500 = devm_kzalloc(&pdev->dev, sizeof *ab8500, GFP_KERNEL);
ERROR: space required after that close brace '}'
#1639: FILE: drivers/mfd/ab8500-core.c:1639:
+ }/* Configure AB8500 or AB9540 IRQ */
WARNING: line over 80 characters
#1652: FILE: drivers/mfd/ab8500-core.c:1652:
+ ab8500->oldmask = devm_kzalloc(&pdev->dev, ab8500->mask_size, GFP_KERNEL);
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1677: FILE: drivers/mfd/ab8500-core.c:1677:
+ printk(KERN_CONT " \"%s\"",
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1682: FILE: drivers/mfd/ab8500-core.c:1682:
+ printk(KERN_CONT "\n");
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1684: FILE: drivers/mfd/ab8500-core.c:1684:
+ printk(KERN_CONT " None\n");
WARNING: printk() should include KERN_ facility level
#1695: FILE: drivers/mfd/ab8500-core.c:1695:
+ printk("\"%s\" ", turn_on_status[i]);
WARNING: printk() should include KERN_ facility level
#1700: FILE: drivers/mfd/ab8500-core.c:1700:
+ printk("None\n");
total: 5 errors, 14 warnings, 1869 lines checked
Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Lee Jones <lee.jones@linaro.org>
2014-05-08 14:11:37 +01:00
ab8500 - > mask = devm_kzalloc ( & pdev - > dev , ab8500 - > mask_size ,
GFP_KERNEL ) ;
2012-02-20 21:42:17 +01:00
if ( ! ab8500 - > mask )
return - ENOMEM ;
mfd: ab8500-core: Resolve code style issues
Soothes the following checkpatch warnings:
WARNING: line over 80 characters
#151: FILE: drivers/mfd/ab8500-core.c:151:
+ 0, 1, 2, 3, 4, -1, -1, -1, -1, 11, 18, 19, 20, 21, 12, 13, 24, 5, 22, 23,
ERROR: spaces required around that '=' (ctx:VxW)
#325: FILE: drivers/mfd/ab8500-core.c:325:
+ ret= mask_and_set_register_interruptible(ab8500, bank, reg,
^
WARNING: line over 80 characters
#418: FILE: drivers/mfd/ab8500-core.c:418:
+ else if (offset >= AB9540_INT_GPIO50R && offset <= AB9540_INT_GPIO54R)
WARNING: line over 80 characters
#420: FILE: drivers/mfd/ab8500-core.c:420:
+ else if (offset == AB8540_INT_GPIO43R || offset == AB8540_INT_GPIO44R)
ERROR: spaces required around that '==' (ctx:VxV)
#454: FILE: drivers/mfd/ab8500-core.c:454:
+ if ((i==3) && (*offset >= 24))
^
ERROR: code indent should use tabs where possible
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
WARNING: please, no spaces at the start of a line
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
ERROR: code indent should use tabs where possible
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: please, no spaces at the start of a line
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: char * array declaration might be better as static const
#1554: FILE: drivers/mfd/ab8500-core.c:1554:
+ static char *switch_off_status[] = {
WARNING: char * array declaration might be better as static const
#1563: FILE: drivers/mfd/ab8500-core.c:1563:
+ static char *turn_on_status[] = {
WARNING: sizeof *ab8500 should be sizeof(*ab8500)
#1582: FILE: drivers/mfd/ab8500-core.c:1582:
+ ab8500 = devm_kzalloc(&pdev->dev, sizeof *ab8500, GFP_KERNEL);
ERROR: space required after that close brace '}'
#1639: FILE: drivers/mfd/ab8500-core.c:1639:
+ }/* Configure AB8500 or AB9540 IRQ */
WARNING: line over 80 characters
#1652: FILE: drivers/mfd/ab8500-core.c:1652:
+ ab8500->oldmask = devm_kzalloc(&pdev->dev, ab8500->mask_size, GFP_KERNEL);
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1677: FILE: drivers/mfd/ab8500-core.c:1677:
+ printk(KERN_CONT " \"%s\"",
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1682: FILE: drivers/mfd/ab8500-core.c:1682:
+ printk(KERN_CONT "\n");
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1684: FILE: drivers/mfd/ab8500-core.c:1684:
+ printk(KERN_CONT " None\n");
WARNING: printk() should include KERN_ facility level
#1695: FILE: drivers/mfd/ab8500-core.c:1695:
+ printk("\"%s\" ", turn_on_status[i]);
WARNING: printk() should include KERN_ facility level
#1700: FILE: drivers/mfd/ab8500-core.c:1700:
+ printk("None\n");
total: 5 errors, 14 warnings, 1869 lines checked
Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Lee Jones <lee.jones@linaro.org>
2014-05-08 14:11:37 +01:00
ab8500 - > oldmask = devm_kzalloc ( & pdev - > dev , ab8500 - > mask_size ,
GFP_KERNEL ) ;
2012-11-05 16:10:35 +01:00
if ( ! ab8500 - > oldmask )
return - ENOMEM ;
2011-03-02 11:52:36 +01:00
/*
* ab8500 has switched off due to ( SWITCH_OFF_STATUS ) :
* 0x01 Swoff bit programming
* 0x02 Thermal protection activation
* 0x04 Vbat lower then BattOk falling threshold
* 0x08 Watchdog expired
* 0x10 Non presence of 32 kHz clock
* 0x20 Battery level lower than power on reset threshold
* 0x40 Power on key 1 pressed longer than 10 seconds
* 0x80 DB8500 thermal shutdown
*/
ret = get_register_interruptible ( ab8500 , AB8500_RTC ,
AB8500_SWITCH_OFF_STATUS , & value ) ;
if ( ret < 0 )
return ret ;
2012-06-29 17:46:12 +02:00
dev_info ( ab8500 - > dev , " switch off cause(s) (%#x): " , value ) ;
if ( value ) {
for ( i = 0 ; i < ARRAY_SIZE ( switch_off_status ) ; i + + ) {
if ( value & 1 )
mfd: ab8500-core: Resolve code style issues
Soothes the following checkpatch warnings:
WARNING: line over 80 characters
#151: FILE: drivers/mfd/ab8500-core.c:151:
+ 0, 1, 2, 3, 4, -1, -1, -1, -1, 11, 18, 19, 20, 21, 12, 13, 24, 5, 22, 23,
ERROR: spaces required around that '=' (ctx:VxW)
#325: FILE: drivers/mfd/ab8500-core.c:325:
+ ret= mask_and_set_register_interruptible(ab8500, bank, reg,
^
WARNING: line over 80 characters
#418: FILE: drivers/mfd/ab8500-core.c:418:
+ else if (offset >= AB9540_INT_GPIO50R && offset <= AB9540_INT_GPIO54R)
WARNING: line over 80 characters
#420: FILE: drivers/mfd/ab8500-core.c:420:
+ else if (offset == AB8540_INT_GPIO43R || offset == AB8540_INT_GPIO44R)
ERROR: spaces required around that '==' (ctx:VxV)
#454: FILE: drivers/mfd/ab8500-core.c:454:
+ if ((i==3) && (*offset >= 24))
^
ERROR: code indent should use tabs where possible
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
WARNING: please, no spaces at the start of a line
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
ERROR: code indent should use tabs where possible
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: please, no spaces at the start of a line
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: char * array declaration might be better as static const
#1554: FILE: drivers/mfd/ab8500-core.c:1554:
+ static char *switch_off_status[] = {
WARNING: char * array declaration might be better as static const
#1563: FILE: drivers/mfd/ab8500-core.c:1563:
+ static char *turn_on_status[] = {
WARNING: sizeof *ab8500 should be sizeof(*ab8500)
#1582: FILE: drivers/mfd/ab8500-core.c:1582:
+ ab8500 = devm_kzalloc(&pdev->dev, sizeof *ab8500, GFP_KERNEL);
ERROR: space required after that close brace '}'
#1639: FILE: drivers/mfd/ab8500-core.c:1639:
+ }/* Configure AB8500 or AB9540 IRQ */
WARNING: line over 80 characters
#1652: FILE: drivers/mfd/ab8500-core.c:1652:
+ ab8500->oldmask = devm_kzalloc(&pdev->dev, ab8500->mask_size, GFP_KERNEL);
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1677: FILE: drivers/mfd/ab8500-core.c:1677:
+ printk(KERN_CONT " \"%s\"",
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1682: FILE: drivers/mfd/ab8500-core.c:1682:
+ printk(KERN_CONT "\n");
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1684: FILE: drivers/mfd/ab8500-core.c:1684:
+ printk(KERN_CONT " None\n");
WARNING: printk() should include KERN_ facility level
#1695: FILE: drivers/mfd/ab8500-core.c:1695:
+ printk("\"%s\" ", turn_on_status[i]);
WARNING: printk() should include KERN_ facility level
#1700: FILE: drivers/mfd/ab8500-core.c:1700:
+ printk("None\n");
total: 5 errors, 14 warnings, 1869 lines checked
Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Lee Jones <lee.jones@linaro.org>
2014-05-08 14:11:37 +01:00
pr_cont ( " \" %s \" " , switch_off_status [ i ] ) ;
2012-06-29 17:46:12 +02:00
value = value > > 1 ;
}
mfd: ab8500-core: Resolve code style issues
Soothes the following checkpatch warnings:
WARNING: line over 80 characters
#151: FILE: drivers/mfd/ab8500-core.c:151:
+ 0, 1, 2, 3, 4, -1, -1, -1, -1, 11, 18, 19, 20, 21, 12, 13, 24, 5, 22, 23,
ERROR: spaces required around that '=' (ctx:VxW)
#325: FILE: drivers/mfd/ab8500-core.c:325:
+ ret= mask_and_set_register_interruptible(ab8500, bank, reg,
^
WARNING: line over 80 characters
#418: FILE: drivers/mfd/ab8500-core.c:418:
+ else if (offset >= AB9540_INT_GPIO50R && offset <= AB9540_INT_GPIO54R)
WARNING: line over 80 characters
#420: FILE: drivers/mfd/ab8500-core.c:420:
+ else if (offset == AB8540_INT_GPIO43R || offset == AB8540_INT_GPIO44R)
ERROR: spaces required around that '==' (ctx:VxV)
#454: FILE: drivers/mfd/ab8500-core.c:454:
+ if ((i==3) && (*offset >= 24))
^
ERROR: code indent should use tabs where possible
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
WARNING: please, no spaces at the start of a line
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
ERROR: code indent should use tabs where possible
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: please, no spaces at the start of a line
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: char * array declaration might be better as static const
#1554: FILE: drivers/mfd/ab8500-core.c:1554:
+ static char *switch_off_status[] = {
WARNING: char * array declaration might be better as static const
#1563: FILE: drivers/mfd/ab8500-core.c:1563:
+ static char *turn_on_status[] = {
WARNING: sizeof *ab8500 should be sizeof(*ab8500)
#1582: FILE: drivers/mfd/ab8500-core.c:1582:
+ ab8500 = devm_kzalloc(&pdev->dev, sizeof *ab8500, GFP_KERNEL);
ERROR: space required after that close brace '}'
#1639: FILE: drivers/mfd/ab8500-core.c:1639:
+ }/* Configure AB8500 or AB9540 IRQ */
WARNING: line over 80 characters
#1652: FILE: drivers/mfd/ab8500-core.c:1652:
+ ab8500->oldmask = devm_kzalloc(&pdev->dev, ab8500->mask_size, GFP_KERNEL);
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1677: FILE: drivers/mfd/ab8500-core.c:1677:
+ printk(KERN_CONT " \"%s\"",
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1682: FILE: drivers/mfd/ab8500-core.c:1682:
+ printk(KERN_CONT "\n");
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1684: FILE: drivers/mfd/ab8500-core.c:1684:
+ printk(KERN_CONT " None\n");
WARNING: printk() should include KERN_ facility level
#1695: FILE: drivers/mfd/ab8500-core.c:1695:
+ printk("\"%s\" ", turn_on_status[i]);
WARNING: printk() should include KERN_ facility level
#1700: FILE: drivers/mfd/ab8500-core.c:1700:
+ printk("None\n");
total: 5 errors, 14 warnings, 1869 lines checked
Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Lee Jones <lee.jones@linaro.org>
2014-05-08 14:11:37 +01:00
pr_cont ( " \n " ) ;
2012-06-29 17:46:12 +02:00
} else {
mfd: ab8500-core: Resolve code style issues
Soothes the following checkpatch warnings:
WARNING: line over 80 characters
#151: FILE: drivers/mfd/ab8500-core.c:151:
+ 0, 1, 2, 3, 4, -1, -1, -1, -1, 11, 18, 19, 20, 21, 12, 13, 24, 5, 22, 23,
ERROR: spaces required around that '=' (ctx:VxW)
#325: FILE: drivers/mfd/ab8500-core.c:325:
+ ret= mask_and_set_register_interruptible(ab8500, bank, reg,
^
WARNING: line over 80 characters
#418: FILE: drivers/mfd/ab8500-core.c:418:
+ else if (offset >= AB9540_INT_GPIO50R && offset <= AB9540_INT_GPIO54R)
WARNING: line over 80 characters
#420: FILE: drivers/mfd/ab8500-core.c:420:
+ else if (offset == AB8540_INT_GPIO43R || offset == AB8540_INT_GPIO44R)
ERROR: spaces required around that '==' (ctx:VxV)
#454: FILE: drivers/mfd/ab8500-core.c:454:
+ if ((i==3) && (*offset >= 24))
^
ERROR: code indent should use tabs where possible
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
WARNING: please, no spaces at the start of a line
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
ERROR: code indent should use tabs where possible
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: please, no spaces at the start of a line
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: char * array declaration might be better as static const
#1554: FILE: drivers/mfd/ab8500-core.c:1554:
+ static char *switch_off_status[] = {
WARNING: char * array declaration might be better as static const
#1563: FILE: drivers/mfd/ab8500-core.c:1563:
+ static char *turn_on_status[] = {
WARNING: sizeof *ab8500 should be sizeof(*ab8500)
#1582: FILE: drivers/mfd/ab8500-core.c:1582:
+ ab8500 = devm_kzalloc(&pdev->dev, sizeof *ab8500, GFP_KERNEL);
ERROR: space required after that close brace '}'
#1639: FILE: drivers/mfd/ab8500-core.c:1639:
+ }/* Configure AB8500 or AB9540 IRQ */
WARNING: line over 80 characters
#1652: FILE: drivers/mfd/ab8500-core.c:1652:
+ ab8500->oldmask = devm_kzalloc(&pdev->dev, ab8500->mask_size, GFP_KERNEL);
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1677: FILE: drivers/mfd/ab8500-core.c:1677:
+ printk(KERN_CONT " \"%s\"",
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1682: FILE: drivers/mfd/ab8500-core.c:1682:
+ printk(KERN_CONT "\n");
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1684: FILE: drivers/mfd/ab8500-core.c:1684:
+ printk(KERN_CONT " None\n");
WARNING: printk() should include KERN_ facility level
#1695: FILE: drivers/mfd/ab8500-core.c:1695:
+ printk("\"%s\" ", turn_on_status[i]);
WARNING: printk() should include KERN_ facility level
#1700: FILE: drivers/mfd/ab8500-core.c:1700:
+ printk("None\n");
total: 5 errors, 14 warnings, 1869 lines checked
Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Lee Jones <lee.jones@linaro.org>
2014-05-08 14:11:37 +01:00
pr_cont ( " None \n " ) ;
2012-06-29 17:46:12 +02:00
}
2012-09-28 09:34:24 +02:00
ret = get_register_interruptible ( ab8500 , AB8500_SYS_CTRL1_BLOCK ,
AB8500_TURN_ON_STATUS , & value ) ;
if ( ret < 0 )
return ret ;
dev_info ( ab8500 - > dev , " turn on reason(s) (%#x): " , value ) ;
if ( value ) {
for ( i = 0 ; i < ARRAY_SIZE ( turn_on_status ) ; i + + ) {
if ( value & 1 )
mfd: ab8500-core: Resolve code style issues
Soothes the following checkpatch warnings:
WARNING: line over 80 characters
#151: FILE: drivers/mfd/ab8500-core.c:151:
+ 0, 1, 2, 3, 4, -1, -1, -1, -1, 11, 18, 19, 20, 21, 12, 13, 24, 5, 22, 23,
ERROR: spaces required around that '=' (ctx:VxW)
#325: FILE: drivers/mfd/ab8500-core.c:325:
+ ret= mask_and_set_register_interruptible(ab8500, bank, reg,
^
WARNING: line over 80 characters
#418: FILE: drivers/mfd/ab8500-core.c:418:
+ else if (offset >= AB9540_INT_GPIO50R && offset <= AB9540_INT_GPIO54R)
WARNING: line over 80 characters
#420: FILE: drivers/mfd/ab8500-core.c:420:
+ else if (offset == AB8540_INT_GPIO43R || offset == AB8540_INT_GPIO44R)
ERROR: spaces required around that '==' (ctx:VxV)
#454: FILE: drivers/mfd/ab8500-core.c:454:
+ if ((i==3) && (*offset >= 24))
^
ERROR: code indent should use tabs where possible
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
WARNING: please, no spaces at the start of a line
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
ERROR: code indent should use tabs where possible
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: please, no spaces at the start of a line
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: char * array declaration might be better as static const
#1554: FILE: drivers/mfd/ab8500-core.c:1554:
+ static char *switch_off_status[] = {
WARNING: char * array declaration might be better as static const
#1563: FILE: drivers/mfd/ab8500-core.c:1563:
+ static char *turn_on_status[] = {
WARNING: sizeof *ab8500 should be sizeof(*ab8500)
#1582: FILE: drivers/mfd/ab8500-core.c:1582:
+ ab8500 = devm_kzalloc(&pdev->dev, sizeof *ab8500, GFP_KERNEL);
ERROR: space required after that close brace '}'
#1639: FILE: drivers/mfd/ab8500-core.c:1639:
+ }/* Configure AB8500 or AB9540 IRQ */
WARNING: line over 80 characters
#1652: FILE: drivers/mfd/ab8500-core.c:1652:
+ ab8500->oldmask = devm_kzalloc(&pdev->dev, ab8500->mask_size, GFP_KERNEL);
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1677: FILE: drivers/mfd/ab8500-core.c:1677:
+ printk(KERN_CONT " \"%s\"",
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1682: FILE: drivers/mfd/ab8500-core.c:1682:
+ printk(KERN_CONT "\n");
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1684: FILE: drivers/mfd/ab8500-core.c:1684:
+ printk(KERN_CONT " None\n");
WARNING: printk() should include KERN_ facility level
#1695: FILE: drivers/mfd/ab8500-core.c:1695:
+ printk("\"%s\" ", turn_on_status[i]);
WARNING: printk() should include KERN_ facility level
#1700: FILE: drivers/mfd/ab8500-core.c:1700:
+ printk("None\n");
total: 5 errors, 14 warnings, 1869 lines checked
Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Lee Jones <lee.jones@linaro.org>
2014-05-08 14:11:37 +01:00
pr_cont ( " \" %s \" " , turn_on_status [ i ] ) ;
2012-09-28 09:34:24 +02:00
value = value > > 1 ;
}
mfd: ab8500-core: Resolve code style issues
Soothes the following checkpatch warnings:
WARNING: line over 80 characters
#151: FILE: drivers/mfd/ab8500-core.c:151:
+ 0, 1, 2, 3, 4, -1, -1, -1, -1, 11, 18, 19, 20, 21, 12, 13, 24, 5, 22, 23,
ERROR: spaces required around that '=' (ctx:VxW)
#325: FILE: drivers/mfd/ab8500-core.c:325:
+ ret= mask_and_set_register_interruptible(ab8500, bank, reg,
^
WARNING: line over 80 characters
#418: FILE: drivers/mfd/ab8500-core.c:418:
+ else if (offset >= AB9540_INT_GPIO50R && offset <= AB9540_INT_GPIO54R)
WARNING: line over 80 characters
#420: FILE: drivers/mfd/ab8500-core.c:420:
+ else if (offset == AB8540_INT_GPIO43R || offset == AB8540_INT_GPIO44R)
ERROR: spaces required around that '==' (ctx:VxV)
#454: FILE: drivers/mfd/ab8500-core.c:454:
+ if ((i==3) && (*offset >= 24))
^
ERROR: code indent should use tabs where possible
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
WARNING: please, no spaces at the start of a line
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
ERROR: code indent should use tabs where possible
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: please, no spaces at the start of a line
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: char * array declaration might be better as static const
#1554: FILE: drivers/mfd/ab8500-core.c:1554:
+ static char *switch_off_status[] = {
WARNING: char * array declaration might be better as static const
#1563: FILE: drivers/mfd/ab8500-core.c:1563:
+ static char *turn_on_status[] = {
WARNING: sizeof *ab8500 should be sizeof(*ab8500)
#1582: FILE: drivers/mfd/ab8500-core.c:1582:
+ ab8500 = devm_kzalloc(&pdev->dev, sizeof *ab8500, GFP_KERNEL);
ERROR: space required after that close brace '}'
#1639: FILE: drivers/mfd/ab8500-core.c:1639:
+ }/* Configure AB8500 or AB9540 IRQ */
WARNING: line over 80 characters
#1652: FILE: drivers/mfd/ab8500-core.c:1652:
+ ab8500->oldmask = devm_kzalloc(&pdev->dev, ab8500->mask_size, GFP_KERNEL);
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1677: FILE: drivers/mfd/ab8500-core.c:1677:
+ printk(KERN_CONT " \"%s\"",
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1682: FILE: drivers/mfd/ab8500-core.c:1682:
+ printk(KERN_CONT "\n");
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1684: FILE: drivers/mfd/ab8500-core.c:1684:
+ printk(KERN_CONT " None\n");
WARNING: printk() should include KERN_ facility level
#1695: FILE: drivers/mfd/ab8500-core.c:1695:
+ printk("\"%s\" ", turn_on_status[i]);
WARNING: printk() should include KERN_ facility level
#1700: FILE: drivers/mfd/ab8500-core.c:1700:
+ printk("None\n");
total: 5 errors, 14 warnings, 1869 lines checked
Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Lee Jones <lee.jones@linaro.org>
2014-05-08 14:11:37 +01:00
pr_cont ( " \n " ) ;
2012-09-28 09:34:24 +02:00
} else {
mfd: ab8500-core: Resolve code style issues
Soothes the following checkpatch warnings:
WARNING: line over 80 characters
#151: FILE: drivers/mfd/ab8500-core.c:151:
+ 0, 1, 2, 3, 4, -1, -1, -1, -1, 11, 18, 19, 20, 21, 12, 13, 24, 5, 22, 23,
ERROR: spaces required around that '=' (ctx:VxW)
#325: FILE: drivers/mfd/ab8500-core.c:325:
+ ret= mask_and_set_register_interruptible(ab8500, bank, reg,
^
WARNING: line over 80 characters
#418: FILE: drivers/mfd/ab8500-core.c:418:
+ else if (offset >= AB9540_INT_GPIO50R && offset <= AB9540_INT_GPIO54R)
WARNING: line over 80 characters
#420: FILE: drivers/mfd/ab8500-core.c:420:
+ else if (offset == AB8540_INT_GPIO43R || offset == AB8540_INT_GPIO44R)
ERROR: spaces required around that '==' (ctx:VxV)
#454: FILE: drivers/mfd/ab8500-core.c:454:
+ if ((i==3) && (*offset >= 24))
^
ERROR: code indent should use tabs where possible
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
WARNING: please, no spaces at the start of a line
#576: FILE: drivers/mfd/ab8500-core.c:576:
+ .map = ab8500_irq_map,$
ERROR: code indent should use tabs where possible
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: please, no spaces at the start of a line
#577: FILE: drivers/mfd/ab8500-core.c:577:
+ .xlate = irq_domain_xlate_twocell,$
WARNING: char * array declaration might be better as static const
#1554: FILE: drivers/mfd/ab8500-core.c:1554:
+ static char *switch_off_status[] = {
WARNING: char * array declaration might be better as static const
#1563: FILE: drivers/mfd/ab8500-core.c:1563:
+ static char *turn_on_status[] = {
WARNING: sizeof *ab8500 should be sizeof(*ab8500)
#1582: FILE: drivers/mfd/ab8500-core.c:1582:
+ ab8500 = devm_kzalloc(&pdev->dev, sizeof *ab8500, GFP_KERNEL);
ERROR: space required after that close brace '}'
#1639: FILE: drivers/mfd/ab8500-core.c:1639:
+ }/* Configure AB8500 or AB9540 IRQ */
WARNING: line over 80 characters
#1652: FILE: drivers/mfd/ab8500-core.c:1652:
+ ab8500->oldmask = devm_kzalloc(&pdev->dev, ab8500->mask_size, GFP_KERNEL);
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1677: FILE: drivers/mfd/ab8500-core.c:1677:
+ printk(KERN_CONT " \"%s\"",
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1682: FILE: drivers/mfd/ab8500-core.c:1682:
+ printk(KERN_CONT "\n");
WARNING: Prefer [subsystem eg: netdev]_cont([subsystem]dev, ... then dev_cont(dev, ... then pr_cont(... to printk(KERN_CONT ...
#1684: FILE: drivers/mfd/ab8500-core.c:1684:
+ printk(KERN_CONT " None\n");
WARNING: printk() should include KERN_ facility level
#1695: FILE: drivers/mfd/ab8500-core.c:1695:
+ printk("\"%s\" ", turn_on_status[i]);
WARNING: printk() should include KERN_ facility level
#1700: FILE: drivers/mfd/ab8500-core.c:1700:
+ printk("None\n");
total: 5 errors, 14 warnings, 1869 lines checked
Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Lee Jones <lee.jones@linaro.org>
2014-05-08 14:11:37 +01:00
pr_cont ( " None \n " ) ;
2012-09-28 09:34:24 +02:00
}
2011-03-02 11:52:36 +01:00
2012-05-30 16:32:37 +05:30
if ( is_ab9540 ( ab8500 ) ) {
ret = get_register_interruptible ( ab8500 , AB8500_CHARGER ,
AB8500_CH_USBCH_STAT1_REG , & value ) ;
if ( ret < 0 )
return ret ;
if ( ( value & VBUS_DET_DBNC1 ) & & ( value & VBUS_DET_DBNC100 ) )
ab8500_override_turn_on_stat ( ~ AB8500_POW_KEY_1_ON ,
AB8500_VBUS_DET ) ;
}
2010-05-19 11:39:02 +02:00
/* Clear and mask all interrupts */
2012-02-20 21:42:17 +01:00
for ( i = 0 ; i < ab8500 - > mask_size ; i + + ) {
2012-02-20 21:42:10 +01:00
/*
* Interrupt register 12 doesn ' t exist prior to AB8500 version
* 2.0
*/
if ( ab8500 - > irq_reg_offset [ i ] = = 11 & &
is_ab8500_1p1_or_earlier ( ab8500 ) )
2010-12-07 11:20:47 +01:00
continue ;
2010-05-19 11:39:02 +02:00
2013-02-25 14:57:35 +00:00
if ( ab8500 - > irq_reg_offset [ i ] < 0 )
continue ;
2010-09-10 17:47:56 +02:00
get_register_interruptible ( ab8500 , AB8500_INTERRUPT ,
2012-02-20 21:42:17 +01:00
AB8500_IT_LATCH1_REG + ab8500 - > irq_reg_offset [ i ] ,
2010-12-07 11:20:47 +01:00
& value ) ;
2010-09-10 17:47:56 +02:00
set_register_interruptible ( ab8500 , AB8500_INTERRUPT ,
2012-02-20 21:42:17 +01:00
AB8500_IT_MASK1_REG + ab8500 - > irq_reg_offset [ i ] , 0xff ) ;
2010-05-19 11:39:02 +02:00
}
2010-09-10 17:47:56 +02:00
ret = abx500_register_ops ( ab8500 - > dev , & ab8500_ops ) ;
if ( ret )
2012-11-05 16:10:35 +01:00
return ret ;
2010-09-10 17:47:56 +02:00
2012-02-20 21:42:17 +01:00
for ( i = 0 ; i < ab8500 - > mask_size ; i + + )
2010-05-19 11:39:02 +02:00
ab8500 - > mask [ i ] = ab8500 - > oldmask [ i ] = 0xff ;
2012-06-20 13:56:37 +01:00
ret = ab8500_irq_init ( ab8500 , np ) ;
if ( ret )
2012-11-05 16:10:35 +01:00
return ret ;
2010-05-19 11:39:02 +02:00
2012-11-26 13:31:26 +01:00
ret = devm_request_threaded_irq ( & pdev - > dev , ab8500 - > irq , NULL ,
ab8500_hierarchical_irq ,
IRQF_ONESHOT | IRQF_NO_SUSPEND ,
" ab8500 " , ab8500 ) ;
if ( ret )
return ret ;
2010-05-19 11:39:02 +02:00
2012-07-02 17:10:56 +02:00
if ( is_ab9540 ( ab8500 ) )
ret = mfd_add_devices ( ab8500 - > dev , 0 , ab9540_devs ,
ARRAY_SIZE ( ab9540_devs ) , NULL ,
2014-02-04 00:35:56 +01:00
0 , ab8500 - > domain ) ;
2013-05-24 11:59:47 +02:00
else if ( is_ab8540 ( ab8500 ) ) {
2013-02-12 15:04:09 +00:00
ret = mfd_add_devices ( ab8500 - > dev , 0 , ab8540_devs ,
ARRAY_SIZE ( ab8540_devs ) , NULL ,
2014-02-04 00:35:56 +01:00
0 , ab8500 - > domain ) ;
2013-05-24 11:59:47 +02:00
if ( ret )
return ret ;
if ( is_ab8540_1p2_or_earlier ( ab8500 ) )
ret = mfd_add_devices ( ab8500 - > dev , 0 , ab8540_cut1_devs ,
ARRAY_SIZE ( ab8540_cut1_devs ) , NULL ,
2014-02-04 00:35:56 +01:00
0 , ab8500 - > domain ) ;
2013-05-24 11:59:47 +02:00
else /* ab8540 >= cut2 */
ret = mfd_add_devices ( ab8500 - > dev , 0 , ab8540_cut2_devs ,
ARRAY_SIZE ( ab8540_cut2_devs ) , NULL ,
2014-02-04 00:35:56 +01:00
0 , ab8500 - > domain ) ;
2013-05-24 11:59:47 +02:00
} else if ( is_ab8505 ( ab8500 ) )
2013-02-12 15:04:09 +00:00
ret = mfd_add_devices ( ab8500 - > dev , 0 , ab8505_devs ,
ARRAY_SIZE ( ab8505_devs ) , NULL ,
2014-02-04 00:35:56 +01:00
0 , ab8500 - > domain ) ;
2012-07-02 17:10:56 +02:00
else
ret = mfd_add_devices ( ab8500 - > dev , 0 , ab8500_devs ,
ARRAY_SIZE ( ab8500_devs ) , NULL ,
2014-02-04 00:35:56 +01:00
0 , ab8500 - > domain ) ;
2012-07-02 17:10:56 +02:00
if ( ret )
2012-11-05 16:10:35 +01:00
return ret ;
2012-04-17 09:30:14 +02:00
2012-04-17 09:30:57 +02:00
if ( ! no_bm ) {
/* Add battery management devices */
ret = mfd_add_devices ( ab8500 - > dev , 0 , ab8500_bm_devs ,
ARRAY_SIZE ( ab8500_bm_devs ) , NULL ,
2014-02-04 00:35:56 +01:00
0 , ab8500 - > domain ) ;
2012-04-17 09:30:57 +02:00
if ( ret )
dev_err ( ab8500 - > dev , " error adding bm devices \n " ) ;
}
2013-02-26 10:09:41 +00:00
if ( ( ( is_ab8505 ( ab8500 ) | | is_ab9540 ( ab8500 ) ) & &
ab8500 - > chip_id > = AB8500_CUT2P0 ) | | is_ab8540 ( ab8500 ) )
2012-02-20 21:42:24 +01:00
ret = sysfs_create_group ( & ab8500 - > dev - > kobj ,
& ab9540_attr_group ) ;
else
ret = sysfs_create_group ( & ab8500 - > dev - > kobj ,
& ab8500_attr_group ) ;
2012-05-31 16:16:36 +02:00
if ( ( is_ab8505 ( ab8500 ) | | is_ab9540 ( ab8500 ) ) & &
ab8500 - > chip_id > = AB8500_CUT2P0 )
ret = sysfs_create_group ( & ab8500 - > dev - > kobj ,
& ab8505_attr_group ) ;
2010-12-02 15:09:36 +01:00
if ( ret )
dev_err ( ab8500 - > dev , " error creating sysfs entries \n " ) ;
2012-06-20 13:56:37 +01:00
return ret ;
2010-05-19 11:39:02 +02:00
}
2012-05-19 17:21:37 +02:00
static const struct platform_device_id ab8500_id [ ] = {
{ " ab8500-core " , AB8500_VERSION_AB8500 } ,
{ " ab8505-i2c " , AB8500_VERSION_AB8505 } ,
{ " ab9540-i2c " , AB8500_VERSION_AB9540 } ,
{ " ab8540-i2c " , AB8500_VERSION_AB8540 } ,
{ }
} ;
static struct platform_driver ab8500_core_driver = {
. driver = {
. name = " ab8500-core " ,
2016-10-29 21:24:36 -04:00
. suppress_bind_attrs = true ,
2012-05-19 17:21:37 +02:00
} ,
. probe = ab8500_probe ,
. id_table = ab8500_id ,
} ;
static int __init ab8500_core_init ( void )
{
return platform_driver_register ( & ab8500_core_driver ) ;
}
2012-06-11 16:25:00 +01:00
core_initcall ( ab8500_core_init ) ;