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
f761d24d
Unverified
Commit
f761d24d
authored
Mar 10, 2020
by
Christian Brauner
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
cgfsng: use __do_free_string_list all over
Signed-off-by:
Christian Brauner
<
christian.brauner@ubuntu.com
>
parent
e1e08f39
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
15 additions
and
29 deletions
+15
-29
cgfsng.c
src/lxc/cgroups/cgfsng.c
+15
-29
No files found.
src/lxc/cgroups/cgfsng.c
View file @
f761d24d
...
@@ -287,10 +287,9 @@ static uint32_t *lxc_cpumask(char *buf, size_t nbits)
...
@@ -287,10 +287,9 @@ static uint32_t *lxc_cpumask(char *buf, size_t nbits)
/* Turn cpumask into simple, comma-separated cpulist. */
/* Turn cpumask into simple, comma-separated cpulist. */
static
char
*
lxc_cpumask_to_cpulist
(
uint32_t
*
bitarr
,
size_t
nbits
)
static
char
*
lxc_cpumask_to_cpulist
(
uint32_t
*
bitarr
,
size_t
nbits
)
{
{
__do_free_string_list
char
**
cpulist
=
NULL
;
int
ret
;
int
ret
;
size_t
i
;
size_t
i
;
char
*
tmp
=
NULL
;
char
**
cpulist
=
NULL
;
char
numstr
[
INTTYPE_TO_STRLEN
(
size_t
)]
=
{
0
};
char
numstr
[
INTTYPE_TO_STRLEN
(
size_t
)]
=
{
0
};
for
(
i
=
0
;
i
<=
nbits
;
i
++
)
{
for
(
i
=
0
;
i
<=
nbits
;
i
++
)
{
...
@@ -298,25 +297,18 @@ static char *lxc_cpumask_to_cpulist(uint32_t *bitarr, size_t nbits)
...
@@ -298,25 +297,18 @@ static char *lxc_cpumask_to_cpulist(uint32_t *bitarr, size_t nbits)
continue
;
continue
;
ret
=
snprintf
(
numstr
,
sizeof
(
numstr
),
"%zu"
,
i
);
ret
=
snprintf
(
numstr
,
sizeof
(
numstr
),
"%zu"
,
i
);
if
(
ret
<
0
||
(
size_t
)
ret
>=
sizeof
(
numstr
))
{
if
(
ret
<
0
||
(
size_t
)
ret
>=
sizeof
(
numstr
))
lxc_free_array
((
void
**
)
cpulist
,
free
);
return
NULL
;
return
NULL
;
}
ret
=
lxc_append_string
(
&
cpulist
,
numstr
);
ret
=
lxc_append_string
(
&
cpulist
,
numstr
);
if
(
ret
<
0
)
{
if
(
ret
<
0
)
lxc_free_array
((
void
**
)
cpulist
,
free
);
return
ret_set_errno
(
NULL
,
ENOMEM
);
return
ret_set_errno
(
NULL
,
ENOMEM
);
}
}
}
if
(
!
cpulist
)
if
(
!
cpulist
)
return
ret_set_errno
(
NULL
,
ENOMEM
);
return
ret_set_errno
(
NULL
,
ENOMEM
);
tmp
=
lxc_string_join
(
","
,
(
const
char
**
)
cpulist
,
false
);
return
lxc_string_join
(
","
,
(
const
char
**
)
cpulist
,
false
);
lxc_free_array
((
void
**
)
cpulist
,
free
);
return
tmp
;
}
}
static
ssize_t
get_max_cpus
(
char
*
cpulist
)
static
ssize_t
get_max_cpus
(
char
*
cpulist
)
...
@@ -666,10 +658,10 @@ static char **cg_hybrid_get_controllers(char **klist, char **nlist, char *line,
...
@@ -666,10 +658,10 @@ static char **cg_hybrid_get_controllers(char **klist, char **nlist, char *line,
/* The fourth field is /sys/fs/cgroup/comma-delimited-controller-list
/* The fourth field is /sys/fs/cgroup/comma-delimited-controller-list
* for legacy hierarchies.
* for legacy hierarchies.
*/
*/
__do_free_string_list
char
**
aret
=
NULL
;
int
i
;
int
i
;
char
*
p2
,
*
tok
;
char
*
p2
,
*
tok
;
char
*
p
=
line
,
*
sep
=
","
;
char
*
p
=
line
,
*
sep
=
","
;
char
**
aret
=
NULL
;
for
(
i
=
0
;
i
<
4
;
i
++
)
{
for
(
i
=
0
;
i
<
4
;
i
++
)
{
p
=
strchr
(
p
,
' '
);
p
=
strchr
(
p
,
' '
);
...
@@ -710,24 +702,24 @@ static char **cg_hybrid_get_controllers(char **klist, char **nlist, char *line,
...
@@ -710,24 +702,24 @@ static char **cg_hybrid_get_controllers(char **klist, char **nlist, char *line,
}
}
*
p2
=
' '
;
*
p2
=
' '
;
return
aret
;
return
move_ptr
(
aret
)
;
}
}
static
char
**
cg_unified_make_empty_controller
(
void
)
static
char
**
cg_unified_make_empty_controller
(
void
)
{
{
__do_free_string_list
char
**
aret
=
NULL
;
int
newentry
;
int
newentry
;
char
**
aret
=
NULL
;
newentry
=
append_null_to_list
((
void
***
)
&
aret
);
newentry
=
append_null_to_list
((
void
***
)
&
aret
);
aret
[
newentry
]
=
NULL
;
aret
[
newentry
]
=
NULL
;
return
aret
;
return
move_ptr
(
aret
)
;
}
}
static
char
**
cg_unified_get_controllers
(
const
char
*
file
)
static
char
**
cg_unified_get_controllers
(
const
char
*
file
)
{
{
__do_free
char
*
buf
=
NULL
;
__do_free
char
*
buf
=
NULL
;
__do_free_string_list
char
**
aret
=
NULL
;
char
*
sep
=
"
\t\n
"
;
char
*
sep
=
"
\t\n
"
;
char
**
aret
=
NULL
;
char
*
tok
;
char
*
tok
;
buf
=
read_file
(
file
);
buf
=
read_file
(
file
);
...
@@ -743,7 +735,7 @@ static char **cg_unified_get_controllers(const char *file)
...
@@ -743,7 +735,7 @@ static char **cg_unified_get_controllers(const char *file)
aret
[
newentry
]
=
copy
;
aret
[
newentry
]
=
copy
;
}
}
return
aret
;
return
move_ptr
(
aret
)
;
}
}
static
struct
hierarchy
*
add_hierarchy
(
struct
hierarchy
***
h
,
char
**
clist
,
char
*
mountpoint
,
static
struct
hierarchy
*
add_hierarchy
(
struct
hierarchy
***
h
,
char
**
clist
,
char
*
mountpoint
,
...
@@ -2789,12 +2781,11 @@ __cgfsng_ops bool cgfsng_devices_activate(struct cgroup_ops *ops,
...
@@ -2789,12 +2781,11 @@ __cgfsng_ops bool cgfsng_devices_activate(struct cgroup_ops *ops,
bool
__cgfsng_delegate_controllers
(
struct
cgroup_ops
*
ops
,
const
char
*
cgroup
)
bool
__cgfsng_delegate_controllers
(
struct
cgroup_ops
*
ops
,
const
char
*
cgroup
)
{
{
__do_free
char
*
add_controllers
=
NULL
,
*
base_path
=
NULL
;
__do_free
char
*
add_controllers
=
NULL
,
*
base_path
=
NULL
;
__do_free_string_list
char
**
parts
=
NULL
;
struct
hierarchy
*
unified
=
ops
->
unified
;
struct
hierarchy
*
unified
=
ops
->
unified
;
ssize_t
parts_len
;
ssize_t
parts_len
;
char
**
it
;
char
**
it
;
size_t
full_len
=
0
;
size_t
full_len
=
0
;
char
**
parts
=
NULL
;
bool
bret
=
false
;
if
(
!
ops
->
hierarchies
||
!
pure_unified_layout
(
ops
)
||
if
(
!
ops
->
hierarchies
||
!
pure_unified_layout
(
ops
)
||
!
unified
->
controllers
[
0
])
!
unified
->
controllers
[
0
])
...
@@ -2822,7 +2813,7 @@ bool __cgfsng_delegate_controllers(struct cgroup_ops *ops, const char *cgroup)
...
@@ -2822,7 +2813,7 @@ bool __cgfsng_delegate_controllers(struct cgroup_ops *ops, const char *cgroup)
parts
=
lxc_string_split
(
cgroup
,
'/'
);
parts
=
lxc_string_split
(
cgroup
,
'/'
);
if
(
!
parts
)
if
(
!
parts
)
goto
on_error
;
return
false
;
parts_len
=
lxc_array_len
((
void
**
)
parts
);
parts_len
=
lxc_array_len
((
void
**
)
parts
);
if
(
parts_len
>
0
)
if
(
parts_len
>
0
)
...
@@ -2838,17 +2829,12 @@ bool __cgfsng_delegate_controllers(struct cgroup_ops *ops, const char *cgroup)
...
@@ -2838,17 +2829,12 @@ bool __cgfsng_delegate_controllers(struct cgroup_ops *ops, const char *cgroup)
target
=
must_make_path
(
base_path
,
"cgroup.subtree_control"
,
NULL
);
target
=
must_make_path
(
base_path
,
"cgroup.subtree_control"
,
NULL
);
ret
=
lxc_writeat
(
-
1
,
target
,
add_controllers
,
full_len
);
ret
=
lxc_writeat
(
-
1
,
target
,
add_controllers
,
full_len
);
if
(
ret
<
0
)
if
(
ret
<
0
)
log_error_errno
(
goto
on_error
,
return
log_error_errno
(
false
,
errno
,
"Could not enable
\"
%s
\"
controllers in the unified cgroup
\"
%s
\"
"
,
errno
,
"Could not enable
\"
%s
\"
controllers in the unified cgroup
\"
%s
\"
"
,
add_controllers
,
target
);
add_controllers
,
target
);
TRACE
(
"Enable
\"
%s
\"
controllers in the unified cgroup
\"
%s
\"
"
,
add_controllers
,
target
);
TRACE
(
"Enable
\"
%s
\"
controllers in the unified cgroup
\"
%s
\"
"
,
add_controllers
,
target
);
}
}
bret
=
true
;
return
true
;
on_error:
lxc_free_array
((
void
**
)
parts
,
free
);
return
bret
;
}
}
__cgfsng_ops
bool
cgfsng_monitor_delegate_controllers
(
struct
cgroup_ops
*
ops
)
__cgfsng_ops
bool
cgfsng_monitor_delegate_controllers
(
struct
cgroup_ops
*
ops
)
...
...
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