0
0
mirror of https://github.com/zeromq/libzmq.git synced 2025-01-15 02:07:59 +08:00

Problem: use of unsafe strcpy

Solution: use memcpy with known size instead
This commit is contained in:
Simon Giesecke 2019-12-23 11:06:22 +01:00
parent 334e837b88
commit 3dbbc28bb8

View File

@ -411,6 +411,7 @@ void zmq::print_backtrace (void)
while (unw_step (&cursor) > 0) { while (unw_step (&cursor) > 0) {
unw_word_t offset; unw_word_t offset;
unw_proc_info_t p_info; unw_proc_info_t p_info;
static const char unknown[] = "?";
const char *file_name; const char *file_name;
char *demangled_name; char *demangled_name;
char func_name[256] = ""; char func_name[256] = "";
@ -422,14 +423,14 @@ void zmq::print_backtrace (void)
rc = unw_get_proc_name (&cursor, func_name, 256, &offset); rc = unw_get_proc_name (&cursor, func_name, 256, &offset);
if (rc == -UNW_ENOINFO) if (rc == -UNW_ENOINFO)
strcpy (func_name, "?"); memcpy (func_name, unknown, sizeof unknown);
addr = (void *) (p_info.start_ip + offset); addr = (void *) (p_info.start_ip + offset);
if (dladdr (addr, &dl_info) && dl_info.dli_fname) if (dladdr (addr, &dl_info) && dl_info.dli_fname)
file_name = dl_info.dli_fname; file_name = dl_info.dli_fname;
else else
file_name = "?"; file_name = unknown;
demangled_name = abi::__cxa_demangle (func_name, NULL, NULL, &rc); demangled_name = abi::__cxa_demangle (func_name, NULL, NULL, &rc);