1 /* $NetBSD: gelf_symshndx.c,v 1.2 2014/03/09 16:58:04 christos Exp $ */
4 * Copyright (c) 2006,2008 Joseph Koshy
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * 2. Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
16 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
17 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
20 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29 #if HAVE_NBTOOL_CONFIG_H
30 # include "nbtool_config.h"
33 #include <sys/cdefs.h>
40 __RCSID("$NetBSD: gelf_symshndx.c,v 1.2 2014/03/09 16:58:04 christos Exp $");
41 ELFTC_VCSID("Id: gelf_symshndx.c 2283 2011-12-04 04:07:24Z jkoshy ");
44 gelf_getsymshndx(Elf_Data
*d
, Elf_Data
*id
, int ndx
, GElf_Sym
*dst
,
52 struct _Libelf_Data
*ld
, *lid
;
54 ld
= (struct _Libelf_Data
*) d
;
55 lid
= (struct _Libelf_Data
*) id
;
57 if (gelf_getsym(d
, ndx
, dst
) == 0)
60 if (lid
== NULL
|| (scn
= lid
->d_scn
) == NULL
||
61 (e
= scn
->s_elf
) == NULL
|| (e
!= ld
->d_scn
->s_elf
) ||
63 LIBELF_SET_ERROR(ARGUMENT
, 0);
68 assert(ec
== ELFCLASS32
|| ec
== ELFCLASS64
);
71 sh_type
= scn
->s_shdr
.s_shdr32
.sh_type
;
73 sh_type
= scn
->s_shdr
.s_shdr64
.sh_type
;
75 if (_libelf_xlate_shtype(sh_type
) != ELF_T_WORD
||
76 id
->d_type
!= ELF_T_WORD
) {
77 LIBELF_SET_ERROR(ARGUMENT
, 0);
81 msz
= _libelf_msize(ELF_T_WORD
, ec
, e
->e_version
);
85 if (msz
* ndx
>= id
->d_size
) {
86 LIBELF_SET_ERROR(ARGUMENT
, 0);
90 *shindex
= ((Elf32_Word
*) id
->d_buf
)[ndx
];
96 gelf_update_symshndx(Elf_Data
*d
, Elf_Data
*id
, int ndx
, GElf_Sym
*gs
,
104 struct _Libelf_Data
*ld
, *lid
;
106 ld
= (struct _Libelf_Data
*) d
;
107 lid
= (struct _Libelf_Data
*) id
;
109 if (gelf_update_sym(d
, ndx
, gs
) == 0)
112 if (lid
== NULL
|| (scn
= lid
->d_scn
) == NULL
||
113 (e
= scn
->s_elf
) == NULL
|| (e
!= ld
->d_scn
->s_elf
)) {
114 LIBELF_SET_ERROR(ARGUMENT
, 0);
119 assert(ec
== ELFCLASS32
|| ec
== ELFCLASS64
);
121 if (ec
== ELFCLASS32
)
122 sh_type
= scn
->s_shdr
.s_shdr32
.sh_type
;
124 sh_type
= scn
->s_shdr
.s_shdr64
.sh_type
;
126 if (_libelf_xlate_shtype(sh_type
) != ELF_T_WORD
||
127 d
->d_type
!= ELF_T_WORD
) {
128 LIBELF_SET_ERROR(ARGUMENT
, 0);
132 msz
= _libelf_msize(ELF_T_WORD
, ec
, e
->e_version
);
135 if (msz
* ndx
>= id
->d_size
) {
136 LIBELF_SET_ERROR(ARGUMENT
, 0);
140 *(((Elf32_Word
*) id
->d_buf
) + ndx
) = xindex
;