Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
L
linux-davinci
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
linux
linux-davinci
Commits
576efd11
Commit
576efd11
authored
Nov 22, 2005
by
Jarkko Nikula
Committed by
Tony Lindgren
Nov 22, 2005
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[PATCH] ARM: OMAP: Improved GPIO level interrupt handling for 24xx
Improved GPIO level interrupt handling for 24xx
parent
69898301
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
21 additions
and
7 deletions
+21
-7
arch/arm/plat-omap/gpio.c
arch/arm/plat-omap/gpio.c
+21
-7
No files found.
arch/arm/plat-omap/gpio.c
View file @
576efd11
...
...
@@ -757,22 +757,28 @@ static void gpio_irq_handler(unsigned int irq, struct irqdesc *desc,
if
(
bank
->
method
==
METHOD_GPIO_24XX
)
isr_reg
=
bank
->
base
+
OMAP24XX_GPIO_IRQSTATUS1
;
#endif
while
(
1
)
{
u32
isr_saved
,
level_mask
=
0
;
isr_saved
=
isr
=
__raw_readl
(
isr_reg
);
if
(
cpu_is_omap24xx
())
level_mask
=
__raw_readl
(
bank
->
base
+
OMAP24XX_GPIO_LEVELDETECT0
)
|
level_mask
=
__raw_readl
(
bank
->
base
+
OMAP24XX_GPIO_LEVELDETECT0
)
|
__raw_readl
(
bank
->
base
+
OMAP24XX_GPIO_LEVELDETECT1
);
OMAP24XX_GPIO_LEVELDETECT1
);
/* clear edge sensitive interrupts before handler(s) */
/* clear edge sensitive interrupts before handler(s) are
called so that we don't miss any interrupt occurred while
executing them */
_enable_gpio_irqbank
(
bank
,
isr_saved
&
~
level_mask
,
0
);
_clear_gpio_irqbank
(
bank
,
isr_saved
&
~
level_mask
);
_enable_gpio_irqbank
(
bank
,
isr_saved
&
~
level_mask
,
1
);
desc
->
chip
->
unmask
(
irq
);
/* if there is only edge sensitive GPIO pin interrupts
configured, we could unmask GPIO bank interrupt immediately */
if
(
!
level_mask
)
desc
->
chip
->
unmask
(
irq
);
if
(
!
isr
)
break
;
...
...
@@ -785,12 +791,20 @@ static void gpio_irq_handler(unsigned int irq, struct irqdesc *desc,
d
=
irq_desc
+
gpio_irq
;
desc_handle_irq
(
gpio_irq
,
d
,
regs
);
}
/* clear level sensitive interrupts after handler(s) */
if
(
cpu_is_omap24xx
())
{
/* clear level sensitive interrupts after handler(s) */
_enable_gpio_irqbank
(
bank
,
isr_saved
&
level_mask
,
0
);
_clear_gpio_irqbank
(
bank
,
isr_saved
&
level_mask
);
_enable_gpio_irqbank
(
bank
,
isr_saved
&
level_mask
,
1
);
}
/* if bank has any level sensitive GPIO pin interrupt
configured, we must unmask the bank interrupt only after
handler(s) are executed in order to avoid spurious bank
interrupt */
if
(
level_mask
)
desc
->
chip
->
unmask
(
irq
);
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment