File: block.ha

package info (click to toggle)
hare 0.25.2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 6,948 kB
  • sloc: asm: 1,264; makefile: 123; sh: 114; lisp: 101
file content (30 lines) | stat: -rw-r--r-- 946 bytes parent folder | download | duplicates (2)
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
29
30
// SPDX-License-Identifier: MPL-2.0
// (c) Hare authors <https://harelang.org>

// An abstract interface for implementing block ciphers.
export type blockvtable = struct {
	blocksz: size,

	nparallel: size,

	encrypt: *fn(b: *block, dest: []u8, src: []u8) void,
	decrypt: *fn(b: *block, dest: []u8, src: []u8) void,
	finish: *fn(b: *block) void,
};

export type block = *blockvtable;

// Returns the block size in bytes for a [[block]] cipher.
export fn blocksz(b: *block) size = b.blocksz;

// Returns the number of blocks that can be processed at once for a [[block]]
// cipher.
export fn nparallel(b: *block) size = b.nparallel;

// Encrypt up to [[nparallel]] blocks from 'src' and writes to 'dest'.
export fn encrypt(b: *block, dest: []u8, src: []u8) void =
	b.encrypt(b, dest, src);

// Decrypt up to [[nparallel]] blocks from 'src' and writes to 'dest'.
export fn decrypt(b: *block, dest: []u8, src: []u8) void =
	b.decrypt(b, dest, src);