From: Alexey Izbyshev Date: Fri, 10 Mar 2023 17:00:31 +0000 (+0300) Subject: getopt: fix null pointer arithmetic ub X-Git-Url: http://nsz.repo.hu/git/?p=musl;a=commitdiff_plain;h=6d322159c633050a405b03b927db76b89e402014 getopt: fix null pointer arithmetic ub When an option that requires an argument is the last character of argv[argc-1], getopt computes argv[argc] + optpos. While optpos is always zero in this case, adding it to null pointer is still undefined. --- diff --git a/src/misc/getopt.c b/src/misc/getopt.c index c3f66995..b02b81c3 100644 --- a/src/misc/getopt.c +++ b/src/misc/getopt.c @@ -87,7 +87,8 @@ int getopt(int argc, char * const argv[], const char *optstring) if (optstring[i] == ':') { optarg = 0; if (optstring[i+1] != ':' || optpos) { - optarg = argv[optind++] + optpos; + optarg = argv[optind++]; + if (optpos) optarg += optpos; optpos = 0; } if (optind > argc) {