summaryrefslogtreecommitdiffstats
path: root/src/util-host-info.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/util-host-info.c')
-rw-r--r--src/util-host-info.c36
1 files changed, 23 insertions, 13 deletions
diff --git a/src/util-host-info.c b/src/util-host-info.c
index c0dd93b..282b2fb 100644
--- a/src/util-host-info.c
+++ b/src/util-host-info.c
@@ -44,7 +44,6 @@ int SCKernelVersionIsAtLeast(int major, int minor)
PCRE2_SIZE eo;
int ret;
int kmajor, kminor;
- PCRE2_UCHAR **list;
/* get local version */
if (uname(&kuname) != 0) {
@@ -79,25 +78,36 @@ int SCKernelVersionIsAtLeast(int major, int minor)
goto error;
}
- pcre2_substring_list_get(version_regex_match, &list, NULL);
+ char majorstr[32];
+ size_t pcre2len = sizeof(majorstr);
+ ret = pcre2_substring_copy_bynumber(
+ version_regex_match, 1, (PCRE2_UCHAR8 *)majorstr, &pcre2len);
+ if (ret < 0) {
+ SCLogError("pcre2_substring_copy_bynumber failed");
+ goto error;
+ }
- bool err = false;
- if (StringParseInt32(&kmajor, 10, 0, (const char *)list[1]) < 0) {
- SCLogError("Invalid value for kmajor: '%s'", list[1]);
- err = true;
+ char minorstr[32];
+ pcre2len = sizeof(majorstr);
+ ret = pcre2_substring_copy_bynumber(
+ version_regex_match, 2, (PCRE2_UCHAR8 *)minorstr, &pcre2len);
+ if (ret < 0) {
+ SCLogError("pcre2_substring_copy_bynumber failed");
+ goto error;
}
- if (StringParseInt32(&kminor, 10, 0, (const char *)list[2]) < 0) {
- SCLogError("Invalid value for kminor: '%s'", list[2]);
- err = true;
+
+ if (StringParseInt32(&kmajor, 10, 0, (const char *)majorstr) < 0) {
+ SCLogError("Invalid value for kmajor: '%s'", minorstr);
+ goto error;
+ }
+ if (StringParseInt32(&kminor, 10, 0, (const char *)minorstr) < 0) {
+ SCLogError("Invalid value for kminor: '%s'", minorstr);
+ goto error;
}
- pcre2_substring_list_free((PCRE2_SPTR *)list);
pcre2_match_data_free(version_regex_match);
pcre2_code_free(version_regex);
- if (err)
- goto error;
-
if (kmajor > major)
return 1;
if (kmajor == major && kminor >= minor)