Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
L
linux-davinci-2.6.23
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-2.6.23
Commits
cddece4b
Commit
cddece4b
authored
Mar 20, 2007
by
Len Brown
Browse files
Options
Browse Files
Download
Plain Diff
Pull c2 into release branch
parents
b25e8442
25496cae
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
29 additions
and
9 deletions
+29
-9
drivers/acpi/processor_idle.c
drivers/acpi/processor_idle.c
+29
-9
No files found.
drivers/acpi/processor_idle.c
View file @
cddece4b
...
@@ -89,6 +89,12 @@ module_param(nocst, uint, 0000);
...
@@ -89,6 +89,12 @@ module_param(nocst, uint, 0000);
static
unsigned
int
bm_history
__read_mostly
=
static
unsigned
int
bm_history
__read_mostly
=
(
HZ
>=
800
?
0xFFFFFFFF
:
((
1U
<<
(
HZ
/
25
))
-
1
));
(
HZ
>=
800
?
0xFFFFFFFF
:
((
1U
<<
(
HZ
/
25
))
-
1
));
module_param
(
bm_history
,
uint
,
0644
);
module_param
(
bm_history
,
uint
,
0644
);
static
unsigned
use_ipi
=
2
;
module_param
(
use_ipi
,
uint
,
0644
);
MODULE_PARM_DESC
(
use_ipi
,
"IPI (vs. LAPIC) irqs for not waking up from C2/C3"
" machines. 0=apic, 1=ipi, 2=auto
\n
"
);
/* --------------------------------------------------------------------------
/* --------------------------------------------------------------------------
Power Management
Power Management
-------------------------------------------------------------------------- */
-------------------------------------------------------------------------- */
...
@@ -260,9 +266,8 @@ static void acpi_cstate_enter(struct acpi_processor_cx *cstate)
...
@@ -260,9 +266,8 @@ static void acpi_cstate_enter(struct acpi_processor_cx *cstate)
/*
/*
* Some BIOS implementations switch to C3 in the published C2 state.
* Some BIOS implementations switch to C3 in the published C2 state.
* This seems to be a common problem on AMD boxen, but other vendors
* This seems to be a common problem on AMD boxen and Intel Dothan/Banias
* are affected too. We pick the most conservative approach: we assume
* Pentium M machines.
* that the local APIC stops in both C2 and C3.
*/
*/
static
void
acpi_timer_check_state
(
int
state
,
struct
acpi_processor
*
pr
,
static
void
acpi_timer_check_state
(
int
state
,
struct
acpi_processor
*
pr
,
struct
acpi_processor_cx
*
cx
)
struct
acpi_processor_cx
*
cx
)
...
@@ -276,8 +281,17 @@ static void acpi_timer_check_state(int state, struct acpi_processor *pr,
...
@@ -276,8 +281,17 @@ static void acpi_timer_check_state(int state, struct acpi_processor *pr,
if
(
pwr
->
timer_broadcast_on_state
<
state
)
if
(
pwr
->
timer_broadcast_on_state
<
state
)
return
;
return
;
if
(
cx
->
type
>=
ACPI_STATE_C2
)
if
(
cx
->
type
>=
ACPI_STATE_C2
)
{
pr
->
power
.
timer_broadcast_on_state
=
state
;
if
(
boot_cpu_data
.
x86_vendor
==
X86_VENDOR_AMD
)
pr
->
power
.
timer_broadcast_on_state
=
state
;
else
if
((
boot_cpu_data
.
x86_vendor
==
X86_VENDOR_INTEL
&&
boot_cpu_data
.
x86
==
6
)
&&
(
boot_cpu_data
.
x86_model
==
13
||
boot_cpu_data
.
x86_model
==
9
))
{
pr
->
power
.
timer_broadcast_on_state
=
state
;
}
}
}
}
static
void
acpi_propagate_timer_broadcast
(
struct
acpi_processor
*
pr
)
static
void
acpi_propagate_timer_broadcast
(
struct
acpi_processor
*
pr
)
...
@@ -292,10 +306,16 @@ static void acpi_propagate_timer_broadcast(struct acpi_processor *pr)
...
@@ -292,10 +306,16 @@ static void acpi_propagate_timer_broadcast(struct acpi_processor *pr)
#else
#else
cpumask_t
mask
=
cpumask_of_cpu
(
pr
->
id
);
cpumask_t
mask
=
cpumask_of_cpu
(
pr
->
id
);
if
(
pr
->
power
.
timer_broadcast_on_state
<
INT_MAX
)
if
(
use_ipi
==
0
)
on_each_cpu
(
switch_APIC_timer_to_ipi
,
&
mask
,
1
,
1
);
on_each_cpu
(
switch_APIC_timer_to_ipi
,
&
mask
,
1
,
1
);
else
else
if
(
use_ipi
==
1
)
on_each_cpu
(
switch_ipi_to_APIC_timer
,
&
mask
,
1
,
1
);
on_each_cpu
(
switch_ipi_to_APIC_timer
,
&
mask
,
1
,
1
);
else
{
if
(
pr
->
power
.
timer_broadcast_on_state
<
INT_MAX
)
on_each_cpu
(
switch_APIC_timer_to_ipi
,
&
mask
,
1
,
1
);
else
on_each_cpu
(
switch_ipi_to_APIC_timer
,
&
mask
,
1
,
1
);
}
#endif
#endif
}
}
...
@@ -1013,13 +1033,13 @@ static int acpi_processor_power_verify(struct acpi_processor *pr)
...
@@ -1013,13 +1033,13 @@ static int acpi_processor_power_verify(struct acpi_processor *pr)
case
ACPI_STATE_C2
:
case
ACPI_STATE_C2
:
acpi_processor_power_verify_c2
(
cx
);
acpi_processor_power_verify_c2
(
cx
);
if
(
cx
->
valid
)
if
(
cx
->
valid
&&
use_ipi
!=
0
&&
use_ipi
!=
1
)
acpi_timer_check_state
(
i
,
pr
,
cx
);
acpi_timer_check_state
(
i
,
pr
,
cx
);
break
;
break
;
case
ACPI_STATE_C3
:
case
ACPI_STATE_C3
:
acpi_processor_power_verify_c3
(
pr
,
cx
);
acpi_processor_power_verify_c3
(
pr
,
cx
);
if
(
cx
->
valid
)
if
(
cx
->
valid
&&
use_ipi
!=
0
&&
use_ipi
!=
1
)
acpi_timer_check_state
(
i
,
pr
,
cx
);
acpi_timer_check_state
(
i
,
pr
,
cx
);
break
;
break
;
}
}
...
...
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