xref: /aosp_15_r20/external/elfutils/libelf/elf_rawdata.c (revision 7304104da70ce23c86437a01be71edd1a2d7f37e)
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