Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-cw
Commits
f8037bdd
Commit
f8037bdd
authored
Oct 27, 2005
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Make the unmount_device request take a handle to the device file
itself instead of a handle to a file opened on the device.
parent
e46a0c47
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
17 additions
and
5 deletions
+17
-5
fd.c
server/fd.c
+17
-5
No files found.
server/fd.c
View file @
f8037bdd
...
@@ -580,7 +580,7 @@ void main_loop(void)
...
@@ -580,7 +580,7 @@ void main_loop(void)
static
struct
list
device_hash
[
DEVICE_HASH_SIZE
];
static
struct
list
device_hash
[
DEVICE_HASH_SIZE
];
/* retrieve the device object for a given fd, creating it if needed */
/* retrieve the device object for a given fd, creating it if needed */
static
struct
device
*
get_device
(
dev_t
dev
)
static
struct
device
*
get_device
(
dev_t
dev
,
int
create
)
{
{
struct
device
*
device
;
struct
device
*
device
;
unsigned
int
i
,
hash
=
dev
%
DEVICE_HASH_SIZE
;
unsigned
int
i
,
hash
=
dev
%
DEVICE_HASH_SIZE
;
...
@@ -593,6 +593,8 @@ static struct device *get_device( dev_t dev )
...
@@ -593,6 +593,8 @@ static struct device *get_device( dev_t dev )
else
list_init
(
&
device_hash
[
hash
]
);
else
list_init
(
&
device_hash
[
hash
]
);
/* not found, create it */
/* not found, create it */
if
(
!
create
)
return
NULL
;
if
((
device
=
alloc_object
(
&
device_ops
)))
if
((
device
=
alloc_object
(
&
device_ops
)))
{
{
device
->
dev
=
dev
;
device
->
dev
=
dev
;
...
@@ -695,7 +697,7 @@ static struct inode *get_inode( dev_t dev, ino_t ino )
...
@@ -695,7 +697,7 @@ static struct inode *get_inode( dev_t dev, ino_t ino )
struct
inode
*
inode
;
struct
inode
*
inode
;
unsigned
int
hash
=
ino
%
INODE_HASH_SIZE
;
unsigned
int
hash
=
ino
%
INODE_HASH_SIZE
;
if
(
!
(
device
=
get_device
(
dev
)))
return
NULL
;
if
(
!
(
device
=
get_device
(
dev
,
1
)))
return
NULL
;
LIST_FOR_EACH_ENTRY
(
inode
,
&
device
->
inode_hash
[
hash
],
struct
inode
,
entry
)
LIST_FOR_EACH_ENTRY
(
inode
,
&
device
->
inode_hash
[
hash
],
struct
inode
,
entry
)
{
{
...
@@ -1580,12 +1582,22 @@ void no_cancel_async( struct fd *fd )
...
@@ -1580,12 +1582,22 @@ void no_cancel_async( struct fd *fd )
}
}
/* close all Unix file descriptors on a device to allow unmounting it */
/* close all Unix file descriptors on a device to allow unmounting it */
static
void
unmount_device
(
struct
device
*
device
)
static
void
unmount_device
(
struct
fd
*
device_fd
)
{
{
unsigned
int
i
;
unsigned
int
i
;
struct
stat
st
;
struct
device
*
device
;
struct
inode
*
inode
;
struct
inode
*
inode
;
struct
fd
*
fd
;
struct
fd
*
fd
;
if
(
device_fd
->
unix_fd
==
-
1
||
fstat
(
device_fd
->
unix_fd
,
&
st
)
==
-
1
||
!
S_ISBLK
(
st
.
st_mode
))
{
set_error
(
STATUS_INVALID_PARAMETER
);
return
;
}
if
(
!
(
device
=
get_device
(
st
.
st_rdev
,
0
)))
return
;
for
(
i
=
0
;
i
<
INODE_HASH_SIZE
;
i
++
)
for
(
i
=
0
;
i
<
INODE_HASH_SIZE
;
i
++
)
{
{
LIST_FOR_EACH_ENTRY
(
inode
,
&
device
->
inode_hash
[
i
],
struct
inode
,
entry
)
LIST_FOR_EACH_ENTRY
(
inode
,
&
device
->
inode_hash
[
i
],
struct
inode
,
entry
)
...
@@ -1600,6 +1612,7 @@ static void unmount_device( struct device *device )
...
@@ -1600,6 +1612,7 @@ static void unmount_device( struct device *device )
/* remove it from the hash table */
/* remove it from the hash table */
list_remove
(
&
device
->
entry
);
list_remove
(
&
device
->
entry
);
list_init
(
&
device
->
entry
);
list_init
(
&
device
->
entry
);
release_object
(
device
);
}
}
/* same as get_handle_obj but retrieve the struct fd associated to the object */
/* same as get_handle_obj but retrieve the struct fd associated to the object */
...
@@ -1682,8 +1695,7 @@ DECL_HANDLER(unmount_device)
...
@@ -1682,8 +1695,7 @@ DECL_HANDLER(unmount_device)
if
((
fd
=
get_handle_fd_obj
(
current
->
process
,
req
->
handle
,
0
)))
if
((
fd
=
get_handle_fd_obj
(
current
->
process
,
req
->
handle
,
0
)))
{
{
if
(
fd
->
inode
)
unmount_device
(
fd
->
inode
->
device
);
unmount_device
(
fd
);
else
set_error
(
STATUS_OBJECT_TYPE_MISMATCH
);
release_object
(
fd
);
release_object
(
fd
);
}
}
}
}
...
...
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