forked from EvgenyMuryshkin/AXISoCQuadCoreModule
-
Notifications
You must be signed in to change notification settings - Fork 0
/
AXISoCQuadCoreModule_TopLevel_CPU3_CPU_ALU.v
162 lines (162 loc) · 6.5 KB
/
AXISoCQuadCoreModule_TopLevel_CPU3_CPU_ALU.v
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
`timescale 1ns/1ps
`default_nettype none
// PLEASE READ THIS, IT MAY SAVE YOU SOME TIME AND MONEY, THANK YOU!
// * This file was generated by Quokka FPGA Toolkit.
// * Generated code is your property, do whatever you want with it
// * Place custom code between [BEGIN USER ***] and [END USER ***].
// * CAUTION: All code outside of [USER] scope is subject to regeneration.
// * Bad things happen sometimes in developer's life,
// it is recommended to use source control management software (e.g. git, bzr etc) to keep your custom code safe'n'sound.
// * Internal structure of code is subject to change.
// You can use some of signals in custom code, but most likely they will not exist in future (e.g. will get shorter or gone completely)
// * Please send your feedback, comments, improvement ideas etc. to [email protected]
// * Visit https://github.com/EvgenyMuryshkin/QuokkaEvaluation to access latest version of playground
//
// DISCLAIMER:
// Code comes AS-IS, it is your responsibility to make sure it is working as expected
// no responsibility will be taken for any loss or damage caused by use of Quokka toolkit.
//
// System configuration name is AXISoCQuadCoreModule_TopLevel_CPU3_CPU_ALU, clock frequency is 1Hz, Embedded
// FSM summary
// -- Packages
module AXISoCQuadCoreModule_TopLevel_CPU3_CPU_ALU
(
// [BEGIN USER PORTS]
// [END USER PORTS]
input wire [31:0] Op1,
input wire [31:0] Op2,
input wire [4:0] SHAMT,
output wire [31:0] ADD,
output wire [31:0] resAND,
output wire [31:0] resOR,
output wire [31:0] resXOR,
output wire [31:0] SHLL,
output wire [31:0] SHRA,
output wire [31:0] SHRL,
output wire [31:0] SUB
);
// [BEGIN USER SIGNALS]
// [END USER SIGNALS]
localparam HiSignal = 1'b1;
localparam LoSignal = 1'b0;
wire Zero = 1'b0;
wire One = 1'b1;
wire true = 1'b1;
wire false = 1'b0;
wire [31: 0] Inputs_Op1;
wire [31: 0] Inputs_Op2;
wire [4: 0] Inputs_SHAMT;
wire signed [32: 0] internalAdd;
wire signed [34: 0] internalSub;
wire signed [31: 0] ALUModule_L15F46T65_SignChange;
wire signed [31: 0] ALUModule_L15F68T87_SignChange;
wire signed [31: 0] ALUModule_L16F46T65_SignChange;
wire signed [32: 0] ALUModule_L16F46T77_Resize;
wire signed [31: 0] ALUModule_L16F80T99_SignChange;
wire signed [32: 0] ALUModule_L16F80T111_Resize;
wire [31: 0] ALUModule_L18F35T53_Index;
wire [31: 0] ALUModule_L23F36T71_Index;
wire signed [31: 0] ALUModule_L25F37T56_SignChange;
wire [31: 0] ALUModule_L25F36T80_Index;
wire [31: 0] ALUModule_L24F37T58_SignChange;
wire [31: 0] ALUModule_L24F36T82_Index;
wire [31: 0] ALUModule_L19F35T53_Index;
wire [31: 0] ALUModule_L20F38T61_Expr;
wire [31: 0] ALUModule_L20F38T61_Expr_1;
wire [31: 0] ALUModule_L20F38T61_Expr_2;
wire [31: 0] ALUModule_L21F37T60_Expr;
wire [31: 0] ALUModule_L21F37T60_Expr_1;
wire [31: 0] ALUModule_L21F37T60_Expr_2;
wire [31: 0] ALUModule_L22F38T61_Expr;
wire [31: 0] ALUModule_L22F38T61_Expr_1;
wire [31: 0] ALUModule_L22F38T61_Expr_2;
wire [31: 0] ALUModule_L23F37T63_Expr;
wire [31: 0] ALUModule_L23F37T63_Expr_1;
wire signed [31: 0] ALUModule_L25F37T72_Expr;
wire signed [31: 0] ALUModule_L25F37T72_Expr_1;
wire [31: 0] ALUModule_L24F37T74_Expr;
wire [31: 0] ALUModule_L24F37T74_Expr_1;
wire signed [32: 0] ALUModule_L15F46T87_Expr;
wire signed [32: 0] ALUModule_L15F46T87_Expr_1;
wire signed [32: 0] ALUModule_L15F46T87_Expr_2;
wire signed [33: 0] ALUModule_L16F46T111_Expr;
wire signed [33: 0] ALUModule_L16F46T111_Expr_1;
wire signed [33: 0] ALUModule_L16F46T111_Expr_2;
assign ALUModule_L20F38T61_Expr = ALUModule_L20F38T61_Expr_1 & ALUModule_L20F38T61_Expr_2;
assign ALUModule_L21F37T60_Expr = ALUModule_L21F37T60_Expr_1 | ALUModule_L21F37T60_Expr_2;
assign ALUModule_L22F38T61_Expr = ALUModule_L22F38T61_Expr_1 ^ ALUModule_L22F38T61_Expr_2;
assign ALUModule_L23F37T63_Expr = (ALUModule_L23F37T63_Expr_1 << Inputs_SHAMT);
assign ALUModule_L25F37T72_Expr = (ALUModule_L25F37T72_Expr_1 >>> Inputs_SHAMT);
assign ALUModule_L24F37T74_Expr = (ALUModule_L24F37T74_Expr_1 >> Inputs_SHAMT);
assign ALUModule_L15F46T87_Expr = ALUModule_L15F46T87_Expr_1 + ALUModule_L15F46T87_Expr_2;
assign ALUModule_L16F46T111_Expr = ALUModule_L16F46T111_Expr_1 - ALUModule_L16F46T111_Expr_2;
assign ALUModule_L20F38T61_Expr_1 = Inputs_Op1;
assign ALUModule_L20F38T61_Expr_2 = Inputs_Op2;
assign ALUModule_L21F37T60_Expr_1 = Inputs_Op1;
assign ALUModule_L21F37T60_Expr_2 = Inputs_Op2;
assign ALUModule_L22F38T61_Expr_1 = Inputs_Op1;
assign ALUModule_L22F38T61_Expr_2 = Inputs_Op2;
assign ALUModule_L23F37T63_Expr_1 = Inputs_Op1;
assign ALUModule_L25F37T72_Expr_1 = ALUModule_L25F37T56_SignChange;
assign ALUModule_L24F37T74_Expr_1 = ALUModule_L24F37T58_SignChange;
assign ALUModule_L15F46T87_Expr_1 = {
ALUModule_L15F46T65_SignChange[31],
ALUModule_L15F46T65_SignChange
}
;
assign ALUModule_L15F46T87_Expr_2 = {
ALUModule_L15F68T87_SignChange[31],
ALUModule_L15F68T87_SignChange
}
;
assign ALUModule_L16F46T111_Expr_1 = {
ALUModule_L16F46T77_Resize[32],
ALUModule_L16F46T77_Resize
}
;
assign ALUModule_L16F46T111_Expr_2 = {
ALUModule_L16F80T111_Resize[32],
ALUModule_L16F80T111_Resize
}
;
assign Inputs_Op1 = Op1;
assign Inputs_Op2 = Op2;
assign Inputs_SHAMT = SHAMT;
assign ALUModule_L15F46T65_SignChange = Inputs_Op1;
assign ALUModule_L15F68T87_SignChange = Inputs_Op2;
assign internalAdd = ALUModule_L15F46T87_Expr;
assign ALUModule_L16F46T65_SignChange = Inputs_Op1;
assign ALUModule_L16F46T77_Resize = {
ALUModule_L16F46T65_SignChange[31],
ALUModule_L16F46T65_SignChange
}
;
assign ALUModule_L16F80T99_SignChange = Inputs_Op2;
assign ALUModule_L16F80T111_Resize = {
ALUModule_L16F80T99_SignChange[31],
ALUModule_L16F80T99_SignChange
}
;
assign internalSub = {
ALUModule_L16F46T111_Expr[33],
ALUModule_L16F46T111_Expr
}
;
assign ALUModule_L18F35T53_Index = internalAdd[31:0];
assign ADD = ALUModule_L18F35T53_Index;
assign resAND = ALUModule_L20F38T61_Expr;
assign resOR = ALUModule_L21F37T60_Expr;
assign resXOR = ALUModule_L22F38T61_Expr;
assign ALUModule_L23F36T71_Index = ALUModule_L23F37T63_Expr[31:0];
assign SHLL = ALUModule_L23F36T71_Index;
assign ALUModule_L25F37T56_SignChange = Inputs_Op1;
assign ALUModule_L25F36T80_Index = ALUModule_L25F37T72_Expr[31:0];
assign SHRA = ALUModule_L25F36T80_Index;
assign ALUModule_L24F37T58_SignChange = Inputs_Op1;
assign ALUModule_L24F36T82_Index = ALUModule_L24F37T74_Expr[31:0];
assign SHRL = ALUModule_L24F36T82_Index;
assign ALUModule_L19F35T53_Index = internalSub[31:0];
assign SUB = ALUModule_L19F35T53_Index;
// [BEGIN USER ARCHITECTURE]
// [END USER ARCHITECTURE]
endmodule