LCOV - code coverage report
Current view: top level - libelf - gelf_getsym.c (source / functions) Coverage Total Hit
Test: elfutils-0.194 Lines: 78.6 % 28 22
Test Date: 2026-03-06 15:09:22 Functions: 100.0 % 1 1
Legend: Lines:     hit not hit
Branches: + taken - not taken # not executed
Branches: 60.0 % 10 6

             Branch data     Line data    Source code
       1                 :             : /* Get symbol information from symbol table at the given index.
       2                 :             :    Copyright (C) 1999, 2000, 2001, 2002, 2005, 2009, 2014, 2015 Red Hat, Inc.
       3                 :             :    This file is part of elfutils.
       4                 :             :    Written by Ulrich Drepper <drepper@redhat.com>, 1999.
       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 <gelf.h>
      35                 :             : #include <string.h>
      36                 :             : 
      37                 :             : #include "libelfP.h"
      38                 :             : 
      39                 :             : 
      40                 :             : GElf_Sym *
      41                 :      458560 : gelf_getsym (Elf_Data *data, int ndx, GElf_Sym *dst)
      42                 :             : {
      43                 :      458560 :   Elf_Data_Scn *data_scn = (Elf_Data_Scn *) data;
      44                 :      458560 :   GElf_Sym *result = NULL;
      45                 :             : 
      46         [ -  + ]:      458560 :   if (data == NULL)
      47                 :             :     return NULL;
      48                 :             : 
      49         [ -  + ]:      458560 :   if (unlikely (data->d_type != ELF_T_SYM))
      50                 :             :     {
      51                 :           0 :       __libelf_seterrno (ELF_E_INVALID_HANDLE);
      52                 :           0 :       return NULL;
      53                 :             :     }
      54                 :             : 
      55                 :      458560 :   rwlock_rdlock (data_scn->s->elf->lock);
      56                 :             : 
      57                 :             :   /* This is the one place where we have to take advantage of the fact
      58                 :             :      that an `Elf_Data' pointer is also a pointer to `Elf_Data_Scn'.
      59                 :             :      The interface is broken so that it requires this hack.  */
      60         [ +  + ]:      458560 :   if (data_scn->s->elf->class == ELFCLASS32)
      61                 :             :     {
      62                 :       69356 :       Elf32_Sym *src;
      63                 :             : 
      64                 :             :       /* Here it gets a bit more complicated.  The format of the symbol
      65                 :             :          table entries has to be adopted.  The user better has provided
      66                 :             :          a buffer where we can store the information.  While copying the
      67                 :             :          data we are converting the format.  */
      68         [ -  + ]:       69356 :       if (INVALID_NDX (ndx, Elf32_Sym, data))
      69                 :             :         {
      70                 :           0 :           __libelf_seterrno (ELF_E_INVALID_INDEX);
      71                 :           0 :           goto out;
      72                 :             :         }
      73                 :             : 
      74                 :       69356 :       src = &((Elf32_Sym *) data->d_buf)[ndx];
      75                 :             : 
      76                 :             :       /* This might look like a simple copy operation but it's
      77                 :             :          not.  There are zero- and sign-extensions going on.  */
      78                 :             : #define COPY(name) \
      79                 :             :       dst->name = src->name
      80                 :       69356 :       COPY (st_name);
      81                 :             :       /* Please note that we can simply copy the `st_info' element since
      82                 :             :          the definitions of ELFxx_ST_BIND and ELFxx_ST_TYPE are the same
      83                 :             :          for the 64 bit variant.  */
      84                 :       69356 :       COPY (st_info);
      85                 :       69356 :       COPY (st_other);
      86                 :       69356 :       COPY (st_shndx);
      87                 :       69356 :       COPY (st_value);
      88                 :       69356 :       COPY (st_size);
      89                 :             :     }
      90                 :             :   else
      91                 :             :     {
      92                 :             :       /* If this is a 64 bit object it's easy.  */
      93                 :      389204 :       eu_static_assert (sizeof (GElf_Sym) == sizeof (Elf64_Sym));
      94                 :             : 
      95                 :             :       /* The data is already in the correct form.  Just make sure the
      96                 :             :          index is OK.  */
      97         [ -  + ]:      389204 :       if (INVALID_NDX (ndx, GElf_Sym, data))
      98                 :             :         {
      99                 :           0 :           __libelf_seterrno (ELF_E_INVALID_INDEX);
     100                 :           0 :           goto out;
     101                 :             :         }
     102                 :             : 
     103                 :      389204 :       *dst = ((GElf_Sym *) data->d_buf)[ndx];
     104                 :             :     }
     105                 :             : 
     106                 :             :   result = dst;
     107                 :             : 
     108                 :      458560 :  out:
     109                 :      458560 :   rwlock_unlock (data_scn->s->elf->lock);
     110                 :             : 
     111                 :      458560 :   return result;
     112                 :             : }
     113                 :             : INTDEF(gelf_getsym)
        

Generated by: LCOV version 2.0-1