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
4167ab90
Commit
4167ab90
authored
Sep 29, 2011
by
Ingo Molnar
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'core' of
git://amd64.org/linux/rric
into perf/core
parents
d6eed550
298557db
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
2 additions
and
25 deletions
+2
-25
arch/x86/oprofile/op_model_ppro.c
arch/x86/oprofile/op_model_ppro.c
+2
-25
No files found.
arch/x86/oprofile/op_model_ppro.c
View file @
4167ab90
...
@@ -28,7 +28,7 @@ static int counter_width = 32;
...
@@ -28,7 +28,7 @@ static int counter_width = 32;
#define MSR_PPRO_EVENTSEL_RESERVED ((0xFFFFFFFFULL<<32)|(1ULL<<21))
#define MSR_PPRO_EVENTSEL_RESERVED ((0xFFFFFFFFULL<<32)|(1ULL<<21))
static
u64
*
reset_value
;
static
u64
reset_value
[
OP_MAX_COUNTER
]
;
static
void
ppro_shutdown
(
struct
op_msrs
const
*
const
msrs
)
static
void
ppro_shutdown
(
struct
op_msrs
const
*
const
msrs
)
{
{
...
@@ -40,10 +40,6 @@ static void ppro_shutdown(struct op_msrs const * const msrs)
...
@@ -40,10 +40,6 @@ static void ppro_shutdown(struct op_msrs const * const msrs)
release_perfctr_nmi
(
MSR_P6_PERFCTR0
+
i
);
release_perfctr_nmi
(
MSR_P6_PERFCTR0
+
i
);
release_evntsel_nmi
(
MSR_P6_EVNTSEL0
+
i
);
release_evntsel_nmi
(
MSR_P6_EVNTSEL0
+
i
);
}
}
if
(
reset_value
)
{
kfree
(
reset_value
);
reset_value
=
NULL
;
}
}
}
static
int
ppro_fill_in_addresses
(
struct
op_msrs
*
const
msrs
)
static
int
ppro_fill_in_addresses
(
struct
op_msrs
*
const
msrs
)
...
@@ -79,13 +75,6 @@ static void ppro_setup_ctrs(struct op_x86_model_spec const *model,
...
@@ -79,13 +75,6 @@ static void ppro_setup_ctrs(struct op_x86_model_spec const *model,
u64
val
;
u64
val
;
int
i
;
int
i
;
if
(
!
reset_value
)
{
reset_value
=
kzalloc
(
sizeof
(
reset_value
[
0
])
*
num_counters
,
GFP_ATOMIC
);
if
(
!
reset_value
)
return
;
}
if
(
cpu_has_arch_perfmon
)
{
if
(
cpu_has_arch_perfmon
)
{
union
cpuid10_eax
eax
;
union
cpuid10_eax
eax
;
eax
.
full
=
cpuid_eax
(
0xa
);
eax
.
full
=
cpuid_eax
(
0xa
);
...
@@ -141,13 +130,6 @@ static int ppro_check_ctrs(struct pt_regs * const regs,
...
@@ -141,13 +130,6 @@ static int ppro_check_ctrs(struct pt_regs * const regs,
u64
val
;
u64
val
;
int
i
;
int
i
;
/*
* This can happen if perf counters are in use when
* we steal the die notifier NMI.
*/
if
(
unlikely
(
!
reset_value
))
goto
out
;
for
(
i
=
0
;
i
<
num_counters
;
++
i
)
{
for
(
i
=
0
;
i
<
num_counters
;
++
i
)
{
if
(
!
reset_value
[
i
])
if
(
!
reset_value
[
i
])
continue
;
continue
;
...
@@ -158,7 +140,6 @@ static int ppro_check_ctrs(struct pt_regs * const regs,
...
@@ -158,7 +140,6 @@ static int ppro_check_ctrs(struct pt_regs * const regs,
wrmsrl
(
msrs
->
counters
[
i
].
addr
,
-
reset_value
[
i
]);
wrmsrl
(
msrs
->
counters
[
i
].
addr
,
-
reset_value
[
i
]);
}
}
out:
/* Only P6 based Pentium M need to re-unmask the apic vector but it
/* Only P6 based Pentium M need to re-unmask the apic vector but it
* doesn't hurt other P6 variant */
* doesn't hurt other P6 variant */
apic_write
(
APIC_LVTPC
,
apic_read
(
APIC_LVTPC
)
&
~
APIC_LVT_MASKED
);
apic_write
(
APIC_LVTPC
,
apic_read
(
APIC_LVTPC
)
&
~
APIC_LVT_MASKED
);
...
@@ -179,8 +160,6 @@ static void ppro_start(struct op_msrs const * const msrs)
...
@@ -179,8 +160,6 @@ static void ppro_start(struct op_msrs const * const msrs)
u64
val
;
u64
val
;
int
i
;
int
i
;
if
(
!
reset_value
)
return
;
for
(
i
=
0
;
i
<
num_counters
;
++
i
)
{
for
(
i
=
0
;
i
<
num_counters
;
++
i
)
{
if
(
reset_value
[
i
])
{
if
(
reset_value
[
i
])
{
rdmsrl
(
msrs
->
controls
[
i
].
addr
,
val
);
rdmsrl
(
msrs
->
controls
[
i
].
addr
,
val
);
...
@@ -196,8 +175,6 @@ static void ppro_stop(struct op_msrs const * const msrs)
...
@@ -196,8 +175,6 @@ static void ppro_stop(struct op_msrs const * const msrs)
u64
val
;
u64
val
;
int
i
;
int
i
;
if
(
!
reset_value
)
return
;
for
(
i
=
0
;
i
<
num_counters
;
++
i
)
{
for
(
i
=
0
;
i
<
num_counters
;
++
i
)
{
if
(
!
reset_value
[
i
])
if
(
!
reset_value
[
i
])
continue
;
continue
;
...
@@ -242,7 +219,7 @@ static void arch_perfmon_setup_counters(void)
...
@@ -242,7 +219,7 @@ static void arch_perfmon_setup_counters(void)
eax
.
split
.
bit_width
=
40
;
eax
.
split
.
bit_width
=
40
;
}
}
num_counters
=
eax
.
split
.
num_counters
;
num_counters
=
min
((
int
)
eax
.
split
.
num_counters
,
OP_MAX_COUNTER
)
;
op_arch_perfmon_spec
.
num_counters
=
num_counters
;
op_arch_perfmon_spec
.
num_counters
=
num_counters
;
op_arch_perfmon_spec
.
num_controls
=
num_counters
;
op_arch_perfmon_spec
.
num_controls
=
num_counters
;
...
...
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