open-iscsi/0012-Fix-issue-where-iscsi-iname-p-core-dumps.patch

56 lines
1.4 KiB
Diff
Raw Normal View History

2020-07-10 14:33:48 +08:00
From 40454759ba37c69c59473d63635cfccc7bb5ec8d Mon Sep 17 00:00:00 2001
2020-05-12 17:27:41 +08:00
From: Lee Duncan <lduncan@suse.com>
Date: Tue, 12 May 2020 16:01:50 +0800
Subject: [PATCH] Fix issue where 'iscsi-iname -p' core dumps
Fix issue where 'iscsi-iname -p' core dumps
Signed-off-by: Lee Duncan <lduncan@suse.com>
---
2020-07-10 14:33:48 +08:00
utils/iscsi-iname.c | 17 +++++++++++++----
1 file changed, 13 insertions(+), 4 deletions(-)
2020-05-12 17:27:41 +08:00
diff --git a/utils/iscsi-iname.c b/utils/iscsi-iname.c
2020-07-10 14:33:48 +08:00
index da850dc..d1c067b 100644
2020-05-12 17:27:41 +08:00
--- a/utils/iscsi-iname.c
+++ b/utils/iscsi-iname.c
2020-07-10 14:33:48 +08:00
@@ -40,6 +40,13 @@
* a seperator and 12 characters (6 random bytes in hex representation) */
#define PREFIX_MAX_LEN 210
2020-05-12 17:27:41 +08:00
+static void usage(void)
+{
+ fprintf(stderr, "Usage: iscsi-iname [-h | --help | -p <prefix>]\n");
+ fprintf(stderr, "where <prefix> has max length of %d\n",
+ PREFIX_MAX_LEN);
+}
+
int
main(int argc, char *argv[])
{
2020-07-10 14:33:48 +08:00
@@ -68,15 +75,17 @@ main(int argc, char *argv[])
2020-05-12 17:27:41 +08:00
"on every invocation.\n");
exit(0);
} else if ( strcmp(prefix, "-p") == 0 ) {
2020-07-10 14:33:48 +08:00
+ if (argc != 3){
2020-05-12 17:27:41 +08:00
+ usage();
+ exit(1);
+ }
prefix = argv[2];
if (strnlen(prefix, PREFIX_MAX_LEN + 1) > PREFIX_MAX_LEN) {
2020-07-10 14:33:48 +08:00
- printf("Error: Prefix cannot exceed %d "
- "characters.\n", PREFIX_MAX_LEN);
2020-05-12 17:27:41 +08:00
+ usage();
2020-07-10 14:33:48 +08:00
exit(1);
2020-05-12 17:27:41 +08:00
}
} else {
- printf("\nUsage: iscsi-iname [-h | --help | "
- "-p <prefix>]\n");
+ usage();
exit(0);
}
} else {
--
1.8.3.1