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
28d1aea6
Commit
28d1aea6
authored
May 30, 2003
by
Christoph Hellwig
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[PATCH] switch /proc/scsi/scsi to seq_file and proper device model
parent
0859138b
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
64 additions
and
82 deletions
+64
-82
drivers/scsi/scsi_priv.h
drivers/scsi/scsi_priv.h
+1
-0
drivers/scsi/scsi_proc.c
drivers/scsi/scsi_proc.c
+62
-81
drivers/scsi/scsi_sysfs.c
drivers/scsi/scsi_sysfs.c
+1
-1
No files found.
drivers/scsi/scsi_priv.h
View file @
28d1aea6
...
@@ -130,5 +130,6 @@ extern struct class_device_attribute *scsi_sysfs_shost_attrs[];
...
@@ -130,5 +130,6 @@ extern struct class_device_attribute *scsi_sysfs_shost_attrs[];
extern
struct
device_attribute
*
scsi_sysfs_sdev_attrs
[];
extern
struct
device_attribute
*
scsi_sysfs_sdev_attrs
[];
extern
struct
class
shost_class
;
extern
struct
class
shost_class
;
extern
struct
bus_type
scsi_bus_type
;
#endif
/* _SCSI_PRIV_H */
#endif
/* _SCSI_PRIV_H */
drivers/scsi/scsi_proc.c
View file @
28d1aea6
...
@@ -24,6 +24,7 @@
...
@@ -24,6 +24,7 @@
#include <linux/proc_fs.h>
#include <linux/proc_fs.h>
#include <linux/errno.h>
#include <linux/errno.h>
#include <linux/blk.h>
#include <linux/blk.h>
#include <linux/seq_file.h>
#include <asm/uaccess.h>
#include <asm/uaccess.h>
#include "scsi.h"
#include "scsi.h"
...
@@ -86,7 +87,7 @@ static int proc_scsi_read(char *buffer, char **start, off_t offset,
...
@@ -86,7 +87,7 @@ static int proc_scsi_read(char *buffer, char **start, off_t offset,
return
n
;
return
n
;
}
}
static
int
proc_scsi_write
(
struct
file
*
file
,
const
char
*
buf
,
static
int
proc_scsi_write
_proc
(
struct
file
*
file
,
const
char
*
buf
,
unsigned
long
count
,
void
*
data
)
unsigned
long
count
,
void
*
data
)
{
{
struct
Scsi_Host
*
shost
=
data
;
struct
Scsi_Host
*
shost
=
data
;
...
@@ -137,7 +138,7 @@ void scsi_proc_host_add(struct Scsi_Host *shost)
...
@@ -137,7 +138,7 @@ void scsi_proc_host_add(struct Scsi_Host *shost)
return
;
return
;
}
}
p
->
write_proc
=
proc_scsi_write
;
p
->
write_proc
=
proc_scsi_write
_proc
;
p
->
owner
=
shost
->
hostt
->
module
;
p
->
owner
=
shost
->
hostt
->
module
;
}
}
...
@@ -152,96 +153,52 @@ void scsi_proc_host_rm(struct Scsi_Host *shost)
...
@@ -152,96 +153,52 @@ void scsi_proc_host_rm(struct Scsi_Host *shost)
remove_proc_entry
(
shost
->
hostt
->
proc_name
,
proc_scsi
);
remove_proc_entry
(
shost
->
hostt
->
proc_name
,
proc_scsi
);
}
}
static
void
proc_print_scsidevice
(
struct
scsi_device
*
sdev
,
char
*
buffer
,
static
int
proc_print_scsidevice
(
struct
device
*
dev
,
void
*
data
)
int
*
size
,
int
len
)
{
{
struct
scsi_device
*
sdev
=
to_scsi_device
(
dev
);
int
x
,
y
=
*
size
;
struct
seq_file
*
s
=
data
;
extern
const
char
*
const
scsi_device_types
[
MAX_SCSI_DEVICE_CODE
]
;
int
i
;
y
=
sprintf
(
buffer
+
len
,
seq_printf
(
s
,
"Host: scsi%d Channel: %02d Id: %02d Lun: %02d
\n
Vendor: "
,
"Host: scsi%d Channel: %02d Id: %02d Lun: %02d
\n
Vendor: "
,
sdev
->
host
->
host_no
,
sdev
->
channel
,
sdev
->
id
,
sdev
->
lun
);
sdev
->
host
->
host_no
,
sdev
->
channel
,
sdev
->
id
,
sdev
->
lun
);
for
(
x
=
0
;
x
<
8
;
x
++
)
{
for
(
i
=
0
;
i
<
8
;
i
++
)
{
if
(
sdev
->
vendor
[
x
]
>=
0x20
)
if
(
sdev
->
vendor
[
i
]
>=
0x20
)
y
+=
sprintf
(
buffer
+
len
+
y
,
"%c"
,
sdev
->
vendor
[
x
]);
seq_printf
(
s
,
"%c"
,
sdev
->
vendor
[
i
]);
else
else
y
+=
sprintf
(
buffer
+
len
+
y
,
" "
);
seq_printf
(
s
,
" "
);
}
}
y
+=
sprintf
(
buffer
+
len
+
y
,
" Model: "
);
for
(
x
=
0
;
x
<
16
;
x
++
)
{
seq_printf
(
s
,
" Model: "
);
if
(
sdev
->
model
[
x
]
>=
0x20
)
for
(
i
=
0
;
i
<
16
;
i
++
)
{
y
+=
sprintf
(
buffer
+
len
+
y
,
"%c"
,
sdev
->
model
[
x
]);
if
(
sdev
->
model
[
i
]
>=
0x20
)
seq_printf
(
s
,
"%c"
,
sdev
->
model
[
i
]);
else
else
y
+=
sprintf
(
buffer
+
len
+
y
,
" "
);
seq_printf
(
s
,
" "
);
}
}
y
+=
sprintf
(
buffer
+
len
+
y
,
" Rev: "
);
for
(
x
=
0
;
x
<
4
;
x
++
)
{
seq_printf
(
s
,
" Rev: "
);
if
(
sdev
->
rev
[
x
]
>=
0x20
)
for
(
i
=
0
;
i
<
4
;
i
++
)
{
y
+=
sprintf
(
buffer
+
len
+
y
,
"%c"
,
sdev
->
rev
[
x
]);
if
(
sdev
->
rev
[
i
]
>=
0x20
)
seq_printf
(
s
,
"%c"
,
sdev
->
rev
[
i
]);
else
else
y
+=
sprintf
(
buffer
+
len
+
y
,
" "
);
seq_printf
(
s
,
" "
);
}
}
y
+=
sprintf
(
buffer
+
len
+
y
,
"
\n
"
);
y
+=
sprintf
(
buffer
+
len
+
y
,
" Type: %s "
,
seq_printf
(
s
,
"
\n
"
);
seq_printf
(
s
,
" Type: %s "
,
sdev
->
type
<
MAX_SCSI_DEVICE_CODE
?
sdev
->
type
<
MAX_SCSI_DEVICE_CODE
?
scsi_device_types
[(
int
)
sdev
->
type
]
:
"Unknown "
);
scsi_device_types
[(
int
)
sdev
->
type
]
:
"Unknown "
);
y
+=
sprintf
(
buffer
+
len
+
y
,
" ANSI"
seq_printf
(
s
,
" ANSI"
" SCSI revision: %02x"
,
(
sdev
->
scsi_level
-
1
)
?
" SCSI revision: %02x"
,
(
sdev
->
scsi_level
-
1
)
?
sdev
->
scsi_level
-
1
:
1
);
sdev
->
scsi_level
-
1
:
1
);
if
(
sdev
->
scsi_level
==
2
)
if
(
sdev
->
scsi_level
==
2
)
y
+=
sprintf
(
buffer
+
len
+
y
,
" CCS
\n
"
);
seq_printf
(
s
,
" CCS
\n
"
);
else
else
y
+=
sprintf
(
buffer
+
len
+
y
,
"
\n
"
);
seq_printf
(
s
,
"
\n
"
);
*
size
=
y
;
return
;
}
static
int
scsi_proc_info
(
char
*
buffer
,
char
**
start
,
off_t
offset
,
int
length
)
return
0
;
{
struct
Scsi_Host
*
shost
;
Scsi_Device
*
sdev
;
int
size
,
len
=
0
;
off_t
begin
=
0
;
off_t
pos
=
0
;
/*
* First, see if there are any attached devices or not.
*/
for
(
shost
=
scsi_host_get_next
(
NULL
);
shost
;
shost
=
scsi_host_get_next
(
shost
))
{
if
(
!
list_empty
(
&
shost
->
my_devices
))
{
break
;
}
}
size
=
sprintf
(
buffer
+
len
,
"Attached devices: %s
\n
"
,
(
shost
)
?
""
:
"none"
);
len
+=
size
;
pos
=
begin
+
len
;
for
(
shost
=
scsi_host_get_next
(
NULL
);
shost
;
shost
=
scsi_host_get_next
(
shost
))
{
list_for_each_entry
(
sdev
,
&
shost
->
my_devices
,
siblings
)
{
proc_print_scsidevice
(
sdev
,
buffer
,
&
size
,
len
);
len
+=
size
;
pos
=
begin
+
len
;
if
(
pos
<
offset
)
{
len
=
0
;
begin
=
pos
;
}
if
(
pos
>
offset
+
length
)
goto
stop_output
;
}
}
stop_output:
*
start
=
buffer
+
(
offset
-
begin
);
/* Start of wanted data */
len
-=
(
offset
-
begin
);
/* Start slop */
if
(
len
>
length
)
len
=
length
;
/* Ending slop */
return
(
len
);
}
}
static
int
scsi_add_single_device
(
uint
host
,
uint
channel
,
uint
id
,
uint
lun
)
static
int
scsi_add_single_device
(
uint
host
,
uint
channel
,
uint
id
,
uint
lun
)
...
@@ -287,8 +244,8 @@ static int scsi_remove_single_device(uint host, uint channel, uint id, uint lun)
...
@@ -287,8 +244,8 @@ static int scsi_remove_single_device(uint host, uint channel, uint id, uint lun)
return
error
;
return
error
;
}
}
static
int
proc_scsi_
gen_write
(
struct
file
*
file
,
const
char
*
buf
,
static
int
proc_scsi_
write
(
struct
file
*
file
,
const
char
*
buf
,
unsigned
long
length
,
void
*
data
)
size_t
length
,
loff_t
*
ppos
)
{
{
int
host
,
channel
,
id
,
lun
;
int
host
,
channel
,
id
,
lun
;
char
*
buffer
,
*
p
;
char
*
buffer
,
*
p
;
...
@@ -431,6 +388,30 @@ static int proc_scsi_gen_write(struct file * file, const char * buf,
...
@@ -431,6 +388,30 @@ static int proc_scsi_gen_write(struct file * file, const char * buf,
return
err
;
return
err
;
}
}
static
int
proc_scsi_show
(
struct
seq_file
*
s
,
void
*
p
)
{
seq_printf
(
s
,
"Attached devices:
\n
"
);
bus_for_each_dev
(
&
scsi_bus_type
,
NULL
,
s
,
proc_print_scsidevice
);
return
0
;
}
static
int
proc_scsi_open
(
struct
inode
*
inode
,
struct
file
*
file
)
{
/*
* We don't really needs this for the write case but it doesn't
* harm either.
*/
return
single_open
(
file
,
proc_scsi_show
,
NULL
);
}
static
struct
file_operations
proc_scsi_operations
=
{
.
open
=
proc_scsi_open
,
.
read
=
seq_read
,
.
write
=
proc_scsi_write
,
.
llseek
=
seq_lseek
,
.
release
=
single_release
,
};
int
__init
scsi_init_procfs
(
void
)
int
__init
scsi_init_procfs
(
void
)
{
{
struct
proc_dir_entry
*
pde
;
struct
proc_dir_entry
*
pde
;
...
@@ -439,10 +420,10 @@ int __init scsi_init_procfs(void)
...
@@ -439,10 +420,10 @@ int __init scsi_init_procfs(void)
if
(
!
proc_scsi
)
if
(
!
proc_scsi
)
goto
err1
;
goto
err1
;
pde
=
create_proc_
info_entry
(
"scsi/scsi"
,
0
,
0
,
scsi_proc_info
);
pde
=
create_proc_
entry
(
"scsi/scsi"
,
0
,
NULL
);
if
(
!
pde
)
if
(
!
pde
)
goto
err2
;
goto
err2
;
pde
->
write_proc
=
proc_scsi_gen_write
;
pde
->
proc_fops
=
&
proc_scsi_operations
;
return
0
;
return
0
;
...
...
drivers/scsi/scsi_sysfs.c
View file @
28d1aea6
...
@@ -68,7 +68,7 @@ static int scsi_bus_match(struct device *dev, struct device_driver *gendrv)
...
@@ -68,7 +68,7 @@ static int scsi_bus_match(struct device *dev, struct device_driver *gendrv)
return
1
;
return
1
;
}
}
st
atic
st
ruct
bus_type
scsi_bus_type
=
{
struct
bus_type
scsi_bus_type
=
{
.
name
=
"scsi"
,
.
name
=
"scsi"
,
.
match
=
scsi_bus_match
,
.
match
=
scsi_bus_match
,
};
};
...
...
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