1 /* $NetBSD: gelf_move.c,v 1.3 2009/12/19 07:31:04 thorpej Exp $ */
4 * Copyright (c) 2006 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 #include <sys/cdefs.h>
30 /* __FBSDID("$FreeBSD: src/lib/libelf/gelf_move.c,v 1.2.10.1.2.1 2009/10/25 01:10:29 kensmith Exp $"); */
38 #if defined(__LIBELF_HAVE_ELF_MOVE)
41 gelf_getmove(Elf_Data
*d
, int ndx
, GElf_Move
*dst
)
51 if (d
== NULL
|| ndx
< 0 || dst
== NULL
||
52 (scn
= d
->d_scn
) == NULL
||
53 (e
= scn
->s_elf
) == NULL
) {
54 LIBELF_SET_ERROR(ARGUMENT
, 0);
59 assert(ec
== ELFCLASS32
|| ec
== ELFCLASS64
);
62 sh_type
= scn
->s_shdr
.s_shdr32
.sh_type
;
64 sh_type
= scn
->s_shdr
.s_shdr64
.sh_type
;
66 if (_libelf_xlate_shtype(sh_type
) != ELF_T_MOVE
) {
67 LIBELF_SET_ERROR(ARGUMENT
, 0);
71 msz
= _libelf_msize(ELF_T_MOVE
, ec
, e
->e_version
);
75 if (msz
* ndx
>= d
->d_size
) {
76 LIBELF_SET_ERROR(ARGUMENT
, 0);
80 if (ec
== ELFCLASS32
) {
82 move32
= (Elf32_Move
*) d
->d_buf
+ ndx
;
84 dst
->m_value
= move32
->m_value
;
85 dst
->m_info
= (Elf64_Xword
) move32
->m_info
;
86 dst
->m_poffset
= (Elf64_Xword
) move32
->m_poffset
;
87 dst
->m_repeat
= move32
->m_repeat
;
88 dst
->m_stride
= move32
->m_stride
;
91 move64
= (Elf64_Move
*) d
->d_buf
+ ndx
;
100 gelf_update_move(Elf_Data
*d
, int ndx
, GElf_Move
*gm
)
110 if (d
== NULL
|| ndx
< 0 || gm
== NULL
||
111 (scn
= d
->d_scn
) == NULL
||
112 (e
= scn
->s_elf
) == NULL
) {
113 LIBELF_SET_ERROR(ARGUMENT
, 0);
118 assert(ec
== ELFCLASS32
|| ec
== ELFCLASS64
);
120 if (ec
== ELFCLASS32
)
121 sh_type
= scn
->s_shdr
.s_shdr32
.sh_type
;
123 sh_type
= scn
->s_shdr
.s_shdr64
.sh_type
;
125 if (_libelf_xlate_shtype(sh_type
) != ELF_T_MOVE
) {
126 LIBELF_SET_ERROR(ARGUMENT
, 0);
130 msz
= _libelf_msize(ELF_T_MOVE
, ec
, e
->e_version
);
133 if (msz
* ndx
>= d
->d_size
) {
134 LIBELF_SET_ERROR(ARGUMENT
, 0);
138 if (ec
== ELFCLASS32
) {
139 move32
= (Elf32_Move
*) d
->d_buf
+ ndx
;
141 move32
->m_value
= gm
->m_value
;
142 LIBELF_COPY_U32(move32
, gm
, m_info
);
143 LIBELF_COPY_U32(move32
, gm
, m_poffset
);
144 move32
->m_repeat
= gm
->m_repeat
;
145 move32
->m_stride
= gm
->m_stride
;
148 move64
= (Elf64_Move
*) d
->d_buf
+ ndx
;
156 #endif /* __LIBELF_HAVE_ELF_MOVE */