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
88cd32b2
Commit
88cd32b2
authored
Jan 09, 2002
by
Martin Wilck
Committed by
Alexandre Julliard
Jan 09, 2002
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
More general approach to file descriptor types and flags.
parent
06ffc1ab
Hide whitespace changes
Inline
Side-by-side
Showing
14 changed files
with
83 additions
and
60 deletions
+83
-60
file.c
files/file.c
+22
-15
server_protocol.h
include/wine/server_protocol.h
+10
-6
console.c
server/console.c
+3
-2
device.c
server/device.c
+3
-2
file.c
server/file.c
+7
-7
mapping.c
server/mapping.c
+5
-4
named_pipe.c
server/named_pipe.c
+3
-2
object.c
server/object.c
+2
-1
object.h
server/object.h
+2
-2
pipe.c
server/pipe.c
+3
-2
protocol.def
server/protocol.def
+10
-6
serial.c
server/serial.c
+8
-8
sock.c
server/sock.c
+3
-2
trace.c
server/trace.c
+2
-1
No files found.
files/file.c
View file @
88cd32b2
...
@@ -210,7 +210,7 @@ HANDLE FILE_DupUnixHandle( int fd, DWORD access, BOOL inherit )
...
@@ -210,7 +210,7 @@ HANDLE FILE_DupUnixHandle( int fd, DWORD access, BOOL inherit )
* Retrieve the Unix handle corresponding to a file handle.
* Retrieve the Unix handle corresponding to a file handle.
* Returns -1 on failure.
* Returns -1 on failure.
*/
*/
int
FILE_GetUnixHandleType
(
HANDLE
handle
,
DWORD
access
,
DWORD
*
type
)
static
int
FILE_GetUnixHandleType
(
HANDLE
handle
,
DWORD
access
,
enum
fd_type
*
type
,
DWORD
*
flags
)
{
{
int
ret
,
fd
=
-
1
;
int
ret
,
fd
=
-
1
;
...
@@ -225,6 +225,7 @@ int FILE_GetUnixHandleType( HANDLE handle, DWORD access, DWORD *type )
...
@@ -225,6 +225,7 @@ int FILE_GetUnixHandleType( HANDLE handle, DWORD access, DWORD *type )
fd
=
reply
->
fd
;
fd
=
reply
->
fd
;
}
}
if
(
type
)
*
type
=
reply
->
type
;
if
(
type
)
*
type
=
reply
->
type
;
if
(
flags
)
*
flags
=
reply
->
flags
;
}
}
SERVER_END_REQ
;
SERVER_END_REQ
;
if
(
ret
)
return
-
1
;
if
(
ret
)
return
-
1
;
...
@@ -250,7 +251,7 @@ int FILE_GetUnixHandleType( HANDLE handle, DWORD access, DWORD *type )
...
@@ -250,7 +251,7 @@ int FILE_GetUnixHandleType( HANDLE handle, DWORD access, DWORD *type )
*/
*/
int
FILE_GetUnixHandle
(
HANDLE
handle
,
DWORD
access
)
int
FILE_GetUnixHandle
(
HANDLE
handle
,
DWORD
access
)
{
{
return
FILE_GetUnixHandleType
(
handle
,
access
,
NULL
);
return
FILE_GetUnixHandleType
(
handle
,
access
,
NULL
,
NULL
);
}
}
/*************************************************************************
/*************************************************************************
...
@@ -1449,7 +1450,8 @@ BOOL WINAPI ReadFile( HANDLE hFile, LPVOID buffer, DWORD bytesToRead,
...
@@ -1449,7 +1450,8 @@ BOOL WINAPI ReadFile( HANDLE hFile, LPVOID buffer, DWORD bytesToRead,
LPDWORD
bytesRead
,
LPOVERLAPPED
overlapped
)
LPDWORD
bytesRead
,
LPOVERLAPPED
overlapped
)
{
{
int
unix_handle
,
result
;
int
unix_handle
,
result
;
DWORD
type
;
enum
fd_type
type
;
DWORD
flags
;
TRACE
(
"%d %p %ld %p %p
\n
"
,
hFile
,
buffer
,
bytesToRead
,
TRACE
(
"%d %p %ld %p %p
\n
"
,
hFile
,
buffer
,
bytesToRead
,
bytesRead
,
overlapped
);
bytesRead
,
overlapped
);
...
@@ -1457,11 +1459,10 @@ BOOL WINAPI ReadFile( HANDLE hFile, LPVOID buffer, DWORD bytesToRead,
...
@@ -1457,11 +1459,10 @@ BOOL WINAPI ReadFile( HANDLE hFile, LPVOID buffer, DWORD bytesToRead,
if
(
bytesRead
)
*
bytesRead
=
0
;
/* Do this before anything else */
if
(
bytesRead
)
*
bytesRead
=
0
;
/* Do this before anything else */
if
(
!
bytesToRead
)
return
TRUE
;
if
(
!
bytesToRead
)
return
TRUE
;
unix_handle
=
FILE_GetUnixHandleType
(
hFile
,
GENERIC_READ
,
&
type
);
unix_handle
=
FILE_GetUnixHandleType
(
hFile
,
GENERIC_READ
,
&
type
,
&
flags
);
switch
(
type
)
if
(
flags
&
FD_FLAG_OVERLAPPED
)
{
{
case
FD_TYPE_OVERLAPPED
:
if
(
unix_handle
==
-
1
)
return
FALSE
;
if
(
unix_handle
==
-
1
)
return
FALSE
;
if
(
(
overlapped
==
NULL
)
||
NtResetEvent
(
overlapped
->
hEvent
,
NULL
)
)
if
(
(
overlapped
==
NULL
)
||
NtResetEvent
(
overlapped
->
hEvent
,
NULL
)
)
{
{
...
@@ -1506,13 +1507,16 @@ BOOL WINAPI ReadFile( HANDLE hFile, LPVOID buffer, DWORD bytesToRead,
...
@@ -1506,13 +1507,16 @@ BOOL WINAPI ReadFile( HANDLE hFile, LPVOID buffer, DWORD bytesToRead,
/* fail on return, with ERROR_IO_PENDING */
/* fail on return, with ERROR_IO_PENDING */
SetLastError
(
ERROR_IO_PENDING
);
SetLastError
(
ERROR_IO_PENDING
);
return
FALSE
;
return
FALSE
;
}
case
FD_TYPE_CONSOLE
:
if
(
flags
&
FD_FLAG_TIMEOUT
)
return
ReadConsoleA
(
hFile
,
buffer
,
bytesToRead
,
bytesRead
,
NULL
);
{
case
FD_TYPE_TIMEOUT
:
close
(
unix_handle
);
close
(
unix_handle
);
return
FILE_TimeoutRead
(
hFile
,
buffer
,
bytesToRead
,
bytesRead
);
return
FILE_TimeoutRead
(
hFile
,
buffer
,
bytesToRead
,
bytesRead
);
}
switch
(
type
)
{
case
FD_TYPE_CONSOLE
:
return
ReadConsoleA
(
hFile
,
buffer
,
bytesToRead
,
bytesRead
,
NULL
);
default:
default:
/* normal unix files */
/* normal unix files */
...
@@ -1668,7 +1672,8 @@ BOOL WINAPI WriteFile( HANDLE hFile, LPCVOID buffer, DWORD bytesToWrite,
...
@@ -1668,7 +1672,8 @@ BOOL WINAPI WriteFile( HANDLE hFile, LPCVOID buffer, DWORD bytesToWrite,
LPDWORD
bytesWritten
,
LPOVERLAPPED
overlapped
)
LPDWORD
bytesWritten
,
LPOVERLAPPED
overlapped
)
{
{
int
unix_handle
,
result
;
int
unix_handle
,
result
;
DWORD
type
;
enum
fd_type
type
;
DWORD
flags
;
TRACE
(
"%d %p %ld %p %p
\n
"
,
hFile
,
buffer
,
bytesToWrite
,
TRACE
(
"%d %p %ld %p %p
\n
"
,
hFile
,
buffer
,
bytesToWrite
,
bytesWritten
,
overlapped
);
bytesWritten
,
overlapped
);
...
@@ -1676,11 +1681,10 @@ BOOL WINAPI WriteFile( HANDLE hFile, LPCVOID buffer, DWORD bytesToWrite,
...
@@ -1676,11 +1681,10 @@ BOOL WINAPI WriteFile( HANDLE hFile, LPCVOID buffer, DWORD bytesToWrite,
if
(
bytesWritten
)
*
bytesWritten
=
0
;
/* Do this before anything else */
if
(
bytesWritten
)
*
bytesWritten
=
0
;
/* Do this before anything else */
if
(
!
bytesToWrite
)
return
TRUE
;
if
(
!
bytesToWrite
)
return
TRUE
;
unix_handle
=
FILE_GetUnixHandleType
(
hFile
,
GENERIC_WRITE
,
&
type
);
unix_handle
=
FILE_GetUnixHandleType
(
hFile
,
GENERIC_WRITE
,
&
type
,
&
flags
);
switch
(
type
)
if
(
flags
&
FD_FLAG_OVERLAPPED
)
{
{
case
FD_TYPE_OVERLAPPED
:
if
(
unix_handle
==
-
1
)
return
FALSE
;
if
(
unix_handle
==
-
1
)
return
FALSE
;
if
(
(
overlapped
==
NULL
)
||
NtResetEvent
(
overlapped
->
hEvent
,
NULL
)
)
if
(
(
overlapped
==
NULL
)
||
NtResetEvent
(
overlapped
->
hEvent
,
NULL
)
)
{
{
...
@@ -1727,7 +1731,10 @@ BOOL WINAPI WriteFile( HANDLE hFile, LPCVOID buffer, DWORD bytesToWrite,
...
@@ -1727,7 +1731,10 @@ BOOL WINAPI WriteFile( HANDLE hFile, LPCVOID buffer, DWORD bytesToWrite,
/* fail on return, with ERROR_IO_PENDING */
/* fail on return, with ERROR_IO_PENDING */
SetLastError
(
ERROR_IO_PENDING
);
SetLastError
(
ERROR_IO_PENDING
);
return
FALSE
;
return
FALSE
;
}
switch
(
type
)
{
case
FD_TYPE_CONSOLE
:
case
FD_TYPE_CONSOLE
:
TRACE
(
"%d %s %ld %p %p
\n
"
,
hFile
,
debugstr_an
(
buffer
,
bytesToWrite
),
bytesToWrite
,
TRACE
(
"%d %s %ld %p %p
\n
"
,
hFile
,
debugstr_an
(
buffer
,
bytesToWrite
),
bytesToWrite
,
bytesWritten
,
overlapped
);
bytesWritten
,
overlapped
);
...
...
include/wine/server_protocol.h
View file @
88cd32b2
...
@@ -730,12 +730,16 @@ struct get_handle_fd_reply
...
@@ -730,12 +730,16 @@ struct get_handle_fd_reply
struct
reply_header
__header
;
struct
reply_header
__header
;
int
fd
;
int
fd
;
int
type
;
int
type
;
int
flags
;
};
enum
fd_type
{
FD_TYPE_INVALID
,
FD_TYPE_DEFAULT
,
FD_TYPE_CONSOLE
};
};
#define FD_TYPE_INVALID 0
#define FD_FLAG_OVERLAPPED 0x01
#define FD_TYPE_DEFAULT 1
#define FD_FLAG_TIMEOUT 0x02
#define FD_TYPE_CONSOLE 2
#define FD_TYPE_OVERLAPPED 3
#define FD_TYPE_TIMEOUT 4
...
@@ -3038,6 +3042,6 @@ union generic_reply
...
@@ -3038,6 +3042,6 @@ union generic_reply
struct
get_window_properties_reply
get_window_properties_reply
;
struct
get_window_properties_reply
get_window_properties_reply
;
};
};
#define SERVER_PROTOCOL_VERSION 6
8
#define SERVER_PROTOCOL_VERSION 6
9
#endif
/* __WINE_WINE_SERVER_PROTOCOL_H */
#endif
/* __WINE_WINE_SERVER_PROTOCOL_H */
server/console.c
View file @
88cd32b2
...
@@ -25,7 +25,7 @@ static void console_input_destroy( struct object *obj );
...
@@ -25,7 +25,7 @@ static void console_input_destroy( struct object *obj );
static
int
console_input_signaled
(
struct
object
*
obj
,
struct
thread
*
thread
);
static
int
console_input_signaled
(
struct
object
*
obj
,
struct
thread
*
thread
);
/* common routine */
/* common routine */
static
int
console_get_file_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
);
static
int
console_get_file_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
,
int
*
flags
);
static
const
struct
object_ops
console_input_ops
=
static
const
struct
object_ops
console_input_ops
=
{
{
...
@@ -785,7 +785,7 @@ static void console_input_dump( struct object *obj, int verbose )
...
@@ -785,7 +785,7 @@ static void console_input_dump( struct object *obj, int verbose )
console
->
active
,
console
->
evt
);
console
->
active
,
console
->
evt
);
}
}
static
int
console_get_file_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
)
static
int
console_get_file_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
,
int
*
flags
)
{
{
if
(
reply
)
if
(
reply
)
{
{
...
@@ -800,6 +800,7 @@ static int console_get_file_info( struct object *obj, struct get_file_info_reply
...
@@ -800,6 +800,7 @@ static int console_get_file_info( struct object *obj, struct get_file_info_reply
reply
->
index_low
=
0
;
reply
->
index_low
=
0
;
reply
->
serial
=
0
;
reply
->
serial
=
0
;
}
}
*
flags
=
0
;
return
FD_TYPE_CONSOLE
;
return
FD_TYPE_CONSOLE
;
}
}
...
...
server/device.c
View file @
88cd32b2
...
@@ -29,7 +29,7 @@ struct device
...
@@ -29,7 +29,7 @@ struct device
};
};
static
void
device_dump
(
struct
object
*
obj
,
int
verbose
);
static
void
device_dump
(
struct
object
*
obj
,
int
verbose
);
static
int
device_get_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
);
static
int
device_get_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
,
int
*
flags
);
static
const
struct
object_ops
device_ops
=
static
const
struct
object_ops
device_ops
=
{
{
...
@@ -65,7 +65,7 @@ static void device_dump( struct object *obj, int verbose )
...
@@ -65,7 +65,7 @@ static void device_dump( struct object *obj, int verbose )
fprintf
(
stderr
,
"Device id=%08x
\n
"
,
dev
->
id
);
fprintf
(
stderr
,
"Device id=%08x
\n
"
,
dev
->
id
);
}
}
static
int
device_get_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
)
static
int
device_get_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
,
int
*
flags
)
{
{
struct
device
*
dev
=
(
struct
device
*
)
obj
;
struct
device
*
dev
=
(
struct
device
*
)
obj
;
assert
(
obj
->
ops
==
&
device_ops
);
assert
(
obj
->
ops
==
&
device_ops
);
...
@@ -83,6 +83,7 @@ static int device_get_info( struct object *obj, struct get_file_info_reply *repl
...
@@ -83,6 +83,7 @@ static int device_get_info( struct object *obj, struct get_file_info_reply *repl
reply
->
index_low
=
0
;
reply
->
index_low
=
0
;
reply
->
serial
=
0
;
reply
->
serial
=
0
;
}
}
*
flags
=
0
;
return
FD_TYPE_DEFAULT
;
return
FD_TYPE_DEFAULT
;
}
}
...
...
server/file.c
View file @
88cd32b2
...
@@ -53,7 +53,7 @@ static int file_get_poll_events( struct object *obj );
...
@@ -53,7 +53,7 @@ static int file_get_poll_events( struct object *obj );
static
void
file_poll_event
(
struct
object
*
obj
,
int
event
);
static
void
file_poll_event
(
struct
object
*
obj
,
int
event
);
static
int
file_get_fd
(
struct
object
*
obj
);
static
int
file_get_fd
(
struct
object
*
obj
);
static
int
file_flush
(
struct
object
*
obj
);
static
int
file_flush
(
struct
object
*
obj
);
static
int
file_get_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
);
static
int
file_get_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
,
int
*
flags
);
static
void
file_destroy
(
struct
object
*
obj
);
static
void
file_destroy
(
struct
object
*
obj
);
static
struct
async_queue
*
file_queue_async
(
struct
object
*
obj
,
struct
async
*
async
,
int
type
,
int
count
);
static
struct
async_queue
*
file_queue_async
(
struct
object
*
obj
,
struct
async
*
async
,
int
type
,
int
count
);
...
@@ -303,7 +303,7 @@ static int file_flush( struct object *obj )
...
@@ -303,7 +303,7 @@ static int file_flush( struct object *obj )
return
ret
;
return
ret
;
}
}
static
int
file_get_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
)
static
int
file_get_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
,
int
*
flags
)
{
{
struct
stat
st
;
struct
stat
st
;
struct
file
*
file
=
(
struct
file
*
)
obj
;
struct
file
*
file
=
(
struct
file
*
)
obj
;
...
@@ -339,9 +339,8 @@ static int file_get_info( struct object *obj, struct get_file_info_reply *reply
...
@@ -339,9 +339,8 @@ static int file_get_info( struct object *obj, struct get_file_info_reply *reply
reply
->
index_low
=
st
.
st_ino
;
reply
->
index_low
=
st
.
st_ino
;
reply
->
serial
=
0
;
/* FIXME */
reply
->
serial
=
0
;
/* FIXME */
}
}
*
flags
=
0
;
if
(
file
->
flags
&
FILE_FLAG_OVERLAPPED
)
return
FD_TYPE_OVERLAPPED
;
if
(
file
->
flags
&
FILE_FLAG_OVERLAPPED
)
*
flags
|=
FD_FLAG_OVERLAPPED
;
return
FD_TYPE_DEFAULT
;
return
FD_TYPE_DEFAULT
;
}
}
...
@@ -587,7 +586,7 @@ DECL_HANDLER(get_handle_fd)
...
@@ -587,7 +586,7 @@ DECL_HANDLER(get_handle_fd)
if
((
fd
=
obj
->
ops
->
get_fd
(
obj
))
!=
-
1
)
if
((
fd
=
obj
->
ops
->
get_fd
(
obj
))
!=
-
1
)
send_client_fd
(
current
->
process
,
fd
,
req
->
handle
);
send_client_fd
(
current
->
process
,
fd
,
req
->
handle
);
}
}
reply
->
type
=
obj
->
ops
->
get_file_info
(
obj
,
NULL
);
reply
->
type
=
obj
->
ops
->
get_file_info
(
obj
,
NULL
,
&
reply
->
flags
);
release_object
(
obj
);
release_object
(
obj
);
}
}
}
}
...
@@ -633,7 +632,8 @@ DECL_HANDLER(get_file_info)
...
@@ -633,7 +632,8 @@ DECL_HANDLER(get_file_info)
if
((
obj
=
get_handle_obj
(
current
->
process
,
req
->
handle
,
0
,
NULL
)))
if
((
obj
=
get_handle_obj
(
current
->
process
,
req
->
handle
,
0
,
NULL
)))
{
{
obj
->
ops
->
get_file_info
(
obj
,
reply
);
int
flags
;
obj
->
ops
->
get_file_info
(
obj
,
reply
,
&
flags
);
release_object
(
obj
);
release_object
(
obj
);
}
}
}
}
...
...
server/mapping.c
View file @
88cd32b2
...
@@ -34,7 +34,7 @@ struct mapping
...
@@ -34,7 +34,7 @@ struct mapping
};
};
static
int
mapping_get_fd
(
struct
object
*
obj
);
static
int
mapping_get_fd
(
struct
object
*
obj
);
static
int
mapping_get_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
);
static
int
mapping_get_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
,
int
*
flags
);
static
void
mapping_dump
(
struct
object
*
obj
,
int
verbose
);
static
void
mapping_dump
(
struct
object
*
obj
,
int
verbose
);
static
void
mapping_destroy
(
struct
object
*
obj
);
static
void
mapping_destroy
(
struct
object
*
obj
);
...
@@ -264,9 +264,10 @@ static struct object *create_mapping( int size_high, int size_low, int protect,
...
@@ -264,9 +264,10 @@ static struct object *create_mapping( int size_high, int size_low, int protect,
}
}
if
(
!
size_high
&&
!
size_low
)
if
(
!
size_high
&&
!
size_low
)
{
{
int
flags
;
struct
get_file_info_reply
reply
;
struct
get_file_info_reply
reply
;
struct
object
*
obj
=
(
struct
object
*
)
mapping
->
file
;
struct
object
*
obj
=
(
struct
object
*
)
mapping
->
file
;
obj
->
ops
->
get_file_info
(
obj
,
&
reply
);
obj
->
ops
->
get_file_info
(
obj
,
&
reply
,
&
flags
);
size_high
=
reply
.
size_high
;
size_high
=
reply
.
size_high
;
size_low
=
ROUND_SIZE
(
0
,
reply
.
size_low
);
size_low
=
ROUND_SIZE
(
0
,
reply
.
size_low
);
}
}
...
@@ -312,14 +313,14 @@ static int mapping_get_fd( struct object *obj )
...
@@ -312,14 +313,14 @@ static int mapping_get_fd( struct object *obj )
return
get_mmap_fd
(
mapping
->
file
);
return
get_mmap_fd
(
mapping
->
file
);
}
}
static
int
mapping_get_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
)
static
int
mapping_get_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
,
int
*
flags
)
{
{
struct
mapping
*
mapping
=
(
struct
mapping
*
)
obj
;
struct
mapping
*
mapping
=
(
struct
mapping
*
)
obj
;
struct
object
*
file
=
(
struct
object
*
)
mapping
->
file
;
struct
object
*
file
=
(
struct
object
*
)
mapping
->
file
;
assert
(
obj
->
ops
==
&
mapping_ops
);
assert
(
obj
->
ops
==
&
mapping_ops
);
assert
(
file
);
assert
(
file
);
return
file
->
ops
->
get_file_info
(
file
,
reply
);
return
file
->
ops
->
get_file_info
(
file
,
reply
,
flags
);
}
}
static
void
mapping_destroy
(
struct
object
*
obj
)
static
void
mapping_destroy
(
struct
object
*
obj
)
...
...
server/named_pipe.c
View file @
88cd32b2
...
@@ -87,7 +87,7 @@ static const struct object_ops named_pipe_ops =
...
@@ -87,7 +87,7 @@ static const struct object_ops named_pipe_ops =
static
void
pipe_user_dump
(
struct
object
*
obj
,
int
verbose
);
static
void
pipe_user_dump
(
struct
object
*
obj
,
int
verbose
);
static
void
pipe_user_destroy
(
struct
object
*
obj
);
static
void
pipe_user_destroy
(
struct
object
*
obj
);
static
int
pipe_user_get_fd
(
struct
object
*
obj
);
static
int
pipe_user_get_fd
(
struct
object
*
obj
);
static
int
pipe_user_get_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
);
static
int
pipe_user_get_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
,
int
*
flags
);
static
const
struct
object_ops
pipe_user_ops
=
static
const
struct
object_ops
pipe_user_ops
=
{
{
...
@@ -182,7 +182,7 @@ static int pipe_user_get_fd( struct object *obj )
...
@@ -182,7 +182,7 @@ static int pipe_user_get_fd( struct object *obj )
return
user
->
obj
.
fd
;
return
user
->
obj
.
fd
;
}
}
static
int
pipe_user_get_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
)
static
int
pipe_user_get_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
,
int
*
flags
)
{
{
if
(
reply
)
if
(
reply
)
{
{
...
@@ -197,6 +197,7 @@ static int pipe_user_get_info( struct object *obj, struct get_file_info_reply *r
...
@@ -197,6 +197,7 @@ static int pipe_user_get_info( struct object *obj, struct get_file_info_reply *r
reply
->
index_low
=
0
;
reply
->
index_low
=
0
;
reply
->
serial
=
0
;
reply
->
serial
=
0
;
}
}
*
flags
=
0
;
return
FD_TYPE_DEFAULT
;
return
FD_TYPE_DEFAULT
;
}
}
...
...
server/object.c
View file @
88cd32b2
...
@@ -263,9 +263,10 @@ int no_flush( struct object *obj )
...
@@ -263,9 +263,10 @@ int no_flush( struct object *obj )
return
0
;
return
0
;
}
}
int
no_get_file_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
info
)
int
no_get_file_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
info
,
int
*
flags
)
{
{
set_error
(
STATUS_OBJECT_TYPE_MISMATCH
);
set_error
(
STATUS_OBJECT_TYPE_MISMATCH
);
*
flags
=
0
;
return
FD_TYPE_INVALID
;
return
FD_TYPE_INVALID
;
}
}
...
...
server/object.h
View file @
88cd32b2
...
@@ -48,7 +48,7 @@ struct object_ops
...
@@ -48,7 +48,7 @@ struct object_ops
/* flush the object buffers */
/* flush the object buffers */
int
(
*
flush
)(
struct
object
*
);
int
(
*
flush
)(
struct
object
*
);
/* get file information */
/* get file information */
int
(
*
get_file_info
)(
struct
object
*
,
struct
get_file_info_reply
*
);
int
(
*
get_file_info
)(
struct
object
*
,
struct
get_file_info_reply
*
,
int
*
flags
);
/* queue an async operation */
/* queue an async operation */
struct
async_queue
*
(
*
queue_async
)(
struct
object
*
,
struct
async
*
async
,
int
type
,
int
count
);
struct
async_queue
*
(
*
queue_async
)(
struct
object
*
,
struct
async
*
async
,
int
type
,
int
count
);
/* destroy on refcount == 0 */
/* destroy on refcount == 0 */
...
@@ -92,7 +92,7 @@ extern int no_add_queue( struct object *obj, struct wait_queue_entry *entry );
...
@@ -92,7 +92,7 @@ extern int no_add_queue( struct object *obj, struct wait_queue_entry *entry );
extern
int
no_satisfied
(
struct
object
*
obj
,
struct
thread
*
thread
);
extern
int
no_satisfied
(
struct
object
*
obj
,
struct
thread
*
thread
);
extern
int
no_get_fd
(
struct
object
*
obj
);
extern
int
no_get_fd
(
struct
object
*
obj
);
extern
int
no_flush
(
struct
object
*
obj
);
extern
int
no_flush
(
struct
object
*
obj
);
extern
int
no_get_file_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
info
);
extern
int
no_get_file_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
info
,
int
*
flags
);
extern
void
no_destroy
(
struct
object
*
obj
);
extern
void
no_destroy
(
struct
object
*
obj
);
extern
int
default_poll_add_queue
(
struct
object
*
obj
,
struct
wait_queue_entry
*
entry
);
extern
int
default_poll_add_queue
(
struct
object
*
obj
,
struct
wait_queue_entry
*
entry
);
extern
void
default_poll_remove_queue
(
struct
object
*
obj
,
struct
wait_queue_entry
*
entry
);
extern
void
default_poll_remove_queue
(
struct
object
*
obj
,
struct
wait_queue_entry
*
entry
);
...
...
server/pipe.c
View file @
88cd32b2
...
@@ -37,7 +37,7 @@ struct pipe
...
@@ -37,7 +37,7 @@ struct pipe
static
void
pipe_dump
(
struct
object
*
obj
,
int
verbose
);
static
void
pipe_dump
(
struct
object
*
obj
,
int
verbose
);
static
int
pipe_get_poll_events
(
struct
object
*
obj
);
static
int
pipe_get_poll_events
(
struct
object
*
obj
);
static
int
pipe_get_fd
(
struct
object
*
obj
);
static
int
pipe_get_fd
(
struct
object
*
obj
);
static
int
pipe_get_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
);
static
int
pipe_get_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
,
int
*
flags
);
static
void
pipe_destroy
(
struct
object
*
obj
);
static
void
pipe_destroy
(
struct
object
*
obj
);
static
const
struct
object_ops
pipe_ops
=
static
const
struct
object_ops
pipe_ops
=
...
@@ -125,7 +125,7 @@ static int pipe_get_fd( struct object *obj )
...
@@ -125,7 +125,7 @@ static int pipe_get_fd( struct object *obj )
return
pipe
->
obj
.
fd
;
return
pipe
->
obj
.
fd
;
}
}
static
int
pipe_get_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
)
static
int
pipe_get_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
,
int
*
flags
)
{
{
if
(
reply
)
if
(
reply
)
{
{
...
@@ -140,6 +140,7 @@ static int pipe_get_info( struct object *obj, struct get_file_info_reply *reply
...
@@ -140,6 +140,7 @@ static int pipe_get_info( struct object *obj, struct get_file_info_reply *reply
reply
->
index_low
=
0
;
reply
->
index_low
=
0
;
reply
->
serial
=
0
;
reply
->
serial
=
0
;
}
}
*
flags
=
0
;
return
FD_TYPE_DEFAULT
;
return
FD_TYPE_DEFAULT
;
}
}
...
...
server/protocol.def
View file @
88cd32b2
...
@@ -542,13 +542,17 @@ enum event_op { PULSE_EVENT, SET_EVENT, RESET_EVENT };
...
@@ -542,13 +542,17 @@ enum event_op { PULSE_EVENT, SET_EVENT, RESET_EVENT };
unsigned int access; /* wanted access rights */
unsigned int access; /* wanted access rights */
@REPLY
@REPLY
int fd; /* file descriptor */
int fd; /* file descriptor */
int type; /* the type of file */
int type; /* the type of file (see below) */
int flags; /* file read/write flags (see below) */
@END
@END
#define FD_TYPE_INVALID 0
enum fd_type
#define FD_TYPE_DEFAULT 1
{
#define FD_TYPE_CONSOLE 2
FD_TYPE_INVALID,
#define FD_TYPE_OVERLAPPED 3
FD_TYPE_DEFAULT,
#define FD_TYPE_TIMEOUT 4
FD_TYPE_CONSOLE
};
#define FD_FLAG_OVERLAPPED 0x01
#define FD_FLAG_TIMEOUT 0x02
/* Set a file current position */
/* Set a file current position */
...
...
server/serial.c
View file @
88cd32b2
...
@@ -35,7 +35,7 @@
...
@@ -35,7 +35,7 @@
static
void
serial_dump
(
struct
object
*
obj
,
int
verbose
);
static
void
serial_dump
(
struct
object
*
obj
,
int
verbose
);
static
int
serial_get_fd
(
struct
object
*
obj
);
static
int
serial_get_fd
(
struct
object
*
obj
);
static
int
serial_get_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
);
static
int
serial_get_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
,
int
*
flags
);
static
int
serial_get_poll_events
(
struct
object
*
obj
);
static
int
serial_get_poll_events
(
struct
object
*
obj
);
static
struct
async_queue
*
serial_queue_async
(
struct
object
*
obj
,
struct
async
*
async
,
int
type
,
int
count
);
static
struct
async_queue
*
serial_queue_async
(
struct
object
*
obj
,
struct
async
*
async
,
int
type
,
int
count
);
static
void
destroy_serial
(
struct
object
*
obj
);
static
void
destroy_serial
(
struct
object
*
obj
);
...
@@ -189,7 +189,7 @@ static int serial_get_fd( struct object *obj )
...
@@ -189,7 +189,7 @@ static int serial_get_fd( struct object *obj )
return
serial
->
obj
.
fd
;
return
serial
->
obj
.
fd
;
}
}
static
int
serial_get_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
)
static
int
serial_get_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
,
int
*
flags
)
{
{
struct
serial
*
serial
=
(
struct
serial
*
)
obj
;
struct
serial
*
serial
=
(
struct
serial
*
)
obj
;
assert
(
obj
->
ops
==
&
serial_ops
);
assert
(
obj
->
ops
==
&
serial_ops
);
...
@@ -208,14 +208,14 @@ static int serial_get_info( struct object *obj, struct get_file_info_reply *repl
...
@@ -208,14 +208,14 @@ static int serial_get_info( struct object *obj, struct get_file_info_reply *repl
reply
->
serial
=
0
;
reply
->
serial
=
0
;
}
}
*
flags
=
0
;
if
(
serial
->
attrib
&
FILE_FLAG_OVERLAPPED
)
if
(
serial
->
attrib
&
FILE_FLAG_OVERLAPPED
)
return
FD_TYPE_OVERLAPPED
;
*
flags
|=
FD_FLAG_OVERLAPPED
;
else
if
(
!
((
serial
->
readinterval
==
MAXDWORD
)
&&
(
serial
->
readmult
==
0
)
&&
(
serial
->
readconst
==
0
))
)
*
flags
|=
FD_FLAG_TIMEOUT
;
if
(
(
serial
->
readinterval
==
MAXDWORD
)
&&
return
FD_TYPE_DEFAULT
;
(
serial
->
readmult
==
0
)
&&
(
serial
->
readconst
==
0
)
)
return
FD_TYPE_DEFAULT
;
return
FD_TYPE_TIMEOUT
;
}
}
static
void
serial_poll_event
(
struct
object
*
obj
,
int
event
)
static
void
serial_poll_event
(
struct
object
*
obj
,
int
event
)
...
...
server/sock.c
View file @
88cd32b2
...
@@ -59,7 +59,7 @@ static int sock_signaled( struct object *obj, struct thread *thread );
...
@@ -59,7 +59,7 @@ static int sock_signaled( struct object *obj, struct thread *thread );
static
int
sock_get_poll_events
(
struct
object
*
obj
);
static
int
sock_get_poll_events
(
struct
object
*
obj
);
static
void
sock_poll_event
(
struct
object
*
obj
,
int
event
);
static
void
sock_poll_event
(
struct
object
*
obj
,
int
event
);
static
int
sock_get_fd
(
struct
object
*
obj
);
static
int
sock_get_fd
(
struct
object
*
obj
);
static
int
sock_get_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
);
static
int
sock_get_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
,
int
*
flags
);
static
void
sock_destroy
(
struct
object
*
obj
);
static
void
sock_destroy
(
struct
object
*
obj
);
static
int
sock_get_error
(
int
err
);
static
int
sock_get_error
(
int
err
);
static
void
sock_set_error
(
void
);
static
void
sock_set_error
(
void
);
...
@@ -273,7 +273,7 @@ static int sock_get_fd( struct object *obj )
...
@@ -273,7 +273,7 @@ static int sock_get_fd( struct object *obj )
return
sock
->
obj
.
fd
;
return
sock
->
obj
.
fd
;
}
}
static
int
sock_get_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
)
static
int
sock_get_info
(
struct
object
*
obj
,
struct
get_file_info_reply
*
reply
,
int
*
flags
)
{
{
if
(
reply
)
if
(
reply
)
{
{
...
@@ -288,6 +288,7 @@ static int sock_get_info( struct object *obj, struct get_file_info_reply *reply
...
@@ -288,6 +288,7 @@ static int sock_get_info( struct object *obj, struct get_file_info_reply *reply
reply
->
index_low
=
0
;
reply
->
index_low
=
0
;
reply
->
serial
=
0
;
reply
->
serial
=
0
;
}
}
*
flags
=
0
;
return
FD_TYPE_DEFAULT
;
return
FD_TYPE_DEFAULT
;
}
}
...
...
server/trace.c
View file @
88cd32b2
...
@@ -722,7 +722,8 @@ static void dump_get_handle_fd_request( const struct get_handle_fd_request *req
...
@@ -722,7 +722,8 @@ static void dump_get_handle_fd_request( const struct get_handle_fd_request *req
static
void
dump_get_handle_fd_reply
(
const
struct
get_handle_fd_reply
*
req
)
static
void
dump_get_handle_fd_reply
(
const
struct
get_handle_fd_reply
*
req
)
{
{
fprintf
(
stderr
,
" fd=%d,"
,
req
->
fd
);
fprintf
(
stderr
,
" fd=%d,"
,
req
->
fd
);
fprintf
(
stderr
,
" type=%d"
,
req
->
type
);
fprintf
(
stderr
,
" type=%d,"
,
req
->
type
);
fprintf
(
stderr
,
" flags=%d"
,
req
->
flags
);
}
}
static
void
dump_set_file_pointer_request
(
const
struct
set_file_pointer_request
*
req
)
static
void
dump_set_file_pointer_request
(
const
struct
set_file_pointer_request
*
req
)
...
...
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