1 |
2 |
arif_endro |
-- ------------------------------------------------------------------------
|
2 |
|
|
-- Copyright (C) 2010 Arif Endro Nugroho
|
3 |
|
|
-- All rights reserved.
|
4 |
|
|
--
|
5 |
|
|
-- Redistribution and use in source and binary forms, with or without
|
6 |
|
|
-- modification, are permitted provided that the following conditions
|
7 |
|
|
-- are met:
|
8 |
|
|
--
|
9 |
|
|
-- 1. Redistributions of source code must retain the above copyright
|
10 |
|
|
-- notice, this list of conditions and the following disclaimer.
|
11 |
|
|
-- 2. Redistributions in binary form must reproduce the above copyright
|
12 |
|
|
-- notice, this list of conditions and the following disclaimer in the
|
13 |
|
|
-- documentation and/or other materials provided with the distribution.
|
14 |
|
|
--
|
15 |
|
|
-- THIS SOFTWARE IS PROVIDED BY ARIF ENDRO NUGROHO "AS IS" AND ANY EXPRESS
|
16 |
|
|
-- OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
17 |
|
|
-- WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
18 |
|
|
-- DISCLAIMED. IN NO EVENT SHALL ARIF ENDRO NUGROHO BE LIABLE FOR ANY
|
19 |
|
|
-- DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
20 |
|
|
-- DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
21 |
|
|
-- OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
22 |
|
|
-- HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
|
23 |
|
|
-- STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
24 |
|
|
-- ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
25 |
|
|
-- POSSIBILITY OF SUCH DAMAGE.
|
26 |
|
|
--
|
27 |
|
|
-- End Of License.
|
28 |
|
|
-- ------------------------------------------------------------------------
|
29 |
|
|
|
30 |
|
|
library ieee;
|
31 |
|
|
use ieee.std_logic_1164.all;
|
32 |
|
|
use ieee.std_logic_unsigned.all;
|
33 |
|
|
|
34 |
|
|
entity sboxs2 is
|
35 |
|
|
port (
|
36 |
|
|
w : in bit_vector ( 31 downto 0);
|
37 |
|
|
r : out bit_vector ( 31 downto 0)
|
38 |
|
|
);
|
39 |
|
|
end sboxs2;
|
40 |
|
|
|
41 |
|
|
architecture phy of sboxs2 is
|
42 |
|
|
signal w0 : bit_vector ( 7 downto 0);
|
43 |
|
|
signal w1 : bit_vector ( 7 downto 0);
|
44 |
|
|
signal w2 : bit_vector ( 7 downto 0);
|
45 |
|
|
signal w3 : bit_vector ( 7 downto 0);
|
46 |
|
|
signal r0 : bit_vector ( 7 downto 0);
|
47 |
|
|
signal r1 : bit_vector ( 7 downto 0);
|
48 |
|
|
signal r2 : bit_vector ( 7 downto 0);
|
49 |
|
|
signal r3 : bit_vector ( 7 downto 0);
|
50 |
|
|
signal sq0i : bit_vector ( 7 downto 0);
|
51 |
|
|
signal sq1i : bit_vector ( 7 downto 0);
|
52 |
|
|
signal sq2i : bit_vector ( 7 downto 0);
|
53 |
|
|
signal sq3i : bit_vector ( 7 downto 0);
|
54 |
|
|
signal sq0o : bit_vector ( 7 downto 0);
|
55 |
|
|
signal sq1o : bit_vector ( 7 downto 0);
|
56 |
|
|
signal sq2o : bit_vector ( 7 downto 0);
|
57 |
|
|
signal sq3o : bit_vector ( 7 downto 0);
|
58 |
|
|
signal mlx0vi : bit_vector ( 7 downto 0);
|
59 |
|
|
signal mlx0ci : bit_vector ( 7 downto 0);
|
60 |
|
|
signal mlx0wo : bit_vector ( 7 downto 0);
|
61 |
|
|
signal mlx1vi : bit_vector ( 7 downto 0);
|
62 |
|
|
signal mlx1ci : bit_vector ( 7 downto 0);
|
63 |
|
|
signal mlx1wo : bit_vector ( 7 downto 0);
|
64 |
|
|
signal mlx2vi : bit_vector ( 7 downto 0);
|
65 |
|
|
signal mlx2ci : bit_vector ( 7 downto 0);
|
66 |
|
|
signal mlx2wo : bit_vector ( 7 downto 0);
|
67 |
|
|
signal mlx3vi : bit_vector ( 7 downto 0);
|
68 |
|
|
signal mlx3ci : bit_vector ( 7 downto 0);
|
69 |
|
|
signal mlx3wo : bit_vector ( 7 downto 0);
|
70 |
|
|
component sboxq
|
71 |
|
|
port (
|
72 |
|
|
di : in bit_vector ( 7 downto 0);
|
73 |
|
|
do : out bit_vector ( 7 downto 0)
|
74 |
|
|
);
|
75 |
|
|
end component;
|
76 |
|
|
component mulx
|
77 |
|
|
port (
|
78 |
|
|
V : in bit_vector ( 7 downto 0);
|
79 |
|
|
c : in bit_vector ( 7 downto 0);
|
80 |
|
|
w : out bit_Vector ( 7 downto 0)
|
81 |
|
|
);
|
82 |
|
|
end component;
|
83 |
|
|
begin
|
84 |
|
|
sq0 : sboxq
|
85 |
|
|
port map (
|
86 |
|
|
di => sq0i,
|
87 |
|
|
do => sq0o
|
88 |
|
|
);
|
89 |
|
|
sq1 : sboxq
|
90 |
|
|
port map (
|
91 |
|
|
di => sq1i,
|
92 |
|
|
do => sq1o
|
93 |
|
|
);
|
94 |
|
|
sq2 : sboxq
|
95 |
|
|
port map (
|
96 |
|
|
di => sq2i,
|
97 |
|
|
do => sq2o
|
98 |
|
|
);
|
99 |
|
|
sq3 : sboxq
|
100 |
|
|
port map (
|
101 |
|
|
di => sq3i,
|
102 |
|
|
do => sq3o
|
103 |
|
|
);
|
104 |
|
|
mlx0 : mulx
|
105 |
|
|
port map (
|
106 |
|
|
V => mlx0vi,
|
107 |
|
|
c => mlx0ci,
|
108 |
|
|
w => mlx0wo
|
109 |
|
|
);
|
110 |
|
|
mlx1 : mulx
|
111 |
|
|
port map (
|
112 |
|
|
V => mlx1vi,
|
113 |
|
|
c => mlx1ci,
|
114 |
|
|
w => mlx1wo
|
115 |
|
|
);
|
116 |
|
|
mlx2 : mulx
|
117 |
|
|
port map (
|
118 |
|
|
V => mlx2vi,
|
119 |
|
|
c => mlx2ci,
|
120 |
|
|
w => mlx2wo
|
121 |
|
|
);
|
122 |
|
|
mlx3 : mulx
|
123 |
|
|
port map (
|
124 |
|
|
V => mlx3vi,
|
125 |
|
|
c => mlx3ci,
|
126 |
|
|
w => mlx3wo
|
127 |
|
|
);
|
128 |
|
|
--persistent connection
|
129 |
|
|
w0 <= w ( 31 downto 24);
|
130 |
|
|
w1 <= w ( 23 downto 16);
|
131 |
|
|
w2 <= w ( 15 downto 8);
|
132 |
|
|
w3 <= w ( 7 downto 0);
|
133 |
|
|
sq0i <= w0;
|
134 |
|
|
sq1i <= w1;
|
135 |
|
|
sq2i <= w2;
|
136 |
|
|
sq3i <= w3;
|
137 |
|
|
mlx0vi <= sq0o; --SQ(w0)
|
138 |
|
|
mlx1vi <= sq1o; --SQ(w1)
|
139 |
|
|
mlx2vi <= sq2o; --SQ(w2)
|
140 |
|
|
mlx3vi <= sq3o; --SQ(w3)
|
141 |
|
|
mlx0ci <= X"69";
|
142 |
|
|
mlx1ci <= X"69";
|
143 |
|
|
mlx2ci <= X"69";
|
144 |
|
|
mlx3ci <= X"69";
|
145 |
|
|
r0 <= mlx0wo xor sq1o xor sq2o xor mlx3wo xor sq3o;
|
146 |
|
|
r1 <= mlx0wo xor sq0o xor mlx1wo xor sq2o xor sq3o;
|
147 |
|
|
r2 <= sq0o xor mlx1wo xor sq1o xor mlx2wo xor sq3o;
|
148 |
|
|
r3 <= sq0o xor sq1o xor mlx2wo xor sq2o xor mlx3wo;
|
149 |
|
|
r ( 31 downto 24)<= r0;
|
150 |
|
|
r ( 23 downto 16)<= r1;
|
151 |
|
|
r ( 15 downto 8)<= r2;
|
152 |
|
|
r ( 7 downto 0)<= r3;
|
153 |
|
|
--persistent connection
|
154 |
|
|
end phy;
|