提交 37862f19 编写于 作者: A aph

8076475: Misuses of strncpy/strncat

Summary: Various small fixes around strncpy and strncat
Reviewed-by: andrew
上级 9f54daa4
...@@ -215,7 +215,12 @@ lib_info* add_lib_info_fd(struct ps_prochandle* ph, const char* libname, int fd, ...@@ -215,7 +215,12 @@ lib_info* add_lib_info_fd(struct ps_prochandle* ph, const char* libname, int fd,
return NULL; return NULL;
} }
strncpy(newlib->name, libname, sizeof(newlib->name)); if (strlen(libname) >= sizeof(newlib->name)) {
print_debug("libname %s too long\n", libname);
return NULL;
}
strcpy(newlib->name, libname);
newlib->base = base; newlib->base = base;
if (fd == -1) { if (fd == -1) {
......
...@@ -159,7 +159,12 @@ lib_info* add_lib_info_fd(struct ps_prochandle* ph, const char* libname, int fd, ...@@ -159,7 +159,12 @@ lib_info* add_lib_info_fd(struct ps_prochandle* ph, const char* libname, int fd,
return NULL; return NULL;
} }
strncpy(newlib->name, libname, sizeof(newlib->name)); if (strlen(libname) >= sizeof(newlib->name)) {
print_debug("libname %s too long\n", libname);
return NULL;
}
strcpy(newlib->name, libname);
newlib->base = base; newlib->base = base;
if (fd == -1) { if (fd == -1) {
......
...@@ -543,13 +543,14 @@ name_for_methodPtr(jvm_agent_t* J, uint64_t methodPtr, char * result, size_t siz ...@@ -543,13 +543,14 @@ name_for_methodPtr(jvm_agent_t* J, uint64_t methodPtr, char * result, size_t siz
CHECK_FAIL(err); CHECK_FAIL(err);
result[0] = '\0'; result[0] = '\0';
strncat(result, klassString, size); if (snprintf(result, size,
size -= strlen(klassString); "%s.%s%s",
strncat(result, ".", size); klassString,
size -= 1; nameString,
strncat(result, nameString, size); signatureString) >= size) {
size -= strlen(nameString); // truncation
strncat(result, signatureString, size); goto fail;
}
if (nameString != NULL) free(nameString); if (nameString != NULL) free(nameString);
if (klassString != NULL) free(klassString); if (klassString != NULL) free(klassString);
...@@ -1056,9 +1057,9 @@ name_for_nmethod(jvm_agent_t* J, ...@@ -1056,9 +1057,9 @@ name_for_nmethod(jvm_agent_t* J,
CHECK_FAIL(err); CHECK_FAIL(err);
} }
if (deoptimized) { if (deoptimized) {
strncat(result + 1, " [deoptimized frame]; ", size-1); strncat(result, " [deoptimized frame]; ", size - strlen(result) - 1);
} else { } else {
strncat(result + 1, " [compiled] ", size-1); strncat(result, " [compiled] ", size - strlen(result) - 1);
} }
if (debug) if (debug)
fprintf(stderr, "name_for_nmethod: END: method name: %s, vf_cnt: %d\n\n", fprintf(stderr, "name_for_nmethod: END: method name: %s, vf_cnt: %d\n\n",
......
...@@ -97,6 +97,7 @@ bool MachODecoder::decode(address addr, char *buf, ...@@ -97,6 +97,7 @@ bool MachODecoder::decode(address addr, char *buf,
char * symname = mach_find_in_stringtable((char*) ((uintptr_t)mach_base + stroff), strsize, found_strx); char * symname = mach_find_in_stringtable((char*) ((uintptr_t)mach_base + stroff), strsize, found_strx);
if (symname) { if (symname) {
strncpy(buf, symname, buflen); strncpy(buf, symname, buflen);
buf[buflen - 1] = '\0';
return true; return true;
} }
DEBUG_ONLY(tty->print_cr("no string or null string found.")); DEBUG_ONLY(tty->print_cr("no string or null string found."));
......
...@@ -543,13 +543,14 @@ name_for_methodPtr(jvm_agent_t* J, uint64_t methodPtr, char * result, size_t siz ...@@ -543,13 +543,14 @@ name_for_methodPtr(jvm_agent_t* J, uint64_t methodPtr, char * result, size_t siz
CHECK_FAIL(err); CHECK_FAIL(err);
result[0] = '\0'; result[0] = '\0';
strncat(result, klassString, size); if (snprintf(result, size,
size -= strlen(klassString); "%s.%s%s",
strncat(result, ".", size); klassString,
size -= 1; nameString,
strncat(result, nameString, size); signatureString) >= size) {
size -= strlen(nameString); // truncation
strncat(result, signatureString, size); goto fail;
}
if (nameString != NULL) free(nameString); if (nameString != NULL) free(nameString);
if (klassString != NULL) free(klassString); if (klassString != NULL) free(klassString);
...@@ -1056,9 +1057,9 @@ name_for_nmethod(jvm_agent_t* J, ...@@ -1056,9 +1057,9 @@ name_for_nmethod(jvm_agent_t* J,
CHECK_FAIL(err); CHECK_FAIL(err);
} }
if (deoptimized) { if (deoptimized) {
strncat(result + 1, " [deoptimized frame]; ", size-1); strncat(result, " [deoptimized frame]; ", size - strlen(result) - 1);
} else { } else {
strncat(result + 1, " [compiled] ", size-1); strncat(result, " [compiled] ", size - strlen(result) - 1);
} }
if (debug) if (debug)
fprintf(stderr, "name_for_nmethod: END: method name: %s, vf_cnt: %d\n\n", fprintf(stderr, "name_for_nmethod: END: method name: %s, vf_cnt: %d\n\n",
......
...@@ -438,6 +438,7 @@ static void parse_caller_options(struct hsdis_app_data* app_data, const char* ca ...@@ -438,6 +438,7 @@ static void parse_caller_options(struct hsdis_app_data* app_data, const char* ca
} }
p = q; p = q;
} }
*iop = '\0';
} }
static void print_help(struct hsdis_app_data* app_data, static void print_help(struct hsdis_app_data* app_data,
......
...@@ -173,7 +173,8 @@ class CompilerCounters : public CHeapObj<mtCompiler> { ...@@ -173,7 +173,8 @@ class CompilerCounters : public CHeapObj<mtCompiler> {
// these methods should be called in a thread safe context // these methods should be called in a thread safe context
void set_current_method(const char* method) { void set_current_method(const char* method) {
strncpy(_current_method, method, (size_t)cmname_buffer_length); strncpy(_current_method, method, (size_t)cmname_buffer_length-1);
_current_method[cmname_buffer_length-1] = '\0';
if (UsePerfData) _perf_current_method->set_value(method); if (UsePerfData) _perf_current_method->set_value(method);
} }
......
...@@ -295,6 +295,7 @@ address decode_env::handle_event(const char* event, address arg) { ...@@ -295,6 +295,7 @@ address decode_env::handle_event(const char* event, address arg) {
strlen((const char*)arg) > sizeof(buffer) - 1) { strlen((const char*)arg) > sizeof(buffer) - 1) {
// Only print this when the mach changes // Only print this when the mach changes
strncpy(buffer, (const char*)arg, sizeof(buffer) - 1); strncpy(buffer, (const char*)arg, sizeof(buffer) - 1);
buffer[sizeof(buffer) - 1] = '\0';
output()->print_cr("[Disassembling for mach='%s']", arg); output()->print_cr("[Disassembling for mach='%s']", arg);
} }
} else if (match(event, "format bytes-per-line")) { } else if (match(event, "format bytes-per-line")) {
......
...@@ -3476,8 +3476,7 @@ void Arguments::fix_appclasspath() { ...@@ -3476,8 +3476,7 @@ void Arguments::fix_appclasspath() {
src ++; src ++;
} }
char* copy = AllocateHeap(strlen(src) + 1, mtInternal); char* copy = os::strdup(src, mtInternal);
strncpy(copy, src, strlen(src) + 1);
// trim all trailing empty paths // trim all trailing empty paths
for (char* tail = copy + strlen(copy) - 1; tail >= copy && *tail == separator; tail--) { for (char* tail = copy + strlen(copy) - 1; tail >= copy && *tail == separator; tail--) {
...@@ -3856,18 +3855,14 @@ static char* get_shared_archive_path() { ...@@ -3856,18 +3855,14 @@ static char* get_shared_archive_path() {
if (end != NULL) *end = '\0'; if (end != NULL) *end = '\0';
size_t jvm_path_len = strlen(jvm_path); size_t jvm_path_len = strlen(jvm_path);
size_t file_sep_len = strlen(os::file_separator()); size_t file_sep_len = strlen(os::file_separator());
shared_archive_path = NEW_C_HEAP_ARRAY(char, jvm_path_len + const size_t len = jvm_path_len + file_sep_len + 20;
file_sep_len + 20, mtInternal); shared_archive_path = NEW_C_HEAP_ARRAY(char, len, mtInternal);
if (shared_archive_path != NULL) { if (shared_archive_path != NULL) {
strncpy(shared_archive_path, jvm_path, jvm_path_len + 1); jio_snprintf(shared_archive_path, len, "%s%sclasses.jsa",
strncat(shared_archive_path, os::file_separator(), file_sep_len); jvm_path, os::file_separator());
strncat(shared_archive_path, "classes.jsa", 11);
} }
} else { } else {
shared_archive_path = NEW_C_HEAP_ARRAY(char, strlen(SharedArchiveFile) + 1, mtInternal); shared_archive_path = os::strdup(SharedArchiveFile, mtInternal);
if (shared_archive_path != NULL) {
strncpy(shared_archive_path, SharedArchiveFile, strlen(SharedArchiveFile) + 1);
}
} }
return shared_archive_path; return shared_archive_path;
} }
......
...@@ -344,15 +344,19 @@ void stringStream::write(const char* s, size_t len) { ...@@ -344,15 +344,19 @@ void stringStream::write(const char* s, size_t len) {
assert(rm == NULL || Thread::current()->current_resource_mark() == rm, assert(rm == NULL || Thread::current()->current_resource_mark() == rm,
"stringStream is re-allocated with a different ResourceMark"); "stringStream is re-allocated with a different ResourceMark");
buffer = NEW_RESOURCE_ARRAY(char, end); buffer = NEW_RESOURCE_ARRAY(char, end);
strncpy(buffer, oldbuf, buffer_pos); if (buffer_pos > 0) {
memcpy(buffer, oldbuf, buffer_pos);
}
buffer_length = end; buffer_length = end;
} }
} }
// invariant: buffer is always null-terminated // invariant: buffer is always null-terminated
guarantee(buffer_pos + write_len + 1 <= buffer_length, "stringStream oob"); guarantee(buffer_pos + write_len + 1 <= buffer_length, "stringStream oob");
buffer[buffer_pos + write_len] = 0; if (write_len > 0) {
strncpy(buffer + buffer_pos, s, write_len); buffer[buffer_pos + write_len] = 0;
buffer_pos += write_len; memcpy(buffer + buffer_pos, s, write_len);
buffer_pos += write_len;
}
// Note that the following does not depend on write_len. // Note that the following does not depend on write_len.
// This means that position and count get updated // This means that position and count get updated
......
...@@ -455,14 +455,7 @@ void VMError::report(outputStream* st) { ...@@ -455,14 +455,7 @@ void VMError::report(outputStream* st) {
#else #else
const char *file = _filename; const char *file = _filename;
#endif #endif
size_t len = strlen(file); st->print(" (%s:%d)", file, _lineno);
size_t buflen = sizeof(buf);
strncpy(buf, file, buflen);
if (len + 10 < buflen) {
sprintf(buf + len, ":%d", _lineno);
}
st->print(" (%s)", buf);
} else { } else {
st->print(" (0x%x)", _id); st->print(" (0x%x)", _id);
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册