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
e1b24127
Commit
e1b24127
authored
Oct 06, 2002
by
Martin Schwidefsky
Committed by
Linus Torvalds
Oct 06, 2002
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[PATCH] s390 dasd driver update
Get rid of name and bdev in dasd_device_t structure.
parent
2d0dbb4b
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
21 additions
and
30 deletions
+21
-30
drivers/s390/block/dasd.c
drivers/s390/block/dasd.c
+7
-15
drivers/s390/block/dasd_genhd.c
drivers/s390/block/dasd_genhd.c
+7
-6
drivers/s390/block/dasd_int.h
drivers/s390/block/dasd_int.h
+3
-4
drivers/s390/block/dasd_ioctl.c
drivers/s390/block/dasd_ioctl.c
+1
-0
drivers/s390/block/dasd_proc.c
drivers/s390/block/dasd_proc.c
+3
-5
No files found.
drivers/s390/block/dasd.c
View file @
e1b24127
...
@@ -236,7 +236,7 @@ dasd_alloc_device(dasd_devmap_t *devmap)
...
@@ -236,7 +236,7 @@ dasd_alloc_device(dasd_devmap_t *devmap)
}
}
/* Allocate gendisk structure for device. */
/* Allocate gendisk structure for device. */
gdp
=
dasd_gendisk_alloc
(
dev
ice
->
name
,
dev
map
->
devindex
);
gdp
=
dasd_gendisk_alloc
(
devmap
->
devindex
);
if
(
IS_ERR
(
gdp
))
{
if
(
IS_ERR
(
gdp
))
{
free_page
((
unsigned
long
)
device
->
erp_mem
);
free_page
((
unsigned
long
)
device
->
erp_mem
);
free_pages
((
unsigned
long
)
device
->
ccw_mem
,
1
);
free_pages
((
unsigned
long
)
device
->
ccw_mem
,
1
);
...
@@ -294,10 +294,6 @@ dasd_state_new_to_known(dasd_device_t *device)
...
@@ -294,10 +294,6 @@ dasd_state_new_to_known(dasd_device_t *device)
return
-
ENODEV
;
return
-
ENODEV
;
minor
=
devmap
->
devindex
%
DASD_PER_MAJOR
;
minor
=
devmap
->
devindex
%
DASD_PER_MAJOR
;
/* Set bdev and the device name. */
device
->
bdev
=
bdget
(
MKDEV
(
major
,
minor
<<
DASD_PARTN_BITS
));
strcpy
(
device
->
name
,
device
->
gdp
->
disk_name
);
/* Find a discipline for the device. */
/* Find a discipline for the device. */
rc
=
dasd_find_disc
(
device
);
rc
=
dasd_find_disc
(
device
);
if
(
rc
)
if
(
rc
)
...
@@ -341,8 +337,8 @@ dasd_state_known_to_new(dasd_device_t * device)
...
@@ -341,8 +337,8 @@ dasd_state_known_to_new(dasd_device_t * device)
device
->
state
=
DASD_STATE_NEW
;
device
->
state
=
DASD_STATE_NEW
;
/* Forget the block device */
/* Forget the block device */
bdev
=
device
->
bdev
;
bdev
=
bdget
(
MKDEV
(
device
->
gdp
->
major
,
device
->
gdp
->
first_minor
))
;
device
->
bdev
=
NULL
;
bdput
(
bdev
)
;
bdput
(
bdev
);
bdput
(
bdev
);
}
}
...
@@ -355,7 +351,7 @@ dasd_state_known_to_basic(dasd_device_t * device)
...
@@ -355,7 +351,7 @@ dasd_state_known_to_basic(dasd_device_t * device)
int
rc
;
int
rc
;
/* register 'device' debug area, used for all DBF_DEV_XXX calls */
/* register 'device' debug area, used for all DBF_DEV_XXX calls */
device
->
debug_area
=
debug_register
(
device
->
name
,
0
,
2
,
device
->
debug_area
=
debug_register
(
device
->
gdp
->
disk_
name
,
0
,
2
,
8
*
sizeof
(
long
));
8
*
sizeof
(
long
));
debug_register_view
(
device
->
debug_area
,
&
debug_sprintf_view
);
debug_register_view
(
device
->
debug_area
,
&
debug_sprintf_view
);
debug_set_level
(
device
->
debug_area
,
DBF_ERR
);
debug_set_level
(
device
->
debug_area
,
DBF_ERR
);
...
@@ -436,7 +432,7 @@ dasd_state_accept_to_basic(dasd_device_t * device)
...
@@ -436,7 +432,7 @@ dasd_state_accept_to_basic(dasd_device_t * device)
static
inline
kdev_t
static
inline
kdev_t
dasd_partition_to_kdev_t
(
dasd_device_t
*
device
,
unsigned
int
partition
)
dasd_partition_to_kdev_t
(
dasd_device_t
*
device
,
unsigned
int
partition
)
{
{
return
to_kdev_t
(
device
->
bdev
->
bd_dev
+
partition
);
return
mk_kdev
(
device
->
gdp
->
major
,
device
->
gdp
->
first_minor
+
partition
);
}
}
...
@@ -453,6 +449,7 @@ dasd_state_accept_to_ready(dasd_device_t * device)
...
@@ -453,6 +449,7 @@ dasd_state_accept_to_ready(dasd_device_t * device)
if
(
devmap
->
features
&
DASD_FEATURE_READONLY
)
{
if
(
devmap
->
features
&
DASD_FEATURE_READONLY
)
{
for
(
i
=
0
;
i
<
(
1
<<
DASD_PARTN_BITS
);
i
++
)
for
(
i
=
0
;
i
<
(
1
<<
DASD_PARTN_BITS
);
i
++
)
set_device_ro
(
dasd_partition_to_kdev_t
(
device
,
i
),
1
);
set_device_ro
(
dasd_partition_to_kdev_t
(
device
,
i
),
1
);
device
->
ro_flag
=
1
;
DEV_MESSAGE
(
KERN_WARNING
,
device
,
"%s"
,
DEV_MESSAGE
(
KERN_WARNING
,
device
,
"%s"
,
"setting read-only mode "
);
"setting read-only mode "
);
}
}
...
@@ -1582,17 +1579,12 @@ dasd_end_request_cb(dasd_ccw_req_t * cqr, void *data)
...
@@ -1582,17 +1579,12 @@ dasd_end_request_cb(dasd_ccw_req_t * cqr, void *data)
static
inline
void
static
inline
void
__dasd_process_blk_queue
(
dasd_device_t
*
device
)
__dasd_process_blk_queue
(
dasd_device_t
*
device
)
{
{
struct
block_device
*
bdev
;
request_queue_t
*
queue
;
request_queue_t
*
queue
;
struct
list_head
*
l
;
struct
list_head
*
l
;
struct
request
*
req
;
struct
request
*
req
;
dasd_ccw_req_t
*
cqr
;
dasd_ccw_req_t
*
cqr
;
int
nr_queued
;
int
nr_queued
;
/* No bdev, no queue. */
bdev
=
device
->
bdev
;
if
(
!
bdev
)
return
;
queue
=
device
->
request_queue
;
queue
=
device
->
request_queue
;
/* No queue ? Then there is nothing to do. */
/* No queue ? Then there is nothing to do. */
if
(
queue
==
NULL
)
if
(
queue
==
NULL
)
...
@@ -1619,7 +1611,7 @@ __dasd_process_blk_queue(dasd_device_t * device)
...
@@ -1619,7 +1611,7 @@ __dasd_process_blk_queue(dasd_device_t * device)
!
blk_queue_empty
(
queue
)
&&
!
blk_queue_empty
(
queue
)
&&
nr_queued
<
DASD_CHANQ_MAX_SIZE
)
{
nr_queued
<
DASD_CHANQ_MAX_SIZE
)
{
req
=
elv_next_request
(
queue
);
req
=
elv_next_request
(
queue
);
if
(
bdev_read_only
(
bdev
)
&&
rq_data_dir
(
req
)
==
WRITE
)
{
if
(
device
->
ro_flag
&&
rq_data_dir
(
req
)
==
WRITE
)
{
DBF_EVENT
(
DBF_ERR
,
DBF_EVENT
(
DBF_ERR
,
"(%04x) Rejecting write request %p"
,
"(%04x) Rejecting write request %p"
,
device
->
devinfo
.
devno
,
req
);
device
->
devinfo
.
devno
,
req
);
...
...
drivers/s390/block/dasd_genhd.c
View file @
e1b24127
...
@@ -162,7 +162,7 @@ dasd_device_name(char *str, int index, int partition)
...
@@ -162,7 +162,7 @@ dasd_device_name(char *str, int index, int partition)
* Allocate gendisk structure for devindex.
* Allocate gendisk structure for devindex.
*/
*/
struct
gendisk
*
struct
gendisk
*
dasd_gendisk_alloc
(
char
*
device_name
,
int
devindex
)
dasd_gendisk_alloc
(
int
devindex
)
{
{
struct
list_head
*
l
;
struct
list_head
*
l
;
struct
major_info
*
mi
;
struct
major_info
*
mi
;
...
@@ -195,7 +195,7 @@ dasd_gendisk_alloc(char *device_name, int devindex)
...
@@ -195,7 +195,7 @@ dasd_gendisk_alloc(char *device_name, int devindex)
return
ERR_PTR
(
-
ENOMEM
);
return
ERR_PTR
(
-
ENOMEM
);
/* Initialize gendisk structure. */
/* Initialize gendisk structure. */
mem
cpy
(
gdp
->
disk_name
,
device_name
,
16
);
/* huh? -- AV */
mem
set
(
gdp
,
0
,
sizeof
(
struct
gendisk
));
gdp
->
major
=
mi
->
major
;
gdp
->
major
=
mi
->
major
;
gdp
->
first_minor
=
index
<<
DASD_PARTN_BITS
;
gdp
->
first_minor
=
index
<<
DASD_PARTN_BITS
;
gdp
->
minor_shift
=
DASD_PARTN_BITS
;
gdp
->
minor_shift
=
DASD_PARTN_BITS
;
...
@@ -207,15 +207,16 @@ dasd_gendisk_alloc(char *device_name, int devindex)
...
@@ -207,15 +207,16 @@ dasd_gendisk_alloc(char *device_name, int devindex)
* dasdaa - dasdzz : 676 devices, added up = 702
* dasdaa - dasdzz : 676 devices, added up = 702
* dasdaaa - dasdzzz : 17576 devices, added up = 18278
* dasdaaa - dasdzzz : 17576 devices, added up = 18278
*/
*/
len
=
sprintf
(
device
_name
,
"dasd"
);
len
=
sprintf
(
gdp
->
disk
_name
,
"dasd"
);
if
(
devindex
>
25
)
{
if
(
devindex
>
25
)
{
if
(
devindex
>
701
)
if
(
devindex
>
701
)
len
+=
sprintf
(
device
_name
+
len
,
"%c"
,
len
+=
sprintf
(
gdp
->
disk
_name
+
len
,
"%c"
,
'a'
+
(((
devindex
-
702
)
/
676
)
%
26
));
'a'
+
(((
devindex
-
702
)
/
676
)
%
26
));
len
+=
sprintf
(
device
_name
+
len
,
"%c"
,
len
+=
sprintf
(
gdp
->
disk
_name
+
len
,
"%c"
,
'a'
+
(((
devindex
-
26
)
/
26
)
%
26
));
'a'
+
(((
devindex
-
26
)
/
26
)
%
26
));
}
}
len
+=
sprintf
(
device_name
+
len
,
"%c"
,
'a'
+
(
devindex
%
26
));
len
+=
sprintf
(
gdp
->
disk_name
+
len
,
"%c"
,
'a'
+
(
devindex
%
26
));
return
gdp
;
return
gdp
;
}
}
...
...
drivers/s390/block/dasd_int.h
View file @
e1b24127
...
@@ -140,7 +140,7 @@ do { \
...
@@ -140,7 +140,7 @@ do { \
#define DEV_MESSAGE(d_loglevel,d_device,d_string,d_args...)\
#define DEV_MESSAGE(d_loglevel,d_device,d_string,d_args...)\
do { \
do { \
printk(d_loglevel PRINTK_HEADER " %s,%04x@%02x: " \
printk(d_loglevel PRINTK_HEADER " %s,%04x@%02x: " \
d_string "\n",
bdevname(d_device->bdev)
, \
d_string "\n",
d_device->gdp->disk_name
, \
d_device->devinfo.devno, d_device->devinfo.irq, \
d_device->devinfo.devno, d_device->devinfo.irq, \
d_args); \
d_args); \
DBF_DEV_EVENT(DBF_ALERT, d_device, d_string, d_args); \
DBF_DEV_EVENT(DBF_ALERT, d_device, d_string, d_args); \
...
@@ -258,8 +258,6 @@ typedef struct dasd_discipline_t {
...
@@ -258,8 +258,6 @@ typedef struct dasd_discipline_t {
typedef
struct
dasd_device_t
{
typedef
struct
dasd_device_t
{
/* Block device stuff. */
/* Block device stuff. */
char
name
[
16
];
/* The device name in /dev. */
struct
block_device
*
bdev
;
struct
gendisk
*
gdp
;
struct
gendisk
*
gdp
;
devfs_handle_t
devfs_entry
;
devfs_handle_t
devfs_entry
;
request_queue_t
*
request_queue
;
request_queue_t
*
request_queue
;
...
@@ -267,6 +265,7 @@ typedef struct dasd_device_t {
...
@@ -267,6 +265,7 @@ typedef struct dasd_device_t {
unsigned
long
blocks
;
/* size of volume in blocks */
unsigned
long
blocks
;
/* size of volume in blocks */
unsigned
int
bp_block
;
/* bytes per block */
unsigned
int
bp_block
;
/* bytes per block */
unsigned
int
s2b_shift
;
/* log2 (bp_block/512) */
unsigned
int
s2b_shift
;
/* log2 (bp_block/512) */
int
ro_flag
;
/* read-only flag */
/* Device discipline stuff. */
/* Device discipline stuff. */
dasd_discipline_t
*
discipline
;
dasd_discipline_t
*
discipline
;
...
@@ -479,7 +478,7 @@ int dasd_gendisk_init(void);
...
@@ -479,7 +478,7 @@ int dasd_gendisk_init(void);
void
dasd_gendisk_exit
(
void
);
void
dasd_gendisk_exit
(
void
);
int
dasd_gendisk_major_index
(
int
);
int
dasd_gendisk_major_index
(
int
);
int
dasd_gendisk_index_major
(
int
);
int
dasd_gendisk_index_major
(
int
);
struct
gendisk
*
dasd_gendisk_alloc
(
char
*
,
int
);
struct
gendisk
*
dasd_gendisk_alloc
(
int
);
void
dasd_setup_partitions
(
dasd_device_t
*
);
void
dasd_setup_partitions
(
dasd_device_t
*
);
void
dasd_destroy_partitions
(
dasd_device_t
*
);
void
dasd_destroy_partitions
(
dasd_device_t
*
);
...
...
drivers/s390/block/dasd_ioctl.c
View file @
e1b24127
...
@@ -464,6 +464,7 @@ dasd_ioctl_set_ro(struct block_device *bdev, int no, long args)
...
@@ -464,6 +464,7 @@ dasd_ioctl_set_ro(struct block_device *bdev, int no, long args)
devmap
->
features
&=
~
DASD_FEATURE_READONLY
;
devmap
->
features
&=
~
DASD_FEATURE_READONLY
;
for
(
i
=
0
;
i
<
(
1
<<
DASD_PARTN_BITS
);
i
++
)
for
(
i
=
0
;
i
<
(
1
<<
DASD_PARTN_BITS
);
i
++
)
set_device_ro
(
to_kdev_t
(
bdev
->
bd_dev
+
i
),
intval
);
set_device_ro
(
to_kdev_t
(
bdev
->
bd_dev
+
i
),
intval
);
device
->
ro_flag
=
intval
;
dasd_put_device
(
devmap
);
dasd_put_device
(
devmap
);
return
0
;
return
0
;
}
}
...
...
drivers/s390/block/dasd_proc.c
View file @
e1b24127
...
@@ -154,7 +154,6 @@ dasd_devices_print(dasd_devmap_t *devmap, char *str)
...
@@ -154,7 +154,6 @@ dasd_devices_print(dasd_devmap_t *devmap, char *str)
{
{
dasd_device_t
*
device
;
dasd_device_t
*
device
;
char
*
substr
;
char
*
substr
;
int
major
,
minor
;
int
len
;
int
len
;
device
=
dasd_get_device
(
devmap
);
device
=
dasd_get_device
(
devmap
);
...
@@ -168,11 +167,10 @@ dasd_devices_print(dasd_devmap_t *devmap, char *str)
...
@@ -168,11 +167,10 @@ dasd_devices_print(dasd_devmap_t *devmap, char *str)
else
else
len
+=
sprintf
(
str
+
len
,
"(none)"
);
len
+=
sprintf
(
str
+
len
,
"(none)"
);
/* Print kdev. */
/* Print kdev. */
major
=
MAJOR
(
device
->
bdev
->
bd_dev
);
len
+=
sprintf
(
str
+
len
,
" at (%3d:%3d)"
,
minor
=
MINOR
(
device
->
bdev
->
bd_dev
);
device
->
gdp
->
major
,
device
->
gdp
->
first_minor
);
len
+=
sprintf
(
str
+
len
,
" at (%3d:%3d)"
,
major
,
minor
);
/* Print device name. */
/* Print device name. */
len
+=
sprintf
(
str
+
len
,
" is %-7s"
,
device
->
name
);
len
+=
sprintf
(
str
+
len
,
" is %-7s"
,
device
->
gdp
->
disk_
name
);
/* Print devices features. */
/* Print devices features. */
substr
=
(
devmap
->
features
&
DASD_FEATURE_READONLY
)
?
"(ro)"
:
" "
;
substr
=
(
devmap
->
features
&
DASD_FEATURE_READONLY
)
?
"(ro)"
:
" "
;
len
+=
sprintf
(
str
+
len
,
"%4s: "
,
substr
);
len
+=
sprintf
(
str
+
len
,
"%4s: "
,
substr
);
...
...
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