Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
linux
Commits
8e3a7330
Commit
8e3a7330
authored
Apr 30, 2002
by
Tom Rini
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
PPC32: Minor cleanups to the i8259 and OpenPIC code. From myself and
Hollis Blanchard.
parent
e66d5915
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
37 additions
and
44 deletions
+37
-44
arch/ppc/kernel/i8259.c
arch/ppc/kernel/i8259.c
+3
-3
arch/ppc/kernel/open_pic.c
arch/ppc/kernel/open_pic.c
+32
-33
arch/ppc/platforms/prep_setup.c
arch/ppc/platforms/prep_setup.c
+1
-7
include/asm-ppc/i8259.h
include/asm-ppc/i8259.h
+1
-1
No files found.
arch/ppc/kernel/i8259.c
View file @
8e3a7330
...
...
@@ -11,7 +11,7 @@
#include <asm/io.h>
#include <asm/i8259.h>
static
volatile
char
*
pci_intack
;
/* RO, gives us the irq vector */
static
volatile
unsigned
char
*
pci_intack
;
/* RO, gives us the irq vector */
unsigned
char
cached_8259
[
2
]
=
{
0xff
,
0xff
};
#define cached_A1 (cached_8259[0])
...
...
@@ -24,13 +24,13 @@ int i8259_pic_irq_offset;
/* Acknowledge the irq using the PCI host bridge's interrupt acknowledge
* feature. (Polling is somehow broken on some IBM and Motorola PReP boxes.)
*/
int
i8259_irq
(
void
)
int
i8259_irq
(
struct
pt_regs
*
regs
)
{
int
irq
;
spin_lock
/*_irqsave*/
(
&
i8259_lock
/*, flags*/
);
irq
=
*
pci_intack
&
0xff
;
irq
=
*
pci_intack
;
if
(
irq
==
7
)
{
/*
* This may be a spurious interrupt.
...
...
arch/ppc/kernel/open_pic.c
View file @
8e3a7330
...
...
@@ -41,16 +41,13 @@ extern int use_of_interrupt_tree;
static
u_int
NumProcessors
;
static
u_int
NumSources
;
static
int
open_pic_irq_offset
;
static
volatile
unsigned
char
*
chrp_int_ack_special
;
static
volatile
unsigned
char
*
chrp_int_ack_special
;
static
volatile
OpenPIC_Source
*
ISR
[
NR_IRQS
];
/* Global Operations */
static
void
openpic_disable_8259_pass_through
(
void
);
static
void
openpic_set_priority
(
u_int
pri
);
static
void
openpic_set_spurious
(
u_int
vector
);
static
void
openpic_enable_sie
(
void
);
static
void
openpic_eicr_set_clk
(
u_int
clkval
);
static
void
openpic_eicr_set_clk
(
u_int
clkval
);
#ifdef CONFIG_SMP
/* Interprocessor Interrupts */
...
...
@@ -73,7 +70,6 @@ static void openpic_mapirq(u_int irq, u_int cpumask, u_int keepmask);
* These functions are not used but the code is kept here
* for completeness and future reference.
*/
static
void
openpic_reset
(
void
);
#ifdef notused
static
void
openpic_enable_8259_pass_through
(
void
);
static
u_int
openpic_get_priority
(
void
);
...
...
@@ -263,6 +259,31 @@ static void openpic_safe_writefield_IPI(volatile u_int *addr, u_int mask, u_int
}
#endif
/* CONFIG_SMP */
#if defined(CONFIG_EPIC_SERIAL_MODE) || defined(CONFIG_PMAC_PBOOK)
static
void
openpic_reset
(
void
)
{
openpic_setfield
(
&
OpenPIC
->
Global
.
Global_Configuration0
,
OPENPIC_CONFIG_RESET
);
while
(
openpic_readfield
(
&
OpenPIC
->
Global
.
Global_Configuration0
,
OPENPIC_CONFIG_RESET
))
mb
();
}
#endif
#ifdef CONFIG_EPIC_SERIAL_MODE
static
void
openpic_enable_sie
(
void
)
{
openpic_setfield
(
&
OpenPIC
->
Global
.
Global_Configuration1
,
OPENPIC_EICR_SIE
);
}
static
void
openpic_eicr_set_clk
(
u_int
clkval
)
{
openpic_writefield
(
&
OpenPIC
->
Global
.
Global_Configuration1
,
OPENPIC_EICR_S_CLK_MASK
,
(
clkval
<<
28
));
}
#endif
void
openpic_set_sources
(
int
first_irq
,
int
num_irqs
,
void
*
first_ISR
)
{
volatile
OpenPIC_Source
*
src
=
first_ISR
;
...
...
@@ -277,7 +298,7 @@ void openpic_set_sources(int first_irq, int num_irqs, void *first_ISR)
ISR
[
i
]
=
src
;
}
void
__init
openpic_init
(
int
main_pic
,
int
offset
,
unsigned
char
*
chrp_ack
,
void
__init
openpic_init
(
int
main_pic
,
int
offset
,
unsigned
char
*
chrp_ack
,
int
programmer_switch_irq
)
{
u_int
t
,
i
;
...
...
@@ -331,7 +352,7 @@ void __init openpic_init(int main_pic, int offset, unsigned char* chrp_ack,
return
;
open_pic_irq_offset
=
offset
;
chrp_int_ack_special
=
(
volatile
unsigned
char
*
)
chrp_ack
;
chrp_int_ack_special
=
chrp_ack
;
/* Initialize timer interrupts */
if
(
ppc_md
.
progress
)
ppc_md
.
progress
(
"openpic timer"
,
0x3ba
);
...
...
@@ -400,40 +421,16 @@ void __init openpic_init(int main_pic, int offset, unsigned char* chrp_ack,
"82c59 cascade"
,
NULL
))
printk
(
"Unable to get OpenPIC IRQ 0 for cascade
\n
"
);
}
#ifdef CONFIG_EPIC_SERIAL_MODE
openpic_disable_8259_pass_through
();
#ifdef CONFIG_EPIC_SERIAL_MODE
openpic_eicr_set_clk
(
7
);
/* Slowest value until we know better */
openpic_enable_sie
();
openpic_set_priority
(
0
);
#else
openpic_disable_8259_pass_through
();
openpic_set_priority
(
0
);
#endif
openpic_set_priority
(
0
);
if
(
ppc_md
.
progress
)
ppc_md
.
progress
(
"openpic exit"
,
0x222
);
}
static
void
openpic_reset
(
void
)
{
openpic_setfield
(
&
OpenPIC
->
Global
.
Global_Configuration0
,
OPENPIC_CONFIG_RESET
);
while
(
openpic_readfield
(
&
OpenPIC
->
Global
.
Global_Configuration0
,
OPENPIC_CONFIG_RESET
))
mb
();
}
static
void
openpic_enable_sie
(
void
)
{
openpic_setfield
(
&
OpenPIC
->
Global
.
Global_Configuration1
,
OPENPIC_EICR_SIE
);
}
static
void
openpic_eicr_set_clk
(
u_int
clkval
)
{
openpic_writefield
(
&
OpenPIC
->
Global
.
Global_Configuration1
,
OPENPIC_EICR_S_CLK_MASK
,
(
clkval
<<
28
));
}
#ifdef notused
static
void
openpic_enable_8259_pass_through
(
void
)
{
...
...
@@ -533,7 +530,9 @@ void openpic_reset_processor_phys(u_int mask)
openpic_write
(
&
OpenPIC
->
Global
.
Processor_Initialization
,
mask
);
}
#if defined(CONFIG_SMP) || defined(CONFIG_PMAC_PBOOK)
static
spinlock_t
openpic_setup_lock
=
SPIN_LOCK_UNLOCKED
;
#endif
#ifdef CONFIG_SMP
/*
...
...
arch/ppc/platforms/prep_setup.c
View file @
8e3a7330
...
...
@@ -685,12 +685,6 @@ prep_irq_cannonicalize(u_int irq)
}
}
static
int
__prep
prep_get_irq
(
struct
pt_regs
*
regs
)
{
return
i8259_irq
();
}
static
void
__init
prep_init_IRQ
(
void
)
{
...
...
@@ -867,7 +861,7 @@ prep_init(unsigned long r3, unsigned long r4, unsigned long r5,
ppc_md
.
irq_cannonicalize
=
prep_irq_cannonicalize
;
ppc_md
.
init_IRQ
=
prep_init_IRQ
;
/* this gets changed later on if we have an OpenPIC -- Cort */
ppc_md
.
get_irq
=
prep_get
_irq
;
ppc_md
.
get_irq
=
i8259
_irq
;
ppc_md
.
init
=
prep_init2
;
ppc_md
.
restart
=
prep_restart
;
...
...
include/asm-ppc/i8259.h
View file @
8e3a7330
...
...
@@ -10,7 +10,7 @@
extern
struct
hw_interrupt_type
i8259_pic
;
void
i8259_init
(
long
);
int
i8259_irq
(
void
);
int
i8259_irq
(
struct
pt_regs
*
regs
);
int
i8259_poll
(
void
);
#endif
/* _PPC_KERNEL_i8259_H */
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