Fix version string parsing for Linux 3.0
authorPaul Khuong <pvk@pvk.ca>
Wed, 3 Aug 2011 14:20:41 +0000 (10:20 -0400)
committerPaul Khuong <pvk@pvk.ca>
Wed, 3 Aug 2011 14:20:41 +0000 (10:20 -0400)
 Stop assuming the presence of minor and patch version numbers; missing
 values are defaulted to 0 (e.g. 3.0.0).

 Reported by a few people on IRC.

src/runtime/linux-os.c

index db72fa6..e262f41 100644 (file)
@@ -198,12 +198,18 @@ os_init(char *argv[], char *envp[])
     int patch_version;
     char *p;
     uname(&name);
+
     p=name.release;
     major_version = atoi(p);
-    p=strchr(p,'.')+1;
-    minor_version = atoi(p);
-    p=strchr(p,'.')+1;
-    patch_version = atoi(p);
+    minor_version = patch_version = 0;
+    p=strchr(p,'.');
+    if (p != NULL) {
+            minor_version = atoi(++p);
+            p=strchr(p,'.');
+            if (p != NULL)
+                    patch_version = atoi(++p);
+    }
+
     if (major_version<2) {
         lose("linux kernel version too old: major version=%d (can't run in version < 2.0.0)\n",
              major_version);