当前位置: 首页>>代码示例>>C++>>正文


C++ AstConst::v3error方法代码示例

本文整理汇总了C++中AstConst::v3error方法的典型用法代码示例。如果您正苦于以下问题:C++ AstConst::v3error方法的具体用法?C++ AstConst::v3error怎么用?C++ AstConst::v3error使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在AstConst的用法示例。


在下文中一共展示了AstConst::v3error方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: visitShift

    void visitShift (AstNodeBiop* nodep) {
    // Shifts of > 32/64 bits in C++ will wrap-around and generate non-0s
    if (!nodep->user2SetOnce()) {
        UINFO(4,"  ShiftFix  "<<nodep<<endl);
        AstConst* shiftp = nodep->rhsp()->castConst();
        if (shiftp && shiftp->num().mostSetBitP1() > 32) {
        shiftp->v3error("Unsupported: Shifting of by over 32-bit number isn't supported."
                <<" (This isn't a shift of 32 bits, but a shift of 2^32, or 4 billion!)\n");
        }
        if (nodep->widthMin()<=64  // Else we'll use large operators which work right
        // C operator's width must be < maximum shift which is based on Verilog width
        && nodep->width() < (1LL<<nodep->rhsp()->widthMin())) {
        AstNRelinker replaceHandle;
        nodep->unlinkFrBack(&replaceHandle);
        AstNode* constzerop;
        int m1value = nodep->widthMin()-1; // Constant of width-1; not changing dtype width
        if (nodep->signedFlavor()) {
            // Then over shifting gives the sign bit, not all zeros
            // Note *NOT* clean output -- just like normal shift!
            // Create equivalent of VL_SIGNONES_(node_width)
            constzerop = new AstNegate (nodep->fileline(),
                        new AstShiftR(nodep->fileline(),
                                  nodep->lhsp()->cloneTree(false),
                                  new AstConst(nodep->fileline(),
                                       m1value),
                                  nodep->width()));
        } else {
            V3Number zeronum  (nodep->fileline(), nodep->width(), 0);
            constzerop = new AstConst(nodep->fileline(), zeronum);
        }
        constzerop->dtypeFrom (nodep);  // unsigned

        V3Number widthnum (nodep->fileline(), nodep->rhsp()->widthMin(), m1value);
        AstNode* constwidthp = new AstConst(nodep->fileline(), widthnum);
        constwidthp->dtypeFrom (nodep->rhsp());  // unsigned
        AstCond* newp =
            new AstCond (nodep->fileline(),
                 new AstGte (nodep->fileline(),
                         constwidthp,
                         nodep->rhsp()->cloneTree(false)),
                 nodep,
                 constzerop);
        replaceHandle.relink(newp);
        }
    }
    nodep->iterateChildren(*this); checkNode(nodep);
    }
开发者ID:phb,项目名称:verilator-dev,代码行数:47,代码来源:V3Premit.cpp


注:本文中的AstConst::v3error方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。