SMOLNET PORTAL home about changes
iRewrite Makefile and add sha256 sources. - sup - small tool for privilege escalation	Err	bitreich.org	70
hgit clone git://bitreich.org/sup git://enlrupgkhuxnvlhsf6lc3fziv5h2hhfrinws65d7roiv6bfj7d652fid.onion/sup	URL:git://bitreich.org/sup git://enlrupgkhuxnvlhsf6lc3fziv5h2hhfrinws65d7roiv6bfj7d652fid.onion/sup	bitreich.org	70
1Log	/scm/sup/log.gph	bitreich.org	70
1Files	/scm/sup/files.gph	bitreich.org	70
1Refs	/scm/sup/refs.gph	bitreich.org	70
1Tags	/scm/sup/tag	bitreich.org	70
1README	/scm/sup/file/README.gph	bitreich.org	70
1LICENSE	/scm/sup/file/LICENSE.gph	bitreich.org	70
i---	Err	bitreich.org	70
1commit 6ff18b795ab40b43d16da0a8e5affbd85781525c	/scm/sup/commit/6ff18b795ab40b43d16da0a8e5affbd85781525c.gph	bitreich.org	70
1parent 1afa45a7fa22830cd02281dfdc21a4e2ab96acdf	/scm/sup/commit/1afa45a7fa22830cd02281dfdc21a4e2ab96acdf.gph	bitreich.org	70
hAuthor: parazyd <parazyd@dyne.org>	URL:mailto:parazyd@dyne.org	bitreich.org	70
iDate:   Tue,  2 Jul 2019 12:46:17 +0200	Err	bitreich.org	70
i	Err	bitreich.org	70
iRewrite Makefile and add sha256 sources.	Err	bitreich.org	70
i	Err	bitreich.org	70
iDiffstat:	Err	bitreich.org	70
i  M Makefile                            |      55 ++++++++++++++++---------------	Err	bitreich.org	70
i  A config.mk                           |       7 +++++++	Err	bitreich.org	70
i  A sha256.c                            |     261 +++++++++++++++++++++++++++++++	Err	bitreich.org	70
i  A sha256.h                            |      24 ++++++++++++++++++++++++	Err	bitreich.org	70
i	Err	bitreich.org	70
i4 files changed, 321 insertions(+), 26 deletions(-)	Err	bitreich.org	70
i---	Err	bitreich.org	70
1diff --git a/Makefile b/Makefile	/scm/sup/file/Makefile.gph	bitreich.org	70
i@@ -1,33 +1,36 @@	Err	bitreich.org	70
i-CC?=gcc	Err	bitreich.org	70
i-DESTDIR?=	Err	bitreich.org	70
i-PREFIX?=/usr	Err	bitreich.org	70
i-VERSION=0.1	Err	bitreich.org	70
i-USER=root	Err	bitreich.org	70
i-GROUP=root	Err	bitreich.org	70
i-CFLAGS?=-O2 -Wall	Err	bitreich.org	70
i+# sup: scale user privileges	Err	bitreich.org	70
i+# See LICENSE file for copyright and license details.	Err	bitreich.org	70
i+.POSIX:	Err	bitreich.org	70
i 	Err	bitreich.org	70
i-all: config.h sup	Err	bitreich.org	70
i+include config.mk	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+BIN = sup	Err	bitreich.org	70
i+MAN = $(BIN).1	Err	bitreich.org	70
i+OBJ = $(BIN:=.o) sha256.o	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+all: $(BIN)	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+$(OBJ): config.h config.mk	Err	bitreich.org	70
i 	Err	bitreich.org	70
i config.h:	Err	bitreich.org	70
i         cp config.def.h config.h	Err	bitreich.org	70
i 	Err	bitreich.org	70
i-sup.o: config.h sup.c	Err	bitreich.org	70
i-        ${CC} ${CFLAGS} -c sup.c	Err	bitreich.org	70
i-	Err	bitreich.org	70
i-sup: sup.o	Err	bitreich.org	70
i-        ${CC} ${LDFLAGS} sup.o -o sup	Err	bitreich.org	70
i+$(BIN): $(OBJ)	Err	bitreich.org	70
i+        $(CC) $(OBJ) $(LDFLAGS) -o $@	Err	bitreich.org	70
i 	Err	bitreich.org	70
i clean:	Err	bitreich.org	70
i-        rm -f sup.o sup	Err	bitreich.org	70
i-	Err	bitreich.org	70
i-mrproper: clean	Err	bitreich.org	70
i-        rm -f config.h	Err	bitreich.org	70
i-	Err	bitreich.org	70
i-install:	Err	bitreich.org	70
i-        mkdir -p ${DESTDIR}${PREFIX}/bin	Err	bitreich.org	70
i-        cp -f sup ${DESTDIR}${PREFIX}/bin	Err	bitreich.org	70
i-        -chown ${USER}:${GROUP} ${DESTDIR}/${PREFIX}/bin/sup	Err	bitreich.org	70
i-        -chmod 4111 ${DESTDIR}${PREFIX}/bin/sup	Err	bitreich.org	70
i-        mkdir -p ${DESTDIR}${PREFIX}/share/man/man1	Err	bitreich.org	70
i-        sed s,VERSION,${VERSION}, sup.1 \	Err	bitreich.org	70
i-          > ${DESTDIR}${PREFIX}/share/man/man1/sup.1	Err	bitreich.org	70
i+        rm -f $(BIN) $(OBJ)	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+install: all	Err	bitreich.org	70
i+        mkdir -p $(DESTDIR)$(PREFIX)/bin	Err	bitreich.org	70
i+        cp -f $(BIN) $(DESTDIR)$(PREFIX)/bin	Err	bitreich.org	70
i+        chmod 4711 $(DESTDIR)$(PREFIX)/bin/$(BIN)	Err	bitreich.org	70
i+        mkdir -p $(DESTDIR)$(MANDIR)	Err	bitreich.org	70
i+        cp -r $(MAN) $(DESTDIR)$(MANDIR)	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+uninstall:	Err	bitreich.org	70
i+        rm -f $(DESTDIR)$(PREFIX)/bin/$(BIN)	Err	bitreich.org	70
i+        rm -f $(DESTDIR)$(PREFIX)/$(MAN)	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+.c.o:	Err	bitreich.org	70
i+        $(CC) $(CFLAGS) -c $<	Err	bitreich.org	70
1diff --git a/config.mk b/config.mk	/scm/sup/file/config.mk.gph	bitreich.org	70
i@@ -0,0 +1,7 @@	Err	bitreich.org	70
i+# Install paths	Err	bitreich.org	70
i+PREFIX = /usr/local	Err	bitreich.org	70
i+MANDIR = $(PREFIX)/share/man/man1	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+# Stock FLAGS	Err	bitreich.org	70
i+CFLAGS = -Os -Wall -Werror -pedantic	Err	bitreich.org	70
i+LDFLAGS = -static -s	Err	bitreich.org	70
1diff --git a/sha256.c b/sha256.c	/scm/sup/file/sha256.c.gph	bitreich.org	70
i@@ -0,0 +1,261 @@	Err	bitreich.org	70
i+/*	Err	bitreich.org	70
i+ *  FIPS-180-2 compliant SHA-256 implementation	Err	bitreich.org	70
i+ *	Err	bitreich.org	70
i+ *  Copyright (C) 2001-2003  Christophe Devine	Err	bitreich.org	70
i+ *	Err	bitreich.org	70
i+ *  This program is free software; you can redistribute it and/or modify	Err	bitreich.org	70
i+ *  it under the terms of the GNU General Public License as published by	Err	bitreich.org	70
i+ *  the Free Software Foundation; either version 2 of the License, or	Err	bitreich.org	70
i+ *  (at your option) any later version.	Err	bitreich.org	70
i+ *	Err	bitreich.org	70
i+ *  This program is distributed in the hope that it will be useful,	Err	bitreich.org	70
i+ *  but WITHOUT ANY WARRANTY; without even the implied warranty of	Err	bitreich.org	70
i+ *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the	Err	bitreich.org	70
i+ *  GNU General Public License for more details.	Err	bitreich.org	70
i+ *	Err	bitreich.org	70
i+ *  You should have received a copy of the GNU General Public License	Err	bitreich.org	70
i+ *  along with this program; if not, write to the Free Software	Err	bitreich.org	70
i+ *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA	Err	bitreich.org	70
i+ */	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+#include <string.h>	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+#include "sha256.h"	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+#define GET_UINT32(n,b,i)                       \	Err	bitreich.org	70
i+{                                               \	Err	bitreich.org	70
i+    (n) = ( (uint32) (b)[(i)    ] << 24 )       \	Err	bitreich.org	70
i+        | ( (uint32) (b)[(i) + 1] << 16 )       \	Err	bitreich.org	70
i+        | ( (uint32) (b)[(i) + 2] <<  8 )       \	Err	bitreich.org	70
i+        | ( (uint32) (b)[(i) + 3]       );      \	Err	bitreich.org	70
i+}	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+#define PUT_UINT32(n,b,i)                       \	Err	bitreich.org	70
i+{                                               \	Err	bitreich.org	70
i+    (b)[(i)    ] = (uint8) ( (n) >> 24 );       \	Err	bitreich.org	70
i+    (b)[(i) + 1] = (uint8) ( (n) >> 16 );       \	Err	bitreich.org	70
i+    (b)[(i) + 2] = (uint8) ( (n) >>  8 );       \	Err	bitreich.org	70
i+    (b)[(i) + 3] = (uint8) ( (n)       );       \	Err	bitreich.org	70
i+}	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+void sha256_starts( sha256_context *ctx )	Err	bitreich.org	70
i+{	Err	bitreich.org	70
i+    ctx->total[0] = 0;	Err	bitreich.org	70
i+    ctx->total[1] = 0;	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+    ctx->state[0] = 0x6A09E667;	Err	bitreich.org	70
i+    ctx->state[1] = 0xBB67AE85;	Err	bitreich.org	70
i+    ctx->state[2] = 0x3C6EF372;	Err	bitreich.org	70
i+    ctx->state[3] = 0xA54FF53A;	Err	bitreich.org	70
i+    ctx->state[4] = 0x510E527F;	Err	bitreich.org	70
i+    ctx->state[5] = 0x9B05688C;	Err	bitreich.org	70
i+    ctx->state[6] = 0x1F83D9AB;	Err	bitreich.org	70
i+    ctx->state[7] = 0x5BE0CD19;	Err	bitreich.org	70
i+}	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+void sha256_process( sha256_context *ctx, uint8 data[64] )	Err	bitreich.org	70
i+{	Err	bitreich.org	70
i+    uint32 temp1, temp2, W[64];	Err	bitreich.org	70
i+    uint32 A, B, C, D, E, F, G, H;	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+    GET_UINT32( W[0],  data,  0 );	Err	bitreich.org	70
i+    GET_UINT32( W[1],  data,  4 );	Err	bitreich.org	70
i+    GET_UINT32( W[2],  data,  8 );	Err	bitreich.org	70
i+    GET_UINT32( W[3],  data, 12 );	Err	bitreich.org	70
i+    GET_UINT32( W[4],  data, 16 );	Err	bitreich.org	70
i+    GET_UINT32( W[5],  data, 20 );	Err	bitreich.org	70
i+    GET_UINT32( W[6],  data, 24 );	Err	bitreich.org	70
i+    GET_UINT32( W[7],  data, 28 );	Err	bitreich.org	70
i+    GET_UINT32( W[8],  data, 32 );	Err	bitreich.org	70
i+    GET_UINT32( W[9],  data, 36 );	Err	bitreich.org	70
i+    GET_UINT32( W[10], data, 40 );	Err	bitreich.org	70
i+    GET_UINT32( W[11], data, 44 );	Err	bitreich.org	70
i+    GET_UINT32( W[12], data, 48 );	Err	bitreich.org	70
i+    GET_UINT32( W[13], data, 52 );	Err	bitreich.org	70
i+    GET_UINT32( W[14], data, 56 );	Err	bitreich.org	70
i+    GET_UINT32( W[15], data, 60 );	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+#define  SHR(x,n) ((x & 0xFFFFFFFF) >> n)	Err	bitreich.org	70
i+#define ROTR(x,n) (SHR(x,n) | (x << (32 - n)))	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+#define S0(x) (ROTR(x, 7) ^ ROTR(x,18) ^  SHR(x, 3))	Err	bitreich.org	70
i+#define S1(x) (ROTR(x,17) ^ ROTR(x,19) ^  SHR(x,10))	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+#define S2(x) (ROTR(x, 2) ^ ROTR(x,13) ^ ROTR(x,22))	Err	bitreich.org	70
i+#define S3(x) (ROTR(x, 6) ^ ROTR(x,11) ^ ROTR(x,25))	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+#define F0(x,y,z) ((x & y) | (z & (x | y)))	Err	bitreich.org	70
i+#define F1(x,y,z) (z ^ (x & (y ^ z)))	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+#define R(t)                                    \	Err	bitreich.org	70
i+(                                               \	Err	bitreich.org	70
i+    W[t] = S1(W[t -  2]) + W[t -  7] +          \	Err	bitreich.org	70
i+           S0(W[t - 15]) + W[t - 16]            \	Err	bitreich.org	70
i+)	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+#define P(a,b,c,d,e,f,g,h,x,K)                  \	Err	bitreich.org	70
i+{                                               \	Err	bitreich.org	70
i+    temp1 = h + S3(e) + F1(e,f,g) + K + x;      \	Err	bitreich.org	70
i+    temp2 = S2(a) + F0(a,b,c);                  \	Err	bitreich.org	70
i+    d += temp1; h = temp1 + temp2;              \	Err	bitreich.org	70
i+}	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+    A = ctx->state[0];	Err	bitreich.org	70
i+    B = ctx->state[1];	Err	bitreich.org	70
i+    C = ctx->state[2];	Err	bitreich.org	70
i+    D = ctx->state[3];	Err	bitreich.org	70
i+    E = ctx->state[4];	Err	bitreich.org	70
i+    F = ctx->state[5];	Err	bitreich.org	70
i+    G = ctx->state[6];	Err	bitreich.org	70
i+    H = ctx->state[7];	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+    P( A, B, C, D, E, F, G, H, W[ 0], 0x428A2F98 );	Err	bitreich.org	70
i+    P( H, A, B, C, D, E, F, G, W[ 1], 0x71374491 );	Err	bitreich.org	70
i+    P( G, H, A, B, C, D, E, F, W[ 2], 0xB5C0FBCF );	Err	bitreich.org	70
i+    P( F, G, H, A, B, C, D, E, W[ 3], 0xE9B5DBA5 );	Err	bitreich.org	70
i+    P( E, F, G, H, A, B, C, D, W[ 4], 0x3956C25B );	Err	bitreich.org	70
i+    P( D, E, F, G, H, A, B, C, W[ 5], 0x59F111F1 );	Err	bitreich.org	70
i+    P( C, D, E, F, G, H, A, B, W[ 6], 0x923F82A4 );	Err	bitreich.org	70
i+    P( B, C, D, E, F, G, H, A, W[ 7], 0xAB1C5ED5 );	Err	bitreich.org	70
i+    P( A, B, C, D, E, F, G, H, W[ 8], 0xD807AA98 );	Err	bitreich.org	70
i+    P( H, A, B, C, D, E, F, G, W[ 9], 0x12835B01 );	Err	bitreich.org	70
i+    P( G, H, A, B, C, D, E, F, W[10], 0x243185BE );	Err	bitreich.org	70
i+    P( F, G, H, A, B, C, D, E, W[11], 0x550C7DC3 );	Err	bitreich.org	70
i+    P( E, F, G, H, A, B, C, D, W[12], 0x72BE5D74 );	Err	bitreich.org	70
i+    P( D, E, F, G, H, A, B, C, W[13], 0x80DEB1FE );	Err	bitreich.org	70
i+    P( C, D, E, F, G, H, A, B, W[14], 0x9BDC06A7 );	Err	bitreich.org	70
i+    P( B, C, D, E, F, G, H, A, W[15], 0xC19BF174 );	Err	bitreich.org	70
i+    P( A, B, C, D, E, F, G, H, R(16), 0xE49B69C1 );	Err	bitreich.org	70
i+    P( H, A, B, C, D, E, F, G, R(17), 0xEFBE4786 );	Err	bitreich.org	70
i+    P( G, H, A, B, C, D, E, F, R(18), 0x0FC19DC6 );	Err	bitreich.org	70
i+    P( F, G, H, A, B, C, D, E, R(19), 0x240CA1CC );	Err	bitreich.org	70
i+    P( E, F, G, H, A, B, C, D, R(20), 0x2DE92C6F );	Err	bitreich.org	70
i+    P( D, E, F, G, H, A, B, C, R(21), 0x4A7484AA );	Err	bitreich.org	70
i+    P( C, D, E, F, G, H, A, B, R(22), 0x5CB0A9DC );	Err	bitreich.org	70
i+    P( B, C, D, E, F, G, H, A, R(23), 0x76F988DA );	Err	bitreich.org	70
i+    P( A, B, C, D, E, F, G, H, R(24), 0x983E5152 );	Err	bitreich.org	70
i+    P( H, A, B, C, D, E, F, G, R(25), 0xA831C66D );	Err	bitreich.org	70
i+    P( G, H, A, B, C, D, E, F, R(26), 0xB00327C8 );	Err	bitreich.org	70
i+    P( F, G, H, A, B, C, D, E, R(27), 0xBF597FC7 );	Err	bitreich.org	70
i+    P( E, F, G, H, A, B, C, D, R(28), 0xC6E00BF3 );	Err	bitreich.org	70
i+    P( D, E, F, G, H, A, B, C, R(29), 0xD5A79147 );	Err	bitreich.org	70
i+    P( C, D, E, F, G, H, A, B, R(30), 0x06CA6351 );	Err	bitreich.org	70
i+    P( B, C, D, E, F, G, H, A, R(31), 0x14292967 );	Err	bitreich.org	70
i+    P( A, B, C, D, E, F, G, H, R(32), 0x27B70A85 );	Err	bitreich.org	70
i+    P( H, A, B, C, D, E, F, G, R(33), 0x2E1B2138 );	Err	bitreich.org	70
i+    P( G, H, A, B, C, D, E, F, R(34), 0x4D2C6DFC );	Err	bitreich.org	70
i+    P( F, G, H, A, B, C, D, E, R(35), 0x53380D13 );	Err	bitreich.org	70
i+    P( E, F, G, H, A, B, C, D, R(36), 0x650A7354 );	Err	bitreich.org	70
i+    P( D, E, F, G, H, A, B, C, R(37), 0x766A0ABB );	Err	bitreich.org	70
i+    P( C, D, E, F, G, H, A, B, R(38), 0x81C2C92E );	Err	bitreich.org	70
i+    P( B, C, D, E, F, G, H, A, R(39), 0x92722C85 );	Err	bitreich.org	70
i+    P( A, B, C, D, E, F, G, H, R(40), 0xA2BFE8A1 );	Err	bitreich.org	70
i+    P( H, A, B, C, D, E, F, G, R(41), 0xA81A664B );	Err	bitreich.org	70
i+    P( G, H, A, B, C, D, E, F, R(42), 0xC24B8B70 );	Err	bitreich.org	70
i+    P( F, G, H, A, B, C, D, E, R(43), 0xC76C51A3 );	Err	bitreich.org	70
i+    P( E, F, G, H, A, B, C, D, R(44), 0xD192E819 );	Err	bitreich.org	70
i+    P( D, E, F, G, H, A, B, C, R(45), 0xD6990624 );	Err	bitreich.org	70
i+    P( C, D, E, F, G, H, A, B, R(46), 0xF40E3585 );	Err	bitreich.org	70
i+    P( B, C, D, E, F, G, H, A, R(47), 0x106AA070 );	Err	bitreich.org	70
i+    P( A, B, C, D, E, F, G, H, R(48), 0x19A4C116 );	Err	bitreich.org	70
i+    P( H, A, B, C, D, E, F, G, R(49), 0x1E376C08 );	Err	bitreich.org	70
i+    P( G, H, A, B, C, D, E, F, R(50), 0x2748774C );	Err	bitreich.org	70
i+    P( F, G, H, A, B, C, D, E, R(51), 0x34B0BCB5 );	Err	bitreich.org	70
i+    P( E, F, G, H, A, B, C, D, R(52), 0x391C0CB3 );	Err	bitreich.org	70
i+    P( D, E, F, G, H, A, B, C, R(53), 0x4ED8AA4A );	Err	bitreich.org	70
i+    P( C, D, E, F, G, H, A, B, R(54), 0x5B9CCA4F );	Err	bitreich.org	70
i+    P( B, C, D, E, F, G, H, A, R(55), 0x682E6FF3 );	Err	bitreich.org	70
i+    P( A, B, C, D, E, F, G, H, R(56), 0x748F82EE );	Err	bitreich.org	70
i+    P( H, A, B, C, D, E, F, G, R(57), 0x78A5636F );	Err	bitreich.org	70
i+    P( G, H, A, B, C, D, E, F, R(58), 0x84C87814 );	Err	bitreich.org	70
i+    P( F, G, H, A, B, C, D, E, R(59), 0x8CC70208 );	Err	bitreich.org	70
i+    P( E, F, G, H, A, B, C, D, R(60), 0x90BEFFFA );	Err	bitreich.org	70
i+    P( D, E, F, G, H, A, B, C, R(61), 0xA4506CEB );	Err	bitreich.org	70
i+    P( C, D, E, F, G, H, A, B, R(62), 0xBEF9A3F7 );	Err	bitreich.org	70
i+    P( B, C, D, E, F, G, H, A, R(63), 0xC67178F2 );	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+    ctx->state[0] += A;	Err	bitreich.org	70
i+    ctx->state[1] += B;	Err	bitreich.org	70
i+    ctx->state[2] += C;	Err	bitreich.org	70
i+    ctx->state[3] += D;	Err	bitreich.org	70
i+    ctx->state[4] += E;	Err	bitreich.org	70
i+    ctx->state[5] += F;	Err	bitreich.org	70
i+    ctx->state[6] += G;	Err	bitreich.org	70
i+    ctx->state[7] += H;	Err	bitreich.org	70
i+}	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+void sha256_update( sha256_context *ctx, uint8 *input, uint32 length )	Err	bitreich.org	70
i+{	Err	bitreich.org	70
i+    uint32 left, fill;	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+    if( ! length ) return;	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+    left = ctx->total[0] & 0x3F;	Err	bitreich.org	70
i+    fill = 64 - left;	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+    ctx->total[0] += length;	Err	bitreich.org	70
i+    ctx->total[0] &= 0xFFFFFFFF;	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+    if( ctx->total[0] < length )	Err	bitreich.org	70
i+        ctx->total[1]++;	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+    if( left && length >= fill )	Err	bitreich.org	70
i+    {	Err	bitreich.org	70
i+        memcpy( (void *) (ctx->buffer + left),	Err	bitreich.org	70
i+                (void *) input, fill );	Err	bitreich.org	70
i+        sha256_process( ctx, ctx->buffer );	Err	bitreich.org	70
i+        length -= fill;	Err	bitreich.org	70
i+        input  += fill;	Err	bitreich.org	70
i+        left = 0;	Err	bitreich.org	70
i+    }	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+    while( length >= 64 )	Err	bitreich.org	70
i+    {	Err	bitreich.org	70
i+        sha256_process( ctx, input );	Err	bitreich.org	70
i+        length -= 64;	Err	bitreich.org	70
i+        input  += 64;	Err	bitreich.org	70
i+    }	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+    if( length )	Err	bitreich.org	70
i+    {	Err	bitreich.org	70
i+        memcpy( (void *) (ctx->buffer + left),	Err	bitreich.org	70
i+                (void *) input, length );	Err	bitreich.org	70
i+    }	Err	bitreich.org	70
i+}	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+static uint8 sha256_padding[64] =	Err	bitreich.org	70
i+{	Err	bitreich.org	70
i+ 0x80, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,	Err	bitreich.org	70
i+    0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,	Err	bitreich.org	70
i+    0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,	Err	bitreich.org	70
i+    0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0	Err	bitreich.org	70
i+};	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+void sha256_finish( sha256_context *ctx, uint8 digest[32] )	Err	bitreich.org	70
i+{	Err	bitreich.org	70
i+    uint32 last, padn;	Err	bitreich.org	70
i+    uint32 high, low;	Err	bitreich.org	70
i+    uint8 msglen[8];	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+    high = ( ctx->total[0] >> 29 )	Err	bitreich.org	70
i+         | ( ctx->total[1] <<  3 );	Err	bitreich.org	70
i+    low  = ( ctx->total[0] <<  3 );	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+    PUT_UINT32( high, msglen, 0 );	Err	bitreich.org	70
i+    PUT_UINT32( low,  msglen, 4 );	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+    last = ctx->total[0] & 0x3F;	Err	bitreich.org	70
i+    padn = ( last < 56 ) ? ( 56 - last ) : ( 120 - last );	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+    sha256_update( ctx, sha256_padding, padn );	Err	bitreich.org	70
i+    sha256_update( ctx, msglen, 8 );	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+    PUT_UINT32( ctx->state[0], digest,  0 );	Err	bitreich.org	70
i+    PUT_UINT32( ctx->state[1], digest,  4 );	Err	bitreich.org	70
i+    PUT_UINT32( ctx->state[2], digest,  8 );	Err	bitreich.org	70
i+    PUT_UINT32( ctx->state[3], digest, 12 );	Err	bitreich.org	70
i+    PUT_UINT32( ctx->state[4], digest, 16 );	Err	bitreich.org	70
i+    PUT_UINT32( ctx->state[5], digest, 20 );	Err	bitreich.org	70
i+    PUT_UINT32( ctx->state[6], digest, 24 );	Err	bitreich.org	70
i+    PUT_UINT32( ctx->state[7], digest, 28 );	Err	bitreich.org	70
i+}	Err	bitreich.org	70
1diff --git a/sha256.h b/sha256.h	/scm/sup/file/sha256.h.gph	bitreich.org	70
i@@ -0,0 +1,24 @@	Err	bitreich.org	70
i+#ifndef _SHA256_H	Err	bitreich.org	70
i+#define _SHA256_H	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+#ifndef uint8	Err	bitreich.org	70
i+#define uint8  unsigned char	Err	bitreich.org	70
i+#endif	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+#ifndef uint32	Err	bitreich.org	70
i+#define uint32 unsigned long int	Err	bitreich.org	70
i+#endif	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+typedef struct	Err	bitreich.org	70
i+{	Err	bitreich.org	70
i+    uint32 total[2];	Err	bitreich.org	70
i+    uint32 state[8];	Err	bitreich.org	70
i+    uint8 buffer[64];	Err	bitreich.org	70
i+}	Err	bitreich.org	70
i+sha256_context;	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+void sha256_starts( sha256_context *ctx );	Err	bitreich.org	70
i+void sha256_update( sha256_context *ctx, uint8 *input, uint32 length );	Err	bitreich.org	70
i+void sha256_finish( sha256_context *ctx, uint8 digest[32] );	Err	bitreich.org	70
i+	Err	bitreich.org	70
i+#endif /* sha256.h */	Err	bitreich.org	70
.
Response: text/plain
Original URLgopher://bitreich.org/0/scm/sup/commit/6ff18b795ab40b43d1...
Content-Typetext/plain; charset=utf-8