blob: 3ee0347894df05bd13334b5acd089eae267aa0c3 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
// test taken from aes_core from iwls2005
module aes_key_expand_128(clk, kld, key, wo_0, wo_1, wo_2, wo_3);
input clk, kld;
input [15:0] key;
output [3:0] wo_0, wo_1, wo_2, wo_3;
reg [3:0] w[3:0];
assign wo_0 = w[0];
assign wo_1 = w[1];
assign wo_2 = w[2];
assign wo_3 = w[3];
always @(posedge clk) begin
w[0] <= kld ? key[15:12] : w[0];
w[1] <= kld ? key[11: 8] : w[0]^w[1];
w[2] <= kld ? key[ 7: 4] : w[0]^w[1]^w[2];
w[3] <= kld ? key[ 3: 0] : w[0]^w[1]^w[2]^w[3];
end
endmodule
|