aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--include/venti.h4
-rw-r--r--src/libventi/mkfile1
-rw-r--r--src/libventi/sha1.c28
3 files changed, 33 insertions, 0 deletions
diff --git a/include/venti.h b/include/venti.h
index d6b753b8..45c0aab8 100644
--- a/include/venti.h
+++ b/include/venti.h
@@ -381,6 +381,10 @@ int vtwritepacket(VtConn*, uchar score[VtScoreSize], uint type, Packet *p);
int vtsync(VtConn*);
int vtping(VtConn*);
+/* sha1 */
+void vtsha1(uchar score[VtScoreSize], uchar*, int);
+int vtsha1check(uchar score[VtScoreSize], uchar*, int);
+
/*
* Data blocks and block cache.
*/
diff --git a/src/libventi/mkfile b/src/libventi/mkfile
index 289262ac..37881855 100644
--- a/src/libventi/mkfile
+++ b/src/libventi/mkfile
@@ -24,6 +24,7 @@ OFILES=\
scorefmt.$O\
send.$O\
server.$O\
+ sha1.$O\
srvhello.$O\
strdup.$O\
string.$O\
diff --git a/src/libventi/sha1.c b/src/libventi/sha1.c
new file mode 100644
index 00000000..358f923d
--- /dev/null
+++ b/src/libventi/sha1.c
@@ -0,0 +1,28 @@
+#include <u.h>
+#include <libc.h>
+#include <venti.h>
+#include <libsec.h>
+
+void
+vtsha1(uchar score[VtScoreSize], uchar *p, int n)
+{
+ DigestState ds;
+
+ memset(&ds, 0, sizeof ds);
+ sha1(p, n, score, &ds);
+}
+
+int
+vtsha1check(uchar score[VtScoreSize], uchar *p, int n)
+{
+ DigestState ds;
+ uchar score2[VtScoreSize];
+
+ memset(&ds, 0, sizeof ds);
+ sha1(p, n, score2, &ds);
+ if(memcmp(score, score2, VtScoreSize) != 0) {
+ werrstr("vtsha1check failed");
+ return -1;
+ }
+ return 0;
+}