41 lines
1.1 KiB
Diff
41 lines
1.1 KiB
Diff
|
|
From 8fd02a2f5bd552894ef415b7e5c525be6bc6c3e3 Mon Sep 17 00:00:00 2001
|
||
|
|
From: Jie Wang <wangjie125@huawei.com>
|
||
|
|
Date: Mon, 7 Mar 2022 16:08:56 +0800
|
||
|
|
Subject: [PATCH] ioctl: add the memory free operation after send_ioctl call
|
||
|
|
fails
|
||
|
|
|
||
|
|
The memory is not freed after send_ioctl fails in function do_gtunable and
|
||
|
|
do_stunable. This will cause memory leaks.
|
||
|
|
|
||
|
|
So this patch adds memory free operation after send_ioctl call fails.
|
||
|
|
|
||
|
|
Fixes: b717ed22d984 ("ethtool: add support for get/set ethtool_tunable")
|
||
|
|
Signed-off-by: Jie Wang <wangjie125@huawei.com>
|
||
|
|
---
|
||
|
|
ethtool.c | 2 ++
|
||
|
|
1 file changed, 2 insertions(+)
|
||
|
|
|
||
|
|
diff --git a/ethtool.c b/ethtool.c
|
||
|
|
index 28ecf69..4f5c234 100644
|
||
|
|
--- a/ethtool.c
|
||
|
|
+++ b/ethtool.c
|
||
|
|
@@ -5097,6 +5097,7 @@ static int do_stunable(struct cmd_context *ctx)
|
||
|
|
ret = send_ioctl(ctx, tuna);
|
||
|
|
if (ret) {
|
||
|
|
perror(tunable_strings[tuna->id]);
|
||
|
|
+ free(tuna);
|
||
|
|
return ret;
|
||
|
|
}
|
||
|
|
free(tuna);
|
||
|
|
@@ -5174,6 +5175,7 @@ static int do_gtunable(struct cmd_context *ctx)
|
||
|
|
ret = send_ioctl(ctx, tuna);
|
||
|
|
if (ret) {
|
||
|
|
fprintf(stderr, "%s: Cannot get tunable\n", ts);
|
||
|
|
+ free(tuna);
|
||
|
|
return ret;
|
||
|
|
}
|
||
|
|
print_tunable(tuna);
|
||
|
|
--
|
||
|
|
2.33.0
|
||
|
|
|