lxc: fix data overflow

Signed-off-by: zhangxiaoyu <zhangxiaoyu58@huawei.com>
This commit is contained in:
zhangxiaoyu 2021-06-01 16:28:36 +08:00
parent 709095931b
commit 02cf571f17
2 changed files with 168 additions and 1 deletions

View 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

View File

@ -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