summaryrefslogtreecommitdiff
path: root/usr
diff options
context:
space:
mode:
authorPeter Dennis - Sustaining Engineer <Peter.Dennis@Sun.COM>2010-02-26 18:11:59 +0000
committerPeter Dennis - Sustaining Engineer <Peter.Dennis@Sun.COM>2010-02-26 18:11:59 +0000
commit6b1abd46bd2c746d42947df930a0a3a632f81256 (patch)
tree49bdad53e61524839122fa4b90b9755b91f2f607 /usr
parent0f5cc0e1bee31c69c160a9cf7ffdff5fac4f8e6d (diff)
downloadillumos-gate-6b1abd46bd2c746d42947df930a0a3a632f81256.tar.gz
6924224 linker should ignore SUNW_dof when calculating the elf checksum
Diffstat (limited to 'usr')
-rw-r--r--usr/src/cmd/sgs/libelf/Makefile.com7
-rw-r--r--usr/src/cmd/sgs/libelf/common/checksum.c81
2 files changed, 41 insertions, 47 deletions
diff --git a/usr/src/cmd/sgs/libelf/Makefile.com b/usr/src/cmd/sgs/libelf/Makefile.com
index e219e178d3..087daaa7c0 100644
--- a/usr/src/cmd/sgs/libelf/Makefile.com
+++ b/usr/src/cmd/sgs/libelf/Makefile.com
@@ -19,11 +19,9 @@
# CDDL HEADER END
#
#
-# Copyright 2008 Sun Microsystems, Inc. All rights reserved.
+# Copyright 2010 Sun Microsystems, Inc. All rights reserved.
# Use is subject to license terms.
#
-# ident "%Z%%M% %I% %E% SMI"
-#
LIBRARY= libelf.a
VERS= .1
@@ -42,7 +40,8 @@ COMOBJS= ar.o begin.o cntl.o cook.o \
rand.o rawdata.o rawfile.o rawput.o \
strptr.o update.o error.o gelf.o \
clscook.o checksum.o
-CLASSOBJS= clscook64.o newehdr64.o newphdr64.o update64.o
+CLASSOBJS= clscook64.o newehdr64.o newphdr64.o update64.o \
+ checksum64.o
BLTOBJS= msg.o xlate.o xlate64.o
MISCOBJS= String.o args.o demangle.o nlist.o \
nplist.o
diff --git a/usr/src/cmd/sgs/libelf/common/checksum.c b/usr/src/cmd/sgs/libelf/common/checksum.c
index 780c1f2c16..c684d3f24b 100644
--- a/usr/src/cmd/sgs/libelf/common/checksum.c
+++ b/usr/src/cmd/sgs/libelf/common/checksum.c
@@ -20,7 +20,7 @@
*/
/*
- * Copyright 2008 Sun Microsystems, Inc. All rights reserved.
+ * Copyright 2010 Sun Microsystems, Inc. All rights reserved.
* Use is subject to license terms.
*/
@@ -30,7 +30,6 @@
/* Copyright (c) 1987, 1988 Microsoft Corporation */
/* All Rights Reserved */
-#pragma ident "%Z%%M% %I% %E% SMI"
#include <errno.h>
#include <libelf.h>
@@ -72,17 +71,43 @@ sumepi(long sum)
return ((ushort_t)(LSW(_sum) + MSW(_sum)));
}
+/*
+ * This module is compiled twice, the second time having
+ * -D_ELF64 defined. The following set of macros represent
+ * the differences between the two compilations. Be
+ * careful *not* to add any class dependent code (anything
+ * that has elf32 or elf64 in the name) to this code
+ * without hiding it behind a switchable macro like these.
+ */
+#if defined(_ELF64)
+
+#define elf_checksum elf64_checksum
+#define Elf_Ehdr Elf64_Ehdr
+#define Elf_Shdr Elf64_Shdr
+#define getehdr elf64_getehdr
+#define getshdr elf64_getshdr
+
+#else /* else ELF32 */
+
+#define elf_checksum elf32_checksum
+#define Elf_Ehdr Elf32_Ehdr
+#define Elf_Shdr Elf32_Shdr
+#define getehdr elf32_getehdr
+#define getshdr elf32_getshdr
+
+#endif /* ELF64 */
+
long
-elf32_checksum(Elf * elf)
+elf_checksum(Elf * elf)
{
long sum = 0;
- Elf32_Ehdr * ehdr;
- Elf32_Shdr * shdr;
+ Elf_Ehdr * ehdr;
+ Elf_Shdr * shdr;
Elf_Scn * scn;
Elf_Data * data, * (* getdata)(Elf_Scn *, Elf_Data *);
size_t shnum;
- if ((ehdr = elf32_getehdr(elf)) == 0)
+ if ((ehdr = getehdr(elf)) == 0)
return (0);
/*
@@ -107,41 +132,7 @@ elf32_checksum(Elf * elf)
for (shnum = 1; shnum < ehdr->e_shnum; shnum++) {
if ((scn = elf_getscn(elf, shnum)) == 0)
return (0);
- if ((shdr = elf32_getshdr(scn)) == 0)
- return (0);
-
- if (!(shdr->sh_flags & SHF_ALLOC))
- continue;
-
- if ((shdr->sh_type == SHT_DYNSYM) ||
- (shdr->sh_type == SHT_DYNAMIC))
- continue;
-
- data = 0;
- while ((data = (*getdata)(scn, data)) != 0)
- sum = sumupd(sum, data->d_buf, data->d_size);
-
- }
- return (sumepi(sum));
-}
-
-long
-elf64_checksum(Elf * elf)
-{
- long sum = 0;
- Elf64_Ehdr * ehdr;
- Elf64_Shdr * shdr;
- Elf_Scn * scn;
- Elf_Data * data;
- size_t shnum;
-
- if ((ehdr = elf64_getehdr(elf)) == 0)
- return (0);
-
- for (shnum = 1; shnum < ehdr->e_shnum; shnum++) {
- if ((scn = elf_getscn(elf, shnum)) == 0)
- return (0);
- if ((shdr = elf64_getshdr(scn)) == 0)
+ if ((shdr = getshdr(scn)) == 0)
return (0);
/* Exclude strippable sections */
@@ -154,13 +145,17 @@ elf64_checksum(Elf * elf)
* that strip might remove.
* - The .dynamic section is modified by the setting of
* this checksum value.
+ * - The .SUNW_dof section uses ftok(3C), which returns
+ * different values, to define a key for the
+ * objects in that section.
*/
if ((shdr->sh_type == SHT_DYNSYM) ||
- (shdr->sh_type == SHT_DYNAMIC))
+ (shdr->sh_type == SHT_DYNAMIC) ||
+ (shdr->sh_type == SHT_SUNW_dof))
continue;
data = 0;
- while ((data = elf_getdata(scn, data)) != 0)
+ while ((data = (*getdata)(scn, data)) != 0)
sum = sumupd(sum, data->d_buf, data->d_size);
}