summaryrefslogtreecommitdiff
path: root/usr/src/tools/ctf/cvt/input.c
diff options
context:
space:
mode:
authorjohnlev <none@none>2006-04-25 05:46:11 -0700
committerjohnlev <none@none>2006-04-25 05:46:11 -0700
commit4d232658ec6831daceb12672726ce4cabe270c23 (patch)
tree10d70f3505d6a1c3cdfd97b7924426eed045c23a /usr/src/tools/ctf/cvt/input.c
parentb2e86e7ad265f48a862ed7380c720874c018bf2f (diff)
downloadillumos-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.c12
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);