lxc: fix data overflow
Signed-off-by: zhangxiaoyu <zhangxiaoyu58@huawei.com>
This commit is contained in:
parent
709095931b
commit
02cf571f17
160
0025-get-cgroup-data-len-first-and-malloc-read-buff-by-le.patch
Normal file
160
0025-get-cgroup-data-len-first-and-malloc-read-buff-by-le.patch
Normal file
@ -0,0 +1,160 @@
|
||||
From 35b321354e3c5216b3fa6aed408e985273e0575e Mon Sep 17 00:00:00 2001
|
||||
From: zhangxiaoyu <zhangxiaoyu58@huawei.com>
|
||||
Date: Mon, 31 May 2021 20:31:26 +0800
|
||||
Subject: [PATCH 25/25] get cgroup data len first, and malloc read buff by len
|
||||
|
||||
Signed-off-by: zhangxiaoyu <zhangxiaoyu58@huawei.com>
|
||||
---
|
||||
src/lxc/lxccontainer.c | 56 ++++++++++++++++++++++++++++--------------
|
||||
1 file changed, 38 insertions(+), 18 deletions(-)
|
||||
|
||||
diff --git a/src/lxc/lxccontainer.c b/src/lxc/lxccontainer.c
|
||||
index 5769b251..01e6cbb6 100644
|
||||
--- a/src/lxc/lxccontainer.c
|
||||
+++ b/src/lxc/lxccontainer.c
|
||||
@@ -5757,11 +5757,11 @@ WRAP_API_1(bool, lxcapi_set_start_timeout, unsigned int)
|
||||
|
||||
static uint64_t metrics_get_ull(struct lxc_container *c, struct cgroup_ops *cgroup_ops, const char *item)
|
||||
{
|
||||
- char buf[80] = {0};
|
||||
+ char buf[81] = {0};
|
||||
int len = 0;
|
||||
uint64_t val = 0;
|
||||
|
||||
- len = cgroup_ops->get(cgroup_ops, item, buf, sizeof(buf), c->name, c->config_path);
|
||||
+ len = cgroup_ops->get(cgroup_ops, item, buf, sizeof(buf) - 1, c->name, c->config_path);
|
||||
if (len <= 0) {
|
||||
DEBUG("unable to read cgroup item %s", item);
|
||||
return 0;
|
||||
@@ -5773,11 +5773,11 @@ static uint64_t metrics_get_ull(struct lxc_container *c, struct cgroup_ops *cgro
|
||||
|
||||
static uint64_t metrics_get_ull_with_max(struct lxc_container *c, struct cgroup_ops *cgroup_ops, const char *item)
|
||||
{
|
||||
- char buf[80] = {0};
|
||||
+ char buf[81] = {0};
|
||||
int len = 0;
|
||||
uint64_t val = 0;
|
||||
|
||||
- len = cgroup_ops->get(cgroup_ops, item, buf, sizeof(buf), c->name, c->config_path);
|
||||
+ len = cgroup_ops->get(cgroup_ops, item, buf, sizeof(buf) - 1, c->name, c->config_path);
|
||||
if (len <= 0) {
|
||||
DEBUG("unable to read cgroup item %s", item);
|
||||
return 0;
|
||||
@@ -5808,22 +5808,29 @@ static inline bool is_blk_metrics_total(const char *value)
|
||||
|
||||
static void metrics_get_blk_stats(struct lxc_container *c, struct cgroup_ops *cgroup_ops, const char *item, struct lxc_blkio_metrics *stats)
|
||||
{
|
||||
-#define BUFSIZE 4096
|
||||
- char buf[BUFSIZE] = {0};
|
||||
+ char *buf = NULL;
|
||||
int i = 0;
|
||||
int len = 0;
|
||||
+ int ret = 0;
|
||||
char **lines = NULL;
|
||||
char **cols = NULL;
|
||||
|
||||
- len = cgroup_ops->get(cgroup_ops, item, buf, sizeof(buf), c->name, c->config_path);
|
||||
+ len = cgroup_ops->get(cgroup_ops, item, NULL, 0, c->name, c->config_path);
|
||||
if (len <= 0) {
|
||||
DEBUG("unable to read cgroup item %s", item);
|
||||
return;
|
||||
}
|
||||
|
||||
+ buf = malloc(len + 1);
|
||||
+ (void)memset(buf, 0, len + 1);
|
||||
+ ret = cgroup_ops->get(cgroup_ops, item, buf, len, c->name, c->config_path);
|
||||
+ if (ret != len) {
|
||||
+ DEBUG("get cgroup item %s len %d has changed to %d", item, len, ret);
|
||||
+ }
|
||||
+
|
||||
lines = lxc_string_split_and_trim(buf, '\n');
|
||||
if (lines == NULL) {
|
||||
- return;
|
||||
+ goto out;
|
||||
}
|
||||
|
||||
(void)memset(stats, 0, sizeof(struct lxc_blkio_metrics));
|
||||
@@ -5833,12 +5840,14 @@ static void metrics_get_blk_stats(struct lxc_container *c, struct cgroup_ops *cg
|
||||
if (cols == NULL) {
|
||||
goto err_out;
|
||||
}
|
||||
- if (is_blk_metrics_read(cols[1])) {
|
||||
- stats->read += strtoull(cols[2], NULL, 0);
|
||||
- } else if (is_blk_metrics_write(cols[1])) {
|
||||
- stats->write += strtoull(cols[2], NULL, 0);
|
||||
+ if (lxc_array_len((void **)cols) == 3) {
|
||||
+ if (is_blk_metrics_read(cols[1])) {
|
||||
+ stats->read += strtoull(cols[2], NULL, 0);
|
||||
+ } else if (is_blk_metrics_write(cols[1])) {
|
||||
+ stats->write += strtoull(cols[2], NULL, 0);
|
||||
+ }
|
||||
}
|
||||
- if (is_blk_metrics_total(cols[0])) {
|
||||
+ if (lxc_array_len((void **)cols) == 2 && is_blk_metrics_total(cols[0])) {
|
||||
stats->total = strtoull(cols[1], NULL, 0);
|
||||
}
|
||||
|
||||
@@ -5846,29 +5855,38 @@ static void metrics_get_blk_stats(struct lxc_container *c, struct cgroup_ops *cg
|
||||
}
|
||||
err_out:
|
||||
lxc_free_array((void **)lines, free);
|
||||
+out:
|
||||
+ free(buf);
|
||||
return;
|
||||
}
|
||||
|
||||
static void metrics_get_io_stats_v2(struct lxc_container *c, struct cgroup_ops *cgroup_ops, const char *item, struct lxc_blkio_metrics *stats, func_is_io_stat_read is_io_stat_read, func_is_io_stat_write is_io_stat_write)
|
||||
{
|
||||
-#define BUFSIZE 4096
|
||||
- char buf[BUFSIZE] = {0};
|
||||
+ char *buf = NULL;
|
||||
int i = 0;
|
||||
int j = 0;
|
||||
int len = 0;
|
||||
+ int ret = 0;
|
||||
char **lines = NULL;
|
||||
char **cols = NULL;
|
||||
char **kv = NULL;
|
||||
|
||||
- len = cgroup_ops->get(cgroup_ops, item, buf, sizeof(buf), c->name, c->config_path);
|
||||
+ len = cgroup_ops->get(cgroup_ops, item, NULL, 0, c->name, c->config_path);
|
||||
if (len <= 0) {
|
||||
DEBUG("unable to read cgroup item %s", item);
|
||||
return;
|
||||
}
|
||||
|
||||
+ buf = malloc(len + 1);
|
||||
+ (void)memset(buf, 0, len + 1);
|
||||
+ ret = cgroup_ops->get(cgroup_ops, item, buf, len, c->name, c->config_path);
|
||||
+ if (ret != len) {
|
||||
+ DEBUG("get cgroup item %s len %d change to %d", item, len, ret);
|
||||
+ }
|
||||
+
|
||||
lines = lxc_string_split_and_trim(buf, '\n');
|
||||
if (lines == NULL) {
|
||||
- return;
|
||||
+ goto out;
|
||||
}
|
||||
|
||||
(void)memset(stats, 0, sizeof(struct lxc_blkio_metrics));
|
||||
@@ -5900,6 +5918,8 @@ static void metrics_get_io_stats_v2(struct lxc_container *c, struct cgroup_ops *
|
||||
|
||||
err_out:
|
||||
lxc_free_array((void **)lines, free);
|
||||
+out:
|
||||
+ free(buf);
|
||||
return;
|
||||
}
|
||||
|
||||
@@ -5915,7 +5935,7 @@ static uint64_t metrics_match_get_ull(struct lxc_container *c, struct cgroup_ops
|
||||
char **cols = NULL;
|
||||
size_t matchlen = 0;
|
||||
|
||||
- len = cgroup_ops->get(cgroup_ops, item, buf, sizeof(buf), c->name, c->config_path);
|
||||
+ len = cgroup_ops->get(cgroup_ops, item, buf, sizeof(buf) - 1, c->name, c->config_path);
|
||||
if (len <= 0) {
|
||||
DEBUG("unable to read cgroup item %s", item);
|
||||
goto err_out;
|
||||
--
|
||||
2.25.1
|
||||
|
||||
9
lxc.spec
9
lxc.spec
@ -1,4 +1,4 @@
|
||||
%global _release 2021051301
|
||||
%global _release 2021060101
|
||||
|
||||
Name: lxc
|
||||
Version: 4.0.3
|
||||
@ -32,6 +32,7 @@ Patch0021: 0021-support-isula-exec-workdir.patch
|
||||
Patch0022: 0022-print-error-message-if-process-workdir-failed.patch
|
||||
Patch0023: 0023-log-support-long-syslog-tag.patch
|
||||
Patch0024: 0024-log-adjust-log-level-from-error-to-warn.patch
|
||||
Patch0025: 0025-get-cgroup-data-len-first-and-malloc-read-buff-by-le.patch
|
||||
|
||||
BuildRequires: systemd-units git libtool graphviz docbook2X doxygen chrpath
|
||||
BuildRequires: pkgconfig(libseccomp)
|
||||
@ -203,6 +204,12 @@ make check
|
||||
%{_mandir}/*/man7/%{name}*
|
||||
|
||||
%changelog
|
||||
* Tue Jun 01 2021 zhangxiaoyu <zhangxiaoyu58@huawei.com> - 4.0.3-2021060101
|
||||
- Type:bugfix
|
||||
- ID:NA
|
||||
- SUG:NA
|
||||
- DESC:adjust log level
|
||||
|
||||
* Thu Mar 13 2021 lifeng <lifeng68@huawei.com> - 4.0.3-2021051301
|
||||
- Type:bugfix
|
||||
- ID:NA
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user