File: aesOFB.c

package info (click to toggle)
drawterm-9front 0~git20220608.bee4db6-3
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, forky, sid, trixie
  • size: 3,256 kB
  • sloc: ansic: 57,635; makefile: 607; java: 492; objc: 436; xml: 174; asm: 19
file content (28 lines) | stat: -rw-r--r-- 537 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
#include "os.h"
#include <libsec.h>

typedef ulong u32;

void
aesOFBencrypt(uchar *p, int len, AESstate *s)
{
	u32 o = s->offset;

	while(len > 0){
		if(o % 16){
		Odd:
			*p++ ^= s->ivec[o++ % 16], len--;
			continue;
		}
		aes_encrypt(s->ekey, s->rounds, s->ivec, s->ivec);
		if(len < 16 || ((p-(uchar*)0) & 3) != 0)
			goto Odd;
		((u32*)p)[0] ^= ((u32*)s->ivec)[0];
		((u32*)p)[1] ^= ((u32*)s->ivec)[1];
		((u32*)p)[2] ^= ((u32*)s->ivec)[2];
		((u32*)p)[3] ^= ((u32*)s->ivec)[3];
		o += 16, p += 16, len -= 16;
	}
	s->offset = o;
}