summaryrefslogtreecommitdiff
path: root/0042-2268-bugfix-for-the-bliko-zero-value-exception-when-.patch
blob: 2c9f725b9d91da244982c9590530e341c9b81efe (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
From dddba4ec73b56bc2fcf3a95171fad104e962dfda Mon Sep 17 00:00:00 2001
From: zhongtao <zhongtao17@huawei.com>
Date: Wed, 29 Nov 2023 09:33:53 +0000
Subject: [PATCH 42/64] =?UTF-8?q?!2268=20bugfix=20for=20the=20bliko=20zero?=
 =?UTF-8?q?=20value=20exception=20when=20executing=20the=20stats=20command?=
 =?UTF-8?q?=20on=20the=20oci=20container=20*=20bugfix=20for=20the=20bliko?=
 =?UTF-8?q?=20zero=20value=20exception=20when=20executing=20the=20stats=20?=
 =?UTF-8?q?com=E2=80=A6?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

---
 .../modules/runtime/isula/isula_rt_ops.c      | 55 +++++++++++++------
 1 file changed, 38 insertions(+), 17 deletions(-)

diff --git a/src/daemon/modules/runtime/isula/isula_rt_ops.c b/src/daemon/modules/runtime/isula/isula_rt_ops.c
index 5d7ae500..1e2ecdb2 100644
--- a/src/daemon/modules/runtime/isula/isula_rt_ops.c
+++ b/src/daemon/modules/runtime/isula/isula_rt_ops.c
@@ -610,6 +610,43 @@ out:
     return ret;
 }
 
+static void transform_stats_info_from_runtime(shim_client_runtime_stats *stats, struct runtime_container_resources_stats_info *info)
+{
+    if (stats == NULL || stats->data == NULL) {
+        return;
+    }
+    if (stats->data->pids != NULL) {
+        info->pids_current = stats->data->pids->current;
+    }
+    if (stats->data->cpu != NULL && stats->data->cpu->usage != NULL) {
+        info->cpu_use_nanos = stats->data->cpu->usage->total;
+        info->cpu_system_use = stats->data->cpu->usage->kernel;
+    }
+    shim_client_runtime_stats_data_memory *memory = stats->data->memory;
+    if (memory != NULL && memory->usage != NULL) {
+        info->mem_used = memory->usage->usage;
+        info->mem_limit = memory->usage->limit;
+    }
+    if (memory != NULL && memory->raw != NULL) {
+        info->inactive_file_total = memory->raw->total_inactive_file;
+        info->rss_bytes = memory->raw->rss;
+        info->page_faults = memory->raw->pgfault;
+        info->major_page_faults = memory->raw->pgmajfault;
+    }
+    shim_client_runtime_stats_data_blkio *blkio = stats->data->blkio;
+    if (blkio == NULL) {
+        return;
+    }
+    for (size_t i = 0; i < blkio->io_service_bytes_recursive_len; i++) {
+        if (strcasecmp(blkio->io_service_bytes_recursive[i]->op, "read") == 0) {
+            info->blkio_read += blkio->io_service_bytes_recursive[i]->value;
+        }
+        if (strcasecmp(blkio->io_service_bytes_recursive[i]->op, "write") == 0) {
+            info->blkio_write += blkio->io_service_bytes_recursive[i]->value;
+        }
+    }
+}
+
 static int runtime_call_stats(const char *workdir, const char *runtime, const char *id,
                               struct runtime_container_resources_stats_info *info)
 {
@@ -658,23 +695,7 @@ static int runtime_call_stats(const char *workdir, const char *runtime, const ch
         goto out;
     }
 
-    if (stats != NULL && stats->data != NULL && stats->data->pids != NULL) {
-        info->pids_current = stats->data->pids->current;
-    }
-    if (stats != NULL && stats->data != NULL && stats->data->cpu != NULL && stats->data->cpu->usage) {
-        info->cpu_use_nanos = stats->data->cpu->usage->total;
-        info->cpu_system_use = stats->data->cpu->usage->kernel;
-    }
-    if (stats != NULL && stats->data != NULL && stats->data->memory != NULL && stats->data->memory->usage) {
-        info->mem_used = stats->data->memory->usage->usage;
-        info->mem_limit = stats->data->memory->usage->limit;
-    }
-    if (stats != NULL && stats->data != NULL && stats->data->memory != NULL && stats->data->memory->raw) {
-        info->inactive_file_total = stats->data->memory->raw->total_inactive_file;
-        info->rss_bytes = stats->data->memory->raw->rss;
-        info->page_faults = stats->data->memory->raw->pgfault;
-        info->major_page_faults = stats->data->memory->raw->pgmajfault;
-    }
+    transform_stats_info_from_runtime(stats, info);
 
 out:
     free_shim_client_runtime_stats(stats);
-- 
2.42.0