Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
L
lxc
Project
Overview
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
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Chen Yisong
lxc
Commits
c2aed66d
Unverified
Commit
c2aed66d
authored
Jan 31, 2018
by
Christian Brauner
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
cgroups: cgfsng_attach: handle unified hierarchy
Signed-off-by:
Christian Brauner
<
christian.brauner@ubuntu.com
>
parent
0c3deb94
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
98 additions
and
9 deletions
+98
-9
cgfsng.c
src/lxc/cgroups/cgfsng.c
+89
-5
commands.c
src/lxc/commands.c
+9
-4
No files found.
src/lxc/cgroups/cgfsng.c
View file @
c2aed66d
...
@@ -2233,26 +2233,110 @@ static char *build_full_cgpath_from_monitorpath(struct hierarchy *h,
...
@@ -2233,26 +2233,110 @@ static char *build_full_cgpath_from_monitorpath(struct hierarchy *h,
return
must_make_path
(
h
->
mountpoint
,
inpath
,
filename
,
NULL
);
return
must_make_path
(
h
->
mountpoint
,
inpath
,
filename
,
NULL
);
}
}
/* Technically, we're always at a delegation boundary here. (This is especially
* true when cgroup namespaces are available.) The reasoning is that in order
* for us to have been able to start a container in the first place the root
* cgroup must have been a leaf node. Now, either the container's init system
* has populated the cgroup and kept it as a leaf node or it has created
* subtrees. In the former case we will simply attach to the leaf node we
* created when we started the container in the latter case we create our own
* cgroup for the attaching process.
*/
static
int
cg_attach_unified
(
const
struct
hierarchy
*
h
,
const
char
*
name
,
const
char
*
lxcpath
,
const
char
*
pidstr
,
size_t
pidstr_len
,
const
char
*
controller
)
{
int
ret
;
size_t
len
;
int
fret
=
-
1
,
idx
=
0
;
char
*
base_path
=
NULL
,
*
container_cgroup
=
NULL
,
*
full_path
=
NULL
;
container_cgroup
=
lxc_cmd_get_cgroup_path
(
name
,
lxcpath
,
controller
);
/* not running */
if
(
!
container_cgroup
)
return
0
;
base_path
=
must_make_path
(
h
->
mountpoint
,
container_cgroup
,
NULL
);
full_path
=
must_make_path
(
base_path
,
"cgroup.procs"
,
NULL
);
/* cgroup is populated */
ret
=
lxc_write_to_file
(
full_path
,
pidstr
,
pidstr_len
,
false
);
if
(
ret
<
0
&&
errno
!=
EBUSY
)
goto
on_error
;
if
(
ret
==
0
)
goto
on_success
;
free
(
full_path
);
len
=
strlen
(
base_path
)
+
sizeof
(
"/lxc-1000"
)
-
1
+
sizeof
(
"/cgroup-procs"
)
-
1
;
full_path
=
must_alloc
(
len
+
1
);
do
{
if
(
idx
)
ret
=
snprintf
(
full_path
,
len
+
1
,
"%s/lxc-%d"
,
base_path
,
idx
);
else
ret
=
snprintf
(
full_path
,
len
+
1
,
"%s/lxc"
,
base_path
);
if
(
ret
<
0
||
(
size_t
)
ret
>=
len
+
1
)
goto
on_error
;
ret
=
mkdir_p
(
full_path
,
0755
);
if
(
ret
<
0
&&
errno
!=
EEXIST
)
goto
on_error
;
strcat
(
full_path
,
"/cgroup.procs"
);
ret
=
lxc_write_to_file
(
full_path
,
pidstr
,
len
,
false
);
if
(
ret
==
0
)
goto
on_success
;
/* this is a non-leaf node */
if
(
errno
!=
EBUSY
)
goto
on_error
;
}
while
(
++
idx
>
0
&&
idx
<
1000
);
on_success:
if
(
idx
<
1000
)
fret
=
0
;
on_error:
free
(
base_path
);
free
(
container_cgroup
);
free
(
full_path
);
return
fret
;
}
static
bool
cgfsng_attach
(
const
char
*
name
,
const
char
*
lxcpath
,
pid_t
pid
)
static
bool
cgfsng_attach
(
const
char
*
name
,
const
char
*
lxcpath
,
pid_t
pid
)
{
{
int
i
,
len
,
ret
;
char
pidstr
[
25
];
char
pidstr
[
25
];
int
i
,
len
;
len
=
snprintf
(
pidstr
,
25
,
"%d"
,
pid
);
len
=
snprintf
(
pidstr
,
25
,
"%d"
,
pid
);
if
(
len
<
0
||
len
>
25
)
if
(
len
<
0
||
len
>
25
)
return
false
;
return
false
;
for
(
i
=
0
;
hierarchies
[
i
];
i
++
)
{
for
(
i
=
0
;
hierarchies
[
i
];
i
++
)
{
char
*
path
,
*
fullpath
;
char
*
path
;
char
*
fullpath
=
NULL
;
struct
hierarchy
*
h
=
hierarchies
[
i
];
struct
hierarchy
*
h
=
hierarchies
[
i
];
if
(
h
->
version
==
CGROUP2_SUPER_MAGIC
)
{
ret
=
cg_attach_unified
(
h
,
name
,
lxcpath
,
pidstr
,
len
,
h
->
controllers
[
0
]);
if
(
ret
<
0
)
return
false
;
continue
;
}
path
=
lxc_cmd_get_cgroup_path
(
name
,
lxcpath
,
h
->
controllers
[
0
]);
path
=
lxc_cmd_get_cgroup_path
(
name
,
lxcpath
,
h
->
controllers
[
0
]);
if
(
!
path
)
/* not running */
/* not running */
if
(
!
path
)
continue
;
continue
;
fullpath
=
build_full_cgpath_from_monitorpath
(
h
,
path
,
"cgroup.procs"
);
fullpath
=
build_full_cgpath_from_monitorpath
(
h
,
path
,
"cgroup.procs"
);
free
(
path
);
ret
=
lxc_write_to_file
(
fullpath
,
pidstr
,
len
,
false
);
if
(
lxc_write_to_file
(
fullpath
,
pidstr
,
len
,
false
)
!=
0
)
{
if
(
ret
<
0
)
{
SYSERROR
(
"Failed to attach %d to %s"
,
(
int
)
pid
,
fullpath
);
SYSERROR
(
"Failed to attach %d to %s"
,
(
int
)
pid
,
fullpath
);
free
(
fullpath
);
free
(
fullpath
);
return
false
;
return
false
;
...
...
src/lxc/commands.c
View file @
c2aed66d
...
@@ -445,11 +445,16 @@ char *lxc_cmd_get_cgroup_path(const char *name, const char *lxcpath,
...
@@ -445,11 +445,16 @@ char *lxc_cmd_get_cgroup_path(const char *name, const char *lxcpath,
struct
lxc_cmd_rr
cmd
=
{
struct
lxc_cmd_rr
cmd
=
{
.
req
=
{
.
req
=
{
.
cmd
=
LXC_CMD_GET_CGROUP
,
.
cmd
=
LXC_CMD_GET_CGROUP
,
.
datalen
=
strlen
(
subsystem
)
+
1
,
.
data
=
subsystem
,
.
data
=
subsystem
,
.
datalen
=
0
,
},
},
};
};
cmd
.
req
.
data
=
subsystem
;
cmd
.
req
.
datalen
=
0
;
if
(
subsystem
)
cmd
.
req
.
datalen
=
strlen
(
subsystem
)
+
1
;
ret
=
lxc_cmd
(
name
,
&
cmd
,
&
stopped
,
lxcpath
,
NULL
);
ret
=
lxc_cmd
(
name
,
&
cmd
,
&
stopped
,
lxcpath
,
NULL
);
if
(
ret
<
0
)
if
(
ret
<
0
)
return
NULL
;
return
NULL
;
...
@@ -469,10 +474,10 @@ static int lxc_cmd_get_cgroup_callback(int fd, struct lxc_cmd_req *req,
...
@@ -469,10 +474,10 @@ static int lxc_cmd_get_cgroup_callback(int fd, struct lxc_cmd_req *req,
const
char
*
path
;
const
char
*
path
;
struct
lxc_cmd_rsp
rsp
;
struct
lxc_cmd_rsp
rsp
;
if
(
req
->
datalen
<
1
)
if
(
req
->
datalen
>
0
)
return
-
1
;
path
=
cgroup_get_cgroup
(
handler
,
req
->
data
);
path
=
cgroup_get_cgroup
(
handler
,
req
->
data
);
else
path
=
cgroup_get_cgroup
(
handler
,
NULL
);
if
(
!
path
)
if
(
!
path
)
return
-
1
;
return
-
1
;
...
...
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