On Sat, 2014-07-26 at 19:44 +0000, Andreas Tobler wrote:
> Author: andreast
> Date: Sat Jul 26 19:44:45 2014
> New Revision: 269143
> URL: http://svnweb.freebsd.org/changeset/base/269143
> 
> Log:
>   Further improvements on elfdump, to follow up r269092:
>   
>   - Add ARM specific section header types.
>   - Add SHT_GNU_HASH section header type.
>   - Improve reporting of undefined tags in d_tags.
>   - Add DT_GNU_HASH tag.
>   
>   Reviewed by:        emaste
> 
> Modified:
>   head/usr.bin/elfdump/elfdump.c
> 
> Modified: head/usr.bin/elfdump/elfdump.c
> ==============================================================================
> --- head/usr.bin/elfdump/elfdump.c    Sat Jul 26 19:27:34 2014        
> (r269142)
> +++ head/usr.bin/elfdump/elfdump.c    Sat Jul 26 19:44:45 2014        
> (r269143)
> @@ -167,7 +167,10 @@ static int elf64_offsets[] = {
>  
>  /* http://www.sco.com/developers/gabi/latest/ch5.dynamic.html#tag_encodings 
> */
>  static const char *
> -d_tags(u_int64_t tag) {
> +d_tags(u_int64_t tag)
> +{
> +     static char unknown_tag[48];
> +
>       switch (tag) {
>       case 0: return "DT_NULL";
>       case 1: return "DT_NEEDED";
> @@ -215,6 +218,7 @@ d_tags(u_int64_t tag) {
>       case 0x6ffffdfe: return "DT_SYMINSZ";
>       case 0x6ffffdff: return "DT_SYMINENT (DT_VALRNGHI)";
>       case 0x6ffffe00: return "DT_ADDRRNGLO";
> +     case 0x6ffffef5: return "DT_GNU_HASH";
>       case 0x6ffffef8: return "DT_GNU_CONFLICT";
>       case 0x6ffffef9: return "DT_GNU_LIBLIST";
>       case 0x6ffffefa: return "DT_SUNW_CONFIG";
> @@ -236,8 +240,10 @@ d_tags(u_int64_t tag) {
>       case 0x7ffffffd: return "DT_SUNW_AUXILIARY";
>       case 0x7ffffffe: return "DT_SUNW_USED";
>       case 0x7fffffff: return "DT_SUNW_FILTER";
> -     default: return "ERROR: TAG NOT DEFINED";
>       }
> +     snprintf(unknown_tag, sizeof(unknown_tag),
> +             "ERROR: TAG NOT DEFINED -- tag 0x%jx", (uintmax_t)tag);
> +     return (unknown_tag);
>  }
>  
>  static const char *
> @@ -334,6 +340,7 @@ sh_types(uint64_t machine, uint64_t sht)
>               switch (sht) {
>               case 0x6ffffff0: return "XXX:VERSYM";
>               case 0x6ffffff4: return "SHT_SUNW_dof";
> +             case 0x6ffffff6: return "SHT_GNU_HASH";
>               case 0x6ffffff7: return "SHT_GNU_LIBLIST";
>               case 0x6ffffffc: return "XXX:VERDEF";
>               case 0x6ffffffd: return "SHT_SUNW(GNU)_verdef";
> @@ -347,6 +354,15 @@ sh_types(uint64_t machine, uint64_t sht)
>       } else if (sht < 0x80000000) {
>               /* 0x70000000-0x7fffffff processor-specific semantics */
>               switch (machine) {
> +             case EM_ARM:
> +                     switch (sht) {
> +                     case 0x70000001: return "SHT_ARM_EXIDX";
> +                     case 0x70000002: return "SHT_ARM_PREEMPTMAP";
> +                     case 0x70000003: return "SHT_ARM_ATTRIBUTES";
> +                     case 0x70000004: return "SHT_ARM_DEBUGOVERLAY";
> +                     case 0x70000005: return "SHT_ARM_OVERLAYSECTION";
> +                     }
> +                     break;
>               case EM_MIPS:
>                       switch (sht) {
>                       case 0x7000000d: return "SHT_MIPS_OPTIONS";
> 

I'm curious why this code is all full of 0xnnnnnnnn numbers when there
are named constants defined for all this stuff.

-- Ian



_______________________________________________
svn-src-head@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-head
To unsubscribe, send any mail to "svn-src-head-unsubscr...@freebsd.org"

Reply via email to