diff options
author | Julien Cristau <jcristau@debian.org> | 2009-10-14 23:20:44 +0200 |
---|---|---|
committer | Julien Cristau <jcristau@debian.org> | 2009-10-15 01:17:44 +0200 |
commit | 55516094947dd78ad2734bb784a2fb109b64c990 (patch) | |
tree | a33fc94df894e66357c09ec05798355a3a67a11c /os | |
parent | 25344ba7f7845654364d62bf15322b3b79465bd9 (diff) |
Move SHA1 computation from render/glyph.c to os/
Signed-off-by: Julien Cristau <jcristau@debian.org>
Reviewed-by: RĂ©mi Cardona <remi@gentoo.org>
Diffstat (limited to 'os')
-rw-r--r-- | os/Makefile.am | 4 | ||||
-rw-r--r-- | os/xsha1.c | 74 |
2 files changed, 77 insertions, 1 deletions
diff --git a/os/Makefile.am b/os/Makefile.am index a7f34a5b8..9902f045c 100644 --- a/os/Makefile.am +++ b/os/Makefile.am @@ -1,6 +1,6 @@ noinst_LTLIBRARIES = libos.la -AM_CFLAGS = $(DIX_CFLAGS) +AM_CFLAGS = $(DIX_CFLAGS) $(SHA1_CFLAGS) SECURERPC_SRCS = rpcauth.c XDMCP_SRCS = xdmcp.c @@ -22,9 +22,11 @@ libos_la_SOURCES = \ strcasecmp.c \ strcasestr.c \ xdmauth.c \ + xsha1.c \ xstrans.c \ xprintf.c \ $(XORG_SRCS) +libos_la_LIBADD = @SHA1_LIBS@ if SECURE_RPC libos_la_SOURCES += $(SECURERPC_SRCS) diff --git a/os/xsha1.c b/os/xsha1.c new file mode 100644 index 000000000..20169807e --- /dev/null +++ b/os/xsha1.c @@ -0,0 +1,74 @@ +#ifdef HAVE_DIX_CONFIG_H +#include <dix-config.h> +#endif + +#include "os.h" +#include "xsha1.h" + +#ifdef HAVE_SHA1_IN_LIBMD /* Use libmd for SHA1 */ + +# include <sha1.h> + +void *x_sha1_init(void) +{ + SHA1_CTX *ctx = xalloc(sizeof(*ctx)); + if (!ctx) + return NULL; + SHA1Init(ctx); + return ctx; +} + +int x_sha1_update(void *ctx, void *data, int size) +{ + SHA1_CTX *sha1_ctx = ctx; + SHA1Update(sha1_ctx, data, size); + return 1; +} + +int x_sha1_final(void *ctx, unsigned char result[20]) +{ + SHA1_CTX *sha1_ctx = ctx; + SHA1Final(result, sha1_ctx); + xfree(sha1_ctx); + return 1; +} + +#else /* Use OpenSSL's libcrypto */ + +# include <stddef.h> /* buggy openssl/sha.h wants size_t */ +# include <openssl/sha.h> + +void *x_sha1_init(void) +{ + int ret; + SHA_CTX *ctx = xalloc(sizeof(*ctx)); + if (!ctx) + return NULL; + ret = SHA1_Init(ctx); + if (!ret) { + xfree(ctx); + return NULL; + } + return ctx; +} + +int x_sha1_update(void *ctx, void *data, int size) +{ + int ret; + SHA_CTX *sha_ctx = ctx; + ret = SHA1_Update(sha_ctx, data, size); + if (!ret) + xfree(sha_ctx); + return ret; +} + +int x_sha1_final(void *ctx, unsigned char result[20]) +{ + int ret; + SHA_CTX *sha_ctx = ctx; + ret = SHA1_Final(result, sha_ctx); + xfree(sha_ctx); + return ret; +} + +#endif |