diff options
author | Jerry Jelinek <jerry.jelinek@joyent.com> | 2018-10-15 13:44:56 +0000 |
---|---|---|
committer | Jerry Jelinek <jerry.jelinek@joyent.com> | 2018-10-15 13:44:56 +0000 |
commit | 16d3daed247b1695bbf21679b70086c38d044eb7 (patch) | |
tree | b6f459dfe48396dbd24f046a2f746892a3d8e630 /usr/src/lib/libdemangle/common/demangle.c | |
parent | 8fe8a39ea9f7811d9c1e2e48a46932561906883f (diff) | |
parent | a6d101109bfb442cf0db6d8ebb5fb7c32cb16d7e (diff) | |
download | illumos-joyent-16d3daed247b1695bbf21679b70086c38d044eb7.tar.gz |
[illumos-gate merge]
commit a6d101109bfb442cf0db6d8ebb5fb7c32cb16d7e
9472 Add smbutil discon command
commit 4226f635096bf9d814aa9fb335518c4855bbe3a3
6375 Add native name demangling support
commit 83b4671e6262c5aa6b4f9fb5a384b1946dfc2e7f
9664 loader: need UEFI32 support
commit e1bf37b1abeb6653a6e35e2bd6924131cced1efe
9884 cw(1) should use -fpic rather than -Kpic
Conflicts:
usr/src/test/util-tests/tests/Makefile
usr/src/cmd/mdb/common/mdb/mdb_demangle.c
Diffstat (limited to 'usr/src/lib/libdemangle/common/demangle.c')
-rw-r--r-- | usr/src/lib/libdemangle/common/demangle.c | 87 |
1 files changed, 87 insertions, 0 deletions
diff --git a/usr/src/lib/libdemangle/common/demangle.c b/usr/src/lib/libdemangle/common/demangle.c new file mode 100644 index 0000000000..e827fd8cec --- /dev/null +++ b/usr/src/lib/libdemangle/common/demangle.c @@ -0,0 +1,87 @@ +/* + * This file and its contents are supplied under the terms of the + * Common Development and Distribution License ("CDDL"), version 1.0. + * You may only use this file in accordance with the terms of version + * 1.0 of the CDDL. + * + * A full copy of the text of the CDDL should have accompanied this + * source. A copy of the CDDL is also available via the Internet at + * http://www.illumos.org/license/CDDL. + */ + +/* + * Copyright 2018 Jason King + */ + +#include <stdlib.h> +#include <string.h> +#include <errno.h> +#include <pthread.h> +#include <sys/debug.h> +#include "demangle-sys.h" +#include "demangle_int.h" + +#define DEMANGLE_DEBUG "DEMANGLE_DEBUG" + +static pthread_once_t debug_once = PTHREAD_ONCE_INIT; +volatile boolean_t demangle_debug; + +static sysdem_lang_t +detect_lang(const char *str) +{ + size_t n = strlen(str); + + if (n < 3 || str[0] != '_') + return (SYSDEM_LANG_AUTO); + + switch (str[1]) { + case 'Z': + return (SYSDEM_LANG_CPP); + + case '_': + break; + + default: + return (SYSDEM_LANG_AUTO); + } + + /* why they use ___Z sometimes is puzzling... *sigh* */ + if (str[2] == '_' && str[3] == 'Z') + return (SYSDEM_LANG_CPP); + + return (SYSDEM_LANG_AUTO); +} + +static void +check_debug(void) +{ + if (getenv(DEMANGLE_DEBUG)) + demangle_debug = B_TRUE; +} + +char * +sysdemangle(const char *str, sysdem_lang_t lang, sysdem_ops_t *ops) +{ + VERIFY0(pthread_once(&debug_once, check_debug)); + + if (ops == NULL) + ops = sysdem_ops_default; + + if (lang == SYSDEM_LANG_AUTO) { + lang = detect_lang(str); + if (lang == SYSDEM_LANG_AUTO) { + errno = ENOTSUP; + return (NULL); + } + } + + switch (lang) { + case SYSDEM_LANG_AUTO: + break; + case SYSDEM_LANG_CPP: + return (cpp_demangle(str, ops)); + } + + errno = ENOTSUP; + return (NULL); +} |