../src/lowrisc_prim_secded_0.1/rtl/prim_secded_28_22_enc.sv Cov: 100%
1: // Copyright lowRISC contributors.
2: // Licensed under the Apache License, Version 2.0, see LICENSE for details.
3: // SPDX-License-Identifier: Apache-2.0
4: //
5: // SECDED Encoder generated by secded_gen.py
6:
7: module prim_secded_28_22_enc (
8: input [21:0] in,
9: output logic [27:0] out
10: );
11:
12: assign out[0] = in[0] ;
13: assign out[1] = in[1] ;
14: assign out[2] = in[2] ;
15: assign out[3] = in[3] ;
16: assign out[4] = in[4] ;
17: assign out[5] = in[5] ;
18: assign out[6] = in[6] ;
19: assign out[7] = in[7] ;
20: assign out[8] = in[8] ;
21: assign out[9] = in[9] ;
22: assign out[10] = in[10] ;
23: assign out[11] = in[11] ;
24: assign out[12] = in[12] ;
25: assign out[13] = in[13] ;
26: assign out[14] = in[14] ;
27: assign out[15] = in[15] ;
28: assign out[16] = in[16] ;
29: assign out[17] = in[17] ;
30: assign out[18] = in[18] ;
31: assign out[19] = in[19] ;
32: assign out[20] = in[20] ;
33: assign out[21] = in[21] ;
34: assign out[22] = in[0] ^ in[1] ^ in[2] ^ in[3] ^ in[4] ^ in[5] ^ in[6] ^ in[7] ^ in[8] ^ in[9]
35: ^ in[20] ^ in[21];
36: assign out[23] = in[0] ^ in[1] ^ in[2] ^ in[3] ^ in[10] ^ in[11] ^ in[12] ^ in[13] ^ in[14]
37: ^ in[15] ^ in[20] ^ in[21];
38: assign out[24] = in[0] ^ in[4] ^ in[5] ^ in[6] ^ in[10] ^ in[11] ^ in[12] ^ in[16] ^ in[17]
39: ^ in[18] ^ in[20];
40: assign out[25] = in[1] ^ in[4] ^ in[7] ^ in[8] ^ in[10] ^ in[13] ^ in[14] ^ in[16] ^ in[17]
41: ^ in[19] ^ in[21];
42: assign out[26] = in[2] ^ in[5] ^ in[7] ^ in[9] ^ in[11] ^ in[13] ^ in[15] ^ in[16] ^ in[18]
43: ^ in[19] ^ in[20] ^ in[21];
44: assign out[27] = in[3] ^ in[6] ^ in[8] ^ in[9] ^ in[12] ^ in[14] ^ in[15] ^ in[17] ^ in[18]
45: ^ in[19] ^ in[20] ^ in[21];
46: endmodule
47:
48: