blob: 99146ecfb0bccd7df068dc5605b715ba962030e0 (
plain) (
blame)
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
|
// Verilated -*- C++ -*-
// DESCRIPTION: Verilator output: Design implementation internals
// See Valu.h for the primary calling header
#include "verilated.h"
#include "Valu___024root.h"
VL_INLINE_OPT void Valu___024root___combo__TOP__0(Valu___024root* vlSelf) {
if (false && vlSelf) {} // Prevent unused
Valu__Syms* const __restrict vlSymsp VL_ATTR_UNUSED = vlSelf->vlSymsp;
VL_DEBUG_IF(VL_DBG_MSGF("+ Valu___024root___combo__TOP__0\n"); );
// Body
vlSelf->alu__DOT__result = ((8U & (IData)(vlSelf->op))
? ((4U & (IData)(vlSelf->op))
? ((2U & (IData)(vlSelf->op))
? ((1U & (IData)(vlSelf->op))
? vlSelf->in1
: 0U) :
((1U & (IData)(vlSelf->op))
? (((0x1fU
>= vlSelf->in2)
? (vlSelf->in1
>> vlSelf->in2)
: 0U)
| ((vlSelf->in1
>> 0x1fU)
?
((IData)(0xffffffffU)
<<
((0x10U
& ((~
(vlSelf->in2
>> 4U))
<< 4U))
| ((8U
& ((~
(vlSelf->in2
>> 3U))
<< 3U))
| ((4U
& ((~
(vlSelf->in2
>> 2U))
<< 2U))
| ((2U
& ((~
(vlSelf->in2
>> 1U))
<< 1U))
| (1U
& (~ vlSelf->in2)))))))
: 0U))
: 0U)) : 0U)
: ((4U & (IData)(vlSelf->op))
? ((2U & (IData)(vlSelf->op))
? ((1U & (IData)(vlSelf->op))
? (vlSelf->in1
& vlSelf->in2)
: (vlSelf->in1
| vlSelf->in2))
: ((1U & (IData)(vlSelf->op))
? ((0x1fU
>= vlSelf->in2)
?
(vlSelf->in1
>> vlSelf->in2)
: 0U)
: (vlSelf->in1
- vlSelf->in2)))
: ((2U & (IData)(vlSelf->op))
? ((1U & (IData)(vlSelf->op))
? ((vlSelf->in1
< vlSelf->in2)
? 1U
: 0U)
: (((vlSelf->in1
>> 0x1fU)
==
(vlSelf->in2
>> 0x1fU))
? 0U
:
((vlSelf->in1
>> 0x1fU)
? 1U
: 0U)))
: ((1U & (IData)(vlSelf->op))
? ((0x1fU
>= vlSelf->in2)
?
(vlSelf->in1
>> vlSelf->in2)
: 0U)
: (vlSelf->in1
+ vlSelf->in2)))));
vlSelf->out = vlSelf->alu__DOT__result;
}
void Valu___024root___eval(Valu___024root* vlSelf) {
if (false && vlSelf) {} // Prevent unused
Valu__Syms* const __restrict vlSymsp VL_ATTR_UNUSED = vlSelf->vlSymsp;
VL_DEBUG_IF(VL_DBG_MSGF("+ Valu___024root___eval\n"); );
// Body
Valu___024root___combo__TOP__0(vlSelf);
}
#ifdef VL_DEBUG
void Valu___024root___eval_debug_assertions(Valu___024root* vlSelf) {
if (false && vlSelf) {} // Prevent unused
Valu__Syms* const __restrict vlSymsp VL_ATTR_UNUSED = vlSelf->vlSymsp;
VL_DEBUG_IF(VL_DBG_MSGF("+ Valu___024root___eval_debug_assertions\n"); );
// Body
if (VL_UNLIKELY((vlSelf->op & 0xf0U))) {
Verilated::overWidthError("op");}
}
#endif // VL_DEBUG
|