From: Denys Vlasenko Date: Sat, 29 Jul 2017 00:19:01 +0000 (+0200) Subject: standalone shell / prefer_applets: fix "exe" in comm fields X-Git-Tag: 1_28_0~283 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=147d2ce3dd98945a328ab9390dc562923b17c2f3;p=oweals%2Fbusybox.git standalone shell / prefer_applets: fix "exe" in comm fields function old new delta main 92 106 +14 Signed-off-by: Denys Vlasenko --- diff --git a/libbb/appletlib.c b/libbb/appletlib.c index 7a1a7f005..fa28d433b 100644 --- a/libbb/appletlib.c +++ b/libbb/appletlib.c @@ -34,6 +34,13 @@ # include /* for mallopt */ #endif +#include +#ifndef PR_SET_NAME +#define PR_SET_NAME 15 +#endif +#ifndef PR_GET_NAME +#define PR_GET_NAME 16 +#endif /* Declare _main() */ #define PROTOTYPES @@ -1056,6 +1063,17 @@ int main(int argc UNUSED_PARAM, char **argv) if (applet_name[0] == '-') applet_name++; applet_name = bb_basename(applet_name); + +# if defined(__linux__) + /* If we are a result of execv("/proc/self/exe"), fix ugly comm of "exe" */ + if (ENABLE_FEATURE_SH_STANDALONE + || ENABLE_FEATURE_PREFER_APPLETS + || !BB_MMU + ) { + prctl(PR_SET_NAME, (long)applet_name, 0, 0, 0); + } +# endif + parse_config_file(); /* ...maybe, if FEATURE_SUID_CONFIG */ run_applet_and_exit(applet_name, argv);