Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
E
etercifs
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
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
etersoft
etercifs
Commits
a4b5b1eb
Commit
a4b5b1eb
authored
Mar 02, 2010
by
Pavel Shilovsky
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Pull from cifs-2.6 repo for legacy
Implement WINE logic Fix losing locks during fork()
parent
8d4a0452
Hide whitespace changes
Inline
Side-by-side
Showing
9 changed files
with
165 additions
and
39 deletions
+165
-39
cifs_fs_sb.h
sources/legacy/cifs_fs_sb.h
+1
-0
cifsfs.c
sources/legacy/cifsfs.c
+39
-4
cifsglob.h
sources/legacy/cifsglob.h
+2
-0
cifsproto.h
sources/legacy/cifsproto.h
+6
-6
cifssmb.c
sources/legacy/cifssmb.c
+15
-4
connect.c
sources/legacy/connect.c
+7
-0
dir.c
sources/legacy/dir.c
+2
-2
file.c
sources/legacy/file.c
+89
-18
inode.c
sources/legacy/inode.c
+4
-5
No files found.
sources/legacy/cifs_fs_sb.h
View file @
a4b5b1eb
...
...
@@ -31,6 +31,7 @@
#define CIFS_MOUNT_OVERR_UID 0x400
/* override uid returned from server */
#define CIFS_MOUNT_OVERR_GID 0x800
/* override gid returned from server */
#define CIFS_MOUNT_NOPOSIXBRL 0x2000
/* mandatory not posix byte range lock */
#define CIFS_MOUNT_WINE_MODE 0x8000
/* use pid forwarding for wine apps */
struct
cifs_sb_info
{
struct
cifsTconInfo
*
tcon
;
/* primary mount */
...
...
sources/legacy/cifsfs.c
View file @
a4b5b1eb
...
...
@@ -348,6 +348,10 @@ cifs_show_options(struct seq_file *s, struct vfsmount *m)
seq_printf
(
s
,
",domain=%s"
,
cifs_sb
->
tcon
->
ses
->
domainName
);
}
if
(
cifs_sb
->
tcon
->
unix_ext
)
seq_printf
(
s
,
",unix"
);
else
seq_printf
(
s
,
",nounix"
);
}
if
(
cifs_sb
->
mnt_cifs_flags
&
CIFS_MOUNT_POSIX_PATHS
)
seq_printf
(
s
,
",posixpaths"
);
...
...
@@ -357,6 +361,12 @@ cifs_show_options(struct seq_file *s, struct vfsmount *m)
if
((
cifs_sb
->
mnt_cifs_flags
&
CIFS_MOUNT_OVERR_GID
)
||
!
(
cifs_sb
->
tcon
->
unix_ext
))
seq_printf
(
s
,
",gid=%d"
,
cifs_sb
->
mnt_gid
);
if
(
cifs_sb
->
mnt_cifs_flags
&
CIFS_MOUNT_WINE_MODE
)
seq_printf
(
s
,
",wine"
);
if
(
cifs_sb
->
mnt_cifs_flags
&
CIFS_MOUNT_NOPOSIXBRL
)
seq_printf
(
s
,
",forcemand"
);
if
(
cifs_sb
->
mnt_cifs_flags
&
CIFS_MOUNT_DIRECT_IO
)
seq_printf
(
s
,
",directio"
);
seq_printf
(
s
,
",rsize=%d"
,
cifs_sb
->
rsize
);
seq_printf
(
s
,
",wsize=%d"
,
cifs_sb
->
wsize
);
}
...
...
@@ -594,14 +604,15 @@ cifs_get_sb(struct file_system_type *fs_type,
#endif
}
static
ssize_t
cifs_sync_read
(
struct
file
*
filp
,
char
__user
*
buf
,
size_t
len
,
loff_t
*
ppos
)
static
ssize_t
cifs_sync_read
(
struct
file
*
filp
,
char
__user
*
buf
,
size_t
len
,
loff_t
*
ppos
)
{
int
retval
,
read
,
posix_locking
=
0
;
struct
file_lock
pfLock
;
struct
cifsInodeInfo
*
cifsInode
;
struct
cifs_sb_info
*
cifs_sb
;
struct
cifsTconInfo
*
tcon
;
#if LINUX_VERSION_CODE > KERNEL_VERSION(2, 6, 18)
cifs_sb
=
CIFS_SB
(
filp
->
f_path
.
dentry
->
d_sb
);
tcon
=
cifs_sb
->
tcon
;
if
((
tcon
->
ses
->
capabilities
&
CAP_UNIX
)
&&
...
...
@@ -621,8 +632,32 @@ static ssize_t cifs_sync_read(struct file *filp, char __user *buf, size_t len, l
if
(
cifsInode
==
NULL
)
return
-
ENOENT
;
if
(
!
CIFS_I
(
filp
->
f_path
.
dentry
->
d_inode
)
->
clientCanCacheRead
&&
!
posix_locking
)
{
retval
=
cifs_lock
(
filp
,
F_GETLK
,
&
pfLock
);
if
(
!
CIFS_I
(
filp
->
f_path
.
dentry
->
d_inode
)
->
clientCanCacheRead
&&
!
posix_locking
)
{
#else
cifs_sb
=
CIFS_SB
(
filp
->
f_dentry
->
d_sb
);
tcon
=
cifs_sb
->
tcon
;
if
((
tcon
->
ses
->
capabilities
&
CAP_UNIX
)
&&
(
CIFS_UNIX_FCNTL_CAP
&
le64_to_cpu
(
tcon
->
fsUnixInfo
.
Capability
))
&&
((
cifs_sb
->
mnt_cifs_flags
&
CIFS_MOUNT_NOPOSIXBRL
)
==
0
))
posix_locking
=
1
;
retval
=
cifs_revalidate
(
filp
->
f_dentry
);
if
(
retval
<
0
)
return
(
ssize_t
)
retval
;
memset
(
&
pfLock
,
0
,
sizeof
(
pfLock
));
pfLock
.
fl_type
=
F_RDLCK
;
pfLock
.
fl_start
=
*
ppos
;
pfLock
.
fl_end
=
*
ppos
+
len
;
cifsInode
=
CIFS_I
(
filp
->
f_dentry
->
d_inode
);
if
(
cifsInode
==
NULL
)
return
-
ENOENT
;
if
(
!
CIFS_I
(
filp
->
f_dentry
->
d_inode
)
->
clientCanCacheRead
&&
!
posix_locking
)
{
#endif
retval
=
cifs_lock
(
filp
,
F_GETLK
|
CIFS_NOPOSIXBRL_READ
,
&
pfLock
);
if
(
retval
<
0
)
return
(
ssize_t
)
retval
;
if
(
pfLock
.
fl_type
==
F_UNLCK
)
...
...
sources/legacy/cifsglob.h
View file @
a4b5b1eb
...
...
@@ -306,6 +306,8 @@ struct cifsLockInfo {
__u8
type
;
};
#define CIFS_NOPOSIXBRL_READ 64
/*
* One of these for each open instance of a file
*/
...
...
sources/legacy/cifsproto.h
View file @
a4b5b1eb
...
...
@@ -286,16 +286,16 @@ extern int CIFSSMBClose(const int xid, struct cifsTconInfo *tcon,
const
int
smb_file_id
);
extern
int
CIFSSMBRead
(
const
int
xid
,
struct
cifsTconInfo
*
tcon
,
const
int
netfid
,
unsigned
int
count
,
const
int
netfid
,
const
u32
netpid
,
unsigned
int
count
,
const
__u64
lseek
,
unsigned
int
*
nbytes
,
char
**
buf
,
int
*
return_buf_type
);
extern
int
CIFSSMBWrite
(
const
int
xid
,
struct
cifsTconInfo
*
tcon
,
const
int
netfid
,
const
u
nsigned
int
count
,
const
__u64
lseek
,
unsigned
int
*
nbytes
,
const
char
*
buf
,
const
char
__user
*
u
buf
,
const
int
long_op
);
const
int
netfid
,
const
u
32
netpid
,
const
unsigned
int
count
,
const
__u64
lseek
,
unsigned
int
*
nbytes
,
const
char
*
buf
,
const
char
__user
*
ubuf
,
const
int
long_op
);
extern
int
CIFSSMBWrite2
(
const
int
xid
,
struct
cifsTconInfo
*
tcon
,
const
int
netfid
,
const
unsigned
int
count
,
const
int
netfid
,
u32
netpid
,
const
unsigned
int
count
,
const
__u64
offset
,
unsigned
int
*
nbytes
,
struct
kvec
*
iov
,
const
int
nvec
,
const
int
long_op
);
extern
int
CIFSGetSrvInodeNumber
(
const
int
xid
,
struct
cifsTconInfo
*
tcon
,
...
...
sources/legacy/cifssmb.c
View file @
a4b5b1eb
...
...
@@ -1397,8 +1397,8 @@ openRetry:
int
CIFSSMBRead
(
const
int
xid
,
struct
cifsTconInfo
*
tcon
,
const
int
netfid
,
const
u
nsigned
int
count
,
const
__u64
lseek
,
unsigned
int
*
nbytes
,
char
**
buf
,
int
*
pbuf_type
)
const
u
32
netpid
,
const
unsigned
int
count
,
const
__u64
lseek
,
unsigned
int
*
nbytes
,
char
**
buf
,
int
*
pbuf_type
)
{
int
rc
=
-
EACCES
;
READ_REQ
*
pSMB
=
NULL
;
...
...
@@ -1419,6 +1419,9 @@ CIFSSMBRead(const int xid, struct cifsTconInfo *tcon, const int netfid,
if
(
rc
)
return
rc
;
pSMB
->
hdr
.
Pid
=
cpu_to_le16
((
__u16
)
netpid
);
pSMB
->
hdr
.
PidHigh
=
cpu_to_le16
((
__u16
)(
netpid
>>
16
));
/* tcon and ses pointer are checked in smb_init */
if
(
tcon
->
ses
->
server
==
NULL
)
return
-
ECONNABORTED
;
...
...
@@ -1500,7 +1503,7 @@ CIFSSMBRead(const int xid, struct cifsTconInfo *tcon, const int netfid,
int
CIFSSMBWrite
(
const
int
xid
,
struct
cifsTconInfo
*
tcon
,
const
int
netfid
,
const
unsigned
int
count
,
const
int
netfid
,
const
u
32
netpid
,
const
u
nsigned
int
count
,
const
__u64
offset
,
unsigned
int
*
nbytes
,
const
char
*
buf
,
const
char
__user
*
ubuf
,
const
int
long_op
)
{
...
...
@@ -1524,6 +1527,10 @@ CIFSSMBWrite(const int xid, struct cifsTconInfo *tcon,
(
void
**
)
&
pSMBr
);
if
(
rc
)
return
rc
;
pSMB
->
hdr
.
Pid
=
cpu_to_le16
((
__u16
)
netpid
);
pSMB
->
hdr
.
PidHigh
=
cpu_to_le16
((
__u16
)(
netpid
>>
16
));
/* tcon and ses pointer are checked in smb_init */
if
(
tcon
->
ses
->
server
==
NULL
)
return
-
ECONNABORTED
;
...
...
@@ -1607,7 +1614,7 @@ CIFSSMBWrite(const int xid, struct cifsTconInfo *tcon,
int
CIFSSMBWrite2
(
const
int
xid
,
struct
cifsTconInfo
*
tcon
,
const
int
netfid
,
const
unsigned
int
count
,
const
int
netfid
,
const
u
32
netpid
,
const
u
nsigned
int
count
,
const
__u64
offset
,
unsigned
int
*
nbytes
,
struct
kvec
*
iov
,
int
n_vec
,
const
int
long_op
)
{
...
...
@@ -1626,6 +1633,10 @@ CIFSSMBWrite2(const int xid, struct cifsTconInfo *tcon,
rc
=
small_smb_init
(
SMB_COM_WRITE_ANDX
,
wct
,
tcon
,
(
void
**
)
&
pSMB
);
if
(
rc
)
return
rc
;
pSMB
->
hdr
.
Pid
=
cpu_to_le16
((
__u16
)
netpid
);
pSMB
->
hdr
.
PidHigh
=
cpu_to_le16
((
__u16
)(
netpid
>>
16
));
/* tcon and ses pointer are checked in smb_init */
if
(
tcon
->
ses
->
server
==
NULL
)
return
-
ECONNABORTED
;
...
...
sources/legacy/connect.c
View file @
a4b5b1eb
...
...
@@ -107,6 +107,7 @@ struct smb_vol {
unsigned
nocase
;
/* request case insensitive filenames */
unsigned
nobrl
;
/* disable sending byte range locks to srv */
unsigned
mand_lock
:
1
;
/* send mandatory not posix byte range lock reqs */
bool
wine_mode
:
1
;
unsigned
int
rsize
;
unsigned
int
wsize
;
unsigned
int
sockopt
;
...
...
@@ -1285,6 +1286,10 @@ cifs_parse_mount_options(char *options, const char *devname,
vol
->
server_ino
=
1
;
}
else
if
(
strnicmp
(
data
,
"noserverino"
,
9
)
==
0
)
{
vol
->
server_ino
=
0
;
}
else
if
(
strnicmp
(
data
,
"wine"
,
4
)
==
0
)
{
vol
->
wine_mode
=
1
;
vol
->
mand_lock
=
1
;
vol
->
direct_io
=
1
;
}
else
if
(
strnicmp
(
data
,
"cifsacl"
,
7
)
==
0
)
{
vol
->
cifs_acl
=
1
;
}
else
if
(
strnicmp
(
data
,
"nocifsacl"
,
9
)
==
0
)
{
...
...
@@ -2160,6 +2165,8 @@ cifs_mount(struct super_block *sb, struct cifs_sb_info *cifs_sb,
cifs_sb
->
mnt_cifs_flags
|=
CIFS_MOUNT_NO_BRL
;
if
(
volume_info
.
mand_lock
)
cifs_sb
->
mnt_cifs_flags
|=
CIFS_MOUNT_NOPOSIXBRL
;
if
(
volume_info
.
wine_mode
)
cifs_sb
->
mnt_cifs_flags
|=
CIFS_MOUNT_WINE_MODE
;
if
(
volume_info
.
cifs_acl
)
cifs_sb
->
mnt_cifs_flags
|=
CIFS_MOUNT_CIFS_ACL
;
if
(
volume_info
.
override_uid
)
...
...
sources/legacy/dir.c
View file @
a4b5b1eb
...
...
@@ -443,7 +443,7 @@ int cifs_mknod(struct inode *inode, struct dentry *direntry, int mode, int devic
pdev
->
minor
=
cpu_to_le64
(
MINOR
(
device_number
));
rc
=
CIFSSMBWrite
(
xid
,
pTcon
,
fileHandle
,
fileHandle
,
current
->
tgid
,
sizeof
(
struct
win_dev
),
0
,
&
bytes_written
,
(
char
*
)
pdev
,
NULL
,
0
);
...
...
@@ -454,7 +454,7 @@ int cifs_mknod(struct inode *inode, struct dentry *direntry, int mode, int devic
pdev
->
minor
=
cpu_to_le64
(
MINOR
(
device_number
));
rc
=
CIFSSMBWrite
(
xid
,
pTcon
,
fileHandle
,
fileHandle
,
current
->
tgid
,
sizeof
(
struct
win_dev
),
0
,
&
bytes_written
,
(
char
*
)
pdev
,
NULL
,
0
);
...
...
sources/legacy/file.c
View file @
a4b5b1eb
...
...
@@ -815,9 +815,16 @@ int cifs_lock(struct file *file, int cmd, struct file_lock *pfLock)
FreeXid
(
xid
);
return
-
EBADF
;
}
netpid
=
((
struct
cifsFileInfo
*
)
file
->
private_data
)
->
pid
;
netfid
=
((
struct
cifsFileInfo
*
)
file
->
private_data
)
->
netfid
;
if
((
cmd
&
CIFS_NOPOSIXBRL_READ
)
&&
(
cifs_sb
->
mnt_cifs_flags
&
CIFS_MOUNT_WINE_MODE
))
netpid
=
((
struct
cifsFileInfo
*
)
file
->
private_data
)
->
pid
;
else
netpid
=
current
->
tgid
;
cmd
&=
~
CIFS_NOPOSIXBRL_READ
;
if
((
pTcon
->
ses
->
capabilities
&
CAP_UNIX
)
&&
(
CIFS_UNIX_FCNTL_CAP
&
le64_to_cpu
(
pTcon
->
fsUnixInfo
.
Capability
))
&&
((
cifs_sb
->
mnt_cifs_flags
&
CIFS_MOUNT_NOPOSIXBRL
)
==
0
))
...
...
@@ -856,8 +863,30 @@ int cifs_lock(struct file *file, int cmd, struct file_lock *pfLock)
}
else
{
/* if rc == ERR_SHARING_VIOLATION ? */
rc
=
0
;
/* do not change lock type to unlock
since range in use */
rc
=
0
;
if
(
lockType
&
LOCKING_ANDX_SHARED_LOCK
)
{
pfLock
->
fl_type
=
F_WRLCK
;
}
else
{
rc
=
CIFSSMBLock
(
xid
,
pTcon
,
netfid
,
netpid
,
length
,
pfLock
->
fl_start
,
0
,
1
,
lockType
|
LOCKING_ANDX_SHARED_LOCK
,
0
/* wait flag */
);
if
(
rc
==
0
)
{
rc
=
CIFSSMBLock
(
xid
,
pTcon
,
netfid
,
netpid
,
length
,
pfLock
->
fl_start
,
1
,
0
,
lockType
|
LOCKING_ANDX_SHARED_LOCK
,
0
/* wait flag */
);
pfLock
->
fl_type
=
F_RDLCK
;
if
(
rc
!=
0
)
cERROR
(
1
,
(
"Error unlocking "
"previously locked range %d "
"during test of lock"
,
rc
));
}
else
pfLock
->
fl_type
=
F_WRLCK
;
rc
=
0
;
}
}
FreeXid
(
xid
);
...
...
@@ -916,9 +945,10 @@ int cifs_lock(struct file *file, int cmd, struct file_lock *pfLock)
1
,
0
,
li
->
type
,
FALSE
);
if
(
stored_rc
)
rc
=
stored_rc
;
list_del
(
&
li
->
llist
);
kfree
(
li
);
else
{
list_del
(
&
li
->
llist
);
kfree
(
li
);
}
}
}
mutex_unlock
(
&
fid
->
lock_mutex
);
...
...
@@ -943,6 +973,7 @@ ssize_t cifs_user_write(struct file *file, const char __user *write_data,
struct
cifsTconInfo
*
pTcon
;
int
xid
,
long_op
;
struct
cifsFileInfo
*
open_file
;
__u32
netpid
;
#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 20)
cifs_sb
=
CIFS_SB
(
file
->
f_dentry
->
d_sb
);
...
...
@@ -960,6 +991,11 @@ ssize_t cifs_user_write(struct file *file, const char __user *write_data,
return
-
EBADF
;
open_file
=
(
struct
cifsFileInfo
*
)
file
->
private_data
;
if
(
cifs_sb
->
mnt_cifs_flags
&
CIFS_MOUNT_WINE_MODE
)
netpid
=
open_file
->
pid
;
else
netpid
=
current
->
tgid
;
xid
=
GetXid
();
#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 20)
...
...
@@ -1001,7 +1037,7 @@ ssize_t cifs_user_write(struct file *file, const char __user *write_data,
}
rc
=
CIFSSMBWrite
(
xid
,
pTcon
,
open_file
->
netfid
,
open_file
->
netfid
,
netpid
,
min_t
(
const
int
,
cifs_sb
->
wsize
,
write_size
-
total_written
),
*
poffset
,
&
bytes_written
,
...
...
@@ -1067,6 +1103,7 @@ static ssize_t cifs_write(struct file *file, const char *write_data,
struct
cifsTconInfo
*
pTcon
;
int
xid
,
long_op
;
struct
cifsFileInfo
*
open_file
;
__u32
netpid
;
#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 20)
cifs_sb
=
CIFS_SB
(
file
->
f_dentry
->
d_sb
);
...
...
@@ -1080,6 +1117,11 @@ static ssize_t cifs_write(struct file *file, const char *write_data,
return
-
EBADF
;
open_file
=
(
struct
cifsFileInfo
*
)
file
->
private_data
;
if
(
cifs_sb
->
mnt_cifs_flags
&
CIFS_MOUNT_WINE_MODE
)
netpid
=
open_file
->
pid
;
else
netpid
=
current
->
tgid
;
xid
=
GetXid
();
if
(
*
poffset
>
file
->
f_dentry
->
d_inode
->
i_size
)
...
...
@@ -1095,6 +1137,11 @@ static ssize_t cifs_write(struct file *file, const char *write_data,
return
-
EBADF
;
open_file
=
(
struct
cifsFileInfo
*
)
file
->
private_data
;
if
(
cifs_sb
->
mnt_cifs_flags
&
CIFS_MOUNT_WINE_MODE
)
netpid
=
open_file
->
pid
;
else
netpid
=
current
->
tgid
;
xid
=
GetXid
();
if
(
*
poffset
>
file
->
f_path
.
dentry
->
d_inode
->
i_size
)
...
...
@@ -1146,12 +1193,13 @@ static ssize_t cifs_write(struct file *file, const char *write_data,
total_written
;
iov
[
1
].
iov_len
=
len
;
rc
=
CIFSSMBWrite2
(
xid
,
pTcon
,
open_file
->
netfid
,
len
,
*
poffset
,
&
bytes_written
,
iov
,
1
,
long_op
);
open_file
->
netfid
,
netpid
,
len
,
*
poffset
,
&
bytes_written
,
iov
,
1
,
long_op
);
}
else
rc
=
CIFSSMBWrite
(
xid
,
pTcon
,
open_file
->
netfid
,
open_file
->
netfid
,
netpid
,
min_t
(
const
int
,
cifs_sb
->
wsize
,
write_size
-
total_written
),
*
poffset
,
&
bytes_written
,
...
...
@@ -1346,6 +1394,7 @@ static int cifs_writepages(struct address_space *mapping,
int
rc
=
0
;
int
scanned
=
0
;
int
xid
;
__u32
netpid
;
cifs_sb
=
CIFS_SB
(
mapping
->
host
->
i_sb
);
...
...
@@ -1505,12 +1554,17 @@ retry:
* we used to still be valid
*/
open_file
=
find_writable_file
(
CIFS_I
(
mapping
->
host
));
if
(
cifs_sb
->
mnt_cifs_flags
&
CIFS_MOUNT_WINE_MODE
)
netpid
=
open_file
->
pid
;
else
netpid
=
current
->
tgid
;
if
(
!
open_file
)
{
cERROR
(
1
,
(
"No writable handles for inode"
));
rc
=
-
EBADF
;
}
else
{
rc
=
CIFSSMBWrite2
(
xid
,
cifs_sb
->
tcon
,
open_file
->
netfid
,
open_file
->
netfid
,
netpid
,
bytes_to_write
,
offset
,
&
bytes_written
,
iov
,
n_iov
,
1
);
...
...
@@ -1749,6 +1803,7 @@ ssize_t cifs_user_read(struct file *file, char __user *read_data,
char
*
smb_read_data
;
char
__user
*
current_offset
;
struct
smb_com_read_rsp
*
pSMBr
;
__u32
netpid
;
xid
=
GetXid
();
#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 20)
...
...
@@ -1764,6 +1819,11 @@ ssize_t cifs_user_read(struct file *file, char __user *read_data,
}
open_file
=
(
struct
cifsFileInfo
*
)
file
->
private_data
;
if
(
cifs_sb
->
mnt_cifs_flags
&
CIFS_MOUNT_WINE_MODE
)
netpid
=
open_file
->
pid
;
else
netpid
=
current
->
tgid
;
if
((
file
->
f_flags
&
O_ACCMODE
)
==
O_WRONLY
)
{
cFYI
(
1
,
(
"attempting read on write only file instance"
));
}
...
...
@@ -1783,7 +1843,7 @@ ssize_t cifs_user_read(struct file *file, char __user *read_data,
break
;
}
rc
=
CIFSSMBRead
(
xid
,
pTcon
,
open_file
->
netfid
,
open_file
->
netfid
,
netpid
,
current_read_size
,
*
poffset
,
&
bytes_read
,
&
smb_read_data
,
&
buf_type
);
...
...
@@ -1834,6 +1894,7 @@ static ssize_t cifs_read(struct file *file, char *read_data, size_t read_size,
char
*
current_offset
;
struct
cifsFileInfo
*
open_file
;
int
buf_type
=
CIFS_NO_BUFFER
;
__u32
netpid
;
xid
=
GetXid
();
#if LINUX_VERSION_CODE < KERNEL_VERSION(2, 6, 20)
...
...
@@ -1849,6 +1910,11 @@ static ssize_t cifs_read(struct file *file, char *read_data, size_t read_size,
}
open_file
=
(
struct
cifsFileInfo
*
)
file
->
private_data
;
if
(
cifs_sb
->
mnt_cifs_flags
&
CIFS_MOUNT_WINE_MODE
)
netpid
=
open_file
->
pid
;
else
netpid
=
current
->
tgid
;
if
((
file
->
f_flags
&
O_ACCMODE
)
==
O_WRONLY
)
cFYI
(
1
,
(
"attempting read on write only file instance"
));
...
...
@@ -1873,7 +1939,7 @@ static ssize_t cifs_read(struct file *file, char *read_data, size_t read_size,
break
;
}
rc
=
CIFSSMBRead
(
xid
,
pTcon
,
open_file
->
netfid
,
open_file
->
netfid
,
netpid
,
current_read_size
,
*
poffset
,
&
bytes_read
,
&
current_offset
,
&
buf_type
);
...
...
@@ -1979,6 +2045,7 @@ static int cifs_readpages(struct file *file, struct address_space *mapping,
struct
pagevec
lru_pvec
;
struct
cifsFileInfo
*
open_file
;
int
buf_type
=
CIFS_NO_BUFFER
;
__u32
netpid
;
xid
=
GetXid
();
if
(
file
->
private_data
==
NULL
)
{
...
...
@@ -1993,6 +2060,11 @@ static int cifs_readpages(struct file *file, struct address_space *mapping,
#endif
pTcon
=
cifs_sb
->
tcon
;
if
(
cifs_sb
->
mnt_cifs_flags
&
CIFS_MOUNT_WINE_MODE
)
netpid
=
open_file
->
pid
;
else
netpid
=
current
->
tgid
;
pagevec_init
(
&
lru_pvec
,
0
);
#ifdef CONFIG_CIFS_DEBUG2
cFYI
(
1
,
(
"rpages: num pages %d"
,
num_pages
));
...
...
@@ -2043,10 +2115,9 @@ static int cifs_readpages(struct file *file, struct address_space *mapping,
}
rc
=
CIFSSMBRead
(
xid
,
pTcon
,
open_file
->
netfid
,
read_size
,
offset
,
&
bytes_read
,
&
smb_read_data
,
&
buf_type
);
open_file
->
netfid
,
netpid
,
read_size
,
offset
,
&
bytes_read
,
&
smb_read_data
,
&
buf_type
);
/* BB more RC checks ? */
if
(
rc
==
-
EAGAIN
)
{
if
(
smb_read_data
)
{
...
...
sources/legacy/inode.c
View file @
a4b5b1eb
...
...
@@ -261,8 +261,7 @@ static int decode_sfu_inode(struct inode *inode, __u64 size,
if
(
rc
==
0
)
{
int
buf_type
=
CIFS_NO_BUFFER
;
/* Read header */
rc
=
CIFSSMBRead
(
xid
,
pTcon
,
netfid
,
rc
=
CIFSSMBRead
(
xid
,
pTcon
,
netfid
,
current
->
tgid
,
24
/* length */
,
0
/* offset */
,
&
bytes_read
,
&
pbuf
,
&
buf_type
);
if
((
rc
==
0
)
&&
(
bytes_read
>=
8
))
{
...
...
@@ -1522,8 +1521,8 @@ int cifs_setattr(struct dentry *direntry, struct iattr *attrs)
cFYI
(
1
,
(
"SetFSize for attrs rc = %d"
,
rc
));
if
((
rc
==
-
EINVAL
)
||
(
rc
==
-
EOPNOTSUPP
))
{
unsigned
int
bytes_written
;
rc
=
CIFSSMBWrite
(
xid
,
pTcon
,
n
f
id
,
0
,
attrs
->
ia_size
,
rc
=
CIFSSMBWrite
(
xid
,
pTcon
,
nfid
,
n
p
id
,
0
,
attrs
->
ia_size
,
&
bytes_written
,
NULL
,
NULL
,
1
/* 45 seconds */
);
cFYI
(
1
,
(
"Wrt seteof rc %d"
,
rc
));
...
...
@@ -1556,7 +1555,7 @@ int cifs_setattr(struct dentry *direntry, struct iattr *attrs)
if
(
rc
==
0
)
{
unsigned
int
bytes_written
;
rc
=
CIFSSMBWrite
(
xid
,
pTcon
,
netfid
,
0
,
netfid
,
current
->
tgid
,
0
,
attrs
->
ia_size
,
&
bytes_written
,
NULL
,
NULL
,
1
/* 45 sec */
);
...
...
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