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
c1deb0b0
Commit
c1deb0b0
authored
Dec 11, 2004
by
Steve French
Committed by
Steve French
Dec 11, 2004
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[CIFS] Remove sparse warning in use of cifs_write function
Signed-off-by: Steve French (sfrench@us.ibm.com)
parent
8765fc46
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
142 additions
and
10 deletions
+142
-10
fs/cifs/cifsfs.c
fs/cifs/cifsfs.c
+1
-1
fs/cifs/cifsfs.h
fs/cifs/cifsfs.h
+2
-2
fs/cifs/cifsproto.h
fs/cifs/cifsproto.h
+2
-1
fs/cifs/cifssmb.c
fs/cifs/cifssmb.c
+15
-3
fs/cifs/file.c
fs/cifs/file.c
+122
-3
No files found.
fs/cifs/cifsfs.c
View file @
c1deb0b0
...
@@ -498,7 +498,7 @@ cifs_write_wrapper(struct file * file, const char __user *write_data,
...
@@ -498,7 +498,7 @@ cifs_write_wrapper(struct file * file, const char __user *write_data,
cifs_sb
=
CIFS_SB
(
file
->
f_dentry
->
d_sb
);
cifs_sb
=
CIFS_SB
(
file
->
f_dentry
->
d_sb
);
if
(
cifs_sb
!=
NULL
)
{
if
(
cifs_sb
!=
NULL
)
{
if
(
cifs_sb
->
mnt_cifs_flags
&
CIFS_MOUNT_DIRECT_IO
)
{
if
(
cifs_sb
->
mnt_cifs_flags
&
CIFS_MOUNT_DIRECT_IO
)
{
return
cifs_write
(
file
,
write_data
,
return
cifs_
user_
write
(
file
,
write_data
,
write_size
,
poffset
);
write_size
,
poffset
);
}
}
}
}
...
...
fs/cifs/cifsfs.h
View file @
c1deb0b0
...
@@ -65,8 +65,8 @@ extern int cifs_close(struct inode *inode, struct file *file);
...
@@ -65,8 +65,8 @@ extern int cifs_close(struct inode *inode, struct file *file);
extern
int
cifs_closedir
(
struct
inode
*
inode
,
struct
file
*
file
);
extern
int
cifs_closedir
(
struct
inode
*
inode
,
struct
file
*
file
);
extern
ssize_t
cifs_user_read
(
struct
file
*
file
,
char
__user
*
read_data
,
extern
ssize_t
cifs_user_read
(
struct
file
*
file
,
char
__user
*
read_data
,
size_t
read_size
,
loff_t
*
poffset
);
size_t
read_size
,
loff_t
*
poffset
);
extern
ssize_t
cifs_
write
(
struct
file
*
file
,
const
cha
r
*
write_data
,
extern
ssize_t
cifs_
user_write
(
struct
file
*
file
,
const
char
__use
r
*
write_data
,
size_t
write_size
,
loff_t
*
poffset
);
size_t
write_size
,
loff_t
*
poffset
);
extern
int
cifs_lock
(
struct
file
*
,
int
,
struct
file_lock
*
);
extern
int
cifs_lock
(
struct
file
*
,
int
,
struct
file_lock
*
);
extern
int
cifs_fsync
(
struct
file
*
,
struct
dentry
*
,
int
);
extern
int
cifs_fsync
(
struct
file
*
,
struct
dentry
*
,
int
);
extern
int
cifs_flush
(
struct
file
*
);
extern
int
cifs_flush
(
struct
file
*
);
...
...
fs/cifs/cifsproto.h
View file @
c1deb0b0
...
@@ -192,7 +192,8 @@ extern int CIFSSMBRead(const int xid, struct cifsTconInfo *tcon,
...
@@ -192,7 +192,8 @@ extern int CIFSSMBRead(const int xid, struct cifsTconInfo *tcon,
extern
int
CIFSSMBWrite
(
const
int
xid
,
struct
cifsTconInfo
*
tcon
,
extern
int
CIFSSMBWrite
(
const
int
xid
,
struct
cifsTconInfo
*
tcon
,
const
int
netfid
,
const
unsigned
int
count
,
const
int
netfid
,
const
unsigned
int
count
,
const
__u64
lseek
,
unsigned
int
*
nbytes
,
const
__u64
lseek
,
unsigned
int
*
nbytes
,
const
char
*
buf
,
const
int
long_op
);
const
char
*
buf
,
const
char
__user
*
ubuf
,
const
int
long_op
);
extern
int
CIFSSMBLock
(
const
int
xid
,
struct
cifsTconInfo
*
tcon
,
extern
int
CIFSSMBLock
(
const
int
xid
,
struct
cifsTconInfo
*
tcon
,
const
__u16
netfid
,
const
__u64
len
,
const
__u16
netfid
,
const
__u64
len
,
const
__u64
offset
,
const
__u32
numUnlock
,
const
__u64
offset
,
const
__u32
numUnlock
,
...
...
fs/cifs/cifssmb.c
View file @
c1deb0b0
...
@@ -856,7 +856,7 @@ int
...
@@ -856,7 +856,7 @@ int
CIFSSMBWrite
(
const
int
xid
,
struct
cifsTconInfo
*
tcon
,
CIFSSMBWrite
(
const
int
xid
,
struct
cifsTconInfo
*
tcon
,
const
int
netfid
,
const
unsigned
int
count
,
const
int
netfid
,
const
unsigned
int
count
,
const
__u64
offset
,
unsigned
int
*
nbytes
,
const
char
*
buf
,
const
__u64
offset
,
unsigned
int
*
nbytes
,
const
char
*
buf
,
const
int
long_op
)
const
char
__user
*
ubuf
,
const
int
long_op
)
{
{
int
rc
=
-
EACCES
;
int
rc
=
-
EACCES
;
WRITE_REQ
*
pSMB
=
NULL
;
WRITE_REQ
*
pSMB
=
NULL
;
...
@@ -880,14 +880,26 @@ CIFSSMBWrite(const int xid, struct cifsTconInfo *tcon,
...
@@ -880,14 +880,26 @@ CIFSSMBWrite(const int xid, struct cifsTconInfo *tcon,
pSMB
->
Reserved
=
0xFFFFFFFF
;
pSMB
->
Reserved
=
0xFFFFFFFF
;
pSMB
->
WriteMode
=
0
;
pSMB
->
WriteMode
=
0
;
pSMB
->
Remaining
=
0
;
pSMB
->
Remaining
=
0
;
/* BB can relax this if buffer is big enough in some cases - ie we can
send more if LARGE_WRITE_X capability returned by the server and if
our buffer is big enough or if we convert to iovecs on socket writes
and eliminate the copy to the CIFS buffer */
bytes_sent
=
(
tcon
->
ses
->
server
->
maxBuf
-
MAX_CIFS_HDR_SIZE
)
&
~
0xFF
;
bytes_sent
=
(
tcon
->
ses
->
server
->
maxBuf
-
MAX_CIFS_HDR_SIZE
)
&
~
0xFF
;
if
(
bytes_sent
>
count
)
if
(
bytes_sent
>
count
)
bytes_sent
=
count
;
bytes_sent
=
count
;
pSMB
->
DataLengthHigh
=
0
;
pSMB
->
DataLengthHigh
=
0
;
pSMB
->
DataOffset
=
pSMB
->
DataOffset
=
cpu_to_le16
(
offsetof
(
struct
smb_com_write_req
,
Data
)
-
4
);
cpu_to_le16
(
offsetof
(
struct
smb_com_write_req
,
Data
)
-
4
);
if
(
buf
)
memcpy
(
pSMB
->
Data
,
buf
,
bytes_sent
);
memcpy
(
pSMB
->
Data
,
buf
,
bytes_sent
);
else
if
(
ubuf
)
copy_from_user
(
pSMB
->
Data
,
ubuf
,
bytes_sent
);
else
{
/* No buffer */
if
(
pSMB
)
cifs_buf_release
(
pSMB
);
return
-
EINVAL
;
}
byte_count
=
bytes_sent
+
1
/* pad */
;
byte_count
=
bytes_sent
+
1
/* pad */
;
pSMB
->
DataLengthLow
=
cpu_to_le16
(
bytes_sent
);
pSMB
->
DataLengthLow
=
cpu_to_le16
(
bytes_sent
);
...
...
fs/cifs/file.c
View file @
c1deb0b0
...
@@ -604,6 +604,125 @@ cifs_lock(struct file *file, int cmd, struct file_lock *pfLock)
...
@@ -604,6 +604,125 @@ cifs_lock(struct file *file, int cmd, struct file_lock *pfLock)
}
}
ssize_t
ssize_t
cifs_user_write
(
struct
file
*
file
,
const
char
__user
*
write_data
,
size_t
write_size
,
loff_t
*
poffset
)
{
int
rc
=
0
;
unsigned
int
bytes_written
=
0
;
unsigned
int
total_written
;
struct
cifs_sb_info
*
cifs_sb
;
struct
cifsTconInfo
*
pTcon
;
int
xid
,
long_op
;
struct
cifsFileInfo
*
open_file
;
if
(
file
->
f_dentry
==
NULL
)
return
-
EBADF
;
cifs_sb
=
CIFS_SB
(
file
->
f_dentry
->
d_sb
);
if
(
cifs_sb
==
NULL
)
{
return
-
EBADF
;
}
pTcon
=
cifs_sb
->
tcon
;
/*cFYI(1,
(" write %d bytes to offset %lld of %s", write_size,
*poffset, file->f_dentry->d_name.name)); */
if
(
file
->
private_data
==
NULL
)
{
return
-
EBADF
;
}
else
{
open_file
=
(
struct
cifsFileInfo
*
)
file
->
private_data
;
}
xid
=
GetXid
();
if
(
file
->
f_dentry
->
d_inode
==
NULL
)
{
FreeXid
(
xid
);
return
-
EBADF
;
}
if
(
*
poffset
>
file
->
f_dentry
->
d_inode
->
i_size
)
long_op
=
2
;
/* writes past end of file can take a long time */
else
long_op
=
1
;
for
(
total_written
=
0
;
write_size
>
total_written
;
total_written
+=
bytes_written
)
{
rc
=
-
EAGAIN
;
while
(
rc
==
-
EAGAIN
)
{
if
(
file
->
private_data
==
NULL
)
{
/* file has been closed on us */
FreeXid
(
xid
);
/* if we have gotten here we have written some data
and blocked, and the file has been freed on us
while we blocked so return what we managed to write */
return
total_written
;
}
if
(
open_file
->
closePend
)
{
FreeXid
(
xid
);
if
(
total_written
)
return
total_written
;
else
return
-
EBADF
;
}
if
(
open_file
->
invalidHandle
)
{
if
((
file
->
f_dentry
==
NULL
)
||
(
file
->
f_dentry
->
d_inode
==
NULL
))
{
FreeXid
(
xid
);
return
total_written
;
}
/* we could deadlock if we called
filemap_fdatawait from here so tell
reopen_file not to flush data to server now */
rc
=
cifs_reopen_file
(
file
->
f_dentry
->
d_inode
,
file
,
FALSE
);
if
(
rc
!=
0
)
break
;
}
rc
=
CIFSSMBWrite
(
xid
,
pTcon
,
open_file
->
netfid
,
write_size
-
total_written
,
*
poffset
,
&
bytes_written
,
NULL
,
write_data
+
total_written
,
long_op
);
}
if
(
rc
||
(
bytes_written
==
0
))
{
if
(
total_written
)
break
;
else
{
FreeXid
(
xid
);
return
rc
;
}
}
else
*
poffset
+=
bytes_written
;
long_op
=
FALSE
;
/* subsequent writes fast - 15 seconds is plenty */
}
#ifdef CONFIG_CIFS_STATS
if
(
total_written
>
0
)
{
atomic_inc
(
&
pTcon
->
num_writes
);
spin_lock
(
&
pTcon
->
stat_lock
);
pTcon
->
bytes_written
+=
total_written
;
spin_unlock
(
&
pTcon
->
stat_lock
);
}
#endif
/* since the write may have blocked check these pointers again */
if
(
file
->
f_dentry
)
{
if
(
file
->
f_dentry
->
d_inode
)
{
file
->
f_dentry
->
d_inode
->
i_ctime
=
file
->
f_dentry
->
d_inode
->
i_mtime
=
CURRENT_TIME
;
if
(
total_written
>
0
)
{
if
(
*
poffset
>
file
->
f_dentry
->
d_inode
->
i_size
)
i_size_write
(
file
->
f_dentry
->
d_inode
,
*
poffset
);
}
mark_inode_dirty_sync
(
file
->
f_dentry
->
d_inode
);
}
}
FreeXid
(
xid
);
return
total_written
;
}
static
ssize_t
cifs_write
(
struct
file
*
file
,
const
char
*
write_data
,
cifs_write
(
struct
file
*
file
,
const
char
*
write_data
,
size_t
write_size
,
loff_t
*
poffset
)
size_t
write_size
,
loff_t
*
poffset
)
{
{
...
@@ -680,10 +799,10 @@ cifs_write(struct file * file, const char *write_data,
...
@@ -680,10 +799,10 @@ cifs_write(struct file * file, const char *write_data,
}
}
rc
=
CIFSSMBWrite
(
xid
,
pTcon
,
rc
=
CIFSSMBWrite
(
xid
,
pTcon
,
open_file
->
netfid
,
open_file
->
netfid
,
write_size
-
total_written
,
*
poffset
,
write_size
-
total_written
,
*
poffset
,
&
bytes_written
,
&
bytes_written
,
write_data
+
total_written
,
long_op
);
write_data
+
total_written
,
NULL
,
long_op
);
}
}
if
(
rc
||
(
bytes_written
==
0
))
{
if
(
rc
||
(
bytes_written
==
0
))
{
if
(
total_written
)
if
(
total_written
)
...
@@ -1073,7 +1192,7 @@ cifs_user_read(struct file * file, char __user *read_data, size_t read_size,
...
@@ -1073,7 +1192,7 @@ cifs_user_read(struct file * file, char __user *read_data, size_t read_size,
return
total_read
;
return
total_read
;
}
}
ssize_t
s
tatic
s
size_t
cifs_read
(
struct
file
*
file
,
char
*
read_data
,
size_t
read_size
,
cifs_read
(
struct
file
*
file
,
char
*
read_data
,
size_t
read_size
,
loff_t
*
poffset
)
loff_t
*
poffset
)
{
{
...
...
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