Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
kernel_linux
提交
bcb02034
K
kernel_linux
项目概览
OpenHarmony
/
kernel_linux
上一次同步 3 年多
通知
13
Star
8
Fork
2
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
kernel_linux
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
bcb02034
编写于
9月 25, 2007
作者:
S
Steve French
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[CIFS] move cifs acl code to new file and fix build break
Signed-off-by:
N
Steve French
<
sfrench@us.ibm.com
>
上级
442aa310
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
137 addition
and
109 deletion
+137
-109
fs/cifs/Makefile
fs/cifs/Makefile
+1
-1
fs/cifs/cifsacl.c
fs/cifs/cifsacl.c
+134
-0
fs/cifs/cifsacl.h
fs/cifs/cifsacl.h
+1
-1
fs/cifs/cifsproto.h
fs/cifs/cifsproto.h
+1
-0
fs/cifs/cifssmb.c
fs/cifs/cifssmb.c
+0
-107
未找到文件。
fs/cifs/Makefile
浏览文件 @
bcb02034
...
...
@@ -3,4 +3,4 @@
#
obj-$(CONFIG_CIFS)
+=
cifs.o
cifs-objs
:=
cifsfs.o cifssmb.o cifs_debug.o connect.o dir.o file.o inode.o link.o misc.o netmisc.o smbdes.o smbencrypt.o transport.o asn1.o md4.o md5.o cifs_unicode.o nterr.o xattr.o cifsencrypt.o fcntl.o readdir.o ioctl.o sess.o export.o
cifs-objs
:=
cifsfs.o cifssmb.o cifs_debug.o connect.o dir.o file.o inode.o link.o misc.o netmisc.o smbdes.o smbencrypt.o transport.o asn1.o md4.o md5.o cifs_unicode.o nterr.o xattr.o cifsencrypt.o fcntl.o readdir.o ioctl.o sess.o export.o
cifsacl.o
fs/cifs/cifsacl.c
0 → 100644
浏览文件 @
bcb02034
/*
* fs/cifs/cifsacl.c
*
* Copyright (C) International Business Machines Corp., 2007
* Author(s): Steve French (sfrench@us.ibm.com)
*
* Contains the routines for mapping CIFS/NTFS ACLs
*
* This library is free software; you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published
* by the Free Software Foundation; either version 2.1 of the License, or
* (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See
* the GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
/* security id for everyone */
static
const
struct
cifs_sid
sid_everyone
=
{
1
,
1
,
{
0
,
0
,
0
,
0
,
0
,
0
},
{
0
,
0
,
0
,
0
}};
/* group users */
static
const
struct
cifs_sid
sid_user
=
{
1
,
2
,
{
0
,
0
,
0
,
0
,
0
,
5
},
{
32
,
545
,
0
,
0
}};
static
int
parse_sid
(
struct
cifs_sid
*
psid
,
char
*
end_of_acl
)
{
/* BB need to add parm so we can store the SID BB */
/* validate that we do not go past end of acl */
if
(
end_of_acl
<
(
char
*
)
psid
+
sizeof
(
struct
cifs_sid
))
{
cERROR
(
1
,
(
"ACL to small to parse SID"
));
return
-
EINVAL
;
}
#ifdef CONFIG_CIFS_DEBUG2
cFYI
(
1
,
(
"revision %d num_auth %d First subauth 0x%x"
,
psid
->
revision
,
psid
->
num_auth
,
psid
->
sub_auth
[
0
]));
/* BB add length check to make sure that we do not have huge num auths
and therefore go off the end */
cFYI
(
1
,
(
"RID 0x%x"
,
le32_to_cpu
(
psid
->
sub_auth
[
psid
->
num_auth
])));
#endif
return
0
;
}
/* Convert CIFS ACL to POSIX form */
int
parse_sec_desc
(
struct
cifs_ntsd
*
pntsd
,
int
acl_len
)
{
int
i
;
int
num_aces
=
0
;
int
acl_size
;
struct
cifs_sid
*
owner_sid_ptr
,
*
group_sid_ptr
;
struct
cifs_acl
*
dacl_ptr
;
/* no need for SACL ptr */
struct
cifs_ntace
**
ppntace
;
struct
cifs_ace
**
ppace
;
char
*
acl_base
;
char
*
end_of_acl
=
((
char
*
)
pntsd
)
+
acl_len
;
owner_sid_ptr
=
(
struct
cifs_sid
*
)((
char
*
)
pntsd
+
cpu_to_le32
(
pntsd
->
osidoffset
));
group_sid_ptr
=
(
struct
cifs_sid
*
)((
char
*
)
pntsd
+
cpu_to_le32
(
pntsd
->
gsidoffset
));
dacl_ptr
=
(
struct
cifs_acl
*
)((
char
*
)
pntsd
+
cpu_to_le32
(
pntsd
->
dacloffset
));
#ifdef CONFIG_CIFS_DEBUG2
cFYI
(
1
,
(
"revision %d type 0x%x ooffset 0x%x goffset 0x%x "
"sacloffset 0x%x dacloffset 0x%x"
,
pntsd
->
revision
,
pntsd
->
type
,
pntsd
->
osidoffset
,
pntsd
->
gsidoffset
,
pntsd
->
sacloffset
,
pntsd
->
dacloffset
));
#endif
rc
=
parse_sid
(
owner_sid_ptr
,
end_of_acl
);
if
(
rc
)
return
rc
;
rc
=
parse_sid
(
group_sid_ptr
,
end_of_acl
);
if
(
rc
)
return
rc
;
/* cifscred->uid = owner_sid_ptr->rid;
cifscred->gid = group_sid_ptr->rid;
memcpy((void *)(&(cifscred->osid)), (void *)owner_sid_ptr,
sizeof (struct cifs_sid));
memcpy((void *)(&(cifscred->gsid)), (void *)group_sid_ptr,
sizeof (struct cifs_sid)); */
num_aces
=
cpu_to_le32
(
dacl_ptr
->
num_aces
);
cFYI
(
1
,
(
"num aces %d"
,
num_aces
));
if
(
num_aces
>
0
)
{
ppntace
=
kmalloc
(
num_aces
*
sizeof
(
struct
cifs_ntace
*
),
GFP_KERNEL
);
ppace
=
kmalloc
(
num_aces
*
sizeof
(
struct
cifs_ace
*
),
GFP_KERNEL
);
/* cifscred->cecount = dacl_ptr->num_aces;
cifscred->ntaces = kmalloc(num_aces *
sizeof(struct cifs_ntace *), GFP_KERNEL);
cifscred->aces = kmalloc(num_aces *
sizeof(struct cifs_ace *), GFP_KERNEL);*/
acl_base
=
(
char
*
)
dacl_ptr
;
acl_size
=
sizeof
(
struct
cifs_acl
);
for
(
i
=
0
;
i
<
num_aces
;
++
i
)
{
ppntace
[
i
]
=
(
struct
cifs_ntace
*
)
(
acl_base
+
acl_size
);
ppace
[
i
]
=
(
struct
cifs_ace
*
)
((
char
*
)
ppntace
[
i
]
+
sizeof
(
struct
cifs_ntace
));
/* memcpy((void *)(&(cifscred->ntaces[i])),
(void *)ntace_ptrptr[i],
sizeof(struct cifs_ntace));
memcpy((void *)(&(cifscred->aces[i])),
(void *)ace_ptrptr[i],
sizeof(struct cifs_ace)); */
acl_base
=
(
char
*
)
ppntace
[
i
];
acl_size
=
cpu_to_le32
(
ppntace
[
i
]
->
size
);
#ifdef CONFIG_CIFS_DEBUG2
cFYI
(
1
,
(
"ACE revision:%d"
,
ppace
[
i
]
->
revision
));
#endif
}
kfree
(
ppace
);
kfree
(
ppntace
);
}
return
(
0
);
}
fs/cifs/cifsacl.h
浏览文件 @
bcb02034
/*
* fs/cifs/cifsacl.h
*
* Copyright (c) International Business Machines Corp., 200
5
* Copyright (c) International Business Machines Corp., 200
7
* Author(s): Steve French (sfrench@us.ibm.com)
*
* This library is free software; you can redistribute it and/or modify
...
...
fs/cifs/cifsproto.h
浏览文件 @
bcb02034
...
...
@@ -310,6 +310,7 @@ extern void setup_ntlmv2_rsp(struct cifsSesInfo *, char *,
#ifdef CONFIG_CIFS_WEAK_PW_HASH
extern
void
calc_lanman_hash
(
struct
cifsSesInfo
*
ses
,
char
*
lnm_session_key
);
#endif
/* CIFS_WEAK_PW_HASH */
extern
int
parse_sec_desc
(
struct
cifs_ntsd
*
pntsd
,
int
acl_len
);
extern
int
CIFSSMBCopy
(
int
xid
,
struct
cifsTconInfo
*
source_tcon
,
const
char
*
fromName
,
...
...
fs/cifs/cifssmb.c
浏览文件 @
bcb02034
...
...
@@ -3040,113 +3040,6 @@ CIFSGetExtAttr(const int xid, struct cifsTconInfo *tcon,
#endif
/* CONFIG_POSIX */
/* security id for everyone */
static
const
struct
cifs_sid
sid_everyone
=
{
1
,
1
,
{
0
,
0
,
0
,
0
,
0
,
0
},
{
0
,
0
,
0
,
0
}};
/* group users */
static
const
struct
cifs_sid
sid_user
=
{
1
,
2
,
{
0
,
0
,
0
,
0
,
0
,
5
},
{
32
,
545
,
0
,
0
}};
static
void
parse_sid
(
struct
cifs_sid
*
psid
,
char
*
end_of_acl
)
{
/* BB need to add parm so we can store the SID BB */
/* validate that we do not go past end of acl */
if
(
end_of_acl
<
(
char
*
)
psid
+
sizeof
(
struct
cifs_sid
))
{
cERROR
(
1
,
(
"ACL to small to parse SID"
));
return
;
}
#ifdef CONFIG_CIFS_DEBUG2
cFYI
(
1
,
(
"revision %d num_auth %d First subauth 0x%x"
,
psid
->
revision
,
psid
->
num_auth
,
psid
->
sub_auth
[
0
]));
/* BB add length check to make sure that we do not have huge num auths
and therefore go off the end */
cFYI
(
1
,
(
"RID 0x%x"
,
le32_to_cpu
(
psid
->
sub_auth
[
psid
->
num_auth
])));
#endif
return
;
}
/* Convert CIFS ACL to POSIX form */
static
int
parse_sec_desc
(
struct
cifs_ntsd
*
pntsd
,
int
acl_len
)
{
int
i
;
int
num_aces
=
0
;
int
acl_size
;
struct
cifs_sid
*
owner_sid_ptr
,
*
group_sid_ptr
;
struct
cifs_acl
*
dacl_ptr
;
/* no need for SACL ptr */
struct
cifs_ntace
**
ppntace
;
struct
cifs_ace
**
ppace
;
char
*
acl_base
;
char
*
end_of_acl
=
((
char
*
)
pntsd
)
+
acl_len
;
owner_sid_ptr
=
(
struct
cifs_sid
*
)((
char
*
)
pntsd
+
cpu_to_le32
(
pntsd
->
osidoffset
));
group_sid_ptr
=
(
struct
cifs_sid
*
)((
char
*
)
pntsd
+
cpu_to_le32
(
pntsd
->
gsidoffset
));
dacl_ptr
=
(
struct
cifs_acl
*
)((
char
*
)
pntsd
+
cpu_to_le32
(
pntsd
->
dacloffset
));
#ifdef CONFIG_CIFS_DEBUG2
cFYI
(
1
,(
"revision %d type 0x%x ooffset 0x%x goffset 0x%x "
"sacloffset 0x%x dacloffset 0x%x"
,
pntsd
->
revision
,
pntsd
->
type
,
pntsd
->
osidoffset
,
pntsd
->
gsidoffset
,
pntsd
->
sacloffset
,
pntsd
->
dacloffset
));
#endif
parse_sid
(
owner_sid_ptr
,
end_of_acl
);
parse_sid
(
group_sid_ptr
,
end_of_acl
);
/* cifscred->uid = owner_sid_ptr->rid;
cifscred->gid = group_sid_ptr->rid;
memcpy((void *)(&(cifscred->osid)), (void *)owner_sid_ptr,
sizeof (struct cifs_sid));
memcpy((void *)(&(cifscred->gsid)), (void *)group_sid_ptr,
sizeof (struct cifs_sid)); */
num_aces
=
cpu_to_le32
(
dacl_ptr
->
num_aces
);
cFYI
(
1
,
(
"num aces %d"
,
num_aces
));
if
(
num_aces
>
0
)
{
ppntace
=
kmalloc
(
num_aces
*
sizeof
(
struct
cifs_ntace
*
),
GFP_KERNEL
);
ppace
=
kmalloc
(
num_aces
*
sizeof
(
struct
cifs_ace
*
),
GFP_KERNEL
);
/* cifscred->cecount = dacl_ptr->num_aces;
cifscred->ntaces = kmalloc(num_aces *
sizeof(struct cifs_ntace *), GFP_KERNEL);
cifscred->aces = kmalloc(num_aces *
sizeof(struct cifs_ace *), GFP_KERNEL);*/
acl_base
=
(
char
*
)
dacl_ptr
;
acl_size
=
sizeof
(
struct
cifs_acl
);
for
(
i
=
0
;
i
<
num_aces
;
++
i
)
{
ppntace
[
i
]
=
(
struct
cifs_ntace
*
)
(
acl_base
+
acl_size
);
ppace
[
i
]
=
(
struct
cifs_ace
*
)
((
char
*
)
ppntace
[
i
]
+
sizeof
(
struct
cifs_ntace
));
/* memcpy((void *)(&(cifscred->ntaces[i])),
(void *)ntace_ptrptr[i],
sizeof(struct cifs_ntace));
memcpy((void *)(&(cifscred->aces[i])),
(void *)ace_ptrptr[i],
sizeof(struct cifs_ace)); */
acl_base
=
(
char
*
)
ppntace
[
i
];
acl_size
=
cpu_to_le32
(
ppntace
[
i
]
->
size
);
#ifdef CONFIG_CIFS_DEBUG2
cFYI
(
1
,
(
"ACE revision:%d"
,
ppace
[
i
]
->
revision
));
}
#endif
kfree
(
ppace
);
kfree
(
ppntace
);
}
return
(
0
);
}
/* Get Security Descriptor (by handle) from remote server for a file or dir */
int
CIFSSMBGetCIFSACL
(
const
int
xid
,
struct
cifsTconInfo
*
tcon
,
__u16
fid
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录