Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
L
linux-davinci
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
Commits
ae92dc9f
Commit
ae92dc9f
authored
Mar 16, 2006
by
Russell King
Committed by
Russell King
Mar 21, 2006
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[ARM] Oprofile: dynamically allocate counter_config
Signed-off-by:
Russell King
<
rmk+kernel@arm.linux.org.uk
>
parent
93ad7949
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
10 additions
and
3 deletions
+10
-3
arch/arm/oprofile/common.c
arch/arm/oprofile/common.c
+9
-2
arch/arm/oprofile/op_counter.h
arch/arm/oprofile/op_counter.h
+1
-1
No files found.
arch/arm/oprofile/common.c
View file @
ae92dc9f
...
...
@@ -10,6 +10,7 @@
#include <linux/init.h>
#include <linux/oprofile.h>
#include <linux/errno.h>
#include <linux/slab.h>
#include <linux/sysdev.h>
#include <linux/mutex.h>
...
...
@@ -20,7 +21,7 @@ static struct op_arm_model_spec *op_arm_model;
static
int
op_arm_enabled
;
static
DEFINE_MUTEX
(
op_arm_mutex
);
struct
op_counter_config
counter_config
[
OP_MAX_COUNTER
]
;
struct
op_counter_config
*
counter_config
;
static
int
op_arm_create_files
(
struct
super_block
*
sb
,
struct
dentry
*
root
)
{
...
...
@@ -28,7 +29,7 @@ static int op_arm_create_files(struct super_block *sb, struct dentry *root)
for
(
i
=
0
;
i
<
op_arm_model
->
num_counters
;
i
++
)
{
struct
dentry
*
dir
;
char
buf
[
2
];
char
buf
[
4
];
snprintf
(
buf
,
sizeof
buf
,
"%d"
,
i
);
dir
=
oprofilefs_mkdir
(
sb
,
root
,
buf
);
...
...
@@ -139,6 +140,11 @@ int __init oprofile_arch_init(struct oprofile_operations *ops)
if
(
ret
<
0
)
return
ret
;
counter_config
=
kmalloc
(
sizeof
(
struct
op_counter_config
)
*
spec
->
num_counters
,
GFP_KERNEL
);
if
(
!
counter_config
)
return
-
ENOMEM
;
op_arm_model
=
spec
;
init_driverfs
();
ops
->
create_files
=
op_arm_create_files
;
...
...
@@ -160,4 +166,5 @@ void oprofile_arch_exit(void)
exit_driverfs
();
op_arm_model
=
NULL
;
}
kfree
(
counter_config
);
}
arch/arm/oprofile/op_counter.h
View file @
ae92dc9f
...
...
@@ -24,6 +24,6 @@ struct op_counter_config {
unsigned
long
user
;
};
extern
struct
op_counter_config
counter_config
[]
;
extern
struct
op_counter_config
*
counter_config
;
#endif
/* OP_COUNTER_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