Author: bz
Date: Mon Sep  7 13:37:04 2009
New Revision: 196924
URL: http://svn.freebsd.org/changeset/base/196924

Log:
  MFC r196653:
    Make sure FreeBSD binaries without .note.ABI-tag section work
    correctly and do not match a colliding Debian GNU/kFreeBSD
    brandinfo statements.
    For this mark the Debian GNU/kFreeBSD brandinfo that it must have
    an .note.ABI-tag section and ignore the old EI_OSABI brandinfo
    when comparing a possibly colliding set of options.
  
    Due to SYSINIT we add the brandinfo in a non-deterministic order,
    so native FreeBSD is not always first. We may want to consider
    to force native FreeBSD to come first as well.
  
    The only way a problem could currently be noticed is when running an
    i386 binary without the .note.ABI-tag on amd64 and the Debian GNU/kFreeBSD
    brandinfo  was matched first,  as the fallback to ld-elf32.so.1 does
    not exist in that case.
  
  Reported and tested by:       ticso
  In collaboration with:        kib

Modified:
  stable/7/sys/   (props changed)
  stable/7/sys/amd64/amd64/elf_machdep.c
  stable/7/sys/compat/ia32/ia32_sysvec.c
  stable/7/sys/contrib/pf/   (props changed)
  stable/7/sys/i386/i386/elf_machdep.c
  stable/7/sys/kern/imgact_elf.c
  stable/7/sys/sys/imgact_elf.h

Modified: stable/7/sys/amd64/amd64/elf_machdep.c
==============================================================================
--- stable/7/sys/amd64/amd64/elf_machdep.c      Mon Sep  7 12:41:19 2009        
(r196923)
+++ stable/7/sys/amd64/amd64/elf_machdep.c      Mon Sep  7 13:37:04 2009        
(r196924)
@@ -117,7 +117,7 @@ static Elf64_Brandinfo kfreebsd_brand_in
        .sysvec         = &elf64_freebsd_sysvec,
        .interp_newpath = NULL,
        .brand_note     = &elf64_kfreebsd_brandnote,
