diff options
author | johnlev <none@none> | 2006-04-25 05:46:11 -0700 |
---|---|---|
committer | johnlev <none@none> | 2006-04-25 05:46:11 -0700 |
commit | 4d232658ec6831daceb12672726ce4cabe270c23 (patch) | |
tree | 10d70f3505d6a1c3cdfd97b7924426eed045c23a /usr/src/tools/ctf/cvt/input.c | |
parent | b2e86e7ad265f48a862ed7380c720874c018bf2f (diff) | |
download | illumos-joyent-4d232658ec6831daceb12672726ce4cabe270c23.tar.gz |
5100576 The ctfmerge should use better temporary file name
6314988 ctfconvert's debug option can coredump
6321459 resurrect_functions doesn't skip ignored symbols
6326300 tdtrav_su can return an initialized value
6409619 write_ctf() should behave more like ld and open O_RDWR
6415503 strtab_write() reads stack garbage, bravely staggers on
Diffstat (limited to 'usr/src/tools/ctf/cvt/input.c')
-rw-r--r-- | usr/src/tools/ctf/cvt/input.c | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/usr/src/tools/ctf/cvt/input.c b/usr/src/tools/ctf/cvt/input.c index a29e35a1a5..664a7ba8f8 100644 --- a/usr/src/tools/ctf/cvt/input.c +++ b/usr/src/tools/ctf/cvt/input.c @@ -2,9 +2,8 @@ * CDDL HEADER START * * The contents of this file are subject to the terms of the - * Common Development and Distribution License, Version 1.0 only - * (the "License"). You may not use this file except in compliance - * with the License. + * Common Development and Distribution License (the "License"). + * You may not use this file except in compliance with the License. * * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE * or http://www.opensolaris.org/os/licensing. @@ -20,7 +19,7 @@ * CDDL HEADER END */ /* - * Copyright 2004 Sun Microsystems, Inc. All rights reserved. + * Copyright 2006 Sun Microsystems, Inc. All rights reserved. * Use is subject to license terms. */ @@ -40,6 +39,7 @@ #include "ctftools.h" #include "memory.h" +#include "symbol.h" typedef int read_cb_f(tdata_t *, char *, void *); @@ -386,6 +386,7 @@ GElf_Sym * symit_next(symit_data_t *si, int type) { GElf_Sym sym; + int check_sym = (type == STT_OBJECT || type == STT_FUNC); for (; si->si_next < si->si_nument; si->si_next++) { gelf_getsym(si->si_symd, si->si_next, &si->si_cursym); @@ -399,6 +400,9 @@ symit_next(symit_data_t *si, int type) sym.st_shndx == SHN_UNDEF) continue; + if (check_sym && ignore_symbol(&sym, si->si_curname)) + continue; + si->si_next++; return (&si->si_cursym); |