CoCalc provides the best real-time collaborative environment for Jupyter Notebooks, LaTeX documents, and SageMath, scalable from individual users to large groups and classes!
CoCalc provides the best real-time collaborative environment for Jupyter Notebooks, LaTeX documents, and SageMath, scalable from individual users to large groups and classes!
Path: blob/master/data/headers/windows/c_payload_util/chacha.h
Views: 1904
/*1chacha-merged.c version 200801182D. J. Bernstein3Public domain.4*/56/* $OpenBSD: chacha_private.h,v 1.2 2013/10/04 07:02:27 djm Exp $ */78#include <stddef.h>910typedef unsigned char u8;11typedef unsigned int u32;1213typedef struct14{15u32 input[16]; /* could be compressed */16} chacha_ctx;1718#define U8C(v) (v##U)19#define U32C(v) (v##U)2021#define U8V(v) ((u8)(v) & U8C(0xFF))22#define U32V(v) ((u32)(v) & U32C(0xFFFFFFFF))2324#define ROTL32(v, n) \25(U32V((v) << (n)) | ((v) >> (32 - (n))))2627#define U8TO32_LITTLE(p) \28(((u32)((p)[0]) ) | \29((u32)((p)[1]) << 8) | \30((u32)((p)[2]) << 16) | \31((u32)((p)[3]) << 24))3233#define U32TO8_LITTLE(p, v) \34do { \35(p)[0] = U8V((v) ); \36(p)[1] = U8V((v) >> 8); \37(p)[2] = U8V((v) >> 16); \38(p)[3] = U8V((v) >> 24); \39} while (0)4041#define ROTATE(v,c) (ROTL32(v,c))42#define XOR(v,w) ((v) ^ (w))43#define PLUS(v,w) (U32V((v) + (w)))44#define PLUSONE(v) (PLUS((v),1))4546#define QUARTERROUND(a,b,c,d) \47a = PLUS(a,b); d = ROTATE(XOR(d,a),16); \48c = PLUS(c,d); b = ROTATE(XOR(b,c),12); \49a = PLUS(a,b); d = ROTATE(XOR(d,a), 8); \50c = PLUS(c,d); b = ROTATE(XOR(b,c), 7);5152static const char sigma[16] = "expand 32-byte k";53static const char tau[16] = "expand 16-byte k";5455static void56chacha_keysetup(chacha_ctx *x,const u8 *k,u32 kbits,u32 ivbits)57{58const char *constants;5960x->input[4] = U8TO32_LITTLE(k + 0);61x->input[5] = U8TO32_LITTLE(k + 4);62x->input[6] = U8TO32_LITTLE(k + 8);63x->input[7] = U8TO32_LITTLE(k + 12);64if (kbits == 256) { /* recommended */65k += 16;66constants = sigma;67} else { /* kbits == 128 */68constants = tau;69}70x->input[8] = U8TO32_LITTLE(k + 0);71x->input[9] = U8TO32_LITTLE(k + 4);72x->input[10] = U8TO32_LITTLE(k + 8);73x->input[11] = U8TO32_LITTLE(k + 12);74x->input[0] = U8TO32_LITTLE(constants + 0);75x->input[1] = U8TO32_LITTLE(constants + 4);76x->input[2] = U8TO32_LITTLE(constants + 8);77x->input[3] = U8TO32_LITTLE(constants + 12);78}7980static void81chacha_ivsetup(chacha_ctx *x,const u8 *iv)82{83x->input[12] = 1;84x->input[13] = U8TO32_LITTLE(iv + 0);85x->input[14] = U8TO32_LITTLE(iv + 4);86x->input[15] = U8TO32_LITTLE(iv + 8);87}8889static void90chacha_encrypt_bytes(chacha_ctx *x,const u8 *m,u8 *c,u32 bytes)91{92u32 x0, x1, x2, x3, x4, x5, x6, x7, x8, x9, x10, x11, x12, x13, x14, x15;93u32 j0, j1, j2, j3, j4, j5, j6, j7, j8, j9, j10, j11, j12, j13, j14, j15;94u8 *ctarget = NULL;95u8 tmp[64];96u32 i;9798if (!bytes) return;99100j0 = x->input[0];101j1 = x->input[1];102j2 = x->input[2];103j3 = x->input[3];104j4 = x->input[4];105j5 = x->input[5];106j6 = x->input[6];107j7 = x->input[7];108j8 = x->input[8];109j9 = x->input[9];110j10 = x->input[10];111j11 = x->input[11];112j12 = x->input[12];113j13 = x->input[13];114j14 = x->input[14];115j15 = x->input[15];116117for (;;) {118if (bytes < 64) {119for (i = 0;i < bytes;++i) tmp[i] = m[i];120m = tmp;121ctarget = c;122c = tmp;123}124x0 = j0;125x1 = j1;126x2 = j2;127x3 = j3;128x4 = j4;129x5 = j5;130x6 = j6;131x7 = j7;132x8 = j8;133x9 = j9;134x10 = j10;135x11 = j11;136x12 = j12;137x13 = j13;138x14 = j14;139x15 = j15;140for (i = 20;i > 0;i -= 2) {141QUARTERROUND( x0, x4, x8,x12)142QUARTERROUND( x1, x5, x9,x13)143QUARTERROUND( x2, x6,x10,x14)144QUARTERROUND( x3, x7,x11,x15)145QUARTERROUND( x0, x5,x10,x15)146QUARTERROUND( x1, x6,x11,x12)147QUARTERROUND( x2, x7, x8,x13)148QUARTERROUND( x3, x4, x9,x14)149}150x0 = PLUS(x0,j0);151x1 = PLUS(x1,j1);152x2 = PLUS(x2,j2);153x3 = PLUS(x3,j3);154x4 = PLUS(x4,j4);155x5 = PLUS(x5,j5);156x6 = PLUS(x6,j6);157x7 = PLUS(x7,j7);158x8 = PLUS(x8,j8);159x9 = PLUS(x9,j9);160x10 = PLUS(x10,j10);161x11 = PLUS(x11,j11);162x12 = PLUS(x12,j12);163x13 = PLUS(x13,j13);164x14 = PLUS(x14,j14);165x15 = PLUS(x15,j15);166167#ifndef KEYSTREAM_ONLY168x0 = XOR(x0,U8TO32_LITTLE(m + 0));169x1 = XOR(x1,U8TO32_LITTLE(m + 4));170x2 = XOR(x2,U8TO32_LITTLE(m + 8));171x3 = XOR(x3,U8TO32_LITTLE(m + 12));172x4 = XOR(x4,U8TO32_LITTLE(m + 16));173x5 = XOR(x5,U8TO32_LITTLE(m + 20));174x6 = XOR(x6,U8TO32_LITTLE(m + 24));175x7 = XOR(x7,U8TO32_LITTLE(m + 28));176x8 = XOR(x8,U8TO32_LITTLE(m + 32));177x9 = XOR(x9,U8TO32_LITTLE(m + 36));178x10 = XOR(x10,U8TO32_LITTLE(m + 40));179x11 = XOR(x11,U8TO32_LITTLE(m + 44));180x12 = XOR(x12,U8TO32_LITTLE(m + 48));181x13 = XOR(x13,U8TO32_LITTLE(m + 52));182x14 = XOR(x14,U8TO32_LITTLE(m + 56));183x15 = XOR(x15,U8TO32_LITTLE(m + 60));184#endif185186j12 = PLUSONE(j12);187if (!j12) {188j13 = PLUSONE(j13);189/* stopping at 2^70 bytes per nonce is user's responsibility */190}191192U32TO8_LITTLE(c + 0,x0);193U32TO8_LITTLE(c + 4,x1);194U32TO8_LITTLE(c + 8,x2);195U32TO8_LITTLE(c + 12,x3);196U32TO8_LITTLE(c + 16,x4);197U32TO8_LITTLE(c + 20,x5);198U32TO8_LITTLE(c + 24,x6);199U32TO8_LITTLE(c + 28,x7);200U32TO8_LITTLE(c + 32,x8);201U32TO8_LITTLE(c + 36,x9);202U32TO8_LITTLE(c + 40,x10);203U32TO8_LITTLE(c + 44,x11);204U32TO8_LITTLE(c + 48,x12);205U32TO8_LITTLE(c + 52,x13);206U32TO8_LITTLE(c + 56,x14);207U32TO8_LITTLE(c + 60,x15);208209if (bytes <= 64) {210if (bytes < 64) {211for (i = 0;i < bytes;++i) ctarget[i] = c[i];212}213x->input[12] = j12;214x->input[13] = j13;215return;216}217bytes -= 64;218c += 64;219#ifndef KEYSTREAM_ONLY220m += 64;221#endif222}223}224225226