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
4c82f811
Commit
4c82f811
authored
Aug 03, 2004
by
Dave Jones
Committed by
Dave Jones
Aug 03, 2004
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[CPUFREQ] Whitespace cleanup for centrino speedstep.
Signed-off-by:
Dave Jones
<
davej@redhat.com
>
parent
cb1ddb47
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
28 additions
and
30 deletions
+28
-30
arch/i386/kernel/cpu/cpufreq/speedstep-centrino.c
arch/i386/kernel/cpu/cpufreq/speedstep-centrino.c
+28
-30
No files found.
arch/i386/kernel/cpu/cpufreq/speedstep-centrino.c
View file @
4c82f811
...
@@ -75,7 +75,7 @@ static int centrino_verify_cpu_id(const struct cpuinfo_x86 *c, const struct cpu_
...
@@ -75,7 +75,7 @@ static int centrino_verify_cpu_id(const struct cpuinfo_x86 *c, const struct cpu_
/* Operating points for current CPU */
/* Operating points for current CPU */
static
struct
cpu_model
*
centrino_model
;
static
struct
cpu_model
*
centrino_model
;
static
int
centrino_cpu
;
static
int
centrino_cpu
;
#ifdef CONFIG_X86_SPEEDSTEP_CENTRINO_TABLE
#ifdef CONFIG_X86_SPEEDSTEP_CENTRINO_TABLE
...
@@ -88,7 +88,7 @@ static int centrino_cpu;
...
@@ -88,7 +88,7 @@ static int centrino_cpu;
.index = (((mhz)/100) << 8) | ((mv - 700) / 16) \
.index = (((mhz)/100) << 8) | ((mv - 700) / 16) \
}
}
/*
/*
* These voltage tables were derived from the Intel Pentium M
* These voltage tables were derived from the Intel Pentium M
* datasheet, document 25261202.pdf, Table 5. I have verified they
* datasheet, document 25261202.pdf, Table 5. I have verified they
* are consistent with my IBM ThinkPad X31, which has a 1.3GHz Pentium
* are consistent with my IBM ThinkPad X31, which has a 1.3GHz Pentium
...
@@ -139,7 +139,7 @@ static struct cpufreq_frequency_table banias_1200[] =
...
@@ -139,7 +139,7 @@ static struct cpufreq_frequency_table banias_1200[] =
};
};
/* Intel Pentium M processor 1.30GHz (Banias) */
/* Intel Pentium M processor 1.30GHz (Banias) */
static
struct
cpufreq_frequency_table
banias_1300
[]
=
static
struct
cpufreq_frequency_table
banias_1300
[]
=
{
{
OP
(
600
,
956
),
OP
(
600
,
956
),
OP
(
800
,
1260
),
OP
(
800
,
1260
),
...
@@ -150,7 +150,7 @@ static struct cpufreq_frequency_table banias_1300[] =
...
@@ -150,7 +150,7 @@ static struct cpufreq_frequency_table banias_1300[] =
};
};
/* Intel Pentium M processor 1.40GHz (Banias) */
/* Intel Pentium M processor 1.40GHz (Banias) */
static
struct
cpufreq_frequency_table
banias_1400
[]
=
static
struct
cpufreq_frequency_table
banias_1400
[]
=
{
{
OP
(
600
,
956
),
OP
(
600
,
956
),
OP
(
800
,
1180
),
OP
(
800
,
1180
),
...
@@ -161,7 +161,7 @@ static struct cpufreq_frequency_table banias_1400[] =
...
@@ -161,7 +161,7 @@ static struct cpufreq_frequency_table banias_1400[] =
};
};
/* Intel Pentium M processor 1.50GHz (Banias) */
/* Intel Pentium M processor 1.50GHz (Banias) */
static
struct
cpufreq_frequency_table
banias_1500
[]
=
static
struct
cpufreq_frequency_table
banias_1500
[]
=
{
{
OP
(
600
,
956
),
OP
(
600
,
956
),
OP
(
800
,
1116
),
OP
(
800
,
1116
),
...
@@ -173,7 +173,7 @@ static struct cpufreq_frequency_table banias_1500[] =
...
@@ -173,7 +173,7 @@ static struct cpufreq_frequency_table banias_1500[] =
};
};
/* Intel Pentium M processor 1.60GHz (Banias) */
/* Intel Pentium M processor 1.60GHz (Banias) */
static
struct
cpufreq_frequency_table
banias_1600
[]
=
static
struct
cpufreq_frequency_table
banias_1600
[]
=
{
{
OP
(
600
,
956
),
OP
(
600
,
956
),
OP
(
800
,
1036
),
OP
(
800
,
1036
),
...
@@ -207,7 +207,7 @@ static struct cpufreq_frequency_table banias_1700[] =
...
@@ -207,7 +207,7 @@ static struct cpufreq_frequency_table banias_1700[] =
/* CPU models, their operating frequency range, and freq/voltage
/* CPU models, their operating frequency range, and freq/voltage
operating points */
operating points */
static
struct
cpu_model
models
[]
=
static
struct
cpu_model
models
[]
=
{
{
_BANIAS
(
&
cpu_ids
[
CPU_BANIAS
],
900
,
" 900"
),
_BANIAS
(
&
cpu_ids
[
CPU_BANIAS
],
900
,
" 900"
),
BANIAS
(
1000
),
BANIAS
(
1000
),
...
@@ -238,7 +238,7 @@ static int centrino_cpu_init_table(struct cpufreq_policy *policy)
...
@@ -238,7 +238,7 @@ static int centrino_cpu_init_table(struct cpufreq_policy *policy)
(
model
->
model_name
==
NULL
||
(
model
->
model_name
==
NULL
||
strcmp
(
cpu
->
x86_model_id
,
model
->
model_name
)
==
0
))
strcmp
(
cpu
->
x86_model_id
,
model
->
model_name
)
==
0
))
break
;
break
;
if
(
model
->
cpu_id
==
NULL
)
{
if
(
model
->
cpu_id
==
NULL
)
{
/* No match at all */
/* No match at all */
printk
(
KERN_INFO
PFX
"no support for CPU model
\"
%s
\"
: "
printk
(
KERN_INFO
PFX
"no support for CPU model
\"
%s
\"
: "
...
@@ -254,9 +254,9 @@ static int centrino_cpu_init_table(struct cpufreq_policy *policy)
...
@@ -254,9 +254,9 @@ static int centrino_cpu_init_table(struct cpufreq_policy *policy)
printk
(
KERN_INFO
PFX
"try compiling with CONFIG_X86_SPEEDSTEP_CENTRINO_ACPI enabled
\n
"
);
printk
(
KERN_INFO
PFX
"try compiling with CONFIG_X86_SPEEDSTEP_CENTRINO_ACPI enabled
\n
"
);
return
-
ENOENT
;
return
-
ENOENT
;
}
}
centrino_model
=
model
;
centrino_model
=
model
;
printk
(
KERN_INFO
PFX
"found
\"
%s
\"
: max frequency: %dkHz
\n
"
,
printk
(
KERN_INFO
PFX
"found
\"
%s
\"
: max frequency: %dkHz
\n
"
,
model
->
model_name
,
model
->
max_freq
);
model
->
model_name
,
model
->
max_freq
);
...
@@ -281,7 +281,7 @@ static unsigned extract_clock(unsigned msr)
...
@@ -281,7 +281,7 @@ static unsigned extract_clock(unsigned msr)
{
{
int
i
;
int
i
;
/*
/*
* Extract clock in kHz from PERF_CTL value
* Extract clock in kHz from PERF_CTL value
* for centrino, as some DSDTs are buggy.
* for centrino, as some DSDTs are buggy.
* Ideally, this can be done using the acpi_data structure.
* Ideally, this can be done using the acpi_data structure.
...
@@ -295,9 +295,7 @@ static unsigned extract_clock(unsigned msr)
...
@@ -295,9 +295,7 @@ static unsigned extract_clock(unsigned msr)
return
0
;
return
0
;
msr
&=
0xffff
;
msr
&=
0xffff
;
for
(
i
=
0
;
for
(
i
=
0
;
centrino_model
->
op_points
[
i
].
frequency
!=
CPUFREQ_TABLE_END
;
i
++
)
{
centrino_model
->
op_points
[
i
].
frequency
!=
CPUFREQ_TABLE_END
;
i
++
)
{
if
(
msr
==
centrino_model
->
op_points
[
i
].
index
)
if
(
msr
==
centrino_model
->
op_points
[
i
].
index
)
return
centrino_model
->
op_points
[
i
].
frequency
;
return
centrino_model
->
op_points
[
i
].
frequency
;
}
}
...
@@ -326,7 +324,7 @@ static unsigned int get_cur_freq(unsigned int cpu)
...
@@ -326,7 +324,7 @@ static unsigned int get_cur_freq(unsigned int cpu)
static
struct
acpi_processor_performance
p
;
static
struct
acpi_processor_performance
p
;
/*
/*
* centrino_cpu_init_acpi - register with ACPI P-States library
* centrino_cpu_init_acpi - register with ACPI P-States library
*
*
* Register with the ACPI P-States library (part of drivers/acpi/processor.c)
* Register with the ACPI P-States library (part of drivers/acpi/processor.c)
* in order to determine correct frequency and voltage pairings by reading
* in order to determine correct frequency and voltage pairings by reading
...
@@ -336,7 +334,7 @@ static int centrino_cpu_init_acpi(struct cpufreq_policy *policy)
...
@@ -336,7 +334,7 @@ static int centrino_cpu_init_acpi(struct cpufreq_policy *policy)
{
{
union
acpi_object
arg0
=
{
ACPI_TYPE_BUFFER
};
union
acpi_object
arg0
=
{
ACPI_TYPE_BUFFER
};
u32
arg0_buf
[
3
];
u32
arg0_buf
[
3
];
struct
acpi_object_list
arg_list
=
{
1
,
&
arg0
};
struct
acpi_object_list
arg_list
=
{
1
,
&
arg0
};
unsigned
long
cur_freq
;
unsigned
long
cur_freq
;
int
result
=
0
,
i
;
int
result
=
0
,
i
;
...
@@ -358,7 +356,7 @@ static int centrino_cpu_init_acpi(struct cpufreq_policy *policy)
...
@@ -358,7 +356,7 @@ static int centrino_cpu_init_acpi(struct cpufreq_policy *policy)
printk
(
KERN_DEBUG
"No P-States
\n
"
);
printk
(
KERN_DEBUG
"No P-States
\n
"
);
result
=
-
ENODEV
;
result
=
-
ENODEV
;
goto
err_unreg
;
goto
err_unreg
;
}
}
if
((
p
.
control_register
.
space_id
!=
ACPI_ADR_SPACE_FIXED_HARDWARE
)
||
if
((
p
.
control_register
.
space_id
!=
ACPI_ADR_SPACE_FIXED_HARDWARE
)
||
(
p
.
status_register
.
space_id
!=
ACPI_ADR_SPACE_FIXED_HARDWARE
))
{
(
p
.
status_register
.
space_id
!=
ACPI_ADR_SPACE_FIXED_HARDWARE
))
{
...
@@ -396,7 +394,7 @@ static int centrino_cpu_init_acpi(struct cpufreq_policy *policy)
...
@@ -396,7 +394,7 @@ static int centrino_cpu_init_acpi(struct cpufreq_policy *policy)
centrino_model
->
model_name
=
NULL
;
centrino_model
->
model_name
=
NULL
;
centrino_model
->
max_freq
=
p
.
states
[
0
].
core_frequency
*
1000
;
centrino_model
->
max_freq
=
p
.
states
[
0
].
core_frequency
*
1000
;
centrino_model
->
op_points
=
kmalloc
(
sizeof
(
struct
cpufreq_frequency_table
)
*
centrino_model
->
op_points
=
kmalloc
(
sizeof
(
struct
cpufreq_frequency_table
)
*
(
p
.
state_count
+
1
),
GFP_KERNEL
);
(
p
.
state_count
+
1
),
GFP_KERNEL
);
if
(
!
centrino_model
->
op_points
)
{
if
(
!
centrino_model
->
op_points
)
{
result
=
-
ENOMEM
;
result
=
-
ENOMEM
;
...
@@ -426,7 +424,7 @@ static int centrino_cpu_init_acpi(struct cpufreq_policy *policy)
...
@@ -426,7 +424,7 @@ static int centrino_cpu_init_acpi(struct cpufreq_policy *policy)
}
}
return
0
;
return
0
;
err_kfree_all:
err_kfree_all:
kfree
(
centrino_model
->
op_points
);
kfree
(
centrino_model
->
op_points
);
err_kfree:
err_kfree:
...
@@ -464,7 +462,7 @@ static int centrino_cpu_init(struct cpufreq_policy *policy)
...
@@ -464,7 +462,7 @@ static int centrino_cpu_init(struct cpufreq_policy *policy)
if
(
!
centrino_cpu
)
{
if
(
!
centrino_cpu
)
{
printk
(
KERN_INFO
PFX
"found unsupported CPU with "
printk
(
KERN_INFO
PFX
"found unsupported CPU with "
"Enhanced SpeedStep: send /proc/cpuinfo to "
"Enhanced SpeedStep: send /proc/cpuinfo to "
MAINTAINER
"
\n
"
);
MAINTAINER
"
\n
"
);
return
-
ENODEV
;
return
-
ENODEV
;
}
}
...
@@ -477,11 +475,11 @@ static int centrino_cpu_init(struct cpufreq_policy *policy)
...
@@ -477,11 +475,11 @@ static int centrino_cpu_init(struct cpufreq_policy *policy)
/* Check to see if Enhanced SpeedStep is enabled, and try to
/* Check to see if Enhanced SpeedStep is enabled, and try to
enable it if not. */
enable it if not. */
rdmsr
(
MSR_IA32_MISC_ENABLE
,
l
,
h
);
rdmsr
(
MSR_IA32_MISC_ENABLE
,
l
,
h
);
if
(
!
(
l
&
(
1
<<
16
)))
{
if
(
!
(
l
&
(
1
<<
16
)))
{
l
|=
(
1
<<
16
);
l
|=
(
1
<<
16
);
wrmsr
(
MSR_IA32_MISC_ENABLE
,
l
,
h
);
wrmsr
(
MSR_IA32_MISC_ENABLE
,
l
,
h
);
/* check to see if it stuck */
/* check to see if it stuck */
rdmsr
(
MSR_IA32_MISC_ENABLE
,
l
,
h
);
rdmsr
(
MSR_IA32_MISC_ENABLE
,
l
,
h
);
if
(
!
(
l
&
(
1
<<
16
)))
{
if
(
!
(
l
&
(
1
<<
16
)))
{
...
@@ -498,7 +496,7 @@ static int centrino_cpu_init(struct cpufreq_policy *policy)
...
@@ -498,7 +496,7 @@ static int centrino_cpu_init(struct cpufreq_policy *policy)
dprintk
(
KERN_INFO
PFX
"centrino_cpu_init: policy=%d cur=%dkHz
\n
"
,
dprintk
(
KERN_INFO
PFX
"centrino_cpu_init: policy=%d cur=%dkHz
\n
"
,
policy
->
policy
,
policy
->
cur
);
policy
->
policy
,
policy
->
cur
);
ret
=
cpufreq_frequency_table_cpuinfo
(
policy
,
centrino_model
->
op_points
);
ret
=
cpufreq_frequency_table_cpuinfo
(
policy
,
centrino_model
->
op_points
);
if
(
ret
)
if
(
ret
)
return
(
ret
);
return
(
ret
);
...
@@ -592,7 +590,7 @@ static int centrino_target (struct cpufreq_policy *policy,
...
@@ -592,7 +590,7 @@ static int centrino_target (struct cpufreq_policy *policy,
tell us something happened, but it may leave the things on
tell us something happened, but it may leave the things on
the notifier chain confused; we therefore stick to using
the notifier chain confused; we therefore stick to using
the last programmed speed rather than the current speed for
the last programmed speed rather than the current speed for
"old".
"old".
TODO: work out how the TCC interrupts work, and try to
TODO: work out how the TCC interrupts work, and try to
catch the CPU changing things under us.
catch the CPU changing things under us.
...
@@ -600,18 +598,18 @@ static int centrino_target (struct cpufreq_policy *policy,
...
@@ -600,18 +598,18 @@ static int centrino_target (struct cpufreq_policy *policy,
freqs
.
cpu
=
policy
->
cpu
;
freqs
.
cpu
=
policy
->
cpu
;
freqs
.
old
=
extract_clock
(
oldmsr
);
freqs
.
old
=
extract_clock
(
oldmsr
);
freqs
.
new
=
extract_clock
(
msr
);
freqs
.
new
=
extract_clock
(
msr
);
dprintk
(
KERN_INFO
PFX
"target=%dkHz old=%d new=%d msr=%04x
\n
"
,
dprintk
(
KERN_INFO
PFX
"target=%dkHz old=%d new=%d msr=%04x
\n
"
,
target_freq
,
freqs
.
old
,
freqs
.
new
,
msr
);
target_freq
,
freqs
.
old
,
freqs
.
new
,
msr
);
cpufreq_notify_transition
(
&
freqs
,
CPUFREQ_PRECHANGE
);
cpufreq_notify_transition
(
&
freqs
,
CPUFREQ_PRECHANGE
);
/* all but 16 LSB are "reserved", so treat them with
/* all but 16 LSB are "reserved", so treat them with
care */
care */
oldmsr
&=
~
0xffff
;
oldmsr
&=
~
0xffff
;
msr
&=
0xffff
;
msr
&=
0xffff
;
oldmsr
|=
msr
;
oldmsr
|=
msr
;
wrmsr
(
MSR_IA32_PERF_CTL
,
oldmsr
,
h
);
wrmsr
(
MSR_IA32_PERF_CTL
,
oldmsr
,
h
);
cpufreq_notify_transition
(
&
freqs
,
CPUFREQ_POSTCHANGE
);
cpufreq_notify_transition
(
&
freqs
,
CPUFREQ_POSTCHANGE
);
...
@@ -628,12 +626,12 @@ static struct freq_attr* centrino_attr[] = {
...
@@ -628,12 +626,12 @@ static struct freq_attr* centrino_attr[] = {
};
};
static
struct
cpufreq_driver
centrino_driver
=
{
static
struct
cpufreq_driver
centrino_driver
=
{
.
name
=
"centrino"
,
/* should be speedstep-centrino,
.
name
=
"centrino"
,
/* should be speedstep-centrino,
but there's a 16 char limit */
but there's a 16 char limit */
.
init
=
centrino_cpu_init
,
.
init
=
centrino_cpu_init
,
.
exit
=
centrino_cpu_exit
,
.
exit
=
centrino_cpu_exit
,
.
verify
=
centrino_verify
,
.
verify
=
centrino_verify
,
.
target
=
centrino_target
,
.
target
=
centrino_target
,
.
get
=
get_cur_freq
,
.
get
=
get_cur_freq
,
.
attr
=
centrino_attr
,
.
attr
=
centrino_attr
,
.
owner
=
THIS_MODULE
,
.
owner
=
THIS_MODULE
,
...
...
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