diff options
author | markj <markj@FreeBSD.org> | 2015-01-25 00:34:43 +0000 |
---|---|---|
committer | markj <markj@FreeBSD.org> | 2015-01-25 00:34:43 +0000 |
commit | 054aba9acd5684d6e8eb1857c351530437afc0fe (patch) | |
tree | 7bdf0ffa19728c0373b6efeff082cb75df09c397 /lib/libproc/tests/proc_test.c | |
parent | d14b227ab5d3ce2f8f4471702d14d0eca2c81683 (diff) | |
download | FreeBSD-src-054aba9acd5684d6e8eb1857c351530437afc0fe.zip FreeBSD-src-054aba9acd5684d6e8eb1857c351530437afc0fe.tar.gz |
Ensure that we don't try to demangle a symbol name if we failed to look
up the symbol. Add a test to exercise this code path.
Reviewed by: adrian
Diffstat (limited to 'lib/libproc/tests/proc_test.c')
-rw-r--r-- | lib/libproc/tests/proc_test.c | 40 |
1 files changed, 39 insertions, 1 deletions
diff --git a/lib/libproc/tests/proc_test.c b/lib/libproc/tests/proc_test.c index 0242b5b..dbaace8 100644 --- a/lib/libproc/tests/proc_test.c +++ b/lib/libproc/tests/proc_test.c @@ -1,5 +1,5 @@ /*- - * Copyright (c) 2014 Mark Johnston <markj@FreeBSD.org> + * Copyright (c) 2014, 2015 Mark Johnston <markj@FreeBSD.org> * All rights reserved. * * Redistribution and use in source and binary forms, with or without @@ -295,6 +295,43 @@ ATF_TC_BODY(symbol_lookup, tc) proc_free(phdl); } +ATF_TC(symbol_lookup_fail); +ATF_TC_HEAD(symbol_lookup_fail, tc) +{ + atf_tc_set_md_var(tc, "descr", + "Verify that proc_addr2sym() returns an error when given an offset " + "that it cannot resolve."); +} +ATF_TC_BODY(symbol_lookup_fail, tc) +{ + char symname[32]; + GElf_Sym sym; + struct proc_handle *phdl; + prmap_t *map; + int error; + + phdl = start_prog(tc, false); + + /* Initialize the rtld_db handle. */ + (void)proc_rdagent(phdl); + + map = proc_obj2map(phdl, target_prog_file); + ATF_REQUIRE_MSG(map != NULL, "failed to look up map for '%s'", + target_prog_file); + + /* + * We shouldn't be able to find symbols at the beginning of a mapped + * file. + */ + error = proc_addr2sym(phdl, map->pr_vaddr, symname, sizeof(symname), + &sym); + ATF_REQUIRE_MSG(error != 0, "unexpectedly found a symbol"); + + ATF_CHECK_EQ_MSG(proc_continue(phdl), 0, "failed to resume execution"); + + proc_free(phdl); +} + ATF_TC(signal_forward); ATF_TC_HEAD(signal_forward, tc) { @@ -343,6 +380,7 @@ ATF_TP_ADD_TCS(tp) ATF_TP_ADD_TC(tp, map_alias_name2map); ATF_TP_ADD_TC(tp, map_alias_name2sym); ATF_TP_ADD_TC(tp, symbol_lookup); + ATF_TP_ADD_TC(tp, symbol_lookup_fail); ATF_TP_ADD_TC(tp, signal_forward); return (atf_no_error()); |