亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? config.py

?? linux下基于c++的處理器仿真平臺。具有處理器流水線
?? PY
?? 第 1 頁 / 共 5 頁
字號:
        if not isinstance(other, (int, float)):            raise TypeError, "Proxy multiplier must be integer"        if self._multiplier == None:            self._multiplier = other        else:            # support chained multipliers            self._multiplier *= other        return self    __rmul__ = __mul__    def _mulcheck(self, result):        if self._multiplier == None:            return result        return result * self._multiplier    def unproxy(self, base):        obj = base        done = False        if self._search_self:            result, done = self.find(obj)        if self._search_up:            while not done:                try: obj = obj._parent                except: break                result, done = self.find(obj)        if not done:            raise AttributeError, "Can't resolve proxy '%s' from '%s'" % \\                  (self.path(), base.path())        if isinstance(result, BaseProxy):            if result == self:                raise RuntimeError, "Cycle in unproxy"            result = result.unproxy(obj)        return self._mulcheck(result)    def getindex(obj, index):        if index == None:            return obj        try:            obj = obj[index]        except TypeError:            if index != 0:                raise            # if index is 0 and item is not subscriptable, just            # use item itself (so cpu[0] works on uniprocessors)        return obj    getindex = staticmethod(getindex)    def set_param_desc(self, pdesc):        self._pdesc = pdescclass AttrProxy(BaseProxy):    def __init__(self, search_self, search_up, attr):        super(AttrProxy, self).__init__(search_self, search_up)        self._attr = attr        self._modifiers = []            def __getattr__(self, attr):        # python uses __bases__ internally for inheritance        if attr.startswith('_'):            return super(AttrProxy, self).__getattr__(self, attr)        if hasattr(self, '_pdesc'):            raise AttributeError, "Attribute reference on bound proxy"        self._modifiers.append(attr)        return self    # support indexing on proxies (e.g., Self.cpu[0])    def __getitem__(self, key):        if not isinstance(key, int):            raise TypeError, "Proxy object requires integer index"        self._modifiers.append(key)        return self    def find(self, obj):        try:            val = getattr(obj, self._attr)        except:            return None, False        while isproxy(val):            val = val.unproxy(obj)        for m in self._modifiers:            if isinstance(m, str):                val = getattr(val, m)            elif isinstance(m, int):                val = val[m]            else:                assert("Item must be string or integer")            while isproxy(val):                val = val.unproxy(obj)        return val, True    def path(self):        p = self._attr        for m in self._modifiers:            if isinstance(m, str):                p += '.%s' % m            elif isinstance(m, int):                p += '[%d]' % m            else:                assert("Item must be string or integer")        return pclass AnyProxy(BaseProxy):    def find(self, obj):        return obj.find_any(self._pdesc.ptype)    def path(self):        return 'any'def isproxy(obj):    if isinstance(obj, (BaseProxy, EthernetAddr)):        return True    elif isinstance(obj, (list, tuple)):        for v in obj:            if isproxy(v):                return True    return Falseclass ProxyFactory(object):    def __init__(self, search_self, search_up):        self.search_self = search_self        self.search_up = search_up    def __getattr__(self, attr):        if attr == 'any':            return AnyProxy(self.search_self, self.search_up)        else:            return AttrProxy(self.search_self, self.search_up, attr)# global objects for handling proxiesParent = ProxyFactory(search_self = False, search_up = True)Self = ProxyFactory(search_self = True, search_up = False)####################################################################### Parameter description classes## The _params dictionary in each class maps parameter names to# either a Param or a VectorParam object.  These objects contain the# parameter description string, the parameter type, and the default# value (loaded from the PARAM section of the .odesc files).  The# _convert() method on these objects is used to force whatever value# is assigned to the parameter to the appropriate type.## Note that the default values are loaded into the class's attribute# space when the parameter dictionary is initialized (in# MetaConfigNode._setparams()); after that point they aren't used.####################################################################### Dummy base class to identify types that are legitimate for SimObject# parameters.class ParamValue(object):    # default for printing to .ini file is regular string conversion.    # will be overridden in some cases    def ini_str(self):        return str(self)    # allows us to blithely call unproxy() on things without checking    # if they're really proxies or not    def unproxy(self, base):        return self# Regular parameter description.class ParamDesc(object):    def __init__(self, ptype_str, ptype, *args, **kwargs):        self.ptype_str = ptype_str        # remember ptype only if it is provided        if ptype != None:            self.ptype = ptype        if args:            if len(args) == 1:                self.desc = args[0]            elif len(args) == 2:                self.default = args[0]                self.desc = args[1]            else:                raise TypeError, 'too many arguments'        if kwargs.has_key('desc'):            assert(not hasattr(self, 'desc'))            self.desc = kwargs['desc']            del kwargs['desc']        if kwargs.has_key('default'):            assert(not hasattr(self, 'default'))            self.default = kwargs['default']            del kwargs['default']        if kwargs:            raise TypeError, 'extra unknown kwargs %s' % kwargs        if not hasattr(self, 'desc'):            raise TypeError, 'desc attribute missing'    def __getattr__(self, attr):        if attr == 'ptype':            try:                ptype = eval(self.ptype_str, m5.__dict__)                if not isinstance(ptype, type):                    panic("Param qualifier is not a type: %s" % self.ptype)                self.ptype = ptype                return ptype            except NameError:                pass        raise AttributeError, "'%s' object has no attribute '%s'" % \\              (type(self).__name__, attr)    def convert(self, value):        if isinstance(value, BaseProxy):            value.set_param_desc(self)            return value        if not hasattr(self, 'ptype') and isNullPointer(value):            # deferred evaluation of SimObject; continue to defer if            # we're just assigning a null pointer            return value        if isinstance(value, self.ptype):            return value        if isNullPointer(value) and issubclass(self.ptype, SimObject):            return value        return self.ptype(value)# Vector-valued parameter description.  Just like ParamDesc, except# that the value is a vector (list) of the specified type instead of a# single value.class VectorParamValue(list):    def ini_str(self):        return ' '.join([str(v) for v in self])    def unproxy(self, base):        return [v.unproxy(base) for v in self]class SimObjVector(VectorParamValue):    def print_ini(self):        for v in self:            v.print_ini()class VectorParamDesc(ParamDesc):    # Convert assigned value to appropriate type.  If the RHS is not a    # list or tuple, it generates a single-element list.    def convert(self, value):        if isinstance(value, (list, tuple)):            # list: coerce each element into new list            tmp_list = [ ParamDesc.convert(self, v) for v in value ]            if isSimObjSequence(tmp_list):                return SimObjVector(tmp_list)            else:                return VectorParamValue(tmp_list)        else:            # singleton: leave it be (could coerce to a single-element            # list here, but for some historical reason we don't...            return ParamDesc.convert(self, value)class ParamFactory(object):    def __init__(self, param_desc_class, ptype_str = None):        self.param_desc_class = param_desc_class        self.ptype_str = ptype_str    def __getattr__(self, attr):        if self.ptype_str:            attr = self.ptype_str + '.' + attr        return ParamFactory(self.param_desc_class, attr)    # E.g., Param.Int(5, "number of widgets")    def __call__(self, *args, **kwargs):        caller_frame = inspect.stack()[1][0]        ptype = None        try:            ptype = eval(self.ptype_str,                         caller_frame.f_globals, caller_frame.f_locals)            if not isinstance(ptype, type):                raise TypeError, \\                      "Param qualifier is not a type: %s" % ptype        except NameError:            # if name isn't defined yet, assume it's a SimObject, and            # try to resolve it later            pass        return self.param_desc_class(self.ptype_str, ptype, *args, **kwargs)Param = ParamFactory(ParamDesc)VectorParam = ParamFactory(VectorParamDesc)####################################################################### Parameter Types## Though native Python types could be used to specify parameter types# (the 'ptype' field of the Param and VectorParam classes), it's more# flexible to define our own set of types.  This gives us more control# over how Python expressions are converted to values (via the# __init__() constructor) and how these values are printed out (via# the __str__() conversion method).  Eventually we'll need these types# to correspond to distinct C++ types as well.######################################################################class Range(ParamValue):    type = int # default; can be overridden in subclasses    def __init__(self, *args, **kwargs):        def handle_kwargs(self, kwargs):            if 'end' in kwargs:                self.second = self.type(kwargs.pop('end'))            elif 'size' in kwargs:                self.second = self.first + self.type(kwargs.pop('size')) - 1            else:                raise TypeError, "Either end or size must be specified"        if len(args) == 0:            self.first = self.type(kwargs.pop('start'))            handle_kwargs(self, kwargs)        elif len(args) == 1:            if kwargs:                self.first = self.type(args[0])                handle_kwargs(self, kwargs)            elif isinstance(args[0], Range):                self.first = self.type(args[0].first)                self.second = self.type(args[0].second)            else:                self.first = self.type(0)                self.second = self.type(args[0]) - 1        elif len(args) == 2:            self.first = self.type(args[0])            self.second = self.type(args[1])        else:            raise TypeError, "Too many arguments specified"        if kwargs:            raise TypeError, "too many keywords: %s" % kwargs.keys()    def __str__(self):        return '%s:%s' % (self.first, self.second)# Metaclass for bounds-checked integer parameters.  See CheckedInt.class CheckedIntType(type):    def __init__(cls, name, bases, dict):        super(CheckedIntType, cls).__init__(name, bases, dict)        # CheckedInt is an abstract base class, so we actually don't        # want to do any processing on it... the rest of this code is        # just for classes that derive from CheckedInt.        if name == 'CheckedInt':            return        if not (hasattr(cls, 'min') and hasattr(cls, 'max')):            if not (hasattr(cls, 'size') and hasattr(cls, 'unsigned')):                panic("CheckedInt subclass %s must define either\\n" \\                      "    'min' and 'max' or 'size' and 'unsigned'\\n" \\                      % name);            if cls.unsigned:                cls.min = 0                cls.max = 2 ** cls.size - 1            else:                cls.min = -(2 ** (cls.size - 1))                cls.max = (2 ** (cls.size - 1)) - 1# Abstract superclass for bounds-checked integer parameters.  This# class is subclassed to generate parameter classes with specific# bounds.  Initialization of the min and max bounds is done in the# metaclass CheckedIntType.__init__.class CheckedInt(long,ParamValue):    __metaclass__ = CheckedIntType    def __new__(cls, value):        if isinstance(value, str):            value = toInteger(value)        self = long.__new__(cls, value)        if not cls.min <= self <= cls.max:            raise TypeError, 'Integer param out of bounds %d < %d < %d' % \\                  (cls.min, self, cls.max)        return self

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产69精品久久久久毛片| 久久蜜桃一区二区| 精品福利一区二区三区免费视频| 国产亚洲欧美日韩日本| 亚洲综合男人的天堂| 丰满少妇在线播放bd日韩电影| 欧美三级电影网| 亚洲欧美偷拍另类a∨色屁股| 国产一区二区三区最好精华液| 欧洲国内综合视频| 亚洲人精品午夜| 国产精品123| 精品久久久久久综合日本欧美| 一区二区三区不卡视频在线观看| 成人免费福利片| 久久亚洲综合av| 韩国理伦片一区二区三区在线播放 | 伊人开心综合网| 国产98色在线|日韩| 精品日韩成人av| 麻豆91精品91久久久的内涵| 欧美日韩视频不卡| 亚洲一二三区不卡| 日本精品裸体写真集在线观看 | 欧美日韩免费不卡视频一区二区三区 | 成人免费看黄yyy456| 亚洲精品一区二区三区影院| 日韩一区精品字幕| 在线综合+亚洲+欧美中文字幕| 亚洲国产裸拍裸体视频在线观看乱了| 色哟哟精品一区| 亚洲免费三区一区二区| 色综合天天综合给合国产| 国产精品美女久久久久久久久久久| 国产精品99久久久久久似苏梦涵| 2020国产精品| 粉嫩欧美一区二区三区高清影视 | 国产超碰在线一区| 中文子幕无线码一区tr| 成人激情免费电影网址| 亚洲欧洲性图库| 在线视频欧美精品| 亚瑟在线精品视频| 欧美成人一级视频| 成人小视频免费观看| 中文字幕一区二区三区av| 91麻豆高清视频| 偷拍一区二区三区| www欧美成人18+| 成人动漫视频在线| 一卡二卡欧美日韩| 日韩天堂在线观看| 国产91色综合久久免费分享| 日韩伦理电影网| 91精品一区二区三区在线观看| 奇米四色…亚洲| 中文字幕免费不卡| 欧美午夜视频网站| 韩国女主播成人在线观看| 国产精品国产三级国产aⅴ中文 | 亚洲成人免费电影| 欧美精品一区二区三区一线天视频 | 日韩精品成人一区二区三区| 精品国产乱码久久久久久老虎| av一区二区三区在线| 五月天亚洲精品| 国产日韩视频一区二区三区| 欧美影院午夜播放| 国产夫妻精品视频| 亚洲亚洲精品在线观看| www欧美成人18+| 欧美日韩国产bt| 国产成人精品三级麻豆| 五月综合激情网| 国产精品拍天天在线| 7777精品伊人久久久大香线蕉经典版下载 | 亚洲天堂网中文字| 精品日韩av一区二区| 色av一区二区| 国产成人免费xxxxxxxx| 亚洲va欧美va国产va天堂影院| 久久老女人爱爱| 91精品国产综合久久精品性色| 成人a级免费电影| 麻豆精品久久精品色综合| 曰韩精品一区二区| 中文字幕av资源一区| 精品欧美一区二区在线观看| 欧美三级三级三级爽爽爽| 成人av电影在线| 国产福利精品一区二区| 精品在线播放免费| 日韩avvvv在线播放| 亚洲一区二区三区自拍| 亚洲欧洲性图库| 中文字幕免费在线观看视频一区| 日韩精品一区二区三区蜜臀| 欧美日韩亚洲综合在线| 欧美在线免费观看视频| eeuss国产一区二区三区| 国产酒店精品激情| 九九精品视频在线看| 蜜桃av噜噜一区| 日韩成人一级大片| 日日夜夜精品视频免费| 亚洲国产精品一区二区久久| 亚洲精品国产视频| 亚洲综合色视频| 亚洲综合成人网| 亚洲自拍偷拍综合| 亚洲成a人片综合在线| 亚洲午夜精品在线| 午夜精品久久久久| 石原莉奈一区二区三区在线观看| 亚洲一区二区在线视频| 亚洲午夜久久久久久久久电影院| 亚洲一区二区在线观看视频| 一二三区精品福利视频| 亚洲成人综合网站| 日本不卡视频在线观看| 日本成人在线电影网| 美腿丝袜在线亚洲一区| 麻豆精品一区二区| 国产一区二区女| 成人免费视频免费观看| 色婷婷亚洲一区二区三区| 欧美日韩精品电影| 欧美xfplay| 久久精品一级爱片| 国产精品视频一二三区| 夜夜亚洲天天久久| 蜜臀av一级做a爰片久久| 国产精品一区二区91| av资源网一区| 欧美偷拍一区二区| 精品日韩在线一区| 国产精品久久久久久福利一牛影视 | 色噜噜夜夜夜综合网| 欧美日韩精品一区二区三区蜜桃| 日韩欧美一级精品久久| 国产精品情趣视频| 亚洲第一福利视频在线| 国产一区二区免费在线| 91麻豆免费视频| 日韩欧美国产综合一区 | 99久久精品国产导航| 欧美日本韩国一区二区三区视频 | 亚洲欧洲无码一区二区三区| 亚洲一区二区精品视频| 激情另类小说区图片区视频区| 成人丝袜18视频在线观看| 欧美日韩精品欧美日韩精品一 | 日韩精品一区二区三区三区免费 | 久久综合狠狠综合久久综合88| 中文字幕成人av| 三级影片在线观看欧美日韩一区二区 | 蜜臀av在线播放一区二区三区| 国产精品一区2区| 欧美日本乱大交xxxxx| 国产精品嫩草影院av蜜臀| 五月开心婷婷久久| 99这里只有精品| 日韩免费观看高清完整版在线观看| 中文字幕一区二区三区蜜月| 久久66热偷产精品| 在线视频观看一区| 国产精品久久久久毛片软件| 青青草视频一区| 在线观看日韩高清av| 国产精品美女久久久久久2018 | 香蕉久久夜色精品国产使用方法| 国产成人午夜电影网| 制服.丝袜.亚洲.中文.综合| 亚洲色欲色欲www| 国产69精品久久777的优势| 欧美成人免费网站| 日韩精品电影在线| 欧美日韩中文字幕一区二区| 中文字幕在线一区| 国产成人综合在线观看| 日韩精品一区二区三区老鸭窝| 婷婷成人激情在线网| 欧美综合欧美视频| 亚洲欧美日本韩国| 99在线精品视频| 国产精品美女久久久久aⅴ| 韩国欧美国产一区| 久久蜜桃av一区精品变态类天堂 | 日韩二区三区四区| 欧美色成人综合| 亚洲va欧美va人人爽午夜| 欧美在线播放高清精品| 亚洲乱码国产乱码精品精的特点 | 精品99一区二区| 蜜桃av一区二区三区电影| 日韩一区二区在线观看| 日韩电影在线一区| 日韩精品一区国产麻豆| 久久99蜜桃精品| 久久综合中文字幕|