[PATCH] ARM: Samsung S5P: Unify defines for both gpio interrupt types

Marek Szyprowski m.szyprowski at samsung.com
Thu Sep 30 07:32:43 EDT 2010


Hello,

On Thursday, September 30, 2010 1:23 PM Kukjin Kim wrote:

> Marek Szyprowski wrote:
> >
> > Samsung S5P series have the same interrupt type defines for both
> > external interrupts and gpio interrupts. This patch removes all
> > duplicates from s5pc100 and s5pv210 specific includes as well as gpio
> > int code and put a common defines to plat/irqs.h
> >
> > Signed-off-by: Marek Szyprowski <m.szyprowski at samsung.com>
> > Signed-off-by: Kyungmin Park <kyungmin.park at samsung.com>
> >
> > ---
> >
> > Hello,
> >
> Hi ;-)
> 
> > This patch has been prepared as a continuation of my patch series for
> > gpio interrupts (see "[PATCH v3] ARM: S5P: Add support for gpio
> > interrupts" thread). It requires them to be applied first.
> 
> Ok..I got it.
> >
> > Best regards
> > --
> > Marek Szyprowski
> > Samsung Poland R&D Center
> >
> > ---
> >
> >  arch/arm/mach-s5pc100/include/mach/regs-gpio.h |    7 -------
> >  arch/arm/mach-s5pv210/include/mach/regs-gpio.h |    7 -------
> >  arch/arm/plat-s5p/include/plat/irqs.h          |    7 +++++++
> >  arch/arm/plat-s5p/irq-eint.c                   |   10 +++++-----
> >  arch/arm/plat-s5p/irq-gpioint.c                |   16 +++++-----------
> >  5 files changed, 17 insertions(+), 30 deletions(-)
> >
> > diff --git a/arch/arm/mach-s5pc100/include/mach/regs-gpio.h
> b/arch/arm/mach-
> > s5pc100/include/mach/regs-gpio.h
> > index 6abe481..8c47536 100644
> > --- a/arch/arm/mach-s5pc100/include/mach/regs-gpio.h
> > +++ b/arch/arm/mach-s5pc100/include/mach/regs-gpio.h
> > @@ -64,13 +64,6 @@
> >
> >  #define eint_irq_to_bit(irq)		(1 << (EINT_OFFSET(irq) & 0x7))
> >
> > -/* values for S5P_EXTINT0 */
> > -#define S5P_EXTINT_LOWLEV		(0x00)
> > -#define S5P_EXTINT_HILEV		(0x01)
> > -#define S5P_EXTINT_FALLEDGE		(0x02)
> > -#define S5P_EXTINT_RISEEDGE		(0x03)
> > -#define S5P_EXTINT_BOTHEDGE		(0x04)
> > -
> >  #define EINT_MODE		S3C_GPIO_SFN(0x2)
> >
> >  #define EINT_GPIO_0(x)		S5PC100_GPH0(x)
> > diff --git a/arch/arm/mach-s5pv210/include/mach/regs-gpio.h
> b/arch/arm/mach-
> > s5pv210/include/mach/regs-gpio.h
> > index 49e029b..de0c899 100644
> > --- a/arch/arm/mach-s5pv210/include/mach/regs-gpio.h
> > +++ b/arch/arm/mach-s5pv210/include/mach/regs-gpio.h
> > @@ -31,13 +31,6 @@
> >
> >  #define eint_irq_to_bit(irq)		(1 << (EINT_OFFSET(irq) & 0x7))
> >
> > -/* values for S5P_EXTINT0 */
> > -#define S5P_EXTINT_LOWLEV		(0x00)
> > -#define S5P_EXTINT_HILEV		(0x01)
> > -#define S5P_EXTINT_FALLEDGE		(0x02)
> > -#define S5P_EXTINT_RISEEDGE		(0x03)
> > -#define S5P_EXTINT_BOTHEDGE		(0x04)
> > -
> >  #define EINT_MODE		S3C_GPIO_SFN(0xf)
> >
> >  #define EINT_GPIO_0(x)		S5PV210_GPH0(x)
> > diff --git a/arch/arm/plat-s5p/include/plat/irqs.h b/arch/arm/plat-
> > s5p/include/plat/irqs.h
> > index 5a7bf96..3b402cd 100644
> > --- a/arch/arm/plat-s5p/include/plat/irqs.h
> > +++ b/arch/arm/plat-s5p/include/plat/irqs.h
> > @@ -103,4 +103,11 @@
> >  #define S5P_GPIOINT_GROUP_SIZE	8
> >  #define S5P_GPIOINT_COUNT	(S5P_GPIOINT_GROUP_COUNT *
> > S5P_GPIOINT_GROUP_SIZE)
> >
> > +/* IRQ types common for all s5p platforms */
> > +#define S5P_IRQ_TYPE_LEVEL_LOW		(0x00)
> > +#define S5P_IRQ_TYPE_LEVEL_HIGH		(0x01)
> > +#define S5P_IRQ_TYPE_EDGE_FALLING	(0x02)
> > +#define S5P_IRQ_TYPE_EDGE_RISING	(0x03)
> > +#define S5P_IRQ_TYPE_EDGE_BOTH		(0x04)
> > +
> But the values for S5P64X0 is different. So we should sort it out when
> support this on S5P64X0.
> 
> >  #endif /* __ASM_PLAT_S5P_IRQS_H */
> > diff --git a/arch/arm/plat-s5p/irq-eint.c b/arch/arm/plat-s5p/irq-eint.c
> > index f36cd33..752f1a6 100644
> > --- a/arch/arm/plat-s5p/irq-eint.c
> > +++ b/arch/arm/plat-s5p/irq-eint.c
> > @@ -67,23 +67,23 @@ static int s5p_irq_eint_set_type(unsigned int irq,
> unsigned
> > int type)
> >
> >  	switch (type) {
> >  	case IRQ_TYPE_EDGE_RISING:
> > -		newvalue = S5P_EXTINT_RISEEDGE;
> > +		newvalue = S5P_IRQ_TYPE_EDGE_RISING;
> >  		break;
> >
> >  	case IRQ_TYPE_EDGE_FALLING:
> > -		newvalue = S5P_EXTINT_FALLEDGE;
> > +		newvalue = S5P_IRQ_TYPE_EDGE_FALLING;
> >  		break;
> >
> >  	case IRQ_TYPE_EDGE_BOTH:
> > -		newvalue = S5P_EXTINT_BOTHEDGE;
> > +		newvalue = S5P_IRQ_TYPE_EDGE_BOTH;
> >  		break;
> >
> >  	case IRQ_TYPE_LEVEL_LOW:
> > -		newvalue = S5P_EXTINT_LOWLEV;
> > +		newvalue = S5P_IRQ_TYPE_LEVEL_LOW;
> >  		break;
> >
> >  	case IRQ_TYPE_LEVEL_HIGH:
> > -		newvalue = S5P_EXTINT_HILEV;
> > +		newvalue = S5P_IRQ_TYPE_LEVEL_HIGH;
> >  		break;
> >
> >  	default:
> > diff --git a/arch/arm/plat-s5p/irq-gpioint.c
> b/arch/arm/plat-s5p/irq-gpioint.c
> > index 768fd39..0e5dc8c 100644
> > --- a/arch/arm/plat-s5p/irq-gpioint.c
> > +++ b/arch/arm/plat-s5p/irq-gpioint.c
> > @@ -28,12 +28,6 @@
> >  #define GPIOINT_MASK_OFFSET		0x900
> >  #define GPIOINT_PEND_OFFSET		0xA00
> >
> > -#define GPIOINT_LEVEL_LOW		0x0
> > -#define GPIOINT_LEVEL_HIGH		0x1
> > -#define GPIOINT_EDGE_FALLING		0x2
> > -#define GPIOINT_EDGE_RISING		0x3
> > -#define GPIOINT_EDGE_BOTH		0x4
> > -
> >  static struct s3c_gpio_chip *irq_chips[S5P_GPIOINT_GROUP_MAXNR];
> >
> >  static int s5p_gpioint_get_group(unsigned int irq)
> > @@ -118,19 +112,19 @@ static int s5p_gpioint_set_type(unsigned int irq,
> > unsigned int type)
> >
> >  	switch (type) {
> >  	case IRQ_TYPE_EDGE_RISING:
> > -		type = GPIOINT_EDGE_RISING;
> > +		type = S5P_IRQ_TYPE_EDGE_RISING;
> >  		break;
> >  	case IRQ_TYPE_EDGE_FALLING:
> > -		type = GPIOINT_EDGE_FALLING;
> > +		type = S5P_IRQ_TYPE_EDGE_FALLING;
> >  		break;
> >  	case IRQ_TYPE_EDGE_BOTH:
> > -		type = GPIOINT_EDGE_BOTH;
> > +		type = S5P_IRQ_TYPE_EDGE_BOTH;
> >  		break;
> >  	case IRQ_TYPE_LEVEL_HIGH:
> > -		type = GPIOINT_LEVEL_HIGH;
> > +		type = S5P_IRQ_TYPE_LEVEL_HIGH;
> >  		break;
> >  	case IRQ_TYPE_LEVEL_LOW:
> > -		type = GPIOINT_LEVEL_LOW;
> > +		type = S5P_IRQ_TYPE_LEVEL_LOW;
> >  		break;
> >  	case IRQ_TYPE_NONE:
> >  	default:
> > --
> 
> Ok..firstly looks ok to me now.
> But I don't know...in the future may have to revert back due to S5P64XX.

Well, these defines are used only by plat-s5p/irq-{eint,gpioint}.c. These generic
functions cannot be used for S5P64XX anyway, because it has S3C64XX style of gpio
registers afair. IMHO this shouldn't be a problem. Just S5P64XX would need to
provide it's own code for gpio/ext interrupts (or share the code with s3c64xx
somehow).

> Firstly will apply.

Thx.

Best regards
--
Marek Szyprowski
Samsung Poland R&D Center





More information about the linux-arm-kernel mailing list