404

[ Avaa Bypassed ]




Upload:

Command:

botdev@18.218.137.145: ~ $
/*
 * sha1_base.h - core logic for SHA-1 implementations
 *
 * Copyright (C) 2015 Linaro Ltd <ard.biesheuvel@linaro.org>
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 as
 * published by the Free Software Foundation.
 */

#include <crypto/internal/hash.h>
#include <crypto/sha.h>
#include <linux/crypto.h>
#include <linux/module.h>

#include <asm/unaligned.h>

typedef void (sha1_block_fn)(struct sha1_state *sst, u8 const *src, int blocks);

static inline int sha1_base_init(struct shash_desc *desc)
{
	struct sha1_state *sctx = shash_desc_ctx(desc);

	sctx->state[0] = SHA1_H0;
	sctx->state[1] = SHA1_H1;
	sctx->state[2] = SHA1_H2;
	sctx->state[3] = SHA1_H3;
	sctx->state[4] = SHA1_H4;
	sctx->count = 0;

	return 0;
}

static inline int sha1_base_do_update(struct shash_desc *desc,
				      const u8 *data,
				      unsigned int len,
				      sha1_block_fn *block_fn)
{
	struct sha1_state *sctx = shash_desc_ctx(desc);
	unsigned int partial = sctx->count % SHA1_BLOCK_SIZE;

	sctx->count += len;

	if (unlikely((partial + len) >= SHA1_BLOCK_SIZE)) {
		int blocks;

		if (partial) {
			int p = SHA1_BLOCK_SIZE - partial;

			memcpy(sctx->buffer + partial, data, p);
			data += p;
			len -= p;

			block_fn(sctx, sctx->buffer, 1);
		}

		blocks = len / SHA1_BLOCK_SIZE;
		len %= SHA1_BLOCK_SIZE;

		if (blocks) {
			block_fn(sctx, data, blocks);
			data += blocks * SHA1_BLOCK_SIZE;
		}
		partial = 0;
	}
	if (len)
		memcpy(sctx->buffer + partial, data, len);

	return 0;
}

static inline int sha1_base_do_finalize(struct shash_desc *desc,
					sha1_block_fn *block_fn)
{
	const int bit_offset = SHA1_BLOCK_SIZE - sizeof(__be64);
	struct sha1_state *sctx = shash_desc_ctx(desc);
	__be64 *bits = (__be64 *)(sctx->buffer + bit_offset);
	unsigned int partial = sctx->count % SHA1_BLOCK_SIZE;

	sctx->buffer[partial++] = 0x80;
	if (partial > bit_offset) {
		memset(sctx->buffer + partial, 0x0, SHA1_BLOCK_SIZE - partial);
		partial = 0;

		block_fn(sctx, sctx->buffer, 1);
	}

	memset(sctx->buffer + partial, 0x0, bit_offset - partial);
	*bits = cpu_to_be64(sctx->count << 3);
	block_fn(sctx, sctx->buffer, 1);

	return 0;
}

static inline int sha1_base_finish(struct shash_desc *desc, u8 *out)
{
	struct sha1_state *sctx = shash_desc_ctx(desc);
	__be32 *digest = (__be32 *)out;
	int i;

	for (i = 0; i < SHA1_DIGEST_SIZE / sizeof(__be32); i++)
		put_unaligned_be32(sctx->state[i], digest++);

	*sctx = (struct sha1_state){};
	return 0;
}

Filemanager

Name Type Size Permission Actions
internal Folder 0755
ablk_helper.h File 773 B 0644
acompress.h File 7.89 KB 0644
aead.h File 18.1 KB 0644
aes.h File 1.03 KB 0644
akcipher.h File 11.7 KB 0644
algapi.h File 11.12 KB 0644
authenc.h File 845 B 0644
b128ops.h File 2.41 KB 0644
blake2s.h File 2.37 KB 0644
blowfish.h File 415 B 0644
cast5.h File 590 B 0644
cast6.h File 636 B 0644
cast_common.h File 232 B 0644
cbc.h File 3.48 KB 0644
chacha20.h File 1.01 KB 0644
cryptd.h File 2.5 KB 0644
crypto_wq.h File 161 B 0644
ctr.h File 524 B 0644
des.h File 542 B 0644
dh.h File 2.62 KB 0644
drbg.h File 9.05 KB 0644
ecdh.h File 2.67 KB 0644
engine.h File 4 KB 0644
gcm.h File 140 B 0644
gf128mul.h File 9.41 KB 0644
ghash.h File 381 B 0644
hash.h File 31.48 KB 0644
hash_info.h File 1.13 KB 0644
hmac.h File 173 B 0644
if_alg.h File 7 KB 0644
kpp.h File 9.68 KB 0644
lrw.h File 1.22 KB 0644
mcryptd.h File 2.37 KB 0644
md5.h File 497 B 0644
null.h File 569 B 0644
padlock.h File 649 B 0644
pcrypt.h File 1.4 KB 0644
pkcs7.h File 1.21 KB 0644
poly1305.h File 920 B 0644
public_key.h File 2.08 KB 0644
rng.h File 6.66 KB 0644
scatterwalk.h File 3.67 KB 0644
serpent.h File 712 B 0644
sha.h File 2.88 KB 0644
sha1_base.h File 2.47 KB 0644
sha256_base.h File 3.03 KB 0644
sha3.h File 704 B 0644
sha512_base.h File 3.19 KB 0644
skcipher.h File 20.7 KB 0644
sm3.h File 833 B 0644
sm3_base.h File 2.95 KB 0644
twofish.h File 755 B 0644
xts.h File 1.81 KB 0644