summaryrefslogtreecommitdiff
path: root/verilog/alu/obj_dir/Valu___024root__DepSet_ha59b247d__0.cpp
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