1*9a747e4fSDavid du Colombier #include <u.h>
2*9a747e4fSDavid du Colombier #include <libc.h>
3*9a747e4fSDavid du Colombier #include <authsrv.h>
4*9a747e4fSDavid du Colombier
5*9a747e4fSDavid du Colombier #define CHAR(x) f->x = *p++
6*9a747e4fSDavid du Colombier #define SHORT(x) f->x = (p[0] | (p[1]<<8)); p += 2
7*9a747e4fSDavid du Colombier #define VLONG(q) q = (p[0] | (p[1]<<8) | (p[2]<<16) | (p[3]<<24)); p += 4
8*9a747e4fSDavid du Colombier #define LONG(x) VLONG(f->x)
9*9a747e4fSDavid du Colombier #define STRING(x,n) memmove(f->x, p, n); p += n
10*9a747e4fSDavid du Colombier
11*9a747e4fSDavid du Colombier void
convM2A(char * ap,Authenticator * f,char * key)12*9a747e4fSDavid du Colombier convM2A(char *ap, Authenticator *f, char *key)
13*9a747e4fSDavid du Colombier {
14*9a747e4fSDavid du Colombier uchar *p;
15*9a747e4fSDavid du Colombier
16*9a747e4fSDavid du Colombier if(key)
17*9a747e4fSDavid du Colombier decrypt(key, ap, AUTHENTLEN);
18*9a747e4fSDavid du Colombier p = (uchar*)ap;
19*9a747e4fSDavid du Colombier CHAR(num);
20*9a747e4fSDavid du Colombier STRING(chal, CHALLEN);
21*9a747e4fSDavid du Colombier LONG(id);
22*9a747e4fSDavid du Colombier USED(p);
23*9a747e4fSDavid du Colombier }
24