Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Kernel Liteos A
提交
1f05c6a2
K
Kernel Liteos A
项目概览
OpenHarmony
/
Kernel Liteos A
1 年多 前同步成功
通知
464
Star
414
Fork
55
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
4
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel Liteos A
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
4
Issue
4
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
1f05c6a2
编写于
1月 30, 2023
作者:
O
openharmony_ci
提交者:
Gitee
1月 30, 2023
浏览文件
操作
浏览文件
下载
差异文件
!1101 feat: 支持unshare
Merge pull request !1101 from zhushengle/unshare
上级
1d1f1b06
325b4a49
变更
31
显示空白变更内容
内联
并排
Showing
31 changed file
with
1108 addition
and
95 deletion
+1108
-95
fs/proc/os_adapt/process_proc.c
fs/proc/os_adapt/process_proc.c
+2
-2
kernel/base/container/los_container.c
kernel/base/container/los_container.c
+179
-27
kernel/base/container/los_ipc_container.c
kernel/base/container/los_ipc_container.c
+29
-5
kernel/base/container/los_mnt_container.c
kernel/base/container/los_mnt_container.c
+36
-5
kernel/base/container/los_pid_container.c
kernel/base/container/los_pid_container.c
+49
-5
kernel/base/container/los_time_container.c
kernel/base/container/los_time_container.c
+56
-11
kernel/base/container/los_uts_container.c
kernel/base/container/los_uts_container.c
+31
-5
kernel/base/core/los_process.c
kernel/base/core/los_process.c
+7
-7
kernel/base/include/los_container_pri.h
kernel/base/include/los_container_pri.h
+4
-1
kernel/base/include/los_ipc_container_pri.h
kernel/base/include/los_ipc_container_pri.h
+4
-1
kernel/base/include/los_mnt_container_pri.h
kernel/base/include/los_mnt_container_pri.h
+4
-1
kernel/base/include/los_pid_container_pri.h
kernel/base/include/los_pid_container_pri.h
+3
-0
kernel/base/include/los_process_pri.h
kernel/base/include/los_process_pri.h
+1
-1
kernel/base/include/los_time_container_pri.h
kernel/base/include/los_time_container_pri.h
+3
-0
kernel/base/include/los_uts_container_pri.h
kernel/base/include/los_uts_container_pri.h
+5
-1
syscall/los_syscall.h
syscall/los_syscall.h
+1
-0
syscall/process_syscall.c
syscall/process_syscall.c
+9
-0
syscall/syscall_lookup.h
syscall/syscall_lookup.h
+1
-0
testsuites/unittest/container/It_container_test.cpp
testsuites/unittest/container/It_container_test.cpp
+148
-16
testsuites/unittest/container/It_container_test.h
testsuites/unittest/container/It_container_test.h
+3
-0
testsuites/unittest/container/config.gni
testsuites/unittest/container/config.gni
+3
-0
testsuites/unittest/container/smoke/It_ipc_container_003.cpp
testsuites/unittest/container/smoke/It_ipc_container_003.cpp
+13
-1
testsuites/unittest/container/smoke/It_mnt_container_005.cpp
testsuites/unittest/container/smoke/It_mnt_container_005.cpp
+19
-1
testsuites/unittest/container/smoke/It_pid_container_027.cpp
testsuites/unittest/container/smoke/It_pid_container_027.cpp
+148
-0
testsuites/unittest/container/smoke/It_pid_container_028.cpp
testsuites/unittest/container/smoke/It_pid_container_028.cpp
+146
-0
testsuites/unittest/container/smoke/It_time_container_002.cpp
...suites/unittest/container/smoke/It_time_container_002.cpp
+27
-1
testsuites/unittest/container/smoke/It_time_container_003.cpp
...suites/unittest/container/smoke/It_time_container_003.cpp
+20
-1
testsuites/unittest/container/smoke/It_time_container_004.cpp
...suites/unittest/container/smoke/It_time_container_004.cpp
+20
-1
testsuites/unittest/container/smoke/It_time_container_005.cpp
...suites/unittest/container/smoke/It_time_container_005.cpp
+20
-1
testsuites/unittest/container/smoke/It_time_container_008.cpp
...suites/unittest/container/smoke/It_time_container_008.cpp
+20
-1
testsuites/unittest/container/smoke/It_uts_container_004.cpp
testsuites/unittest/container/smoke/It_uts_container_004.cpp
+97
-0
未找到文件。
fs/proc/os_adapt/process_proc.c
浏览文件 @
1f05c6a2
...
...
@@ -212,7 +212,7 @@ static int ProcSetTimensOffset(const char *buf, LosProcessCB *processCB)
char
*
endptr
=
NULL
;
offsets
.
tv_sec
=
strtoll
(
buf
,
&
endptr
,
DECIMAL_BASE
);
offsets
.
tv_sec
=
strtoll
(
endptr
,
NULL
,
DECIMAL_BASE
);
offsets
.
tv_
n
sec
=
strtoll
(
endptr
,
NULL
,
DECIMAL_BASE
);
if
(
offsets
.
tv_nsec
>=
OS_SYS_NS_PER_SECOND
)
{
return
-
EACCES
;
}
...
...
@@ -308,7 +308,7 @@ static const struct ProcFileOperations PID_FOPS = {
static
struct
ProcProcess
g_procProcess
[]
=
{
{
.
name
=
NULL
,
.
mode
=
S_IFDIR
|
S_IR
USR
|
S_IXUSR
|
S_IRGRP
|
S_IXGRP
|
S_IROTH
|
S_IX
OTH
,
.
mode
=
S_IFDIR
|
S_IR
WXU
|
S_IRWXG
|
S_IR
OTH
,
.
type
=
PROC_PID
,
.
fileOps
=
&
PID_FOPS
...
...
kernel/base/container/los_container.c
浏览文件 @
1f05c6a2
...
...
@@ -84,27 +84,9 @@ STATIC INLINE Container *CreateContainer(VOID)
return
container
;
}
/*
* called from clone. This now handles copy for Container and all
* namespaces therein.
*/
UINT32
OsCopyContainers
(
UINTPTR
flags
,
LosProcessCB
*
child
,
LosProcessCB
*
parent
,
UINT32
*
processID
)
STATIC
UINT32
CopyContainers
(
UINTPTR
flags
,
LosProcessCB
*
child
,
LosProcessCB
*
parent
,
UINT32
*
processID
)
{
UINT32
intSave
;
UINT32
ret
=
LOS_OK
;
if
(
!
(
flags
&
(
CLONE_NEWNS
|
CLONE_NEWUTS
|
CLONE_NEWIPC
|
CLONE_NEWPID
|
CLONE_NEWNET
|
CLONE_NEWTIME
)))
{
SCHEDULER_LOCK
(
intSave
);
child
->
container
=
parent
->
container
;
LOS_AtomicInc
(
&
child
->
container
->
rc
);
SCHEDULER_UNLOCK
(
intSave
);
}
else
{
child
->
container
=
CreateContainer
();
if
(
child
->
container
==
NULL
)
{
return
ENOMEM
;
}
}
/* Pid container initialization must precede other container initialization. */
#ifdef LOSCFG_PID_CONTAINER
ret
=
OsCopyPidContainer
(
flags
,
child
,
parent
,
processID
);
...
...
@@ -139,6 +121,58 @@ UINT32 OsCopyContainers(UINTPTR flags, LosProcessCB *child, LosProcessCB *parent
return
ret
;
}
/*
* called from clone. This now handles copy for Container and all
* namespaces therein.
*/
UINT32
OsCopyContainers
(
UINTPTR
flags
,
LosProcessCB
*
child
,
LosProcessCB
*
parent
,
UINT32
*
processID
)
{
UINT32
intSave
;
if
(
!
(
flags
&
(
CLONE_NEWNS
|
CLONE_NEWUTS
|
CLONE_NEWIPC
|
CLONE_NEWPID
|
CLONE_NEWNET
|
CLONE_NEWTIME
)))
{
#ifdef LOSCFG_PID_CONTAINER
if
(
parent
->
container
->
pidContainer
!=
parent
->
container
->
pidForChildContainer
)
{
goto
CREATE_CONTAINER
;
}
#endif
#ifdef LOSCFG_TIME_CONTAINER
if
(
parent
->
container
->
timeContainer
!=
parent
->
container
->
timeForChildContainer
)
{
goto
CREATE_CONTAINER
;
}
#endif
SCHEDULER_LOCK
(
intSave
);
child
->
container
=
parent
->
container
;
LOS_AtomicInc
(
&
child
->
container
->
rc
);
SCHEDULER_UNLOCK
(
intSave
);
goto
COPY_CONTAINERS
;
}
#if defined(LOSCFG_PID_CONTAINER) || defined(LOSCFG_TIME_CONTAINER)
CREATE_CONTAINER:
#endif
child
->
container
=
CreateContainer
();
if
(
child
->
container
==
NULL
)
{
return
ENOMEM
;
}
COPY_CONTAINERS:
return
CopyContainers
(
flags
,
child
,
parent
,
processID
);
}
#ifndef LOSCFG_PID_CONTAINER
STATIC
VOID
ContainersFree
(
LosProcessCB
*
processCB
)
{
UINT32
intSave
;
SCHEDULER_LOCK
(
intSave
);
LOS_AtomicDec
(
&
processCB
->
container
->
rc
);
if
(
LOS_AtomicRead
(
&
processCB
->
container
->
rc
)
==
0
)
{
(
VOID
)
LOS_MemFree
(
m_aucSysMem1
,
processCB
->
container
);
processCB
->
container
=
NULL
;
}
SCHEDULER_UNLOCK
(
intSave
);
}
#endif
VOID
OsContainersDestroy
(
LosProcessCB
*
processCB
)
{
/* All processes in the container must be destroyed before the container is destroyed. */
...
...
@@ -149,15 +183,15 @@ VOID OsContainersDestroy(LosProcessCB *processCB)
#endif
#ifdef LOSCFG_UTS_CONTAINER
OsUtsContainersDestroy
(
processCB
);
OsUtsContainersDestroy
(
processCB
->
container
);
#endif
#ifdef LOSCFG_MNT_CONTAINER
OsMntContainersDestroy
(
processCB
);
OsMntContainersDestroy
(
processCB
->
container
);
#endif
#ifdef LOSCFG_IPC_CONTAINER
OsIpcContainersDestroy
(
processCB
);
OsIpcContainersDestroy
(
processCB
->
container
);
#endif
#ifdef LOSCFG_TIME_CONTAINER
...
...
@@ -165,11 +199,7 @@ VOID OsContainersDestroy(LosProcessCB *processCB)
#endif
#ifndef LOSCFG_PID_CONTAINER
LOS_AtomicDec
(
&
curr
->
container
->
rc
);
if
(
LOS_AtomicRead
(
&
processCB
->
container
->
rc
)
==
0
)
{
(
VOID
)
LOS_MemFree
(
m_aucSysMem1
,
processCB
->
container
);
processCB
->
container
=
NULL
;
}
ContainersFree
(
processCB
);
#endif
}
...
...
@@ -209,4 +239,126 @@ UINT32 OsGetContainerID(Container *container, ContainerType type)
}
return
OS_INVALID_VALUE
;
}
STATIC
VOID
UnshareDeinitContainerCommon
(
UINT32
flags
,
Container
*
container
)
{
#ifdef LOSCFG_UTS_CONTAINER
if
((
flags
&
CLONE_NEWUTS
)
!=
0
)
{
OsUtsContainersDestroy
(
container
);
}
#endif
#ifdef LOSCFG_MNT_CONTAINER
if
((
flags
&
CLONE_NEWNS
)
!=
0
)
{
OsMntContainersDestroy
(
container
);
}
#endif
#ifdef LOSCFG_IPC_CONTAINER
if
((
flags
&
CLONE_NEWIPC
)
!=
0
)
{
OsIpcContainersDestroy
(
container
);
}
#endif
}
STATIC
VOID
UnshareDeinitContainer
(
UINT32
flags
,
Container
*
container
)
{
if
(
container
==
NULL
)
{
return
;
}
#ifdef LOSCFG_PID_CONTAINER
if
((
container
->
pidForChildContainer
!=
NULL
)
&&
(
container
->
pidForChildContainer
!=
container
->
pidContainer
))
{
(
VOID
)
LOS_MemFree
(
m_aucSysMem1
,
container
->
pidForChildContainer
);
container
->
pidForChildContainer
=
NULL
;
container
->
pidContainer
=
NULL
;
}
#endif
UnshareDeinitContainerCommon
(
flags
,
container
);
#ifdef LOSCFG_TIME_CONTAINER
if
((
container
->
timeForChildContainer
!=
NULL
)
&&
(
container
->
timeForChildContainer
!=
container
->
timeContainer
))
{
(
VOID
)
LOS_MemFree
(
m_aucSysMem1
,
container
->
timeForChildContainer
);
container
->
timeForChildContainer
=
NULL
;
container
->
timeContainer
=
NULL
;
}
#endif
(
VOID
)
LOS_MemFree
(
m_aucSysMem1
,
container
);
}
STATIC
UINT32
CreateNewContainers
(
UINT32
flags
,
LosProcessCB
*
curr
,
Container
*
newContainer
)
{
UINT32
ret
=
LOS_OK
;
#ifdef LOSCFG_PID_CONTAINER
ret
=
OsUnsharePidContainer
(
flags
,
curr
,
newContainer
);
if
(
ret
!=
LOS_OK
)
{
return
ret
;
}
#endif
#ifdef LOSCFG_UTS_CONTAINER
ret
=
OsUnshareUtsContainer
(
flags
,
curr
,
newContainer
);
if
(
ret
!=
LOS_OK
)
{
return
ret
;
}
#endif
#ifdef LOSCFG_MNT_CONTAINER
ret
=
OsUnshareMntContainer
(
flags
,
curr
,
newContainer
);
if
(
ret
!=
LOS_OK
)
{
return
ret
;
}
#endif
#ifdef LOSCFG_IPC_CONTAINER
ret
=
OsUnshareIpcContainer
(
flags
,
curr
,
newContainer
);
if
(
ret
!=
LOS_OK
)
{
return
ret
;
}
#endif
#ifdef LOSCFG_TIME_CONTAINER
ret
=
OsUnshareTimeContainer
(
flags
,
curr
,
newContainer
);
if
(
ret
!=
LOS_OK
)
{
return
ret
;
}
#endif
return
ret
;
}
INT32
OsUnshare
(
UINT32
flags
)
{
UINT32
ret
;
UINT32
intSave
;
LosProcessCB
*
curr
=
OsCurrProcessGet
();
Container
*
oldContainer
=
curr
->
container
;
if
(
!
(
flags
&
(
CLONE_NEWPID
|
CLONE_NEWTIME
|
CLONE_NEWUTS
|
CLONE_NEWNS
|
CLONE_NEWIPC
)))
{
return
-
EINVAL
;
}
Container
*
newContainer
=
CreateContainer
();
if
(
newContainer
==
NULL
)
{
return
-
ENOMEM
;
}
ret
=
CreateNewContainers
(
flags
,
curr
,
newContainer
);
if
(
ret
!=
LOS_OK
)
{
goto
EXIT
;
}
SCHEDULER_LOCK
(
intSave
);
oldContainer
=
curr
->
container
;
curr
->
container
=
newContainer
;
SCHEDULER_UNLOCK
(
intSave
);
UnshareDeinitContainerCommon
(
flags
,
oldContainer
);
SCHEDULER_LOCK
(
intSave
);
LOS_AtomicDec
(
&
oldContainer
->
rc
);
if
(
LOS_AtomicRead
(
&
oldContainer
->
rc
)
==
0
)
{
(
VOID
)
LOS_MemFree
(
m_aucSysMem1
,
oldContainer
);
}
SCHEDULER_UNLOCK
(
intSave
);
return
LOS_OK
;
EXIT:
UnshareDeinitContainer
(
flags
,
newContainer
);
return
-
ret
;
}
#endif
kernel/base/container/los_ipc_container.c
浏览文件 @
1f05c6a2
...
...
@@ -124,22 +124,46 @@ UINT32 OsCopyIpcContainer(UINTPTR flags, LosProcessCB *child, LosProcessCB *pare
return
CreateIpcContainer
(
child
,
parent
);
}
VOID
OsIpcContainersDestroy
(
LosProcessCB
*
cur
r
)
UINT32
OsUnshareIpcContainer
(
UINTPTR
flags
,
LosProcessCB
*
curr
,
Container
*
newContaine
r
)
{
UINT32
intSave
;
if
(
curr
->
container
==
NULL
)
{
IpcContainer
*
parentContainer
=
curr
->
container
->
ipcContainer
;
if
(
!
(
flags
&
CLONE_NEWIPC
))
{
SCHEDULER_LOCK
(
intSave
);
newContainer
->
ipcContainer
=
parentContainer
;
SCHEDULER_UNLOCK
(
intSave
);
return
LOS_OK
;
}
IpcContainer
*
ipcContainer
=
CreateNewIpcContainer
(
parentContainer
);
if
(
ipcContainer
==
NULL
)
{
return
ENOMEM
;
}
SCHEDULER_LOCK
(
intSave
);
newContainer
->
ipcContainer
=
ipcContainer
;
g_currentIpcContainerNum
++
;
SCHEDULER_UNLOCK
(
intSave
);
return
LOS_OK
;
}
VOID
OsIpcContainersDestroy
(
Container
*
container
)
{
UINT32
intSave
;
if
(
container
==
NULL
)
{
return
;
}
SCHEDULER_LOCK
(
intSave
);
IpcContainer
*
ipcContainer
=
c
urr
->
c
ontainer
->
ipcContainer
;
IpcContainer
*
ipcContainer
=
container
->
ipcContainer
;
if
(
ipcContainer
!=
NULL
)
{
LOS_AtomicDec
(
&
ipcContainer
->
rc
);
if
(
LOS_AtomicRead
(
&
ipcContainer
->
rc
)
=
=
0
)
{
if
(
LOS_AtomicRead
(
&
ipcContainer
->
rc
)
<
=
0
)
{
g_currentIpcContainerNum
--
;
SCHEDULER_UNLOCK
(
intSave
);
ShmDeinit
();
c
urr
->
c
ontainer
->
ipcContainer
=
NULL
;
container
->
ipcContainer
=
NULL
;
(
VOID
)
LOS_MemFree
(
m_aucSysMem1
,
ipcContainer
->
allQueue
);
(
VOID
)
LOS_MemFree
(
m_aucSysMem1
,
ipcContainer
);
return
;
...
...
kernel/base/container/los_mnt_container.c
浏览文件 @
1f05c6a2
...
...
@@ -132,6 +132,37 @@ UINT32 OsCopyMntContainer(UINTPTR flags, LosProcessCB *child, LosProcessCB *pare
return
CopyMountList
(
currMntContainer
,
child
->
container
->
mntContainer
);
}
UINT32
OsUnshareMntContainer
(
UINTPTR
flags
,
LosProcessCB
*
curr
,
Container
*
newContainer
)
{
UINT32
intSave
;
UINT32
ret
;
MntContainer
*
parentContainer
=
curr
->
container
->
mntContainer
;
if
(
!
(
flags
&
CLONE_NEWNS
))
{
SCHEDULER_LOCK
(
intSave
);
newContainer
->
mntContainer
=
parentContainer
;
SCHEDULER_UNLOCK
(
intSave
);
return
LOS_OK
;
}
MntContainer
*
mntContainer
=
CreateNewMntContainer
(
parentContainer
);
if
(
mntContainer
==
NULL
)
{
return
ENOMEM
;
}
ret
=
CopyMountList
(
parentContainer
,
mntContainer
);
if
(
ret
!=
LOS_OK
)
{
(
VOID
)
LOS_MemFree
(
m_aucSysMem1
,
mntContainer
);
return
ret
;
}
SCHEDULER_LOCK
(
intSave
);
newContainer
->
mntContainer
=
mntContainer
;
g_currentMntContainerNum
++
;
SCHEDULER_UNLOCK
(
intSave
);
return
LOS_OK
;
}
STATIC
VOID
FreeMountList
(
LIST_HEAD
*
mountList
)
{
struct
Mount
*
mnt
=
NULL
;
...
...
@@ -156,22 +187,22 @@ STATIC VOID FreeMountList(LIST_HEAD *mountList)
return
;
}
VOID
OsMntContainersDestroy
(
LosProcessCB
*
cur
r
)
VOID
OsMntContainersDestroy
(
Container
*
containe
r
)
{
UINT32
intSave
;
if
(
c
urr
->
c
ontainer
==
NULL
)
{
if
(
container
==
NULL
)
{
return
;
}
SCHEDULER_LOCK
(
intSave
);
MntContainer
*
mntContainer
=
c
urr
->
c
ontainer
->
mntContainer
;
MntContainer
*
mntContainer
=
container
->
mntContainer
;
if
(
mntContainer
!=
NULL
)
{
LOS_AtomicDec
(
&
mntContainer
->
rc
);
if
(
LOS_AtomicRead
(
&
mntContainer
->
rc
)
=
=
0
)
{
if
(
LOS_AtomicRead
(
&
mntContainer
->
rc
)
<
=
0
)
{
g_currentMntContainerNum
--
;
SCHEDULER_UNLOCK
(
intSave
);
FreeMountList
(
&
mntContainer
->
mountList
);
c
urr
->
c
ontainer
->
mntContainer
=
NULL
;
container
->
mntContainer
=
NULL
;
(
VOID
)
LOS_MemFree
(
m_aucSysMem1
,
mntContainer
);
return
;
}
...
...
kernel/base/container/los_pid_container.c
浏览文件 @
1f05c6a2
...
...
@@ -274,11 +274,16 @@ STATIC UINT32 CreatePidContainer(LosProcessCB *child, LosProcessCB *parent)
{
UINT32
intSave
;
UINT32
ret
;
PidContainer
*
newPidContainer
=
NULL
;
PidContainer
*
parentContainer
=
parent
->
container
->
pidContainer
;
PidContainer
*
newPidContainer
=
CreateNewPidContainer
(
parentContainer
);
if
(
parentContainer
==
parent
->
container
->
pidForChildContainer
)
{
newPidContainer
=
CreateNewPidContainer
(
parentContainer
);
if
(
newPidContainer
==
NULL
)
{
return
ENOMEM
;
}
}
else
{
newPidContainer
=
parent
->
container
->
pidForChildContainer
;
}
SCHEDULER_LOCK
(
intSave
);
if
((
parentContainer
->
level
+
1
)
>=
PID_CONTAINER_LEVEL_LIMIT
)
{
...
...
@@ -312,8 +317,12 @@ VOID OsPidContainersDestroy(LosProcessCB *curr)
PidContainer
*
pidContainer
=
curr
->
container
->
pidContainer
;
if
(
pidContainer
!=
NULL
)
{
FreeVpid
(
curr
);
if
(
LOS_AtomicRead
(
&
pidContainer
->
rc
)
=
=
0
)
{
if
(
LOS_AtomicRead
(
&
pidContainer
->
rc
)
<
=
0
)
{
g_currentPidContainerNum
--
;
if
((
pidContainer
!=
curr
->
container
->
pidForChildContainer
)
&&
(
LOS_AtomicRead
(
&
curr
->
container
->
pidForChildContainer
->
rc
)
<=
0
))
{
(
VOID
)
LOS_MemFree
(
m_aucSysMem1
,
curr
->
container
->
pidForChildContainer
);
}
curr
->
container
->
pidContainer
=
NULL
;
curr
->
container
->
pidForChildContainer
=
NULL
;
(
VOID
)
LOS_MemFree
(
m_aucSysMem1
,
pidContainer
);
...
...
@@ -332,7 +341,7 @@ UINT32 OsCopyPidContainer(UINTPTR flags, LosProcessCB *child, LosProcessCB *pare
UINT32
ret
;
UINT32
intSave
;
if
(
!
(
flags
&
CLONE_NEWPID
))
{
if
(
!
(
flags
&
CLONE_NEWPID
)
&&
(
parent
->
container
->
pidContainer
==
parent
->
container
->
pidForChildContainer
)
)
{
SCHEDULER_LOCK
(
intSave
);
child
->
container
->
pidContainer
=
parent
->
container
->
pidContainer
;
child
->
container
->
pidForChildContainer
=
parent
->
container
->
pidContainer
;
...
...
@@ -360,6 +369,41 @@ UINT32 OsCopyPidContainer(UINTPTR flags, LosProcessCB *child, LosProcessCB *pare
return
LOS_OK
;
}
UINT32
OsUnsharePidContainer
(
UINTPTR
flags
,
LosProcessCB
*
curr
,
Container
*
newContainer
)
{
UINT32
intSave
;
if
(
!
(
flags
&
CLONE_NEWPID
))
{
SCHEDULER_LOCK
(
intSave
);
newContainer
->
pidContainer
=
curr
->
container
->
pidContainer
;
newContainer
->
pidForChildContainer
=
curr
->
container
->
pidContainer
;
SCHEDULER_UNLOCK
(
intSave
);
return
LOS_OK
;
}
PidContainer
*
pidForChild
=
CreateNewPidContainer
(
curr
->
container
->
pidContainer
);
if
(
pidForChild
==
NULL
)
{
return
ENOMEM
;
}
SCHEDULER_LOCK
(
intSave
);
if
(
curr
->
container
->
pidContainer
!=
curr
->
container
->
pidForChildContainer
)
{
SCHEDULER_UNLOCK
(
intSave
);
(
VOID
)
LOS_MemFree
(
m_aucSysMem1
,
pidForChild
);
return
EINVAL
;
}
if
(
pidForChild
->
level
>=
PID_CONTAINER_LEVEL_LIMIT
)
{
SCHEDULER_UNLOCK
(
intSave
);
(
VOID
)
LOS_MemFree
(
m_aucSysMem1
,
pidForChild
);
return
EINVAL
;
}
newContainer
->
pidContainer
=
curr
->
container
->
pidContainer
;
newContainer
->
pidForChildContainer
=
pidForChild
;
SCHEDULER_UNLOCK
(
intSave
);
return
LOS_OK
;
}
UINT32
OsInitRootPidContainer
(
PidContainer
**
pidContainer
)
{
UINT32
intSave
;
...
...
kernel/base/container/los_time_container.c
浏览文件 @
1f05c6a2
...
...
@@ -57,6 +57,7 @@ STATIC UINT32 CreateTimeContainer(LosProcessCB *child, LosProcessCB *parent)
{
UINT32
intSave
;
TimeContainer
*
parentContainer
=
parent
->
container
->
timeContainer
;
if
(
parentContainer
==
parent
->
container
->
timeForChildContainer
)
{
TimeContainer
*
newTimeContainer
=
CreateNewTimeContainer
(
parentContainer
);
if
(
newTimeContainer
==
NULL
)
{
return
ENOMEM
;
...
...
@@ -70,6 +71,19 @@ STATIC UINT32 CreateTimeContainer(LosProcessCB *child, LosProcessCB *parent)
child
->
container
->
timeForChildContainer
=
newTimeContainer
;
SCHEDULER_UNLOCK
(
intSave
);
return
LOS_OK
;
}
SCHEDULER_LOCK
(
intSave
);
TimeContainer
*
newTimeContainer
=
parent
->
container
->
timeForChildContainer
;
g_currentTimeContainerNum
++
;
LOS_AtomicSet
(
&
newTimeContainer
->
rc
,
1
);
if
(
!
newTimeContainer
->
frozenOffsets
)
{
newTimeContainer
->
frozenOffsets
=
TRUE
;
}
child
->
container
->
timeContainer
=
newTimeContainer
;
child
->
container
->
timeForChildContainer
=
newTimeContainer
;
SCHEDULER_UNLOCK
(
intSave
);
return
LOS_OK
;
}
UINT32
OsInitRootTimeContainer
(
TimeContainer
**
timeContainer
)
...
...
@@ -92,11 +106,8 @@ UINT32 OsCopyTimeContainer(UINTPTR flags, LosProcessCB *child, LosProcessCB *par
UINT32
intSave
;
TimeContainer
*
currTimeContainer
=
parent
->
container
->
timeContainer
;
if
(
!
(
flags
&
CLONE_NEWTIME
))
{
if
(
!
(
flags
&
CLONE_NEWTIME
)
&&
(
currTimeContainer
==
parent
->
container
->
timeForChildContainer
)
)
{
SCHEDULER_LOCK
(
intSave
);
if
(
!
currTimeContainer
->
frozenOffsets
)
{
currTimeContainer
->
frozenOffsets
=
TRUE
;
}
LOS_AtomicInc
(
&
currTimeContainer
->
rc
);
child
->
container
->
timeContainer
=
currTimeContainer
;
child
->
container
->
timeForChildContainer
=
currTimeContainer
;
...
...
@@ -107,6 +118,36 @@ UINT32 OsCopyTimeContainer(UINTPTR flags, LosProcessCB *child, LosProcessCB *par
return
CreateTimeContainer
(
child
,
parent
);
}
UINT32
OsUnshareTimeContainer
(
UINTPTR
flags
,
LosProcessCB
*
curr
,
Container
*
newContainer
)
{
UINT32
intSave
;
if
(
!
(
flags
&
CLONE_NEWTIME
))
{
SCHEDULER_LOCK
(
intSave
);
newContainer
->
timeContainer
=
curr
->
container
->
timeContainer
;
newContainer
->
timeForChildContainer
=
curr
->
container
->
timeForChildContainer
;
SCHEDULER_UNLOCK
(
intSave
);
return
LOS_OK
;
}
TimeContainer
*
timeForChild
=
CreateNewTimeContainer
(
curr
->
container
->
timeContainer
);
if
(
timeForChild
==
NULL
)
{
return
ENOMEM
;
}
SCHEDULER_LOCK
(
intSave
);
if
(
curr
->
container
->
timeContainer
!=
curr
->
container
->
timeForChildContainer
)
{
SCHEDULER_UNLOCK
(
intSave
);
(
VOID
)
LOS_MemFree
(
m_aucSysMem1
,
timeForChild
);
return
EINVAL
;
}
newContainer
->
timeContainer
=
curr
->
container
->
timeContainer
;
newContainer
->
timeForChildContainer
=
timeForChild
;
LOS_AtomicSet
(
&
timeForChild
->
rc
,
0
);
SCHEDULER_UNLOCK
(
intSave
);
return
LOS_OK
;
}
VOID
OsTimeContainersDestroy
(
LosProcessCB
*
curr
)
{
UINT32
intSave
;
...
...
@@ -118,11 +159,15 @@ VOID OsTimeContainersDestroy(LosProcessCB *curr)
TimeContainer
*
timeContainer
=
curr
->
container
->
timeContainer
;
if
(
timeContainer
!=
NULL
)
{
LOS_AtomicDec
(
&
timeContainer
->
rc
);
if
(
LOS_AtomicRead
(
&
timeContainer
->
rc
)
=
=
0
)
{
if
(
LOS_AtomicRead
(
&
timeContainer
->
rc
)
<
=
0
)
{
g_currentTimeContainerNum
--
;
curr
->
container
->
timeContainer
=
NULL
;
curr
->
container
->
timeForChildContainer
=
NULL
;
SCHEDULER_UNLOCK
(
intSave
);
if
((
timeContainer
!=
curr
->
container
->
timeForChildContainer
)
&&
(
LOS_AtomicRead
(
&
curr
->
container
->
timeForChildContainer
->
rc
)
<=
0
))
{
(
VOID
)
LOS_MemFree
(
m_aucSysMem1
,
curr
->
container
->
timeForChildContainer
);
}
curr
->
container
->
timeForChildContainer
=
NULL
;
(
VOID
)
LOS_MemFree
(
m_aucSysMem1
,
timeContainer
);
return
;
}
...
...
kernel/base/container/los_uts_container.c
浏览文件 @
1f05c6a2
...
...
@@ -138,20 +138,46 @@ UINT32 OsCopyUtsContainer(UINTPTR flags, LosProcessCB *child, LosProcessCB *pare
return
CreateUtsContainer
(
child
,
parent
);
}
VOID
OsUtsContainersDestroy
(
LosProcessCB
*
cur
r
)
UINT32
OsUnshareUtsContainer
(
UINTPTR
flags
,
LosProcessCB
*
curr
,
Container
*
newContaine
r
)
{
UINT32
intSave
;
if
(
curr
->
container
==
NULL
)
{
UtsContainer
*
parentContainer
=
curr
->
container
->
utsContainer
;
if
(
!
(
flags
&
CLONE_NEWUTS
))
{
SCHEDULER_LOCK
(
intSave
);
newContainer
->
utsContainer
=
parentContainer
;
SCHEDULER_UNLOCK
(
intSave
);
return
LOS_OK
;
}
UtsContainer
*
utsContainer
=
CreateNewUtsContainer
(
parentContainer
);
if
(
utsContainer
==
NULL
)
{
return
ENOMEM
;
}
SCHEDULER_LOCK
(
intSave
);
newContainer
->
utsContainer
=
utsContainer
;
g_currentUtsContainerNum
++
;
(
VOID
)
memcpy_s
(
&
utsContainer
->
utsName
,
sizeof
(
utsContainer
->
utsName
),
&
parentContainer
->
utsName
,
sizeof
(
parentContainer
->
utsName
));
SCHEDULER_UNLOCK
(
intSave
);
return
LOS_OK
;
}
VOID
OsUtsContainersDestroy
(
Container
*
container
)
{
UINT32
intSave
;
if
(
container
==
NULL
)
{
return
;
}
SCHEDULER_LOCK
(
intSave
);
UtsContainer
*
utsContainer
=
c
urr
->
c
ontainer
->
utsContainer
;
UtsContainer
*
utsContainer
=
container
->
utsContainer
;
if
(
utsContainer
!=
NULL
)
{
LOS_AtomicDec
(
&
utsContainer
->
rc
);
if
(
LOS_AtomicRead
(
&
utsContainer
->
rc
)
=
=
0
)
{
if
(
LOS_AtomicRead
(
&
utsContainer
->
rc
)
<
=
0
)
{
g_currentUtsContainerNum
--
;
c
urr
->
c
ontainer
->
utsContainer
=
NULL
;
container
->
utsContainer
=
NULL
;
SCHEDULER_UNLOCK
(
intSave
);
(
VOID
)
LOS_MemFree
(
m_aucSysMem1
,
utsContainer
);
return
;
...
...
kernel/base/core/los_process.c
浏览文件 @
1f05c6a2
...
...
@@ -398,13 +398,6 @@ LITE_OS_SEC_TEXT VOID OsProcessResourcesToFree(LosProcessCB *processCB)
}
#endif
#ifdef LOSCFG_FS_VFS
if
(
OsProcessIsUserMode
(
processCB
))
{
delete_files
(
processCB
->
files
);
}
processCB
->
files
=
NULL
;
#endif
#ifdef LOSCFG_SECURITY_CAPABILITY
if
(
processCB
->
user
!=
NULL
)
{
(
VOID
)
LOS_MemFree
(
m_aucSysMem1
,
processCB
->
user
);
...
...
@@ -446,6 +439,13 @@ LITE_OS_SEC_TEXT VOID OsProcessResourcesToFree(LosProcessCB *processCB)
OsContainersDestroy
(
processCB
);
#endif
#ifdef LOSCFG_FS_VFS
if
(
OsProcessIsUserMode
(
processCB
))
{
delete_files
(
processCB
->
files
);
}
processCB
->
files
=
NULL
;
#endif
if
(
processCB
->
resourceLimit
!=
NULL
)
{
(
VOID
)
LOS_MemFree
((
VOID
*
)
m_aucSysMem0
,
processCB
->
resourceLimit
);
processCB
->
resourceLimit
=
NULL
;
...
...
kernel/base/include/los_container_pri.h
浏览文件 @
1f05c6a2
...
...
@@ -75,7 +75,7 @@ typedef struct Container {
#ifdef LOSCFG_IPC_CONTAINER
struct
IpcContainer
*
ipcContainer
;
#endif
#ifdef LOSCFG_
IPC
_CONTAINER
#ifdef LOSCFG_
TIME
_CONTAINER
struct
TimeContainer
*
timeContainer
;
struct
TimeContainer
*
timeForChildContainer
;
#endif
...
...
@@ -92,5 +92,8 @@ VOID OsContainersDestroy(LosProcessCB *processCB);
UINT32
OsAllocContainerID
(
VOID
);
UINT32
OsGetContainerID
(
Container
*
container
,
ContainerType
type
);
INT32
OsUnshare
(
UINT32
flags
);
#endif
#endif
/* _LOS_CONTAINER_PRI_H */
kernel/base/include/los_ipc_container_pri.h
浏览文件 @
1f05c6a2
...
...
@@ -37,6 +37,7 @@
#ifdef LOSCFG_IPC_CONTAINER
struct
shmIDSource
;
struct
Container
;
typedef
struct
TagQueueCB
LosQueueCB
;
typedef
struct
OsMux
LosMux
;
typedef
LosMux
pthread_mutex_t
;
...
...
@@ -61,7 +62,9 @@ UINT32 OsInitRootIpcContainer(IpcContainer **ipcContainer);
UINT32
OsCopyIpcContainer
(
UINTPTR
flags
,
LosProcessCB
*
child
,
LosProcessCB
*
parent
);
VOID
OsIpcContainersDestroy
(
LosProcessCB
*
curr
);
UINT32
OsUnshareIpcContainer
(
UINTPTR
flags
,
LosProcessCB
*
curr
,
struct
Container
*
newContainer
);
VOID
OsIpcContainersDestroy
(
struct
Container
*
container
);
UINT32
OsGetIpcContainerID
(
IpcContainer
*
ipcContainer
);
...
...
kernel/base/include/los_mnt_container_pri.h
浏览文件 @
1f05c6a2
...
...
@@ -39,6 +39,7 @@
#ifdef LOSCFG_MNT_CONTAINER
typedef
struct
ProcessCB
LosProcessCB
;
struct
Container
;
typedef
struct
MntContainer
{
Atomic
rc
;
...
...
@@ -52,7 +53,9 @@ UINT32 OsInitRootMntContainer(MntContainer **mntContainer);
UINT32
OsCopyMntContainer
(
UINTPTR
flags
,
LosProcessCB
*
child
,
LosProcessCB
*
parent
);
VOID
OsMntContainersDestroy
(
LosProcessCB
*
curr
);
UINT32
OsUnshareMntContainer
(
UINTPTR
flags
,
LosProcessCB
*
curr
,
struct
Container
*
newContainer
);
VOID
OsMntContainersDestroy
(
struct
Container
*
container
);
UINT32
OsGetMntContainerID
(
MntContainer
*
mntContainer
);
...
...
kernel/base/include/los_pid_container_pri.h
浏览文件 @
1f05c6a2
...
...
@@ -37,6 +37,7 @@
typedef
struct
TagTaskCB
LosTaskCB
;
typedef
struct
ProcessCB
LosProcessCB
;
struct
ProcessGroup
;
struct
Container
;
typedef
struct
{
UINT32
vid
;
/* Virtual ID */
...
...
@@ -75,6 +76,8 @@ VOID OsPidContainersDestroy(LosProcessCB *curr);
UINT32
OsCopyPidContainer
(
UINTPTR
flags
,
LosProcessCB
*
child
,
LosProcessCB
*
parent
,
UINT32
*
processID
);
UINT32
OsUnsharePidContainer
(
UINTPTR
flags
,
LosProcessCB
*
curr
,
struct
Container
*
newContainer
);
UINT32
OsInitRootPidContainer
(
PidContainer
**
pidContainer
);
LosProcessCB
*
OsGetPCBFromVpid
(
UINT32
vpid
);
...
...
kernel/base/include/los_process_pri.h
浏览文件 @
1f05c6a2
...
...
@@ -131,7 +131,7 @@ typedef struct ProcessCB {
#endif
struct
rlimit
*
resourceLimit
;
#ifdef LOSCFG_KERNEL_CONTAINER
struct
Container
*
container
;
Container
*
container
;
#endif
#ifdef LOSCFG_PROC_PROCESS_DIR
struct
ProcDirEntry
*
procDir
;
...
...
kernel/base/include/los_time_container_pri.h
浏览文件 @
1f05c6a2
...
...
@@ -35,6 +35,7 @@
#ifdef LOSCFG_TIME_CONTAINER
typedef
struct
ProcessCB
LosProcessCB
;
struct
Container
;
typedef
struct
TimeContainer
{
Atomic
rc
;
...
...
@@ -47,6 +48,8 @@ UINT32 OsInitRootTimeContainer(TimeContainer **timeContainer);
UINT32
OsCopyTimeContainer
(
UINTPTR
flags
,
LosProcessCB
*
child
,
LosProcessCB
*
parent
);
UINT32
OsUnshareTimeContainer
(
UINTPTR
flags
,
LosProcessCB
*
curr
,
struct
Container
*
newContainer
);
VOID
OsTimeContainersDestroy
(
LosProcessCB
*
curr
);
UINT32
OsGetTimeContainerID
(
TimeContainer
*
timeContainer
);
...
...
kernel/base/include/los_uts_container_pri.h
浏览文件 @
1f05c6a2
...
...
@@ -38,6 +38,8 @@
#ifdef LOSCFG_UTS_CONTAINER
typedef
struct
ProcessCB
LosProcessCB
;
struct
Container
;
typedef
struct
UtsContainer
{
Atomic
rc
;
UINT32
containerID
;
...
...
@@ -48,7 +50,9 @@ UINT32 OsInitRootUtsContainer(UtsContainer **utsContainer);
UINT32
OsCopyUtsContainer
(
UINTPTR
flags
,
LosProcessCB
*
child
,
LosProcessCB
*
parent
);
VOID
OsUtsContainersDestroy
(
LosProcessCB
*
curr
);
UINT32
OsUnshareUtsContainer
(
UINTPTR
flags
,
LosProcessCB
*
curr
,
struct
Container
*
newContainer
);
VOID
OsUtsContainersDestroy
(
struct
Container
*
container
);
struct
utsname
*
OsGetCurrUtsName
(
VOID
);
...
...
syscall/los_syscall.h
浏览文件 @
1f05c6a2
...
...
@@ -85,6 +85,7 @@ extern int SysWaitid(idtype_t type, int pid, USER siginfo_t *info, int options,
extern
int
SysFork
(
void
);
extern
int
SysVfork
(
void
);
extern
int
SysClone
(
int
flags
,
void
*
stack
,
int
*
parentTid
,
unsigned
long
tls
,
int
*
childTid
);
extern
int
SysUnshare
(
int
flags
);
extern
unsigned
int
SysGetPID
(
void
);
extern
unsigned
int
SysGetPPID
(
void
);
extern
int
SysSetGroupID
(
unsigned
int
gid
);
...
...
syscall/process_syscall.c
浏览文件 @
1f05c6a2
...
...
@@ -369,6 +369,15 @@ int SysClone(int flags, void *stack, int *parentTid, unsigned long tls, int *chi
return
OsClone
((
UINT32
)
flags
,
(
UINTPTR
)
stack
,
0
);
}
int
SysUnshare
(
int
flags
)
{
#ifdef LOSCFG_KERNEL_CONTAINER
return
OsUnshare
(
flags
);
#else
return
-
ENOSYS
;
#endif
}
unsigned
int
SysGetPPID
(
void
)
{
#ifdef LOSCFG_PID_CONTAINER
...
...
syscall/syscall_lookup.h
浏览文件 @
1f05c6a2
...
...
@@ -140,6 +140,7 @@ SYSCALL_HAND_DEF(__NR_exit, SysThreadExit, void, ARG_NUM_1)
SYSCALL_HAND_DEF
(
__NR_fork
,
SysFork
,
int
,
ARG_NUM_0
)
SYSCALL_HAND_DEF
(
__NR_vfork
,
SysVfork
,
int
,
ARG_NUM_0
)
SYSCALL_HAND_DEF
(
__NR_clone
,
SysClone
,
int
,
ARG_NUM_5
)
SYSCALL_HAND_DEF
(
__NR_unshare
,
SysUnshare
,
int
,
ARG_NUM_1
)
SYSCALL_HAND_DEF
(
__NR_getpid
,
SysGetPID
,
unsigned
int
,
ARG_NUM_0
)
SYSCALL_HAND_DEF
(
__NR_pause
,
SysPause
,
int
,
ARG_NUM_0
)
...
...
testsuites/unittest/container/It_container_test.cpp
浏览文件 @
1f05c6a2
...
...
@@ -74,24 +74,12 @@ std::string GenContainerLinkPath(int pid, const std::string& containerType)
std
::
string
ReadlinkContainer
(
int
pid
,
const
std
::
string
&
containerType
)
{
char
buf
[
PATH_MAX
];
char
buf
[
PATH_MAX
]
=
{
0
}
;
auto
path
=
GenContainerLinkPath
(
pid
,
containerType
);
struct
stat
sb
;
int
ret
=
lstat
(
path
.
data
(),
&
sb
);
if
(
ret
==
-
1
)
{
throw
std
::
exception
();
}
size_t
bufsiz
=
sb
.
st_size
+
1
;
if
(
sb
.
st_size
==
0
)
{
bufsiz
=
PATH_MAX
;
}
(
void
)
memset_s
(
buf
,
PATH_MAX
,
0
,
PATH_MAX
);
ssize_t
nbytes
=
readlink
(
path
.
c_str
(),
buf
,
bufsiz
);
ssize_t
nbytes
=
readlink
(
path
.
c_str
(),
buf
,
PATH_MAX
);
if
(
nbytes
==
-
1
)
{
throw
std
::
exception
();
printf
(
"pid %d, ReadlinkContainer readlink %s failed, errno=%d
\n
"
,
getpid
(),
path
.
c_str
(),
errno
);
return
path
.
c_str
();
}
return
buf
;
}
...
...
@@ -150,6 +138,30 @@ HWTEST_F(ContainerTest, ItPidContainer026, TestSize.Level0)
{
ItPidContainer026
();
}
/**
* @tc.name: Container_Pid_Test_027
* @tc.desc: pid container function test case
* @tc.type: FUNC
* @tc.require: issueI6BE5A
* @tc.author:
*/
HWTEST_F
(
ContainerTest
,
ItPidContainer027
,
TestSize
.
Level0
)
{
ItPidContainer027
();
}
/**
* @tc.name: Container_Pid_Test_028
* @tc.desc: pid container function test case
* @tc.type: FUNC
* @tc.require: issueI6BE5A
* @tc.author:
*/
HWTEST_F
(
ContainerTest
,
ItPidContainer028
,
TestSize
.
Level0
)
{
ItPidContainer028
();
}
#endif
#if defined(LOSCFG_USER_TEST_UTS_CONTAINER)
/**
...
...
@@ -175,6 +187,18 @@ HWTEST_F(ContainerTest, ItUtsContainer002, TestSize.Level0)
{
ItUtsContainer002
();
}
/**
* @tc.name: Container_UTS_Test_004
* @tc.desc: uts container function test case
* @tc.type: FUNC
* @tc.require: issueI6BE5A
* @tc.author:
*/
HWTEST_F
(
ContainerTest
,
ItUtsContainer004
,
TestSize
.
Level0
)
{
ItUtsContainer004
();
}
#endif
#if defined(LOSCFG_USER_TEST_MNT_CONTAINER)
...
...
@@ -226,6 +250,42 @@ HWTEST_F(ContainerTest, ItMntContainer004, TestSize.Level0)
ItMntContainer004
();
}
/**
* @tc.name: Container_MNT_Test_005
* @tc.desc: mnt container function test case
* @tc.type: FUNC
* @tc.require: issueI6BE5A
* @tc.author:
*/
HWTEST_F
(
ContainerTest
,
ItMntContainer005
,
TestSize
.
Level0
)
{
ItMntContainer005
();
}
/**
* @tc.name: Container_MNT_Test_006
* @tc.desc: mnt container function test case
* @tc.type: FUNC
* @tc.require: issueI6BE5A
* @tc.author:
*/
HWTEST_F
(
ContainerTest
,
ItMntContainer006
,
TestSize
.
Level0
)
{
ItMntContainer006
();
}
/**
* @tc.name: Container_MNT_Test_007
* @tc.desc: mnt container function test case
* @tc.type: FUNC
* @tc.require: issueI6BE5A
* @tc.author:
*/
HWTEST_F
(
ContainerTest
,
ItMntContainer007
,
TestSize
.
Level0
)
{
ItMntContainer007
();
}
/**
* @tc.name: chroot_Test_001
* @tc.desc: chroot function test case
...
...
@@ -254,6 +314,18 @@ HWTEST_F(ContainerTest, ItIpcContainer001, TestSize.Level0)
ItIpcContainer001
();
}
/**
* @tc.name: Container_IPC_Test_003
* @tc.desc: ipc container function test case
* @tc.type: FUNC
* @tc.require: issueI6BE5A
* @tc.author:
*/
HWTEST_F
(
ContainerTest
,
ItIpcContainer003
,
TestSize
.
Level0
)
{
ItIpcContainer003
();
}
/**
* @tc.name: Container_IPC_Test_004
* @tc.desc: ipc container function test case
...
...
@@ -265,6 +337,18 @@ HWTEST_F(ContainerTest, ItIpcContainer004, TestSize.Level0)
{
ItIpcContainer004
();
}
/**
* @tc.name: Container_IPC_Test_005
* @tc.desc: ipc container function test case
* @tc.type: FUNC
* @tc.require: issueI6BE5A
* @tc.author:
*/
HWTEST_F
(
ContainerTest
,
ItIpcContainer005
,
TestSize
.
Level0
)
{
ItIpcContainer005
();
}
#endif
#if defined(LOSCFG_USER_TEST_TIME_CONTAINER)
...
...
@@ -280,6 +364,42 @@ HWTEST_F(ContainerTest, ItTimeContainer001, TestSize.Level0)
ItTimeContainer001
();
}
/**
* @tc.name: Container_TIME_Test_002
* @tc.desc: time container function test case
* @tc.type: FUNC
* @tc.require: issueI6BE5A
* @tc.author:
*/
HWTEST_F
(
ContainerTest
,
ItTimeContainer002
,
TestSize
.
Level0
)
{
ItTimeContainer002
();
}
/**
* @tc.name: Container_TIME_Test_004
* @tc.desc: time container function test case
* @tc.type: FUNC
* @tc.require: issueI6BE5A
* @tc.author:
*/
HWTEST_F
(
ContainerTest
,
ItTimeContainer004
,
TestSize
.
Level0
)
{
ItTimeContainer004
();
}
/**
* @tc.name: Container_TIME_Test_005
* @tc.desc: time container function test case
* @tc.type: FUNC
* @tc.require: issueI6BE5A
* @tc.author:
*/
HWTEST_F
(
ContainerTest
,
ItTimeContainer005
,
TestSize
.
Level0
)
{
ItTimeContainer005
();
}
/*
* @tc.name: Container_TIME_Test_007
* @tc.desc: time container function test case
...
...
@@ -292,6 +412,18 @@ HWTEST_F(ContainerTest, ItTimeContainer007, TestSize.Level0)
ItTimeContainer007
();
}
/**
* @tc.name: Container_TIME_Test_008
* @tc.desc: time container function test case
* @tc.type: FUNC
* @tc.require: issueI6BE5A
* @tc.author:
*/
HWTEST_F
(
ContainerTest
,
ItTimeContainer008
,
TestSize
.
Level0
)
{
ItTimeContainer008
();
}
/**
* @tc.name: Container_TIME_Test_009
* @tc.desc: time container function test case
...
...
testsuites/unittest/container/It_container_test.h
浏览文件 @
1f05c6a2
...
...
@@ -142,10 +142,13 @@ void ItContainerChroot001(void);
void
ItPidContainer023
(
void
);
void
ItPidContainer025
(
void
);
void
ItPidContainer026
(
void
);
void
ItPidContainer027
(
void
);
void
ItPidContainer028
(
void
);
#endif
#if defined(LOSCFG_USER_TEST_UTS_CONTAINER)
void
ItUtsContainer001
(
void
);
void
ItUtsContainer002
(
void
);
void
ItUtsContainer004
(
void
);
#endif
#if defined(LOSCFG_USER_TEST_MNT_CONTAINER)
void
ItMntContainer001
(
void
);
...
...
testsuites/unittest/container/config.gni
浏览文件 @
1f05c6a2
...
...
@@ -48,6 +48,8 @@ if (defined(LOSCFG_USER_TEST_PID_CONTAINER)) {
"$TEST_UNITTEST_DIR/container/smoke/It_pid_container_023.cpp",
"$TEST_UNITTEST_DIR/container/smoke/It_pid_container_025.cpp",
"$TEST_UNITTEST_DIR/container/smoke/It_pid_container_026.cpp",
"$TEST_UNITTEST_DIR/container/smoke/It_pid_container_027.cpp",
"$TEST_UNITTEST_DIR/container/smoke/It_pid_container_028.cpp",
]
sources_full += [
"$TEST_UNITTEST_DIR/container/full/It_pid_container_001.cpp",
...
...
@@ -78,6 +80,7 @@ if (defined(LOSCFG_USER_TEST_UTS_CONTAINER)) {
sources_smoke += [
"$TEST_UNITTEST_DIR/container/smoke/It_uts_container_001.cpp",
"$TEST_UNITTEST_DIR/container/smoke/It_uts_container_002.cpp",
"$TEST_UNITTEST_DIR/container/smoke/It_uts_container_004.cpp",
]
sources_full +=
[ "$TEST_UNITTEST_DIR/container/full/It_uts_container_003.cpp" ]
...
...
testsuites/unittest/container/smoke/It_ipc_container_003.cpp
浏览文件 @
1f05c6a2
...
...
@@ -74,7 +74,7 @@ EXIT1:
return
EXIT_CODE_ERRNO_7
;
}
void
ItIpcContainer003
(
void
)
static
void
IpcContainerUnshare
(
void
)
{
int
status
,
exitCode
,
ret
;
int
arg
=
CHILD_FUNC_ARG
;
...
...
@@ -149,3 +149,15 @@ void ItIpcContainer003(void)
ASSERT_EQ
(
ret
,
strlen
(
msgptr
));
ASSERT_STREQ
(
msgrcd
,
msgptr
);
}
void
ItIpcContainer003
(
void
)
{
auto
pid
=
fork
();
ASSERT_TRUE
(
pid
!=
-
1
);
if
(
pid
==
0
)
{
IpcContainerUnshare
();
exit
(
0
);
}
auto
ret
=
waitpid
(
pid
,
NULL
,
0
);
ASSERT_EQ
(
ret
,
pid
);
}
testsuites/unittest/container/smoke/It_mnt_container_005.cpp
浏览文件 @
1f05c6a2
...
...
@@ -32,7 +32,7 @@
/*
* mount container unshare test: unshare in current pcb with NEW_NS
*/
void
ItMntContainer005
(
void
)
static
void
MntContainerUnshare
(
void
)
{
int
ret
;
...
...
@@ -56,4 +56,22 @@ void ItMntContainer005(void)
ret
=
access
(
ACCESS_FILE_NAME
,
F_OK
);
ASSERT_EQ
(
ret
,
0
);
exit
(
0
);
}
void
ItMntContainer005
(
void
)
{
int
status
=
0
;
auto
pid
=
fork
();
ASSERT_TRUE
(
pid
!=
-
1
);
if
(
pid
==
0
)
{
MntContainerUnshare
();
exit
(
EXIT_CODE_ERRNO_1
);
}
auto
ret
=
waitpid
(
pid
,
&
status
,
0
);
ASSERT_EQ
(
ret
,
pid
);
ret
=
WIFEXITED
(
status
);
ASSERT_NE
(
ret
,
0
);
ret
=
WEXITSTATUS
(
status
);
ASSERT_EQ
(
ret
,
0
);
}
testsuites/unittest/container/smoke/It_pid_container_027.cpp
0 → 100644
浏览文件 @
1f05c6a2
/*
* Copyright (c) 2023-2023 Huawei Device Co., Ltd. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without modification,
* are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice, this list of
* conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright notice, this list
* of conditions and the following disclaimer in the documentation and/or other materials
* provided with the distribution.
*
* 3. Neither the name of the copyright holder nor the names of its contributors may be used
* to endorse or promote products derived from this software without specific prior written
* permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
* THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#include "It_container_test.h"
static
int
ChildFunClone3
(
void
*
p
)
{
(
void
)
p
;
auto
pid
=
getpid
();
if
(
pid
!=
CONTAINER_SECOND_PID
)
{
return
EXIT_CODE_ERRNO_1
;
}
return
0
;
}
static
int
ChildFunClone2
(
void
*
p
)
{
(
void
)
p
;
auto
pid
=
getpid
();
if
(
pid
!=
CONTAINER_FIRST_PID
)
{
return
EXIT_CODE_ERRNO_1
;
}
int
ret
;
int
status
;
void
*
pstk
=
malloc
(
STACK_SIZE
);
if
(
pstk
==
NULL
)
{
return
EXIT_CODE_ERRNO_2
;
}
int
childPid
=
clone
(
ChildFunClone3
,
(
char
*
)
pstk
+
STACK_SIZE
,
SIGCHLD
,
NULL
);
if
(
childPid
==
-
1
)
{
free
(
pstk
);
return
EXIT_CODE_ERRNO_3
;
}
ret
=
waitpid
(
childPid
,
&
status
,
0
);
ret
=
WIFEXITED
(
status
);
ret
=
WEXITSTATUS
(
status
);
if
(
ret
!=
0
)
{
free
(
pstk
);
return
EXIT_CODE_ERRNO_4
;
}
free
(
pstk
);
return
0
;
}
static
int
ChildFunClone1
(
void
*
p
)
{
(
void
)
p
;
int
ret
;
int
status
;
const
char
*
containerType
=
"pid"
;
const
char
*
containerType1
=
"pid_for_children"
;
auto
pid
=
getpid
();
ret
=
unshare
(
CLONE_NEWPID
);
if
(
ret
==
-
1
)
{
return
EXIT_CODE_ERRNO_1
;
}
auto
pid1
=
getpid
();
if
(
pid
!=
pid1
)
{
return
EXIT_CODE_ERRNO_2
;
}
auto
linkBuffer
=
ReadlinkContainer
(
pid
,
containerType
);
auto
linkBuffer1
=
ReadlinkContainer
(
pid
,
containerType1
);
ret
=
linkBuffer
.
compare
(
linkBuffer1
);
if
(
ret
==
0
)
{
printf
(
"linkBuffer: %s linkBuffer1: %s
\n
"
,
linkBuffer
.
c_str
(),
linkBuffer1
.
c_str
());
return
EXIT_CODE_ERRNO_3
;
}
void
*
pstk
=
malloc
(
STACK_SIZE
);
if
(
pstk
==
NULL
)
{
return
EXIT_CODE_ERRNO_4
;
}
int
childPid
=
clone
(
ChildFunClone2
,
(
char
*
)
pstk
+
STACK_SIZE
,
CLONE_NEWUTS
|
SIGCHLD
,
NULL
);
free
(
pstk
);
if
(
childPid
==
-
1
)
{
return
EXIT_CODE_ERRNO_5
;
}
ret
=
unshare
(
CLONE_NEWPID
);
if
(
ret
!=
-
1
)
{
return
EXIT_CODE_ERRNO_6
;
}
ret
=
waitpid
(
childPid
,
&
status
,
0
);
if
(
ret
!=
childPid
)
{
return
EXIT_CODE_ERRNO_7
;
}
ret
=
WIFEXITED
(
status
);
if
(
ret
==
0
)
{
return
EXIT_CODE_ERRNO_8
;
}
ret
=
WEXITSTATUS
(
status
);
if
(
ret
!=
0
)
{
return
EXIT_CODE_ERRNO_9
;
}
return
0
;
}
void
ItPidContainer027
(
void
)
{
void
*
pstk
=
malloc
(
STACK_SIZE
);
ASSERT_TRUE
(
pstk
!=
NULL
);
pid_t
parentPid
=
getpid
();
int
childPid
=
clone
(
ChildFunClone1
,
(
char
*
)
pstk
+
STACK_SIZE
,
SIGCHLD
,
NULL
);
free
(
pstk
);
ASSERT_NE
(
childPid
,
-
1
);
int
status
;
int
ret
=
waitpid
(
childPid
,
&
status
,
0
);
ASSERT_EQ
(
ret
,
childPid
);
ret
=
WIFEXITED
(
status
);
ASSERT_NE
(
ret
,
0
);
ret
=
WEXITSTATUS
(
status
);
ASSERT_EQ
(
ret
,
0
);
}
testsuites/unittest/container/smoke/It_pid_container_028.cpp
0 → 100644
浏览文件 @
1f05c6a2
/*
* Copyright (c) 2023-2023 Huawei Device Co., Ltd. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without modification,
* are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice, this list of
* conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright notice, this list
* of conditions and the following disclaimer in the documentation and/or other materials
* provided with the distribution.
*
* 3. Neither the name of the copyright holder nor the names of its contributors may be used
* to endorse or promote products derived from this software without specific prior written
* permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
* THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#include "It_container_test.h"
static
int
ChildFunClone3
(
void
*
p
)
{
(
void
)
p
;
auto
pid
=
getpid
();
if
(
pid
!=
CONTAINER_SECOND_PID
)
{
return
EXIT_CODE_ERRNO_1
;
}
return
0
;
}
static
int
ChildFunClone2
(
void
*
p
)
{
(
void
)
p
;
auto
pid
=
getpid
();
if
(
pid
!=
CONTAINER_FIRST_PID
)
{
return
EXIT_CODE_ERRNO_1
;
}
int
ret
;
int
status
;
void
*
pstk
=
malloc
(
STACK_SIZE
);
if
(
pstk
==
NULL
)
{
return
EXIT_CODE_ERRNO_2
;
}
int
childPid
=
clone
(
ChildFunClone3
,
(
char
*
)
pstk
+
STACK_SIZE
,
SIGCHLD
,
NULL
);
if
(
childPid
==
-
1
)
{
free
(
pstk
);
return
EXIT_CODE_ERRNO_3
;
}
ret
=
waitpid
(
childPid
,
&
status
,
0
);
ret
=
WIFEXITED
(
status
);
ret
=
WEXITSTATUS
(
status
);
if
(
ret
!=
0
)
{
free
(
pstk
);
return
EXIT_CODE_ERRNO_4
;
}
free
(
pstk
);
return
0
;
}
static
int
ChildFunClone1
(
void
*
p
)
{
(
void
)
p
;
int
ret
;
int
status
;
const
char
*
containerType
=
"pid"
;
const
char
*
containerType1
=
"pid_for_children"
;
auto
pid
=
getpid
();
ret
=
unshare
(
CLONE_NEWPID
);
if
(
ret
==
-
1
)
{
return
EXIT_CODE_ERRNO_1
;
}
auto
pid1
=
getpid
();
if
(
pid
!=
pid1
)
{
return
EXIT_CODE_ERRNO_2
;
}
auto
linkBuffer
=
ReadlinkContainer
(
pid
,
containerType
);
auto
linkBuffer1
=
ReadlinkContainer
(
pid
,
containerType1
);
ret
=
linkBuffer
.
compare
(
linkBuffer1
);
if
(
ret
==
0
)
{
return
EXIT_CODE_ERRNO_3
;
}
void
*
pstk
=
malloc
(
STACK_SIZE
);
if
(
pstk
==
NULL
)
{
return
EXIT_CODE_ERRNO_4
;
}
int
childPid
=
clone
(
ChildFunClone2
,
(
char
*
)
pstk
+
STACK_SIZE
,
CLONE_NEWPID
|
SIGCHLD
,
NULL
);
free
(
pstk
);
if
(
childPid
==
-
1
)
{
return
EXIT_CODE_ERRNO_5
;
}
ret
=
unshare
(
CLONE_NEWPID
);
if
(
ret
!=
-
1
)
{
return
EXIT_CODE_ERRNO_6
;
}
ret
=
waitpid
(
childPid
,
&
status
,
0
);
if
(
ret
!=
childPid
)
{
return
EXIT_CODE_ERRNO_7
;
}
ret
=
WIFEXITED
(
status
);
if
(
ret
==
0
)
{
return
EXIT_CODE_ERRNO_8
;
}
ret
=
WEXITSTATUS
(
status
);
if
(
ret
!=
0
)
{
return
EXIT_CODE_ERRNO_9
;
}
return
0
;
}
void
ItPidContainer028
(
void
)
{
void
*
pstk
=
malloc
(
STACK_SIZE
);
ASSERT_TRUE
(
pstk
!=
NULL
);
pid_t
parentPid
=
getpid
();
int
childPid
=
clone
(
ChildFunClone1
,
(
char
*
)
pstk
+
STACK_SIZE
,
SIGCHLD
,
NULL
);
free
(
pstk
);
ASSERT_NE
(
childPid
,
-
1
);
int
status
;
int
ret
=
waitpid
(
childPid
,
&
status
,
0
);
ASSERT_EQ
(
ret
,
childPid
);
ret
=
WIFEXITED
(
status
);
ASSERT_NE
(
ret
,
0
);
ret
=
WEXITSTATUS
(
status
);
ASSERT_EQ
(
ret
,
0
);
}
testsuites/unittest/container/smoke/It_time_container_002.cpp
浏览文件 @
1f05c6a2
...
...
@@ -67,6 +67,7 @@ static int childFunc(void *arg)
return
0
;
}
static
int
WriteProcTime
(
int
pid
)
{
int
ret
=
0
;
...
...
@@ -98,7 +99,7 @@ static int WriteProcTime(int pid)
return
0
;
}
void
ItTimeContainer002
(
void
)
static
void
TimeContainerUnshare
(
void
)
{
int
ret
;
int
status
;
...
...
@@ -112,6 +113,9 @@ void ItTimeContainer002(void)
ret
=
unshare
(
CLONE_NEWTIME
);
ASSERT_EQ
(
ret
,
0
);
ret
=
unshare
(
CLONE_NEWTIME
);
ASSERT_EQ
(
ret
,
-
1
);
ret
=
WriteProcTime
(
getpid
());
ASSERT_EQ
(
ret
,
0
);
...
...
@@ -128,6 +132,9 @@ void ItTimeContainer002(void)
ret
=
linkBuffer1
.
compare
(
linkBuffer2
);
ASSERT_EQ
(
ret
,
0
);
ret
=
unshare
(
CLONE_NEWTIME
);
ASSERT_EQ
(
ret
,
-
1
);
ret
=
waitpid
(
pid
,
&
status
,
0
);
ASSERT_EQ
(
ret
,
pid
);
...
...
@@ -136,4 +143,23 @@ void ItTimeContainer002(void)
int
exitCode
=
WEXITSTATUS
(
status
);
ASSERT_EQ
(
exitCode
,
0
);
exit
(
0
);
}
void
ItTimeContainer002
(
void
)
{
int
status
=
0
;
auto
pid
=
fork
();
ASSERT_TRUE
(
pid
!=
-
1
);
if
(
pid
==
0
)
{
TimeContainerUnshare
();
exit
(
EXIT_CODE_ERRNO_1
);
}
auto
ret
=
waitpid
(
pid
,
&
status
,
0
);
ASSERT_EQ
(
ret
,
pid
);
ret
=
WIFEXITED
(
status
);
ASSERT_NE
(
ret
,
0
);
ret
=
WEXITSTATUS
(
status
);
ASSERT_EQ
(
ret
,
0
);
}
testsuites/unittest/container/smoke/It_time_container_003.cpp
浏览文件 @
1f05c6a2
...
...
@@ -69,7 +69,7 @@ static int childFunc(void *arg)
return
0
;
}
void
ItTimeContainer003
(
void
)
static
void
TimeContainerUnshare
(
void
)
{
int
ret
;
int
status
;
...
...
@@ -97,4 +97,23 @@ void ItTimeContainer003(void)
int
exitCode
=
WEXITSTATUS
(
status
);
ASSERT_EQ
(
exitCode
,
0
);
exit
(
0
);
}
void
ItTimeContainer003
(
void
)
{
int
status
=
0
;
auto
pid
=
fork
();
ASSERT_TRUE
(
pid
!=
-
1
);
if
(
pid
==
0
)
{
TimeContainerUnshare
();
exit
(
EXIT_CODE_ERRNO_1
);
}
auto
ret
=
waitpid
(
pid
,
&
status
,
0
);
ASSERT_EQ
(
ret
,
pid
);
ret
=
WIFEXITED
(
status
);
ASSERT_NE
(
ret
,
0
);
ret
=
WEXITSTATUS
(
status
);
ASSERT_EQ
(
ret
,
0
);
}
testsuites/unittest/container/smoke/It_time_container_004.cpp
浏览文件 @
1f05c6a2
...
...
@@ -81,7 +81,7 @@ static int WriteProcTime(int pid)
return
0
;
}
void
ItTimeContainer004
(
void
)
static
void
TimeContainerUnshare
(
void
)
{
int
ret
;
int
status
;
...
...
@@ -111,4 +111,23 @@ void ItTimeContainer004(void)
int
exitCode
=
WEXITSTATUS
(
status
);
ASSERT_EQ
(
exitCode
,
0
);
exit
(
0
);
}
void
ItTimeContainer004
(
void
)
{
int
status
=
0
;
auto
pid
=
fork
();
ASSERT_TRUE
(
pid
!=
-
1
);
if
(
pid
==
0
)
{
TimeContainerUnshare
();
exit
(
EXIT_CODE_ERRNO_1
);
}
auto
ret
=
waitpid
(
pid
,
&
status
,
0
);
ASSERT_EQ
(
ret
,
pid
);
ret
=
WIFEXITED
(
status
);
ASSERT_NE
(
ret
,
0
);
ret
=
WEXITSTATUS
(
status
);
ASSERT_EQ
(
ret
,
0
);
}
testsuites/unittest/container/smoke/It_time_container_005.cpp
浏览文件 @
1f05c6a2
...
...
@@ -81,7 +81,7 @@ static int WriteProcTime(int pid)
return
0
;
}
void
ItTimeContainer005
(
void
)
static
void
TimeContainerUnshare
(
void
)
{
int
ret
;
int
status
;
...
...
@@ -111,4 +111,23 @@ void ItTimeContainer005(void)
int
exitCode
=
WEXITSTATUS
(
status
);
ASSERT_EQ
(
exitCode
,
0
);
exit
(
0
);
}
void
ItTimeContainer005
(
void
)
{
int
status
=
0
;
auto
pid
=
fork
();
ASSERT_TRUE
(
pid
!=
-
1
);
if
(
pid
==
0
)
{
TimeContainerUnshare
();
exit
(
EXIT_CODE_ERRNO_1
);
}
auto
ret
=
waitpid
(
pid
,
&
status
,
0
);
ASSERT_EQ
(
ret
,
pid
);
ret
=
WIFEXITED
(
status
);
ASSERT_NE
(
ret
,
0
);
ret
=
WEXITSTATUS
(
status
);
ASSERT_EQ
(
ret
,
0
);
}
testsuites/unittest/container/smoke/It_time_container_008.cpp
浏览文件 @
1f05c6a2
...
...
@@ -63,11 +63,30 @@ static int WriteProcTime(int pid)
return
0
;
}
void
ItTimeContainer008
(
void
)
static
void
TimeContainerUnshare
(
void
)
{
int
ret
=
unshare
(
CLONE_NEWTIME
);
ASSERT_EQ
(
ret
,
0
);
ret
=
WriteProcTime
(
getpid
());
ASSERT_EQ
(
ret
,
0
);
exit
(
0
);
}
void
ItTimeContainer008
(
void
)
{
int
status
=
0
;
auto
pid
=
fork
();
ASSERT_TRUE
(
pid
!=
-
1
);
if
(
pid
==
0
)
{
TimeContainerUnshare
();
exit
(
EXIT_CODE_ERRNO_1
);
}
auto
ret
=
waitpid
(
pid
,
&
status
,
0
);
ASSERT_EQ
(
ret
,
pid
);
ret
=
WIFEXITED
(
status
);
ASSERT_NE
(
ret
,
0
);
ret
=
WEXITSTATUS
(
status
);
ASSERT_EQ
(
ret
,
0
);
}
testsuites/unittest/container/smoke/It_uts_container_004.cpp
0 → 100644
浏览文件 @
1f05c6a2
/*
* Copyright (c) 2023-2023 Huawei Device Co., Ltd. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without modification,
* are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice, this list of
* conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright notice, this list
* of conditions and the following disclaimer in the documentation and/or other materials
* provided with the distribution.
*
* 3. Neither the name of the copyright holder nor the names of its contributors may be used
* to endorse or promote products derived from this software without specific prior written
* permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
* THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#include "It_container_test.h"
#include "sys/utsname.h"
static
int
ChildFunc
(
void
*
arg
)
{
(
void
)
arg
;
int
ret
;
ret
=
unshare
(
CLONE_NEWUTS
);
if
(
ret
!=
0
)
{
return
EXIT_CODE_ERRNO_1
;
}
struct
utsname
newName
;
ret
=
uname
(
&
newName
);
if
(
ret
!=
0
)
{
return
EXIT_CODE_ERRNO_2
;
}
const
char
*
name
=
"TestHostName"
;
ret
=
sethostname
(
name
,
strlen
(
name
));
if
(
ret
!=
0
)
{
return
EXIT_CODE_ERRNO_3
;
}
struct
utsname
newName1
;
ret
=
uname
(
&
newName1
);
if
(
ret
!=
0
)
{
return
EXIT_CODE_ERRNO_4
;
}
ret
=
strcmp
(
newName
.
nodename
,
newName1
.
nodename
);
if
(
ret
==
0
)
{
return
EXIT_CODE_ERRNO_5
;
}
return
0
;
}
void
ItUtsContainer004
(
void
)
{
int
ret
;
char
*
stack
=
(
char
*
)
mmap
(
NULL
,
STACK_SIZE
,
PROT_READ
|
PROT_WRITE
,
CLONE_STACK_MMAP_FLAG
,
-
1
,
0
);
ASSERT_TRUE
(
stack
!=
NULL
);
char
*
stackTop
=
stack
+
STACK_SIZE
;
struct
utsname
oldName
;
ret
=
uname
(
&
oldName
);
ASSERT_EQ
(
ret
,
0
);
auto
pid
=
clone
(
ChildFunc
,
stackTop
,
SIGCHLD
,
NULL
);
(
void
)
munmap
(
stack
,
STACK_SIZE
);
ASSERT_NE
(
pid
,
-
1
);
int
status
;
ret
=
waitpid
(
pid
,
&
status
,
0
);
ASSERT_EQ
(
ret
,
pid
);
int
exitCode
=
WEXITSTATUS
(
status
);
ASSERT_EQ
(
exitCode
,
0
);
struct
utsname
oldName1
;
ret
=
uname
(
&
oldName1
);
ASSERT_EQ
(
ret
,
0
);
ret
=
strcmp
(
oldName
.
nodename
,
oldName1
.
nodename
);
ASSERT_EQ
(
ret
,
0
);
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录