加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
backport-Fix-a-memleak-on-invalid-command-line-options.patch 2.27 KB
一键复制 编辑 原始数据 按行查看 历史
From 1825dbf8244b129665a69481c4537a57b9e03a8f Mon Sep 17 00:00:00 2001
From: Panu Matilainen <pmatilai@redhat.com>
Date: Wed, 21 Feb 2024 16:07:05 +0200
Subject: [PATCH] Fix a memleak on invalid command line options
The OS will clean it up yes, but in the meanwhile ASAN (when enabled)
blew up on your face and scared you silly. Use the opportunity to add a
test for a test on invalid option.
---
lib/poptALL.c | 11 ++++++++---
tests/rpmgeneral.at | 10 +++++++++-
2 files changed, 17 insertions(+), 4 deletions(-)
diff --git a/lib/poptALL.c b/lib/poptALL.c
index b24c13e..a2bbedc 100644
--- a/lib/poptALL.c
+++ b/lib/poptALL.c
@@ -296,7 +296,7 @@ rpmcliFini(poptContext optCon)
poptContext
rpmcliInit(int argc, char *const argv[], struct poptOption * optionsTable)
{
- poptContext optCon;
+ poptContext optCon = NULL;
int rc;
const char *ctx, *execPath;
@@ -336,14 +336,14 @@ rpmcliInit(int argc, char *const argv[], struct poptOption * optionsTable)
while ((rc = poptGetNextOpt(optCon)) > 0) {
fprintf(stderr, _("%s: option table misconfigured (%d)\n"),
xgetprogname(), rc);
- exit(EXIT_FAILURE);
+ goto err;
}
if (rc < -1) {
fprintf(stderr, "%s: %s: %s\n", xgetprogname(),
poptBadOption(optCon, POPT_BADOPTION_NOALIAS),
poptStrerror(rc));
- exit(EXIT_FAILURE);
+ goto err;
}
/* Read rpm configuration (if not already read). */
@@ -355,4 +355,9 @@ rpmcliInit(int argc, char *const argv[], struct poptOption * optionsTable)
}
return optCon;
+
+err:
+ poptFreeContext(optCon);
+ exit(EXIT_FAILURE);
+ return NULL; /* not reached */
}
diff --git a/tests/rpmgeneral.at b/tests/rpmgeneral.at
index cf1f507..4281315 100644
--- a/tests/rpmgeneral.at
+++ b/tests/rpmgeneral.at
@@ -26,7 +26,6 @@ RPMTEST_CHECK([runroot rpm --version],[0],
])
RPMTEST_CLEANUP
-
# ------------------------------
AT_SETUP([rpmbuild --version])
AT_KEYWORDS([basic])
@@ -35,6 +34,15 @@ RPMTEST_CHECK([runroot rpmbuild --version],[0],
])
RPMTEST_CLEANUP
+AT_SETUP([rpm invalid option])
+AT_KEYWORDS([basic])
+AT_CHECK([runroot rpm --badopt],
+[1],
+[],
+[rpm: --badopt: unknown option
+])
+AT_CLEANUP
+
# Check that libtool versioning matches expectations, it's easy to screw up.
AT_SETUP([rpm library version])
AT_KEYWORDS([basic])
--
2.33.0
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化