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
nexedi
linux
Commits
9f283aa1
Commit
9f283aa1
authored
Aug 24, 2003
by
Benjamin Herrenschmidt
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Update PowerMac cpufreq driver to adapt it to some core
changes and fix a race with the PMU driver
parent
d1ef4917
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
23 additions
and
9 deletions
+23
-9
arch/ppc/platforms/pmac_cpufreq.c
arch/ppc/platforms/pmac_cpufreq.c
+23
-9
No files found.
arch/ppc/platforms/pmac_cpufreq.c
View file @
9f283aa1
...
@@ -21,6 +21,7 @@
...
@@ -21,6 +21,7 @@
#include <linux/slab.h>
#include <linux/slab.h>
#include <linux/cpufreq.h>
#include <linux/cpufreq.h>
#include <linux/init.h>
#include <linux/init.h>
#include <linux/sysdev.h>
#include <asm/prom.h>
#include <asm/prom.h>
#include <asm/machdep.h>
#include <asm/machdep.h>
#include <asm/irq.h>
#include <asm/irq.h>
...
@@ -31,12 +32,16 @@
...
@@ -31,12 +32,16 @@
#include <asm/cputable.h>
#include <asm/cputable.h>
#include <asm/time.h>
#include <asm/time.h>
/* WARNING !!! This will cause calibrate_delay() to be called,
* but this is an __init function ! So you MUST go edit
* init/main.c to make it non-init before enabling DEBUG_FREQ
*/
#undef DEBUG_FREQ
#undef DEBUG_FREQ
extern
void
low_choose_750fx_pll
(
int
pll
);
extern
void
low_choose_750fx_pll
(
int
pll
);
extern
void
low_sleep_handler
(
void
);
extern
void
low_sleep_handler
(
void
);
extern
void
openpic_s
leep_save_intrs
(
void
);
extern
void
openpic_s
uspend
(
struct
sys_device
*
sysdev
,
u32
state
);
extern
void
openpic_
sleep_restore_intrs
(
void
);
extern
void
openpic_
resume
(
struct
sys_device
*
sysdev
);
extern
void
enable_kernel_altivec
(
void
);
extern
void
enable_kernel_altivec
(
void
);
extern
void
enable_kernel_fp
(
void
);
extern
void
enable_kernel_fp
(
void
);
...
@@ -116,10 +121,7 @@ pmu_set_cpu_speed(unsigned int low_speed)
...
@@ -116,10 +121,7 @@ pmu_set_cpu_speed(unsigned int low_speed)
printk
(
KERN_DEBUG
"HID1, before: %x
\n
"
,
mfspr
(
SPRN_HID1
));
printk
(
KERN_DEBUG
"HID1, before: %x
\n
"
,
mfspr
(
SPRN_HID1
));
#endif
#endif
/* Disable all interrupt sources on openpic */
/* Disable all interrupt sources on openpic */
openpic_sleep_save_intrs
();
openpic_suspend
(
NULL
,
1
);
/* Make sure the PMU is idle */
pmu_suspend
();
/* Make sure the decrementer won't interrupt us */
/* Make sure the decrementer won't interrupt us */
asm
volatile
(
"mtdec %0"
:
:
"r"
(
0x7fffffff
));
asm
volatile
(
"mtdec %0"
:
:
"r"
(
0x7fffffff
));
...
@@ -154,10 +156,15 @@ pmu_set_cpu_speed(unsigned int low_speed)
...
@@ -154,10 +156,15 @@ pmu_set_cpu_speed(unsigned int low_speed)
while
(
!
req
.
complete
)
while
(
!
req
.
complete
)
pmu_poll
();
pmu_poll
();
/* Prepare the northbridge for the speed transition */
pmac_call_feature
(
PMAC_FTR_SLEEP_STATE
,
NULL
,
1
,
1
);
pmac_call_feature
(
PMAC_FTR_SLEEP_STATE
,
NULL
,
1
,
1
);
/* Call low level code to backup CPU state and recover from
* hardware reset
*/
low_sleep_handler
();
low_sleep_handler
();
/* Restore the northbridge */
pmac_call_feature
(
PMAC_FTR_SLEEP_STATE
,
NULL
,
1
,
0
);
pmac_call_feature
(
PMAC_FTR_SLEEP_STATE
,
NULL
,
1
,
0
);
/* Restore L2 cache */
/* Restore L2 cache */
...
@@ -174,13 +181,14 @@ pmu_set_cpu_speed(unsigned int low_speed)
...
@@ -174,13 +181,14 @@ pmu_set_cpu_speed(unsigned int low_speed)
printk
(
KERN_DEBUG
"HID1, after: %x
\n
"
,
mfspr
(
SPRN_HID1
));
printk
(
KERN_DEBUG
"HID1, after: %x
\n
"
,
mfspr
(
SPRN_HID1
));
#endif
#endif
/* Restore low level PMU operations */
pmu_unlock
();
/* Restore decrementer */
/* Restore decrementer */
wakeup_decrementer
();
wakeup_decrementer
();
/* Restore interrupts */
/* Restore interrupts */
openpic_sleep_restore_intrs
();
openpic_resume
(
NULL
);
pmu_resume
();
/* Let interrupts flow again ... */
/* Let interrupts flow again ... */
local_irq_enable
();
local_irq_enable
();
...
@@ -202,6 +210,9 @@ do_set_cpu_speed(int speed_mode)
...
@@ -202,6 +210,9 @@ do_set_cpu_speed(int speed_mode)
freqs
.
new
=
(
speed_mode
==
PMAC_CPU_HIGH_SPEED
)
?
hi_freq
:
low_freq
;
freqs
.
new
=
(
speed_mode
==
PMAC_CPU_HIGH_SPEED
)
?
hi_freq
:
low_freq
;
freqs
.
cpu
=
smp_processor_id
();
freqs
.
cpu
=
smp_processor_id
();
if
(
freqs
.
old
==
freqs
.
new
)
return
0
;
cpufreq_notify_transition
(
&
freqs
,
CPUFREQ_PRECHANGE
);
cpufreq_notify_transition
(
&
freqs
,
CPUFREQ_PRECHANGE
);
if
(
cpufreq_uses_pmu
)
if
(
cpufreq_uses_pmu
)
rc
=
pmu_set_cpu_speed
(
speed_mode
);
rc
=
pmu_set_cpu_speed
(
speed_mode
);
...
@@ -276,6 +287,9 @@ pmac_cpufreq_setup(void)
...
@@ -276,6 +287,9 @@ pmac_cpufreq_setup(void)
u32
*
value
;
u32
*
value
;
int
has_freq_ctl
=
0
;
int
has_freq_ctl
=
0
;
if
(
strstr
(
cmd_line
,
"nocpufreq"
))
return
0
;
/* Assume only one CPU */
/* Assume only one CPU */
cpunode
=
find_type_devices
(
"cpu"
);
cpunode
=
find_type_devices
(
"cpu"
);
if
(
!
cpunode
)
if
(
!
cpunode
)
...
...
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