v/vlib/crypto/aes/cypher_generic.v

19 lines
514 B
V
Raw Normal View History

2022-01-04 10:21:08 +01:00
// Copyright (c) 2019-2022 Alexander Medvednikov. All rights reserved.
2019-07-25 17:49:57 +02:00
// Use of this source code is governed by an MIT license
// that can be found in the LICENSE file.
module aes
import crypto.cipher
2019-07-25 17:49:57 +02:00
// new_cipher_generic creates and returns a new cipher.Block
// this is the generiv v version, no arch optimisations
fn new_cipher_generic(key []byte) cipher.Block {
2019-07-25 17:49:57 +02:00
n := key.len + 28
2019-08-07 13:37:07 +02:00
mut c := AesCipher{
enc: []u32{len: n}
dec: []u32{len: n}
2019-07-25 17:49:57 +02:00
}
2019-08-07 13:37:07 +02:00
expand_key_generic(key, mut c.enc, mut c.dec)
2019-07-25 17:49:57 +02:00
return c
}