summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--package/busybox/busybox-1.13.0-ash.patch89
1 files changed, 89 insertions, 0 deletions
diff --git a/package/busybox/busybox-1.13.0-ash.patch b/package/busybox/busybox-1.13.0-ash.patch
new file mode 100644
index 000000000..6bfb7219b
--- /dev/null
+++ b/package/busybox/busybox-1.13.0-ash.patch
@@ -0,0 +1,89 @@
+diff -urpN busybox-1.13.0/shell/ash.c busybox-1.13.0-ash/shell/ash.c
+--- busybox-1.13.0/shell/ash.c 2008-10-30 08:41:32.000000000 +0100
++++ busybox-1.13.0-ash/shell/ash.c 2008-11-21 11:38:04.000000000 +0100
+@@ -536,6 +536,7 @@ static const char dolatstr[] ALIGN1 = {
+ #define NHERE 24
+ #define NXHERE 25
+ #define NNOT 26
++#define N_NUMBER 27
+
+ union node;
+
+@@ -7546,43 +7547,44 @@ commandcmd(int argc UNUSED_PARAM, char *
+
+ /* ============ eval.c */
+
+-static int funcblocksize; /* size of structures in function */
+-static int funcstringsize; /* size of strings in node */
+-static void *funcblock; /* block to allocate function from */
+-static char *funcstring; /* block to allocate strings from */
++static int funcblocksize; /* size of structures in function */
++static int funcstringsize; /* size of strings in node */
++static void *funcblock; /* block to allocate function from */
++static char *funcstring; /* block to allocate strings from */
+
+ /* flags in argument to evaltree */
+-#define EV_EXIT 01 /* exit after evaluating tree */
+-#define EV_TESTED 02 /* exit status is checked; ignore -e flag */
++#define EV_EXIT 01 /* exit after evaluating tree */
++#define EV_TESTED 02 /* exit status is checked; ignore -e flag */
+ #define EV_BACKCMD 04 /* command executing within back quotes */
+
+-static const short nodesize[26] = {
+- SHELL_ALIGN(sizeof(struct ncmd)),
+- SHELL_ALIGN(sizeof(struct npipe)),
+- SHELL_ALIGN(sizeof(struct nredir)),
+- SHELL_ALIGN(sizeof(struct nredir)),
+- SHELL_ALIGN(sizeof(struct nredir)),
+- SHELL_ALIGN(sizeof(struct nbinary)),
+- SHELL_ALIGN(sizeof(struct nbinary)),
+- SHELL_ALIGN(sizeof(struct nbinary)),
+- SHELL_ALIGN(sizeof(struct nif)),
+- SHELL_ALIGN(sizeof(struct nbinary)),
+- SHELL_ALIGN(sizeof(struct nbinary)),
+- SHELL_ALIGN(sizeof(struct nfor)),
+- SHELL_ALIGN(sizeof(struct ncase)),
+- SHELL_ALIGN(sizeof(struct nclist)),
+- SHELL_ALIGN(sizeof(struct narg)),
+- SHELL_ALIGN(sizeof(struct narg)),
+- SHELL_ALIGN(sizeof(struct nfile)),
+- SHELL_ALIGN(sizeof(struct nfile)),
+- SHELL_ALIGN(sizeof(struct nfile)),
+- SHELL_ALIGN(sizeof(struct nfile)),
+- SHELL_ALIGN(sizeof(struct nfile)),
+- SHELL_ALIGN(sizeof(struct ndup)),
+- SHELL_ALIGN(sizeof(struct ndup)),
+- SHELL_ALIGN(sizeof(struct nhere)),
+- SHELL_ALIGN(sizeof(struct nhere)),
+- SHELL_ALIGN(sizeof(struct nnot)),
++static const short nodesize[N_NUMBER] = {
++ [NCMD ] = SHELL_ALIGN(sizeof(struct ncmd)),
++ [NPIPE ] = SHELL_ALIGN(sizeof(struct npipe)),
++ [NREDIR ] = SHELL_ALIGN(sizeof(struct nredir)),
++ [NBACKGND ] = SHELL_ALIGN(sizeof(struct nredir)),
++ [NSUBSHELL] = SHELL_ALIGN(sizeof(struct nredir)),
++ [NAND ] = SHELL_ALIGN(sizeof(struct nbinary)),
++ [NOR ] = SHELL_ALIGN(sizeof(struct nbinary)),
++ [NSEMI ] = SHELL_ALIGN(sizeof(struct nbinary)),
++ [NIF ] = SHELL_ALIGN(sizeof(struct nif)),
++ [NWHILE ] = SHELL_ALIGN(sizeof(struct nbinary)),
++ [NUNTIL ] = SHELL_ALIGN(sizeof(struct nbinary)),
++ [NFOR ] = SHELL_ALIGN(sizeof(struct nfor)),
++ [NCASE ] = SHELL_ALIGN(sizeof(struct ncase)),
++ [NCLIST ] = SHELL_ALIGN(sizeof(struct nclist)),
++ [NDEFUN ] = SHELL_ALIGN(sizeof(struct narg)),
++ [NARG ] = SHELL_ALIGN(sizeof(struct narg)),
++ [NTO ] = SHELL_ALIGN(sizeof(struct nfile)),
++ [NTO2 ] = SHELL_ALIGN(sizeof(struct nfile)),
++ [NCLOBBER ] = SHELL_ALIGN(sizeof(struct nfile)),
++ [NFROM ] = SHELL_ALIGN(sizeof(struct nfile)),
++ [NFROMTO ] = SHELL_ALIGN(sizeof(struct nfile)),
++ [NAPPEND ] = SHELL_ALIGN(sizeof(struct nfile)),
++ [NTOFD ] = SHELL_ALIGN(sizeof(struct ndup)),
++ [NFROMFD ] = SHELL_ALIGN(sizeof(struct ndup)),
++ [NHERE ] = SHELL_ALIGN(sizeof(struct nhere)),
++ [NXHERE ] = SHELL_ALIGN(sizeof(struct nhere)),
++ [NNOT ] = SHELL_ALIGN(sizeof(struct nnot)),
+ };
+
+ static void calcsize(union node *n);