-       .flags          = BI_CAN_EXEC_DYN | BI_BRAND_NOTE
+       .flags          = BI_CAN_EXEC_DYN | BI_BRAND_NOTE_MANDATORY
 };
 
 SYSINIT(kelf64, SI_SUB_EXEC, SI_ORDER_ANY,

Modified: stable/7/sys/compat/ia32/ia32_sysvec.c
==============================================================================
--- stable/7/sys/compat/ia32/ia32_sysvec.c      Mon Sep  7 12:41:19 2009        
(r196923)
+++ stable/7/sys/compat/ia32/ia32_sysvec.c      Mon Sep  7 13:37:04 2009        
(r196924)
@@ -179,7 +179,7 @@ static Elf32_Brandinfo kia32_brand_info 
        .interp_path    = "/lib/ld.so.1",
        .sysvec         = &ia32_freebsd_sysvec,
        .brand_note     = &elf32_kfreebsd_brandnote,
-       .flags          = BI_CAN_EXEC_DYN | BI_BRAND_NOTE
+       .flags          = BI_CAN_EXEC_DYN | BI_BRAND_NOTE_MANDATORY
 };
 
 SYSINIT(kia32, SI_SUB_EXEC, SI_ORDER_ANY,

Modified: stable/7/sys/i386/i386/elf_machdep.c
==============================================================================
--- stable/7/sys/i386/i386/elf_machdep.c        Mon Sep  7 12:41:19 2009        
(r196923)
+++ stable/7/sys/i386/i386/elf_machdep.c        Mon Sep  7 13:37:04 2009        
(r196924)
@@ -116,7 +116,7 @@ static Elf32_Brandinfo kfreebsd_brand_in
        .sysvec         = &elf32_freebsd_sysvec,
        .interp_newpath = NULL,
        .brand_note     = &elf32_kfreebsd_brandnote,
-       .flags          = BI_CAN_EXEC_DYN | BI_BRAND_NOTE
+       .flags          = BI_CAN_EXEC_DYN | BI_BRAND_NOTE_MANDATORY
 };
 
 SYSINIT(kelf32, SI_SUB_EXEC, SI_ORDER_ANY,

Modified: stable/7/sys/kern/imgact_elf.c
==============================================================================
--- stable/7/sys/kern/imgact_elf.c      Mon Sep  7 12:41:19 2009        
(r196923)
+++ stable/7/sys/kern/imgact_elf.c      Mon Sep  7 13:37:04 2009        
(r196924)
@@ -241,8 +241,10 @@ __elfN(get_brandinfo)(struct image_param
        /* Look for an ".note.ABI-tag" ELF section */
        for (i = 0; i < MAX_BRANDS; i++) {
                bi = elf_brand_list[i];
-               if (bi != NULL && hdr->e_machine == bi->machine &&
-                   (bi->flags & BI_BRAND_NOTE) != 0) {
+               if (bi == NULL)
+                       continue;
+               if (hdr->e_machine == bi->machine && (bi->flags &
+                   (BI_BRAND_NOTE|BI_BRAND_NOTE_MANDATORY)) != 0) {
                        ret = __elfN(check_note)(imgp, bi->brand_note, osrel);
                        if (ret)
                                return (bi);
@@ -252,7 +254,9 @@ __elfN(get_brandinfo)(struct image_param
        /* If the executable has a brand, search for it in the brand list. */
        for (i = 0; i < MAX_BRANDS; i++) {
                bi = elf_brand_list[i];
-               if (bi != NULL && hdr->e_machine == bi->machine &&
+               if (bi == NULL || bi->flags & BI_BRAND_NOTE_MANDATORY)
+                       continue;
+               if (hdr->e_machine == bi->machine &&
                    (hdr->e_ident[EI_OSABI] == bi->brand ||
                    strncmp((const char *)&hdr->e_ident[OLD_EI_BRAND],
                    bi->compat_3_brand, strlen(bi->compat_3_brand)) == 0))
@@ -263,7 +267,9 @@ __elfN(get_brandinfo)(struct image_param
        if (interp != NULL) {
                for (i = 0; i < MAX_BRANDS; i++) {
                        bi = elf_brand_list[i];
-                       if (bi != NULL && hdr->e_machine == bi->machine &&
+                       if (bi == NULL || bi->flags & BI_BRAND_NOTE_MANDATORY)
+                               continue;
+                       if (hdr->e_machine == bi->machine &&
                            strcmp(interp, bi->interp_path) == 0)
                                return (bi);
                }
@@ -272,7 +278,9 @@ __elfN(get_brandinfo)(struct image_param
        /* Lacking a recognized interpreter, try the default brand */
        for (i = 0; i < MAX_BRANDS; i++) {
                bi = elf_brand_list[i];
-               if (bi != NULL && hdr->e_machine == bi->machine &&
+               if (bi == NULL || bi->flags & BI_BRAND_NOTE_MANDATORY)
+                       continue;
+               if (hdr->e_machine == bi->machine &&
                    __elfN(fallback_brand) == bi->brand)
                        return (bi);
        }

Modified: stable/7/sys/sys/imgact_elf.h
==============================================================================
--- stable/7/sys/sys/imgact_elf.h       Mon Sep  7 12:41:19 2009        
(r196923)
+++ stable/7/sys/sys/imgact_elf.h       Mon Sep  7 13:37:04 2009        
(r196924)
@@ -75,8 +75,9 @@ typedef struct {
        const char *interp_newpath;
        int flags;
        Elf_Brandnote *brand_note;
-#define        BI_CAN_EXEC_DYN 0x0001
-#define        BI_BRAND_NOTE   0x0002
+#define        BI_CAN_EXEC_DYN         0x0001
+#define        BI_BRAND_NOTE           0x0002  /* May have note.ABI-tag 
section. */
+#define        BI_BRAND_NOTE_MANDATORY 0x0004  /* Must have note.ABI-tag 
section. */
 } __ElfN(Brandinfo);
 
 __ElfType(Auxargs);
_______________________________________________
svn-src-all@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-all
To unsubscribe, send any mail to "svn-src-all-unsubscr...@freebsd.org"

Reply via email to