busybox: additional 1.14.0 patches
authorPeter Korsgaard <jacmet@sunsite.dk>
Wed, 13 May 2009 07:19:27 +0000 (09:19 +0200)
committerPeter Korsgaard <jacmet@sunsite.dk>
Wed, 13 May 2009 07:20:10 +0000 (09:20 +0200)
The original mdev patch was buggy.

Signed-off-by: Peter Korsgaard <jacmet@sunsite.dk>
package/busybox/busybox-1.14.0-mdev.patch
package/busybox/busybox-1.14.0-sysctl.patch [new file with mode: 0644]

index 4cefd0dd49ec3c0ec83b4f302244e795d1dd05af..21535b03755f14354561bb5218377936f69a6c95 100644 (file)
@@ -1,5 +1,5 @@
 --- busybox-1.14.0/util-linux/mdev.c   Tue Apr 14 23:23:04 2009
-+++ busybox-1.14.0-mdev/util-linux/mdev.c      Sat May  2 16:31:34 2009
++++ busybox-1.14.0-mdev/util-linux/mdev.c      Mon May  4 19:58:47 2009
 @@ -181,7 +181,8 @@
                 * the rest of fields unless keep_matching == 1 */
  
  
                /* 3rd field: mode - device permissions */
                mode = strtoul(tokens[2], NULL, 8);
-@@ -524,7 +525,10 @@
-                               make_device(temp, 1);
-               }
-               else if (strcmp(action, "add") == 0) {
--                      make_device(temp, 0);
-+                      /* N.B. make_device() mangles the device path, so save it */
-+                      char *s = xstrdup(temp);
-+                      make_device(s, 0);
-+                      free(s);
-                       if (ENABLE_FEATURE_MDEV_LOAD_FIRMWARE) {
-                               if (fw)
-                                       load_firmware(fw, temp);
diff --git a/package/busybox/busybox-1.14.0-sysctl.patch b/package/busybox/busybox-1.14.0-sysctl.patch
new file mode 100644 (file)
index 0000000..6738386
--- /dev/null
@@ -0,0 +1,18 @@
+--- busybox-1.14.0/procps/sysctl.c     Tue Apr 14 01:43:09 2009
++++ busybox-1.14.0-sysctl/procps/sysctl.c      Sun May 10 23:40:52 2009
+@@ -214,11 +214,11 @@
+ // (but _whitespace_ from ends should be trimmed first (and we do it right))
+ //TODO: "var==1" is mishandled (must use "=1" as a value, but uses "1")
+       while (config_read(parser, token, 2, 2, "# \t=", PARSE_NORMAL)) {
++              char *tp;
+               sysctl_dots_to_slashes(token[0]);
+-              /* Save ~4 bytes by using parser internals */
+-              /* parser->line is big enough for sprintf */
+-              sprintf(parser->line, "%s=%s", token[0], token[1]);
+-              sysctl_act_recursive(parser->line);
++              tp = xasprintf("%s=%s", token[0], token[1]);
++              sysctl_act_recursive(tp);
++              free(tp);
+       }
+       if (ENABLE_FEATURE_CLEAN_UP)
+               config_close(parser);