2005-04-16 15:20:36 -07:00
#
# linux/arch/arm/lib/Makefile
#
# Copyright (C) 1995-2000 Russell King
#
lib-y := backtrace.o changebit.o csumipv6.o csumpartial.o \
csumpartialcopy.o csumpartialcopyuser.o clearbit.o \
2006-06-21 20:38:17 +01:00
delay.o findbit.o memchr.o memcpy.o \
2005-11-01 19:52:23 +00:00
memmove.o memset.o memzero.o setbit.o \
strncpy_from_user.o strnlen_user.o \
2005-11-01 19:52:24 +00:00
strchr.o strrchr.o \
testchangebit.o testclearbit.o testsetbit.o \
2005-11-01 19:52:22 +00:00
ashldi3.o ashrdi3.o lshrdi3.o muldi3.o \
[ARM] 2930/1: optimized sha1 implementation for ARM
Patch from Nicolas Pitre
Here's an ARM assembly SHA1 implementation to replace the default C
version. It is approximately 50% faster than the generic C version. On
an XScale processor running at 400MHz:
generic C version: 9.8 MB/s
my version: 14.5 MB/s
This code is useful to quite a few callers in the tree:
crypto/sha1.c: sha_transform(sctx->state, sctx->buffer, temp);
crypto/sha1.c: sha_transform(sctx->state, &data[i], temp);
drivers/char/random.c: sha_transform(buf, (__u8 *)r->pool+i, buf + 5);
drivers/char/random.c: sha_transform(buf, (__u8 *)data, buf + 5);
net/ipv4/syncookies.c: sha_transform(tmp + 16, (__u8 *)tmp, tmp + 16 + 5);
Signed-off-by: Nicolas Pitre <nico@cam.org>
Seems to work fine on big-endian as well.
Signed-off-by: Lennert Buytenhek <buytenh@wantstofly.org>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
2005-10-28 15:26:40 +01:00
ucmpdi2.o lib1funcs.o div64.o sha1.o \
2005-04-16 15:20:36 -07:00
io-readsb.o io-writesb.o io-readsl.o io-writesl.o
2006-06-21 20:38:17 +01:00
mmu-y := clear_user.o copy_page.o getuser.o putuser.o
2005-11-01 19:52:24 +00:00
# the code in uaccess.S is not preemption safe and
# probably faster on ARMv3 only
2006-03-27 15:46:06 +01:00
i f e q ( $( CONFIG_PREEMPT ) , y )
2006-06-21 20:38:17 +01:00
mmu-y += copy_from_user.o copy_to_user.o
2005-11-01 19:52:24 +00:00
e l s e
i f n e q ( $( CONFIG_CPU_ 32v 3) , y )
2006-06-21 20:38:17 +01:00
mmu-y += copy_from_user.o copy_to_user.o
2005-11-01 19:52:24 +00:00
e l s e
2006-06-21 20:38:17 +01:00
mmu-y += uaccess.o
2005-11-01 19:52:24 +00:00
e n d i f
e n d i f
2006-06-21 20:38:17 +01:00
lib-$(CONFIG_MMU) += $( mmu-y)
2005-04-16 15:20:36 -07:00
i f e q ( $( CONFIG_CPU_ 32v 3) , y )
lib-y += io-readsw-armv3.o io-writesw-armv3.o
e l s e
lib-y += io-readsw-armv4.o io-writesw-armv4.o
e n d i f
lib-$(CONFIG_ARCH_RPC) += ecard.o io-acorn.o floppydma.o
lib-$(CONFIG_ARCH_CLPS7500) += io-acorn.o
lib-$(CONFIG_ARCH_L7200) += io-acorn.o
lib-$(CONFIG_ARCH_SHARK) += io-shark.o
$(obj)/csumpartialcopy.o : $( obj ) /csumpartialcopygeneric .S
$(obj)/csumpartialcopyuser.o : $( obj ) /csumpartialcopygeneric .S