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