several fixes from openWRT project
This commit is contained in:
parent
22f6dcb47c
commit
e175ff252f
@ -249,7 +249,8 @@ enum {
|
|||||||
/* builtins */
|
/* builtins */
|
||||||
enum {
|
enum {
|
||||||
B_a2=0, B_ix, B_ma, B_sp, B_ss, B_ti, B_lo, B_up,
|
B_a2=0, B_ix, B_ma, B_sp, B_ss, B_ti, B_lo, B_up,
|
||||||
B_ge, B_gs, B_su
|
B_ge, B_gs, B_su,
|
||||||
|
B_an, B_co, B_ls, B_or, B_rs, B_xo,
|
||||||
};
|
};
|
||||||
|
|
||||||
/* tokens and their corresponding info values */
|
/* tokens and their corresponding info values */
|
||||||
@ -289,6 +290,8 @@ static char * const tokenlist =
|
|||||||
"\5while" NTC
|
"\5while" NTC
|
||||||
"\4else" NTC
|
"\4else" NTC
|
||||||
|
|
||||||
|
"\3and" "\5compl" "\6lshift" "\2or"
|
||||||
|
"\6rshift" "\3xor"
|
||||||
"\5close" "\6system" "\6fflush" "\5atan2" /* BUILTIN */
|
"\5close" "\6system" "\6fflush" "\5atan2" /* BUILTIN */
|
||||||
"\3cos" "\3exp" "\3int" "\3log"
|
"\3cos" "\3exp" "\3int" "\3log"
|
||||||
"\4rand" "\3sin" "\4sqrt" "\5srand"
|
"\4rand" "\3sin" "\4sqrt" "\5srand"
|
||||||
@ -342,6 +345,8 @@ static const uint32_t tokeninfo[] = {
|
|||||||
ST_WHILE,
|
ST_WHILE,
|
||||||
0,
|
0,
|
||||||
|
|
||||||
|
OC_B|B_an|P(0x83), OC_B|B_co|P(0x41), OC_B|B_ls|P(0x83), OC_B|B_or|P(0x83),
|
||||||
|
OC_B|B_rs|P(0x83), OC_B|B_xo|P(0x83),
|
||||||
OC_FBLTIN|Sx|F_cl, OC_FBLTIN|Sx|F_sy, OC_FBLTIN|Sx|F_ff, OC_B|B_a2|P(0x83),
|
OC_FBLTIN|Sx|F_cl, OC_FBLTIN|Sx|F_sy, OC_FBLTIN|Sx|F_ff, OC_B|B_a2|P(0x83),
|
||||||
OC_FBLTIN|Nx|F_co, OC_FBLTIN|Nx|F_ex, OC_FBLTIN|Nx|F_in, OC_FBLTIN|Nx|F_lg,
|
OC_FBLTIN|Nx|F_co, OC_FBLTIN|Nx|F_ex, OC_FBLTIN|Nx|F_in, OC_FBLTIN|Nx|F_lg,
|
||||||
OC_FBLTIN|F_rn, OC_FBLTIN|Nx|F_si, OC_FBLTIN|Nx|F_sq, OC_FBLTIN|Nx|F_sr,
|
OC_FBLTIN|F_rn, OC_FBLTIN|Nx|F_si, OC_FBLTIN|Nx|F_sq, OC_FBLTIN|Nx|F_sr,
|
||||||
@ -1923,6 +1928,30 @@ static var *exec_builtin(node *op, var *res)
|
|||||||
s[n] = '\0';
|
s[n] = '\0';
|
||||||
setvar_p(res, s);
|
setvar_p(res, s);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case B_an:
|
||||||
|
setvar_i(res, (long)getvar_i(av[0]) & (long)getvar_i(av[1]));
|
||||||
|
break;
|
||||||
|
|
||||||
|
case B_co:
|
||||||
|
setvar_i(res, ~(long)getvar_i(av[0]));
|
||||||
|
break;
|
||||||
|
|
||||||
|
case B_ls:
|
||||||
|
setvar_i(res, (long)getvar_i(av[0]) << (long)getvar_i(av[1]));
|
||||||
|
break;
|
||||||
|
|
||||||
|
case B_or:
|
||||||
|
setvar_i(res, (long)getvar_i(av[0]) | (long)getvar_i(av[1]));
|
||||||
|
break;
|
||||||
|
|
||||||
|
case B_rs:
|
||||||
|
setvar_i(res, (long)((unsigned long)getvar_i(av[0]) >> (unsigned long)getvar_i(av[1])));
|
||||||
|
break;
|
||||||
|
|
||||||
|
case B_xo:
|
||||||
|
setvar_i(res, (long)getvar_i(av[0]) ^ (long)getvar_i(av[1]));
|
||||||
|
break;
|
||||||
|
|
||||||
case B_lo:
|
case B_lo:
|
||||||
to_xxx = tolower;
|
to_xxx = tolower;
|
||||||
|
@ -3211,6 +3211,7 @@ USE_FEATURE_START_STOP_DAEMON_FANCY( \
|
|||||||
"\t-n,\t--now\tExit with failure if lease cannot be immediately negotiated\n" \
|
"\t-n,\t--now\tExit with failure if lease cannot be immediately negotiated\n" \
|
||||||
"\t-p,\t--pidfile=file\tStore process ID of daemon in file\n" \
|
"\t-p,\t--pidfile=file\tStore process ID of daemon in file\n" \
|
||||||
"\t-q,\t--quit\tQuit after obtaining lease\n" \
|
"\t-q,\t--quit\tQuit after obtaining lease\n" \
|
||||||
|
"\t-R,\t--release\tRelease IP on quit\n" \
|
||||||
"\t-r,\t--request=IP\tIP address to request (default: none)\n" \
|
"\t-r,\t--request=IP\tIP address to request (default: none)\n" \
|
||||||
"\t-s,\t--script=file\tRun file at dhcp events (default: /usr/share/udhcpc/default.script)\n" \
|
"\t-s,\t--script=file\tRun file at dhcp events (default: /usr/share/udhcpc/default.script)\n" \
|
||||||
"\t-t,\t--retries=NUM\tSend up to NUM request packets\n"\
|
"\t-t,\t--retries=NUM\tSend up to NUM request packets\n"\
|
||||||
|
@ -318,7 +318,7 @@ static int new_password(const struct passwd *pw, int amroot, int algo)
|
|||||||
} else {
|
} else {
|
||||||
orig[0] = '\0';
|
orig[0] = '\0';
|
||||||
}
|
}
|
||||||
cp = bb_askpass(0, "Enter the new password (minimum of 5, maximum of 8 characters).\n"
|
cp = bb_askpass(0, "Enter the new password (minimum of 5 characters).\n"
|
||||||
"Please use a combination of upper and lower case letters and numbers.\n"
|
"Please use a combination of upper and lower case letters and numbers.\n"
|
||||||
"Enter new password: ");
|
"Enter new password: ");
|
||||||
if (!cp ) {
|
if (!cp ) {
|
||||||
|
@ -53,6 +53,7 @@ struct client_config_t client_config = {
|
|||||||
.abort_if_no_lease = 0,
|
.abort_if_no_lease = 0,
|
||||||
.foreground = 0,
|
.foreground = 0,
|
||||||
.quit_after_lease = 0,
|
.quit_after_lease = 0,
|
||||||
|
.release_on_quit = 0,
|
||||||
.background_if_no_lease = 0,
|
.background_if_no_lease = 0,
|
||||||
.interface = "eth0",
|
.interface = "eth0",
|
||||||
.pidfile = NULL,
|
.pidfile = NULL,
|
||||||
@ -169,6 +170,7 @@ int udhcpc_main(int argc, char *argv[])
|
|||||||
{"now", no_argument, 0, 'n'},
|
{"now", no_argument, 0, 'n'},
|
||||||
{"pidfile", required_argument, 0, 'p'},
|
{"pidfile", required_argument, 0, 'p'},
|
||||||
{"quit", no_argument, 0, 'q'},
|
{"quit", no_argument, 0, 'q'},
|
||||||
|
{"release", no_argument, 0, 'R'},
|
||||||
{"request", required_argument, 0, 'r'},
|
{"request", required_argument, 0, 'r'},
|
||||||
{"script", required_argument, 0, 's'},
|
{"script", required_argument, 0, 's'},
|
||||||
{"timeout", required_argument, 0, 'T'},
|
{"timeout", required_argument, 0, 'T'},
|
||||||
@ -180,7 +182,7 @@ int udhcpc_main(int argc, char *argv[])
|
|||||||
/* get options */
|
/* get options */
|
||||||
while (1) {
|
while (1) {
|
||||||
int option_index = 0;
|
int option_index = 0;
|
||||||
c = getopt_long(argc, argv, "c:CV:fbH:h:F:i:np:qr:s:T:t:v", arg_options, &option_index);
|
c = getopt_long(argc, argv, "c:CV:fbH:h:F:i:np:qRr:s:T:t:v", arg_options, &option_index);
|
||||||
if (c == -1) break;
|
if (c == -1) break;
|
||||||
|
|
||||||
switch (c) {
|
switch (c) {
|
||||||
@ -250,6 +252,9 @@ int udhcpc_main(int argc, char *argv[])
|
|||||||
case 'q':
|
case 'q':
|
||||||
client_config.quit_after_lease = 1;
|
client_config.quit_after_lease = 1;
|
||||||
break;
|
break;
|
||||||
|
case 'R':
|
||||||
|
client_config.release_on_quit = 1;
|
||||||
|
break;
|
||||||
case 'r':
|
case 'r':
|
||||||
requested_ip = inet_addr(optarg);
|
requested_ip = inet_addr(optarg);
|
||||||
break;
|
break;
|
||||||
@ -495,8 +500,11 @@ int udhcpc_main(int argc, char *argv[])
|
|||||||
|
|
||||||
state = BOUND;
|
state = BOUND;
|
||||||
change_mode(LISTEN_NONE);
|
change_mode(LISTEN_NONE);
|
||||||
if (client_config.quit_after_lease)
|
if (client_config.quit_after_lease) {
|
||||||
|
if (client_config.release_on_quit)
|
||||||
|
perform_release();
|
||||||
return 0;
|
return 0;
|
||||||
|
}
|
||||||
if (!client_config.foreground)
|
if (!client_config.foreground)
|
||||||
client_background();
|
client_background();
|
||||||
|
|
||||||
@ -526,6 +534,8 @@ int udhcpc_main(int argc, char *argv[])
|
|||||||
break;
|
break;
|
||||||
case SIGTERM:
|
case SIGTERM:
|
||||||
bb_info_msg("Received SIGTERM");
|
bb_info_msg("Received SIGTERM");
|
||||||
|
if (client_config.release_on_quit)
|
||||||
|
perform_release();
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
} else if (retval == -1 && errno == EINTR) {
|
} else if (retval == -1 && errno == EINTR) {
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
struct client_config_t {
|
struct client_config_t {
|
||||||
char foreground; /* Do not fork */
|
char foreground; /* Do not fork */
|
||||||
char quit_after_lease; /* Quit after obtaining lease */
|
char quit_after_lease; /* Quit after obtaining lease */
|
||||||
|
char release_on_quit; /* perform release on quit */
|
||||||
char abort_if_no_lease; /* Abort if no lease */
|
char abort_if_no_lease; /* Abort if no lease */
|
||||||
char background_if_no_lease; /* Fork to background if no lease */
|
char background_if_no_lease; /* Fork to background if no lease */
|
||||||
char *interface; /* The name of the interface to use */
|
char *interface; /* The name of the interface to use */
|
||||||
|
@ -42,8 +42,11 @@ struct dhcp_option dhcp_options[] = {
|
|||||||
{"dhcptype", OPTION_U8, 0x35},
|
{"dhcptype", OPTION_U8, 0x35},
|
||||||
{"serverid", OPTION_IP, 0x36},
|
{"serverid", OPTION_IP, 0x36},
|
||||||
{"message", OPTION_STRING, 0x38},
|
{"message", OPTION_STRING, 0x38},
|
||||||
|
{"vendorclass", OPTION_STRING, 0x3C},
|
||||||
|
{"clientid", OPTION_STRING, 0x3D},
|
||||||
{"tftp", OPTION_STRING, 0x42},
|
{"tftp", OPTION_STRING, 0x42},
|
||||||
{"bootfile", OPTION_STRING, 0x43},
|
{"bootfile", OPTION_STRING, 0x43},
|
||||||
|
{"userclass", OPTION_STRING, 0x4D},
|
||||||
{"", 0x00, 0x00}
|
{"", 0x00, 0x00}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -23,7 +23,7 @@ enum {
|
|||||||
#define OPTION_LIST 0x20 /* There can be a list of 1 or more of these */
|
#define OPTION_LIST 0x20 /* There can be a list of 1 or more of these */
|
||||||
|
|
||||||
struct dhcp_option {
|
struct dhcp_option {
|
||||||
char name[10];
|
char name[12];
|
||||||
char flags;
|
char flags;
|
||||||
uint8_t code;
|
uint8_t code;
|
||||||
};
|
};
|
||||||
|
39
shell/ash.c
39
shell/ash.c
@ -1384,6 +1384,13 @@ static const struct builtincmd builtincmd[] = {
|
|||||||
|
|
||||||
#define NUMBUILTINS (sizeof (builtincmd) / sizeof (struct builtincmd) )
|
#define NUMBUILTINS (sizeof (builtincmd) / sizeof (struct builtincmd) )
|
||||||
|
|
||||||
|
static const char *safe_applets[] = {
|
||||||
|
"[", "test", "echo", "cat",
|
||||||
|
"ln", "cp", "touch", "mkdir", "rm",
|
||||||
|
"cut", "hexdump", "awk", "sort",
|
||||||
|
"find", "xargs", "ls", "dd",
|
||||||
|
"chown", "chmod"
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
struct cmdentry {
|
struct cmdentry {
|
||||||
@ -2034,6 +2041,19 @@ static int dotrap(void);
|
|||||||
static void setinteractive(int);
|
static void setinteractive(int);
|
||||||
static void exitshell(void) ATTRIBUTE_NORETURN;
|
static void exitshell(void) ATTRIBUTE_NORETURN;
|
||||||
|
|
||||||
|
|
||||||
|
static int is_safe_applet(char *name)
|
||||||
|
{
|
||||||
|
int n = sizeof(safe_applets) / sizeof(char *);
|
||||||
|
int i;
|
||||||
|
for (i = 0; i < n; i++)
|
||||||
|
if (strcmp(safe_applets[i], name) == 0)
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This routine is called when an error or an interrupt occurs in an
|
* This routine is called when an error or an interrupt occurs in an
|
||||||
* interactive shell and control is returned to the main command loop.
|
* interactive shell and control is returned to the main command loop.
|
||||||
@ -3681,6 +3701,7 @@ shellexec(char **argv, const char *path, int idx)
|
|||||||
clearredir(1);
|
clearredir(1);
|
||||||
envp = environment();
|
envp = environment();
|
||||||
if (strchr(argv[0], '/') != NULL
|
if (strchr(argv[0], '/') != NULL
|
||||||
|
|| is_safe_applet(argv[0])
|
||||||
#ifdef CONFIG_FEATURE_SH_STANDALONE_SHELL
|
#ifdef CONFIG_FEATURE_SH_STANDALONE_SHELL
|
||||||
|| find_applet_by_name(argv[0])
|
|| find_applet_by_name(argv[0])
|
||||||
#endif
|
#endif
|
||||||
@ -3723,6 +3744,18 @@ static void
|
|||||||
tryexec(char *cmd, char **argv, char **envp)
|
tryexec(char *cmd, char **argv, char **envp)
|
||||||
{
|
{
|
||||||
int repeated = 0;
|
int repeated = 0;
|
||||||
|
struct BB_applet *a;
|
||||||
|
int argc = 0;
|
||||||
|
char **c;
|
||||||
|
|
||||||
|
if(strchr(cmd, '/') == NULL && is_safe_applet(cmd) && (a = find_applet_by_name(cmd)) != NULL) {
|
||||||
|
c = argv;
|
||||||
|
while (*c != NULL) {
|
||||||
|
c++; argc++;
|
||||||
|
}
|
||||||
|
bb_applet_name = cmd;
|
||||||
|
exit(a->main(argc, argv));
|
||||||
|
}
|
||||||
#ifdef CONFIG_FEATURE_SH_STANDALONE_SHELL
|
#ifdef CONFIG_FEATURE_SH_STANDALONE_SHELL
|
||||||
if(find_applet_by_name(cmd) != NULL) {
|
if(find_applet_by_name(cmd) != NULL) {
|
||||||
/* re-exec ourselves with the new arguments */
|
/* re-exec ourselves with the new arguments */
|
||||||
@ -3905,6 +3938,12 @@ find_command(char *name, struct cmdentry *entry, int act, const char *path)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
if (is_safe_applet(name)) {
|
||||||
|
entry->cmdtype = CMDNORMAL;
|
||||||
|
entry->u.index = -1;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
updatetbl = (path == pathval());
|
updatetbl = (path == pathval());
|
||||||
if (!updatetbl) {
|
if (!updatetbl) {
|
||||||
act |= DO_ALTPATH;
|
act |= DO_ALTPATH;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user