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