1*7304104dSAndroid Build Coastguard Worker /* Return raw section content.
2*7304104dSAndroid Build Coastguard Worker Copyright (C) 1998, 1999, 2000, 2002, 2015 Red Hat, Inc.
3*7304104dSAndroid Build Coastguard Worker This file is part of elfutils.
4*7304104dSAndroid Build Coastguard Worker Contributed by Ulrich Drepper <[email protected]>, 1998.
5*7304104dSAndroid Build Coastguard Worker
6*7304104dSAndroid Build Coastguard Worker This file is free software; you can redistribute it and/or modify
7*7304104dSAndroid Build Coastguard Worker it under the terms of either
8*7304104dSAndroid Build Coastguard Worker
9*7304104dSAndroid Build Coastguard Worker * the GNU Lesser General Public License as published by the Free
10*7304104dSAndroid Build Coastguard Worker Software Foundation; either version 3 of the License, or (at
11*7304104dSAndroid Build Coastguard Worker your option) any later version
12*7304104dSAndroid Build Coastguard Worker
13*7304104dSAndroid Build Coastguard Worker or
14*7304104dSAndroid Build Coastguard Worker
15*7304104dSAndroid Build Coastguard Worker * the GNU General Public License as published by the Free
16*7304104dSAndroid Build Coastguard Worker Software Foundation; either version 2 of the License, or (at
17*7304104dSAndroid Build Coastguard Worker your option) any later version
18*7304104dSAndroid Build Coastguard Worker
19*7304104dSAndroid Build Coastguard Worker or both in parallel, as here.
20*7304104dSAndroid Build Coastguard Worker
21*7304104dSAndroid Build Coastguard Worker elfutils is distributed in the hope that it will be useful, but
22*7304104dSAndroid Build Coastguard Worker WITHOUT ANY WARRANTY; without even the implied warranty of
23*7304104dSAndroid Build Coastguard Worker MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
24*7304104dSAndroid Build Coastguard Worker General Public License for more details.
25*7304104dSAndroid Build Coastguard Worker
26*7304104dSAndroid Build Coastguard Worker You should have received copies of the GNU General Public License and
27*7304104dSAndroid Build Coastguard Worker the GNU Lesser General Public License along with this program. If
28*7304104dSAndroid Build Coastguard Worker not, see <http://www.gnu.org/licenses/>. */
29*7304104dSAndroid Build Coastguard Worker
30*7304104dSAndroid Build Coastguard Worker #ifdef HAVE_CONFIG_H
31*7304104dSAndroid Build Coastguard Worker # include <config.h>
32*7304104dSAndroid Build Coastguard Worker #endif
33*7304104dSAndroid Build Coastguard Worker
34*7304104dSAndroid Build Coastguard Worker #include <stdlib.h>
35*7304104dSAndroid Build Coastguard Worker
36*7304104dSAndroid Build Coastguard Worker #include "libelfP.h"
37*7304104dSAndroid Build Coastguard Worker
38*7304104dSAndroid Build Coastguard Worker
39*7304104dSAndroid Build Coastguard Worker Elf_Data *
elf_rawdata(Elf_Scn * scn,Elf_Data * data)40*7304104dSAndroid Build Coastguard Worker elf_rawdata (Elf_Scn *scn, Elf_Data *data)
41*7304104dSAndroid Build Coastguard Worker {
42*7304104dSAndroid Build Coastguard Worker if (scn == NULL || scn->elf->kind != ELF_K_ELF)
43*7304104dSAndroid Build Coastguard Worker {
44*7304104dSAndroid Build Coastguard Worker __libelf_seterrno (ELF_E_INVALID_HANDLE);
45*7304104dSAndroid Build Coastguard Worker return NULL;
46*7304104dSAndroid Build Coastguard Worker }
47*7304104dSAndroid Build Coastguard Worker
48*7304104dSAndroid Build Coastguard Worker /* If `data' is not NULL this means we are not addressing the initial
49*7304104dSAndroid Build Coastguard Worker data in the file. But this also means this data is already read
50*7304104dSAndroid Build Coastguard Worker (since otherwise it is not possible to have a valid `data' pointer)
51*7304104dSAndroid Build Coastguard Worker and all the data structures are initialized as well. In this case
52*7304104dSAndroid Build Coastguard Worker we can simply walk the list of data records. */
53*7304104dSAndroid Build Coastguard Worker if (data != NULL
54*7304104dSAndroid Build Coastguard Worker || (scn->data_read != 0 && (scn->flags & ELF_F_FILEDATA) == 0))
55*7304104dSAndroid Build Coastguard Worker {
56*7304104dSAndroid Build Coastguard Worker /* We don't allow accessing any but the data read from the file
57*7304104dSAndroid Build Coastguard Worker as raw. */
58*7304104dSAndroid Build Coastguard Worker __libelf_seterrno (ELF_E_DATA_MISMATCH);
59*7304104dSAndroid Build Coastguard Worker return NULL;
60*7304104dSAndroid Build Coastguard Worker }
61*7304104dSAndroid Build Coastguard Worker
62*7304104dSAndroid Build Coastguard Worker /* If the data for this section was not yet initialized do it now. */
63*7304104dSAndroid Build Coastguard Worker if (scn->data_read == 0)
64*7304104dSAndroid Build Coastguard Worker {
65*7304104dSAndroid Build Coastguard Worker /* First thing we do is to read the data from the file. There is
66*7304104dSAndroid Build Coastguard Worker always a file (or memory region) associated with this descriptor
67*7304104dSAndroid Build Coastguard Worker since otherwise the `data_read' flag would be set. */
68*7304104dSAndroid Build Coastguard Worker if (__libelf_set_rawdata (scn) != 0)
69*7304104dSAndroid Build Coastguard Worker /* Something went wrong. The error value is already set. */
70*7304104dSAndroid Build Coastguard Worker return NULL;
71*7304104dSAndroid Build Coastguard Worker }
72*7304104dSAndroid Build Coastguard Worker
73*7304104dSAndroid Build Coastguard Worker /* Return the first data element in the list. */
74*7304104dSAndroid Build Coastguard Worker return &scn->rawdata.d;
75*7304104dSAndroid Build Coastguard Worker }
76*7304104dSAndroid Build Coastguard Worker INTDEF(elf_rawdata)
77