Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
linux-seco-imx
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Iterations
Jira
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Locked files
Deploy
Releases
Package registry
Model registry
Operate
Terraform modules
Analyze
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
GitLab community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
Clea OS
bsp
nxp
linux-seco-imx
Commits
a69755b1
Commit
a69755b1
authored
Mar 31, 2013
by
Al Viro
Browse files
Options
Downloads
Patches
Plain Diff
xtensa simdisk: switch to proc_create_data()
Signed-off-by:
Al Viro
<
viro@zeniv.linux.org.uk
>
parent
78846ce6
Branches
Branches containing commit
Tags
Tags containing commit
No related merge requests found
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
arch/xtensa/platforms/iss/simdisk.c
+23
-13
23 additions, 13 deletions
arch/xtensa/platforms/iss/simdisk.c
with
23 additions
and
13 deletions
arch/xtensa/platforms/iss/simdisk.c
+
23
−
13
View file @
a69755b1
...
@@ -214,20 +214,27 @@ static int simdisk_detach(struct simdisk *dev)
...
@@ -214,20 +214,27 @@ static int simdisk_detach(struct simdisk *dev)
return
err
;
return
err
;
}
}
static
in
t
proc_read_simdisk
(
char
*
page
,
char
**
start
,
off_t
of
f
,
static
ssize_
t
proc_read_simdisk
(
struct
file
*
file
,
char
__user
*
bu
f
,
int
count
,
int
*
eof
,
void
*
data
)
size_t
size
,
loff_t
*
ppos
)
{
{
int
len
;
struct
simdisk
*
dev
=
PDE
(
file_inode
(
file
))
->
data
;
struct
simdisk
*
dev
=
(
struct
simdisk
*
)
data
;
char
*
s
=
dev
->
filename
;
len
=
sprintf
(
page
,
"%s
\n
"
,
dev
->
filename
?
dev
->
filename
:
""
);
if
(
s
)
{
return
len
;
ssize_t
n
=
simple_read_from_buffer
(
buf
,
size
,
ppos
,
s
,
strlen
(
s
));
if
(
n
<
0
)
return
n
;
buf
+=
n
;
size
-=
n
;
}
return
simple_read_from_buffer
(
buf
,
size
,
ppos
,
"
\n
"
,
1
);
}
}
static
in
t
proc_write_simdisk
(
struct
file
*
file
,
const
char
*
buf
fer
,
static
ssize_
t
proc_write_simdisk
(
struct
file
*
file
,
const
char
__user
*
buf
,
unsigned
long
count
,
void
*
data
)
size_t
size
,
loff_t
*
ppos
)
{
{
char
*
tmp
=
kmalloc
(
count
+
1
,
GFP_KERNEL
);
char
*
tmp
=
kmalloc
(
count
+
1
,
GFP_KERNEL
);
struct
simdisk
*
dev
=
(
struct
simdisk
*
)
data
;
struct
simdisk
*
dev
=
PDE
(
file_inode
(
file
))
->
data
;
int
err
;
int
err
;
if
(
tmp
==
NULL
)
if
(
tmp
==
NULL
)
...
@@ -256,6 +263,12 @@ static int proc_write_simdisk(struct file *file, const char *buffer,
...
@@ -256,6 +263,12 @@ static int proc_write_simdisk(struct file *file, const char *buffer,
return
err
;
return
err
;
}
}
static
const
struct
file_operations
fops
=
{
.
read
=
proc_read_simdisk
,
.
write
=
proc_write_simdisk
,
.
llseek
=
default_llseek
,
};
static
int
__init
simdisk_setup
(
struct
simdisk
*
dev
,
int
which
,
static
int
__init
simdisk_setup
(
struct
simdisk
*
dev
,
int
which
,
struct
proc_dir_entry
*
procdir
)
struct
proc_dir_entry
*
procdir
)
{
{
...
@@ -289,10 +302,7 @@ static int __init simdisk_setup(struct simdisk *dev, int which,
...
@@ -289,10 +302,7 @@ static int __init simdisk_setup(struct simdisk *dev, int which,
set_capacity
(
dev
->
gd
,
0
);
set_capacity
(
dev
->
gd
,
0
);
add_disk
(
dev
->
gd
);
add_disk
(
dev
->
gd
);
dev
->
procfile
=
create_proc_entry
(
tmp
,
0644
,
procdir
);
dev
->
procfile
=
proc_create_data
(
tmp
,
0644
,
procdir
,
&
fops
,
dev
);
dev
->
procfile
->
data
=
dev
;
dev
->
procfile
->
read_proc
=
proc_read_simdisk
;
dev
->
procfile
->
write_proc
=
proc_write_simdisk
;
return
0
;
return
0
;
out_alloc_disk:
out_alloc_disk:
...
...
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
sign in
to comment