Coverage Report

Created: 2026-02-24 06:49

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/elfutils/libelf/elf32_getphdr.c
Line
Count
Source
1
/* Get ELF program header table.
2
   Copyright (C) 1998-2010, 2014, 2015 Red Hat, Inc.
3
   This file is part of elfutils.
4
   Written by Ulrich Drepper <drepper@redhat.com>, 1998.
5
6
   This file is free software; you can redistribute it and/or modify
7
   it under the terms of either
8
9
     * the GNU Lesser General Public License as published by the Free
10
       Software Foundation; either version 3 of the License, or (at
11
       your option) any later version
12
13
   or
14
15
     * the GNU General Public License as published by the Free
16
       Software Foundation; either version 2 of the License, or (at
17
       your option) any later version
18
19
   or both in parallel, as here.
20
21
   elfutils is distributed in the hope that it will be useful, but
22
   WITHOUT ANY WARRANTY; without even the implied warranty of
23
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
24
   General Public License for more details.
25
26
   You should have received copies of the GNU General Public License and
27
   the GNU Lesser General Public License along with this program.  If
28
   not, see <http://www.gnu.org/licenses/>.  */
29
30
#ifdef HAVE_CONFIG_H
31
# include <config.h>
32
#endif
33
34
#include <errno.h>
35
#include <stdbool.h>
36
#include <stdlib.h>
37
#include <assert.h>
38
39
#include "libelfP.h"
40
#include "common.h"
41
42
#ifndef LIBELFBITS
43
# define LIBELFBITS 32
44
#endif
45
46
ElfW2(LIBELFBITS,Phdr) *
47
__elfw2(LIBELFBITS,getphdr_wrlock) (Elf *elf)
48
18.9k
{
49
18.9k
  ElfW2(LIBELFBITS,Phdr) *result;
50
51
  /* If the program header entry has already been filled in the code
52
     below must already have been run.  So the class is set, too.  No
53
     need to waste any more time here.  */
54
18.9k
  result = elf->state.ELFW(elf,LIBELFBITS).phdr;
55
18.9k
  if (likely (result != NULL))
56
0
    return result;
57
58
18.9k
  if (elf->class == 0)
59
0
    elf->class = ELFW(ELFCLASS,LIBELFBITS);
60
18.9k
  else if (elf->class != ELFW(ELFCLASS,LIBELFBITS))
61
0
    {
62
0
      __libelf_seterrno (ELF_E_INVALID_CLASS);
63
0
      result = NULL;
64
0
      goto out;
65
0
    }
66
67
18.9k
  if (likely (result == NULL))
68
18.9k
    {
69
      /* Read the section header table.  */
70
18.9k
      ElfW2(LIBELFBITS,Ehdr) *ehdr = elf->state.ELFW(elf,LIBELFBITS).ehdr;
71
72
      /* If no program header exists return NULL.  */
73
18.9k
      size_t phnum;
74
18.9k
      if (__elf_getphdrnum_rdlock (elf, &phnum) != 0)
75
0
  goto out;
76
18.9k
      if (phnum == 0 || ehdr->e_phoff == 0)
77
0
  {
78
0
    __libelf_seterrno (ELF_E_NO_PHDR);
79
0
    goto out;
80
0
  }
81
82
      /* Check this doesn't overflow.  */
83
18.9k
      size_t size = phnum * sizeof (ElfW2(LIBELFBITS,Phdr));
84
85
18.9k
      if (phnum > SIZE_MAX / sizeof (ElfW2(LIBELFBITS,Phdr))
86
18.9k
    || ehdr->e_phoff > elf->maximum_size
87
18.9k
    || elf->maximum_size - ehdr->e_phoff < size)
88
309
  {
89
309
    __libelf_seterrno (ELF_E_INVALID_DATA);
90
309
    goto out;
91
309
  }
92
93
18.6k
      if (elf->map_address != NULL)
94
18.6k
  {
95
    /* First see whether the information in the ELF header is
96
       valid and it does not ask for too much.  */
97
18.6k
    if (unlikely (ehdr->e_phoff >= elf->maximum_size)
98
18.6k
        || unlikely (elf->maximum_size - ehdr->e_phoff < size))
99
0
      {
100
        /* Something is wrong.  */
101
0
        __libelf_seterrno (ELF_E_INVALID_PHDR);
102
0
        goto out;
103
0
      }
104
105
    /* All the data is already mapped.  Use it.  */
106
18.6k
    void *file_phdr = ((char *) elf->map_address
107
18.6k
           + elf->start_offset + ehdr->e_phoff);
108
18.6k
    if (ehdr->e_ident[EI_DATA] == MY_ELFDATA
109
8.69k
        && (ALLOW_UNALIGNED
110
0
      || ((uintptr_t) file_phdr
111
0
          & (__alignof__ (ElfW2(LIBELFBITS,Phdr)) - 1)) == 0))
112
      /* Simply use the mapped data.  */
113
8.69k
      elf->state.ELFW(elf,LIBELFBITS).phdr = file_phdr;
114
9.91k
    else
115
9.91k
      {
116
9.91k
        ElfW2(LIBELFBITS,Phdr) *notcvt;
117
9.91k
        ElfW2(LIBELFBITS,Phdr) *phdr;
118
119
        /* Allocate memory for the program headers.  We know the number
120
     of entries from the ELF header.  */
121
9.91k
        phdr = elf->state.ELFW(elf,LIBELFBITS).phdr =
122
9.91k
    (ElfW2(LIBELFBITS,Phdr) *) malloc (size);
123
9.91k
        if (elf->state.ELFW(elf,LIBELFBITS).phdr == NULL)
124
0
    {
125
0
      __libelf_seterrno (ELF_E_NOMEM);
126
0
      goto out;
127
0
    }
128
9.91k
        elf->state.ELFW(elf,LIBELFBITS).phdr_flags |=
129
9.91k
    ELF_F_MALLOCED | ELF_F_DIRTY;
130
131
        /* Now copy the data and at the same time convert the
132
     byte order.  */
133
134
9.91k
        if (ehdr->e_ident[EI_DATA] == MY_ELFDATA)
135
0
    {
136
0
      assert (! ALLOW_UNALIGNED);
137
0
      memcpy (phdr, file_phdr, size);
138
0
    }
139
9.91k
        else
140
9.91k
    {
141
9.91k
      bool copy = ! (ALLOW_UNALIGNED
142
0
         || ((uintptr_t) file_phdr
143
0
             & (__alignof__ (ElfW2(LIBELFBITS,Phdr))
144
0
          - 1)) == 0);
145
9.91k
      if (! copy)
146
9.91k
        notcvt = file_phdr;
147
0
      else
148
0
        {
149
0
          notcvt = (ElfW2(LIBELFBITS,Phdr) *) malloc (size);
150
0
          if (unlikely (notcvt == NULL))
151
0
      {
152
0
        __libelf_seterrno (ELF_E_NOMEM);
153
0
        goto out;
154
0
      }
155
0
          memcpy (notcvt, file_phdr, size);
156
0
        }
157
158
3.36M
      for (size_t cnt = 0; cnt < phnum; ++cnt)
159
3.35M
        {
160
3.35M
          CONVERT_TO (phdr[cnt].p_type, notcvt[cnt].p_type);
161
3.35M
          CONVERT_TO (phdr[cnt].p_offset, notcvt[cnt].p_offset);
162
3.35M
          CONVERT_TO (phdr[cnt].p_vaddr, notcvt[cnt].p_vaddr);
163
3.35M
          CONVERT_TO (phdr[cnt].p_paddr, notcvt[cnt].p_paddr);
164
3.35M
          CONVERT_TO (phdr[cnt].p_filesz, notcvt[cnt].p_filesz);
165
3.35M
          CONVERT_TO (phdr[cnt].p_memsz, notcvt[cnt].p_memsz);
166
3.35M
          CONVERT_TO (phdr[cnt].p_flags, notcvt[cnt].p_flags);
167
3.35M
          CONVERT_TO (phdr[cnt].p_align, notcvt[cnt].p_align);
168
3.35M
        }
169
170
9.91k
      if (copy)
171
0
        free (notcvt);
172
9.91k
    }
173
9.91k
      }
174
18.6k
  }
175
0
      else if (likely (elf->fildes != -1))
176
0
  {
177
    /* Allocate memory for the program headers.  We know the number
178
       of entries from the ELF header.  */
179
0
    elf->state.ELFW(elf,LIBELFBITS).phdr =
180
0
      (ElfW2(LIBELFBITS,Phdr) *) malloc (size);
181
0
    if (elf->state.ELFW(elf,LIBELFBITS).phdr == NULL)
182
0
      {
183
0
        __libelf_seterrno (ELF_E_NOMEM);
184
0
        goto out;
185
0
      }
186
0
    elf->state.ELFW(elf,LIBELFBITS).phdr_flags |= ELF_F_MALLOCED;
187
188
    /* Read the header.  */
189
0
    ssize_t n = pread_retry (elf->fildes,
190
0
           elf->state.ELFW(elf,LIBELFBITS).phdr, size,
191
0
           elf->start_offset + ehdr->e_phoff);
192
0
    if (unlikely ((size_t) n != size))
193
0
      {
194
        /* Severe problems.  We cannot read the data.  */
195
0
        __libelf_seterrno (ELF_E_READ_ERROR);
196
0
        free (elf->state.ELFW(elf,LIBELFBITS).phdr);
197
0
        elf->state.ELFW(elf,LIBELFBITS).phdr = NULL;
198
0
        goto out;
199
0
      }
200
201
    /* If the byte order of the file is not the same as the one
202
       of the host convert the data now.  */
203
0
    if (ehdr->e_ident[EI_DATA] != MY_ELFDATA)
204
0
      {
205
0
        ElfW2(LIBELFBITS,Phdr) *phdr
206
0
    = elf->state.ELFW(elf,LIBELFBITS).phdr;
207
208
0
        for (size_t cnt = 0; cnt < phnum; ++cnt)
209
0
    {
210
0
      CONVERT (phdr[cnt].p_type);
211
0
      CONVERT (phdr[cnt].p_offset);
212
0
      CONVERT (phdr[cnt].p_vaddr);
213
0
      CONVERT (phdr[cnt].p_paddr);
214
0
      CONVERT (phdr[cnt].p_filesz);
215
0
      CONVERT (phdr[cnt].p_memsz);
216
0
      CONVERT (phdr[cnt].p_flags);
217
0
      CONVERT (phdr[cnt].p_align);
218
0
    }
219
0
      }
220
0
  }
221
0
      else
222
0
  {
223
    /* The file descriptor was already enabled and not all data was
224
       read.  */
225
0
    __libelf_seterrno (ELF_E_FD_DISABLED);
226
0
    goto out;
227
0
  }
228
229
18.6k
      result = elf->state.ELFW(elf,LIBELFBITS).phdr;
230
18.6k
    }
231
232
18.9k
 out:
233
18.9k
  return result;
234
18.9k
}
__elf32_getphdr_wrlock
Line
Count
Source
48
14.3k
{
49
14.3k
  ElfW2(LIBELFBITS,Phdr) *result;
50
51
  /* If the program header entry has already been filled in the code
52
     below must already have been run.  So the class is set, too.  No
53
     need to waste any more time here.  */
54
14.3k
  result = elf->state.ELFW(elf,LIBELFBITS).phdr;
55
14.3k
  if (likely (result != NULL))
56
0
    return result;
57
58
14.3k
  if (elf->class == 0)
59
0
    elf->class = ELFW(ELFCLASS,LIBELFBITS);
60
14.3k
  else if (elf->class != ELFW(ELFCLASS,LIBELFBITS))
61
0
    {
62
0
      __libelf_seterrno (ELF_E_INVALID_CLASS);
63
0
      result = NULL;
64
0
      goto out;
65
0
    }
66
67
14.3k
  if (likely (result == NULL))
68
14.3k
    {
69
      /* Read the section header table.  */
70
14.3k
      ElfW2(LIBELFBITS,Ehdr) *ehdr = elf->state.ELFW(elf,LIBELFBITS).ehdr;
71
72
      /* If no program header exists return NULL.  */
73
14.3k
      size_t phnum;
74
14.3k
      if (__elf_getphdrnum_rdlock (elf, &phnum) != 0)
75
0
  goto out;
76
14.3k
      if (phnum == 0 || ehdr->e_phoff == 0)
77
0
  {
78
0
    __libelf_seterrno (ELF_E_NO_PHDR);
79
0
    goto out;
80
0
  }
81
82
      /* Check this doesn't overflow.  */
83
14.3k
      size_t size = phnum * sizeof (ElfW2(LIBELFBITS,Phdr));
84
85
14.3k
      if (phnum > SIZE_MAX / sizeof (ElfW2(LIBELFBITS,Phdr))
86
14.3k
    || ehdr->e_phoff > elf->maximum_size
87
14.3k
    || elf->maximum_size - ehdr->e_phoff < size)
88
148
  {
89
148
    __libelf_seterrno (ELF_E_INVALID_DATA);
90
148
    goto out;
91
148
  }
92
93
14.1k
      if (elf->map_address != NULL)
94
14.1k
  {
95
    /* First see whether the information in the ELF header is
96
       valid and it does not ask for too much.  */
97
14.1k
    if (unlikely (ehdr->e_phoff >= elf->maximum_size)
98
14.1k
        || unlikely (elf->maximum_size - ehdr->e_phoff < size))
99
0
      {
100
        /* Something is wrong.  */
101
0
        __libelf_seterrno (ELF_E_INVALID_PHDR);
102
0
        goto out;
103
0
      }
104
105
    /* All the data is already mapped.  Use it.  */
106
14.1k
    void *file_phdr = ((char *) elf->map_address
107
14.1k
           + elf->start_offset + ehdr->e_phoff);
108
14.1k
    if (ehdr->e_ident[EI_DATA] == MY_ELFDATA
109
5.25k
        && (ALLOW_UNALIGNED
110
0
      || ((uintptr_t) file_phdr
111
0
          & (__alignof__ (ElfW2(LIBELFBITS,Phdr)) - 1)) == 0))
112
      /* Simply use the mapped data.  */
113
5.25k
      elf->state.ELFW(elf,LIBELFBITS).phdr = file_phdr;
114
8.92k
    else
115
8.92k
      {
116
8.92k
        ElfW2(LIBELFBITS,Phdr) *notcvt;
117
8.92k
        ElfW2(LIBELFBITS,Phdr) *phdr;
118
119
        /* Allocate memory for the program headers.  We know the number
120
     of entries from the ELF header.  */
121
8.92k
        phdr = elf->state.ELFW(elf,LIBELFBITS).phdr =
122
8.92k
    (ElfW2(LIBELFBITS,Phdr) *) malloc (size);
123
8.92k
        if (elf->state.ELFW(elf,LIBELFBITS).phdr == NULL)
124
0
    {
125
0
      __libelf_seterrno (ELF_E_NOMEM);
126
0
      goto out;
127
0
    }
128
8.92k
        elf->state.ELFW(elf,LIBELFBITS).phdr_flags |=
129
8.92k
    ELF_F_MALLOCED | ELF_F_DIRTY;
130
131
        /* Now copy the data and at the same time convert the
132
     byte order.  */
133
134
8.92k
        if (ehdr->e_ident[EI_DATA] == MY_ELFDATA)
135
0
    {
136
0
      assert (! ALLOW_UNALIGNED);
137
0
      memcpy (phdr, file_phdr, size);
138
0
    }
139
8.92k
        else
140
8.92k
    {
141
8.92k
      bool copy = ! (ALLOW_UNALIGNED
142
0
         || ((uintptr_t) file_phdr
143
0
             & (__alignof__ (ElfW2(LIBELFBITS,Phdr))
144
0
          - 1)) == 0);
145
8.92k
      if (! copy)
146
8.92k
        notcvt = file_phdr;
147
0
      else
148
0
        {
149
0
          notcvt = (ElfW2(LIBELFBITS,Phdr) *) malloc (size);
150
0
          if (unlikely (notcvt == NULL))
151
0
      {
152
0
        __libelf_seterrno (ELF_E_NOMEM);
153
0
        goto out;
154
0
      }
155
0
          memcpy (notcvt, file_phdr, size);
156
0
        }
157
158
2.13M
      for (size_t cnt = 0; cnt < phnum; ++cnt)
159
2.12M
        {
160
2.12M
          CONVERT_TO (phdr[cnt].p_type, notcvt[cnt].p_type);
161
2.12M
          CONVERT_TO (phdr[cnt].p_offset, notcvt[cnt].p_offset);
162
2.12M
          CONVERT_TO (phdr[cnt].p_vaddr, notcvt[cnt].p_vaddr);
163
2.12M
          CONVERT_TO (phdr[cnt].p_paddr, notcvt[cnt].p_paddr);
164
2.12M
          CONVERT_TO (phdr[cnt].p_filesz, notcvt[cnt].p_filesz);
165
2.12M
          CONVERT_TO (phdr[cnt].p_memsz, notcvt[cnt].p_memsz);
166
2.12M
          CONVERT_TO (phdr[cnt].p_flags, notcvt[cnt].p_flags);
167
2.12M
          CONVERT_TO (phdr[cnt].p_align, notcvt[cnt].p_align);
168
2.12M
        }
169
170
8.92k
      if (copy)
171
0
        free (notcvt);
172
8.92k
    }
173
8.92k
      }
174
14.1k
  }
175
0
      else if (likely (elf->fildes != -1))
176
0
  {
177
    /* Allocate memory for the program headers.  We know the number
178
       of entries from the ELF header.  */
179
0
    elf->state.ELFW(elf,LIBELFBITS).phdr =
180
0
      (ElfW2(LIBELFBITS,Phdr) *) malloc (size);
181
0
    if (elf->state.ELFW(elf,LIBELFBITS).phdr == NULL)
182
0
      {
183
0
        __libelf_seterrno (ELF_E_NOMEM);
184
0
        goto out;
185
0
      }
186
0
    elf->state.ELFW(elf,LIBELFBITS).phdr_flags |= ELF_F_MALLOCED;
187
188
    /* Read the header.  */
189
0
    ssize_t n = pread_retry (elf->fildes,
190
0
           elf->state.ELFW(elf,LIBELFBITS).phdr, size,
191
0
           elf->start_offset + ehdr->e_phoff);
192
0
    if (unlikely ((size_t) n != size))
193
0
      {
194
        /* Severe problems.  We cannot read the data.  */
195
0
        __libelf_seterrno (ELF_E_READ_ERROR);
196
0
        free (elf->state.ELFW(elf,LIBELFBITS).phdr);
197
0
        elf->state.ELFW(elf,LIBELFBITS).phdr = NULL;
198
0
        goto out;
199
0
      }
200
201
    /* If the byte order of the file is not the same as the one
202
       of the host convert the data now.  */
203
0
    if (ehdr->e_ident[EI_DATA] != MY_ELFDATA)
204
0
      {
205
0
        ElfW2(LIBELFBITS,Phdr) *phdr
206
0
    = elf->state.ELFW(elf,LIBELFBITS).phdr;
207
208
0
        for (size_t cnt = 0; cnt < phnum; ++cnt)
209
0
    {
210
0
      CONVERT (phdr[cnt].p_type);
211
0
      CONVERT (phdr[cnt].p_offset);
212
0
      CONVERT (phdr[cnt].p_vaddr);
213
0
      CONVERT (phdr[cnt].p_paddr);
214
0
      CONVERT (phdr[cnt].p_filesz);
215
0
      CONVERT (phdr[cnt].p_memsz);
216
0
      CONVERT (phdr[cnt].p_flags);
217
0
      CONVERT (phdr[cnt].p_align);
218
0
    }
219
0
      }
220
0
  }
221
0
      else
222
0
  {
223
    /* The file descriptor was already enabled and not all data was
224
       read.  */
225
0
    __libelf_seterrno (ELF_E_FD_DISABLED);
226
0
    goto out;
227
0
  }
228
229
14.1k
      result = elf->state.ELFW(elf,LIBELFBITS).phdr;
230
14.1k
    }
231
232
14.3k
 out:
233
14.3k
  return result;
234
14.3k
}
__elf64_getphdr_wrlock
Line
Count
Source
48
4.58k
{
49
4.58k
  ElfW2(LIBELFBITS,Phdr) *result;
50
51
  /* If the program header entry has already been filled in the code
52
     below must already have been run.  So the class is set, too.  No
53
     need to waste any more time here.  */
54
4.58k
  result = elf->state.ELFW(elf,LIBELFBITS).phdr;
55
4.58k
  if (likely (result != NULL))
56
0
    return result;
57
58
4.58k
  if (elf->class == 0)
59
0
    elf->class = ELFW(ELFCLASS,LIBELFBITS);
60
4.58k
  else if (elf->class != ELFW(ELFCLASS,LIBELFBITS))
61
0
    {
62
0
      __libelf_seterrno (ELF_E_INVALID_CLASS);
63
0
      result = NULL;
64
0
      goto out;
65
0
    }
66
67
4.58k
  if (likely (result == NULL))
68
4.58k
    {
69
      /* Read the section header table.  */
70
4.58k
      ElfW2(LIBELFBITS,Ehdr) *ehdr = elf->state.ELFW(elf,LIBELFBITS).ehdr;
71
72
      /* If no program header exists return NULL.  */
73
4.58k
      size_t phnum;
74
4.58k
      if (__elf_getphdrnum_rdlock (elf, &phnum) != 0)
75
0
  goto out;
76
4.58k
      if (phnum == 0 || ehdr->e_phoff == 0)
77
0
  {
78
0
    __libelf_seterrno (ELF_E_NO_PHDR);
79
0
    goto out;
80
0
  }
81
82
      /* Check this doesn't overflow.  */
83
4.58k
      size_t size = phnum * sizeof (ElfW2(LIBELFBITS,Phdr));
84
85
4.58k
      if (phnum > SIZE_MAX / sizeof (ElfW2(LIBELFBITS,Phdr))
86
4.58k
    || ehdr->e_phoff > elf->maximum_size
87
4.58k
    || elf->maximum_size - ehdr->e_phoff < size)
88
161
  {
89
161
    __libelf_seterrno (ELF_E_INVALID_DATA);
90
161
    goto out;
91
161
  }
92
93
4.42k
      if (elf->map_address != NULL)
94
4.42k
  {
95
    /* First see whether the information in the ELF header is
96
       valid and it does not ask for too much.  */
97
4.42k
    if (unlikely (ehdr->e_phoff >= elf->maximum_size)
98
4.42k
        || unlikely (elf->maximum_size - ehdr->e_phoff < size))
99
0
      {
100
        /* Something is wrong.  */
101
0
        __libelf_seterrno (ELF_E_INVALID_PHDR);
102
0
        goto out;
103
0
      }
104
105
    /* All the data is already mapped.  Use it.  */
106
4.42k
    void *file_phdr = ((char *) elf->map_address
107
4.42k
           + elf->start_offset + ehdr->e_phoff);
108
4.42k
    if (ehdr->e_ident[EI_DATA] == MY_ELFDATA
109
3.43k
        && (ALLOW_UNALIGNED
110
0
      || ((uintptr_t) file_phdr
111
0
          & (__alignof__ (ElfW2(LIBELFBITS,Phdr)) - 1)) == 0))
112
      /* Simply use the mapped data.  */
113
3.43k
      elf->state.ELFW(elf,LIBELFBITS).phdr = file_phdr;
114
990
    else
115
990
      {
116
990
        ElfW2(LIBELFBITS,Phdr) *notcvt;
117
990
        ElfW2(LIBELFBITS,Phdr) *phdr;
118
119
        /* Allocate memory for the program headers.  We know the number
120
     of entries from the ELF header.  */
121
990
        phdr = elf->state.ELFW(elf,LIBELFBITS).phdr =
122
990
    (ElfW2(LIBELFBITS,Phdr) *) malloc (size);
123
990
        if (elf->state.ELFW(elf,LIBELFBITS).phdr == NULL)
124
0
    {
125
0
      __libelf_seterrno (ELF_E_NOMEM);
126
0
      goto out;
127
0
    }
128
990
        elf->state.ELFW(elf,LIBELFBITS).phdr_flags |=
129
990
    ELF_F_MALLOCED | ELF_F_DIRTY;
130
131
        /* Now copy the data and at the same time convert the
132
     byte order.  */
133
134
990
        if (ehdr->e_ident[EI_DATA] == MY_ELFDATA)
135
0
    {
136
0
      assert (! ALLOW_UNALIGNED);
137
0
      memcpy (phdr, file_phdr, size);
138
0
    }
139
990
        else
140
990
    {
141
990
      bool copy = ! (ALLOW_UNALIGNED
142
0
         || ((uintptr_t) file_phdr
143
0
             & (__alignof__ (ElfW2(LIBELFBITS,Phdr))
144
0
          - 1)) == 0);
145
990
      if (! copy)
146
990
        notcvt = file_phdr;
147
0
      else
148
0
        {
149
0
          notcvt = (ElfW2(LIBELFBITS,Phdr) *) malloc (size);
150
0
          if (unlikely (notcvt == NULL))
151
0
      {
152
0
        __libelf_seterrno (ELF_E_NOMEM);
153
0
        goto out;
154
0
      }
155
0
          memcpy (notcvt, file_phdr, size);
156
0
        }
157
158
1.22M
      for (size_t cnt = 0; cnt < phnum; ++cnt)
159
1.22M
        {
160
1.22M
          CONVERT_TO (phdr[cnt].p_type, notcvt[cnt].p_type);
161
1.22M
          CONVERT_TO (phdr[cnt].p_offset, notcvt[cnt].p_offset);
162
1.22M
          CONVERT_TO (phdr[cnt].p_vaddr, notcvt[cnt].p_vaddr);
163
1.22M
          CONVERT_TO (phdr[cnt].p_paddr, notcvt[cnt].p_paddr);
164
1.22M
          CONVERT_TO (phdr[cnt].p_filesz, notcvt[cnt].p_filesz);
165
1.22M
          CONVERT_TO (phdr[cnt].p_memsz, notcvt[cnt].p_memsz);
166
1.22M
          CONVERT_TO (phdr[cnt].p_flags, notcvt[cnt].p_flags);
167
1.22M
          CONVERT_TO (phdr[cnt].p_align, notcvt[cnt].p_align);
168
1.22M
        }
169
170
990
      if (copy)
171
0
        free (notcvt);
172
990
    }
173
990
      }
174
4.42k
  }
175
0
      else if (likely (elf->fildes != -1))
176
0
  {
177
    /* Allocate memory for the program headers.  We know the number
178
       of entries from the ELF header.  */
179
0
    elf->state.ELFW(elf,LIBELFBITS).phdr =
180
0
      (ElfW2(LIBELFBITS,Phdr) *) malloc (size);
181
0
    if (elf->state.ELFW(elf,LIBELFBITS).phdr == NULL)
182
0
      {
183
0
        __libelf_seterrno (ELF_E_NOMEM);
184
0
        goto out;
185
0
      }
186
0
    elf->state.ELFW(elf,LIBELFBITS).phdr_flags |= ELF_F_MALLOCED;
187
188
    /* Read the header.  */
189
0
    ssize_t n = pread_retry (elf->fildes,
190
0
           elf->state.ELFW(elf,LIBELFBITS).phdr, size,
191
0
           elf->start_offset + ehdr->e_phoff);
192
0
    if (unlikely ((size_t) n != size))
193
0
      {
194
        /* Severe problems.  We cannot read the data.  */
195
0
        __libelf_seterrno (ELF_E_READ_ERROR);
196
0
        free (elf->state.ELFW(elf,LIBELFBITS).phdr);
197
0
        elf->state.ELFW(elf,LIBELFBITS).phdr = NULL;
198
0
        goto out;
199
0
      }
200
201
    /* If the byte order of the file is not the same as the one
202
       of the host convert the data now.  */
203
0
    if (ehdr->e_ident[EI_DATA] != MY_ELFDATA)
204
0
      {
205
0
        ElfW2(LIBELFBITS,Phdr) *phdr
206
0
    = elf->state.ELFW(elf,LIBELFBITS).phdr;
207
208
0
        for (size_t cnt = 0; cnt < phnum; ++cnt)
209
0
    {
210
0
      CONVERT (phdr[cnt].p_type);
211
0
      CONVERT (phdr[cnt].p_offset);
212
0
      CONVERT (phdr[cnt].p_vaddr);
213
0
      CONVERT (phdr[cnt].p_paddr);
214
0
      CONVERT (phdr[cnt].p_filesz);
215
0
      CONVERT (phdr[cnt].p_memsz);
216
0
      CONVERT (phdr[cnt].p_flags);
217
0
      CONVERT (phdr[cnt].p_align);
218
0
    }
219
0
      }
220
0
  }
221
0
      else
222
0
  {
223
    /* The file descriptor was already enabled and not all data was
224
       read.  */
225
0
    __libelf_seterrno (ELF_E_FD_DISABLED);
226
0
    goto out;
227
0
  }
228
229
4.42k
      result = elf->state.ELFW(elf,LIBELFBITS).phdr;
230
4.42k
    }
231
232
4.58k
 out:
233
4.58k
  return result;
234
4.58k
}
235
236
ElfW2(LIBELFBITS,Phdr) *
237
elfw2(LIBELFBITS,getphdr) (Elf *elf)
238
18.9k
{
239
18.9k
  ElfW2(LIBELFBITS,Phdr) *result;
240
241
18.9k
  if (elf == NULL)
242
0
    return NULL;
243
244
18.9k
  if (unlikely (elf->kind != ELF_K_ELF))
245
0
    {
246
0
      __libelf_seterrno (ELF_E_INVALID_HANDLE);
247
0
      return NULL;
248
0
    }
249
250
  /* If the program header entry has already been filled in the code
251
   * in getphdr_wrlock must already have been run.  So the class is
252
   * set, too.  No need to waste any more time here.  */
253
18.9k
  result = elf->state.ELFW(elf,LIBELFBITS).phdr;
254
18.9k
  if (likely (result != NULL))
255
0
    return result;
256
257
18.9k
  rwlock_wrlock (elf->lock);
258
18.9k
  result = __elfw2(LIBELFBITS,getphdr_wrlock) (elf);
259
18.9k
  rwlock_unlock (elf->lock);
260
261
18.9k
  return result;
262
18.9k
}
elf32_getphdr
Line
Count
Source
238
14.3k
{
239
14.3k
  ElfW2(LIBELFBITS,Phdr) *result;
240
241
14.3k
  if (elf == NULL)
242
0
    return NULL;
243
244
14.3k
  if (unlikely (elf->kind != ELF_K_ELF))
245
0
    {
246
0
      __libelf_seterrno (ELF_E_INVALID_HANDLE);
247
0
      return NULL;
248
0
    }
249
250
  /* If the program header entry has already been filled in the code
251
   * in getphdr_wrlock must already have been run.  So the class is
252
   * set, too.  No need to waste any more time here.  */
253
14.3k
  result = elf->state.ELFW(elf,LIBELFBITS).phdr;
254
14.3k
  if (likely (result != NULL))
255
0
    return result;
256
257
14.3k
  rwlock_wrlock (elf->lock);
258
14.3k
  result = __elfw2(LIBELFBITS,getphdr_wrlock) (elf);
259
14.3k
  rwlock_unlock (elf->lock);
260
261
14.3k
  return result;
262
14.3k
}
elf64_getphdr
Line
Count
Source
238
4.58k
{
239
4.58k
  ElfW2(LIBELFBITS,Phdr) *result;
240
241
4.58k
  if (elf == NULL)
242
0
    return NULL;
243
244
4.58k
  if (unlikely (elf->kind != ELF_K_ELF))
245
0
    {
246
0
      __libelf_seterrno (ELF_E_INVALID_HANDLE);
247
0
      return NULL;
248
0
    }
249
250
  /* If the program header entry has already been filled in the code
251
   * in getphdr_wrlock must already have been run.  So the class is
252
   * set, too.  No need to waste any more time here.  */
253
4.58k
  result = elf->state.ELFW(elf,LIBELFBITS).phdr;
254
4.58k
  if (likely (result != NULL))
255
0
    return result;
256
257
4.58k
  rwlock_wrlock (elf->lock);
258
4.58k
  result = __elfw2(LIBELFBITS,getphdr_wrlock) (elf);
259
4.58k
  rwlock_unlock (elf->lock);
260
261
4.58k
  return result;
262
4.58k
}
263
INTDEF(elfw2(LIBELFBITS,getphdr))