Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
8cc64c6e
K
Kernel
项目概览
openeuler
/
Kernel
大约 1 年 前同步成功
通知
5
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
8cc64c6e
编写于
10月 03, 2005
作者:
S
Steve French
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[CIFS] Allow SMBWrite2 to work to older servers
Signed-off-by: Steve French (sfrench@us.ibm.com)
上级
3e84469d
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
22 addition
and
7 deletion
+22
-7
fs/cifs/cifssmb.c
fs/cifs/cifssmb.c
+22
-7
未找到文件。
fs/cifs/cifssmb.c
浏览文件 @
8cc64c6e
...
...
@@ -1139,11 +1139,15 @@ CIFSSMBWrite2(const int xid, struct cifsTconInfo *tcon,
{
int
rc
=
-
EACCES
;
WRITE_REQ
*
pSMB
=
NULL
;
int
bytes_returned
;
int
bytes_returned
,
wct
;
int
smb_hdr_len
;
cFYI
(
1
,(
"write2 at %lld %d bytes"
,
offset
,
count
));
/* BB removeme BB */
rc
=
small_smb_init
(
SMB_COM_WRITE_ANDX
,
14
,
tcon
,
(
void
**
)
&
pSMB
);
if
(
tcon
->
ses
->
capabilities
&
CAP_LARGE_FILES
)
wct
=
14
;
else
wct
=
12
;
rc
=
small_smb_init
(
SMB_COM_WRITE_ANDX
,
wct
,
tcon
,
(
void
**
)
&
pSMB
);
if
(
rc
)
return
rc
;
/* tcon and ses pointer are checked in smb_init */
...
...
@@ -1153,7 +1157,10 @@ CIFSSMBWrite2(const int xid, struct cifsTconInfo *tcon,
pSMB
->
AndXCommand
=
0xFF
;
/* none */
pSMB
->
Fid
=
netfid
;
pSMB
->
OffsetLow
=
cpu_to_le32
(
offset
&
0xFFFFFFFF
);
pSMB
->
OffsetHigh
=
cpu_to_le32
(
offset
>>
32
);
if
(
wct
==
14
)
pSMB
->
OffsetHigh
=
cpu_to_le32
(
offset
>>
32
);
else
if
((
offset
>>
32
)
>
0
)
/* can not handle this big offset for old */
return
-
EIO
;
pSMB
->
Reserved
=
0xFFFFFFFF
;
pSMB
->
WriteMode
=
0
;
pSMB
->
Remaining
=
0
;
...
...
@@ -1164,9 +1171,17 @@ CIFSSMBWrite2(const int xid, struct cifsTconInfo *tcon,
pSMB
->
DataLengthLow
=
cpu_to_le16
(
count
&
0xFFFF
);
pSMB
->
DataLengthHigh
=
cpu_to_le16
(
count
>>
16
);
smb_hdr_len
=
pSMB
->
hdr
.
smb_buf_length
+
1
;
/* hdr + 1 byte pad */
pSMB
->
hdr
.
smb_buf_length
+=
count
+
1
;
pSMB
->
ByteCount
=
cpu_to_le16
(
count
+
1
);
if
(
wct
==
14
)
pSMB
->
hdr
.
smb_buf_length
+=
count
+
1
;
else
/* wct == 12 */
pSMB
->
hdr
.
smb_buf_length
+=
count
+
5
;
/* smb data starts later */
if
(
wct
==
14
)
pSMB
->
ByteCount
=
cpu_to_le16
(
count
+
1
);
else
/* wct == 12 */
/* bigger pad, smaller smb hdr, keep offset ok */
{
struct
smb_com_writex_req
*
pSMBW
=
(
struct
smb_com_writex_req
*
)
pSMB
;
pSMBW
->
ByteCount
=
cpu_to_le16
(
count
+
5
);
}
iov
[
0
].
iov_base
=
pSMB
;
iov
[
0
].
iov_len
=
smb_hdr_len
+
4
;
...
...
@@ -1174,7 +1189,7 @@ CIFSSMBWrite2(const int xid, struct cifsTconInfo *tcon,
long_op
);
cifs_stats_inc
(
&
tcon
->
num_writes
);
if
(
rc
)
{
cFYI
(
1
,
(
"Send error
in write
= %d"
,
rc
));
cFYI
(
1
,
(
"Send error
Write2
= %d"
,
rc
));
*
nbytes
=
0
;
}
else
{
WRITE_RSP
*
pSMBr
=
(
WRITE_RSP
*
)
pSMB
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录