about summary refs log tree commit diff
path: root/elf/dl-hash.h
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>1998-12-26 09:30:54 +0000
committerUlrich Drepper <drepper@redhat.com>1998-12-26 09:30:54 +0000
commit85f72e9c2a46601358e5e908053c13709b3003c3 (patch)
tree81d271ef44f1c5eeec78864acc54e471b13c9943 /elf/dl-hash.h
parent65c64a0b4afc4814d11af5d185772eb48d72e6ce (diff)
downloadglibc-85f72e9c2a46601358e5e908053c13709b3003c3.tar.gz
glibc-85f72e9c2a46601358e5e908053c13709b3003c3.tar.xz
glibc-85f72e9c2a46601358e5e908053c13709b3003c3.zip
Update.
1998-12-25  Ulrich Drepper  <drepper@cygnus.com>

	* elf/dl-hash.h: Move to...
	* sysdeps/generic/dl-hash.h: ...here.  Correct parameter type (must
	be unsigned char).  Remove conditional from inner loop and rearrange
	binary operations (12-22% performance increase).
	* sysdeps/i386/i686/dl-hash.h: New file.  Yet 10% faster than
	optimized generic version.
Diffstat (limited to 'elf/dl-hash.h')
-rw-r--r--elf/dl-hash.h69
1 files changed, 0 insertions, 69 deletions
diff --git a/elf/dl-hash.h b/elf/dl-hash.h
deleted file mode 100644
index 007f192a23..0000000000
--- a/elf/dl-hash.h
+++ /dev/null
@@ -1,69 +0,0 @@
-/* Compute hash alue for given string according to ELF standard.
-   Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
-   This file is part of the GNU C Library.
-
-   The GNU C Library is free software; you can redistribute it and/or
-   modify it under the terms of the GNU Library General Public License as
-   published by the Free Software Foundation; either version 2 of the
-   License, or (at your option) any later version.
-
-   The GNU C Library is distributed in the hope that it will be useful,
-   but WITHOUT ANY WARRANTY; without even the implied warranty of
-   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
-   Library General Public License for more details.
-
-   You should have received a copy of the GNU Library General Public
-   License along with the GNU C Library; see the file COPYING.LIB.  If not,
-   write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
-   Boston, MA 02111-1307, USA.  */
-
-#ifndef _DL_HASH_H
-#define _DL_HASH_H	1
-
-
-/* This is the hashing function specified by the ELF ABI.  In the
-   first five operations now overflow is possible so we optimized it a
-   bit.  */
-static inline unsigned
-_dl_elf_hash (const char *name)
-{
-  unsigned long int hash = 0;
-  if (*name != '\0')
-    {
-      hash = (hash << 4) + *name++;
-      if (*name != '\0')
-	{
-	  hash = (hash << 4) + *name++;
-	  if (*name != '\0')
-	    {
-	      hash = (hash << 4) + *name++;
-	      if (*name != '\0')
-		{
-		  hash = (hash << 4) + *name++;
-		  if (*name != '\0')
-		    {
-		      hash = (hash << 4) + *name++;
-		      while (*name != '\0')
-			{
-			  unsigned long int hi;
-			  hash = (hash << 4) + *name++;
-			  hi = hash & 0xf0000000;
-			  if (hi != 0)
-			    {
-			      hash ^= hi >> 24;
-			      /* The ELF ABI says `hash &= ~hi', but
-				 this is equivalent in this case and
-				 on some machines one insn instead of
-				 two.  */
-			      hash ^= hi;
-			    }
-			}
-		    }
-		}
-	    }
-	}
-    }
-  return hash;
-}
-
-#endif /* dl-hash.h */