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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? fetch.hh

?? linux下基于c++的處理器仿真平臺。具有處理器流水線
?? HH
字號:
/* * Copyright (c) 2000, 2001, 2002, 2003, 2004, 2005 * The Regents of The University of Michigan * All Rights Reserved * * This code is part of the M5 simulator, developed by Nathan Binkert, * Erik Hallnor, Steve Raasch, and Steve Reinhardt, with contributions * from Ron Dreslinski, Dave Greene, Lisa Hsu, Kevin Lim, Ali Saidi, * and Andrew Schultz. * * Permission is granted to use, copy, create derivative works and * redistribute this software and such derivative works for any * purpose, so long as the copyright notice above, this grant of * permission, and the disclaimer below appear in all copies made; and * so long as the name of The University of Michigan is not used in * any advertising or publicity pertaining to the use or distribution * of this software without specific, written prior authorization. * * THIS SOFTWARE IS PROVIDED AS IS, WITHOUT REPRESENTATION FROM THE * UNIVERSITY OF MICHIGAN AS TO ITS FITNESS FOR ANY PURPOSE, AND * WITHOUT WARRANTY BY THE UNIVERSITY OF MICHIGAN OF ANY KIND, EITHER * EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE. THE REGENTS OF THE UNIVERSITY OF MICHIGAN SHALL NOT BE * LIABLE FOR ANY DAMAGES, INCLUDING DIRECT, SPECIAL, INDIRECT, * INCIDENTAL, OR CONSEQUENTIAL DAMAGES, WITH RESPECT TO ANY CLAIM * ARISING OUT OF OR IN CONNECTION WITH THE USE OF THE SOFTWARE, EVEN * IF IT HAS BEEN OR IS HEREAFTER ADVISED OF THE POSSIBILITY OF SUCH * DAMAGES. */#ifndef __ENCUMBERED_CPU_FULL_FETCH_HH__#define __ENCUMBERED_CPU_FULL_FETCH_HH__#include "base/statistics.hh"#include "cpu/smt.hh"#include "encumbered/cpu/full/bpred.hh"#include "encumbered/cpu/full/floss_reasons.hh"#include "sim/eventq.hh"/* Define flags that connote the different types of memory/fetch stalls */#define BRANCH_STALL 	0x01class FullCPU;class fetch_instr_rec_t{  public:    DynInst *inst;    short  thread_number;    bool squashed;    bool contents_valid;    fetch_instr_rec_t() {	contents_valid = false;	squashed = true;	inst = 0;    }    void squash() {	assert(contents_valid);	assert(!squashed);	//  reserved entries don't have inst set yet...	if (inst) {	    inst->squash();	    delete inst;	    inst = 0;	}	squashed = true;    }};struct FetchQueue{    struct fetch_instr_rec_t *instrs;    short head;    short tail;    short size;    short index_mask;    bool mt_frontend;    // num_threads refers to the number of threads in the non-mt queue,    // but actually referrs to the thred number in the mt case.    short num_threads;    // there are three types of instructions that get counted:    // present-valid: actually stored in the queue, not squashed    // present-squashed: actually stored in the queue, but have been squashed    //     (instrs[i].squashed is set)    // reserved: icache fetch has been initiated, but is not yet complete    //     (not stored in ifq, DynInst structs are in icache_output_buffer)    //    //  Each instruction is counted as either valid, reserved, or squashed    //    short num_valid;    short num_reserved;    short num_squashed;    short num_valid_thread[SMT_MAX_THREADS];    short num_reserved_thread[SMT_MAX_THREADS];    short num_squashed_thread[SMT_MAX_THREADS];    // initialization    void init(FullCPU *cpu, int size, int number_of_threads);    // increment a queue index (with wrap)    int incr(int index) {	return ((index + 1) & index_mask);    }    short num_total() { return num_valid + num_reserved + num_squashed; }    short num_total(unsigned t)    {	assert(mt_frontend && t == num_threads ||	       !mt_frontend && t >= 0 && t <= num_threads);	return num_valid_thread[t] + num_reserved_thread[t]	    + num_squashed_thread[t];    }    short num_available() { return num_valid + num_squashed; }    short num_available(unsigned t)    {	assert(mt_frontend && t == num_threads ||	       !mt_frontend && t >= 0 && t <= num_threads);	return num_valid_thread[t] + num_squashed_thread[t];    }    void reserve(int thread);    // append a newly fetched instruction    void append(DynInst *);    //  grab the next instruction from the queue    DynInst *pull();    // squash all instructions from the specified thread    void squash();          // Used for MT front-end    void squash(int thread);    // Used for non-MT front-end    void dump() { dump(" "); }    void dump(const std::string &str);};struct ThreadListElement{    int thread_number;    int blocked;    int priority;    int sort_key;    Tick last_fetch;};enum FetchPolicyEnum {    RR,			// round-robin    IC,			// instruction-count    ICRC,    Ideal_NP,		// Ideal non-prioritized    Conf,		// Branch-confidence    Redundant,		// Redundant    RedIC,		// Hybrid Redundant/IC)    RedSlack,		// Redundant: target slack    Rand,    NUM_FETCH_POLICIES};void fetch_uninit();/* * Stored in PC[] if we have no valid PC to fetch from.  Must not match * any potentially valid PC. */#define PC_PRED_TAKEN_BTB_MISS		1#define PC_NO_LEADING_THREAD_PRED	2/* Schedulable event to invoke clear_fetch_stall at a particular cycle */class ClearFetchStallEvent : public Event{  private:    // event data fields    FullCPU *cpu;    int thread_number;    int stall_type;  public:    // constructor    ClearFetchStallEvent(FullCPU *_cpu, int thread, int type)	: Event(&mainEventQueue)    {	cpu = _cpu;	thread_number = thread;	stall_type = type;    }    // event execution function    void process();    const char* description();};/* Schedulable event to invoke clear_fetch_stall at a particular cycle */class FetchCompleteEvent : public Event{  private:    // event data fields    FullCPU *cpu;    short thread_number;    short first_index; // starting index in icache_output_buffer[thread_number]    short num_insts;    bool ready;    InstSeqNum first_seq_num;    MemReqPtr req;  public:    // constructor    FetchCompleteEvent(FullCPU *_cpu, int thread,		       int _first_index, int _num_insts,		       InstSeqNum _seq,		       MemReqPtr _req = NULL)	: Event(&mainEventQueue)    {	cpu = _cpu;	thread_number = thread;	first_index = _first_index;	num_insts = _num_insts;	first_seq_num = _seq;	ready = false;	req = _req;    }    // event execution function    void process();    const char* description();    // squash this fetch before it returns... currently the cache    // operation is *not* squashed, but the instructions are discarded    // when they arrive    void squash();};#endif // __ENCUMBERED_CPU_FULL_FETCH_HH__

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
丁香婷婷综合色啪| 欧美一级二级在线观看| 毛片基地黄久久久久久天堂| 亚洲宅男天堂在线观看无病毒| 国产精品每日更新在线播放网址| 久久精品视频免费观看| 精品福利一区二区三区免费视频| 欧美成人官网二区| www国产精品av| 欧美高清在线视频| 亚洲人成精品久久久久| 亚洲日本韩国一区| 亚洲一区二区在线播放相泽| 天堂va蜜桃一区二区三区| 麻豆免费看一区二区三区| 另类小说综合欧美亚洲| 五月婷婷综合网| 97久久精品人人做人人爽| 国产大陆精品国产| 成人黄动漫网站免费app| 91视频com| 在线成人小视频| 久久婷婷国产综合精品青草| 国产午夜精品在线观看| 亚洲柠檬福利资源导航| 天天av天天翘天天综合网| 狠狠色丁香久久婷婷综合丁香| 蜜桃视频一区二区三区在线观看| 国产美女精品在线| 色综合色狠狠天天综合色| 91精品国产91久久综合桃花| 久久久精品中文字幕麻豆发布| 国产精品电影一区二区三区| 亚洲aⅴ怡春院| 国产91精品精华液一区二区三区 | 久久综合五月天婷婷伊人| 久久久777精品电影网影网 | 久久国产精品一区二区| 成人精品在线视频观看| 欧亚一区二区三区| 国产三级精品在线| 亚洲成人免费看| 豆国产96在线|亚洲| 欧美日韩一区二区电影| 中文幕一区二区三区久久蜜桃| 亚洲一区在线观看网站| 高清不卡一区二区| 日韩精品中午字幕| 亚洲福利视频导航| 99热99精品| 欧美精品 国产精品| 亚洲欧美一区二区三区极速播放 | 亚洲线精品一区二区三区八戒| 日韩精品五月天| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 亚洲午夜精品17c| 亚洲不卡在线观看| 国产精品18久久久久久久网站| 无吗不卡中文字幕| 欧美网站一区二区| 这里只有精品免费| 国产精品国产馆在线真实露脸 | 北条麻妃一区二区三区| 日韩午夜在线观看| 香蕉久久夜色精品国产使用方法| 高清不卡在线观看av| 久久网这里都是精品| 毛片一区二区三区| 欧美一区二区三区日韩| 性欧美疯狂xxxxbbbb| 欧美视频中文字幕| 亚洲国产视频直播| 欧美在线观看一二区| 一区二区欧美视频| 色成年激情久久综合| 亚洲另类春色校园小说| 欧美激情一区二区在线| 日韩制服丝袜av| 色呦呦国产精品| 国产精品久久精品日日| 成人久久久精品乱码一区二区三区| 日韩免费在线观看| 国产福利精品一区| 日本一区二区免费在线观看视频| 婷婷中文字幕综合| av成人动漫在线观看| 蜜桃久久av一区| 欧美日韩三级在线| 日韩国产高清影视| 欧美岛国在线观看| 国产成人高清在线| 国产精品福利一区二区三区| 色偷偷一区二区三区| 亚洲国产精品一区二区久久恐怖片 | 中文字幕在线观看不卡视频| 国产一区美女在线| 国产精品麻豆欧美日韩ww| 色综合久久88色综合天天免费| 亚洲黄色小说网站| 欧美一区二区在线不卡| 国产一区二区美女| 亚洲精品国久久99热| 91精品麻豆日日躁夜夜躁| 国产伦精品一区二区三区免费| 国产精品国产三级国产aⅴ中文| 91色porny在线视频| 午夜激情久久久| 国产欧美日韩久久| 色妹子一区二区| 精品亚洲成av人在线观看| 国产日本亚洲高清| 欧美日本一区二区在线观看| 韩国视频一区二区| 亚洲国产精品一区二区久久恐怖片| 精品日本一线二线三线不卡| 99精品一区二区三区| 麻豆成人久久精品二区三区红 | 国产美女精品在线| 亚洲午夜久久久久久久久电影院| 精品久久久久久亚洲综合网| 色狠狠综合天天综合综合| 久久66热re国产| 一区二区三区加勒比av| 久久九九99视频| 欧美精品九九99久久| 99久久久久久| 国产精品伊人色| 日本欧美久久久久免费播放网| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ原创 | 久久青草国产手机看片福利盒子 | 国产亚洲欧美激情| 欧美色综合影院| 成人激情校园春色| 精品一区二区三区的国产在线播放| 亚洲综合免费观看高清完整版| 国产欧美综合色| 精品女同一区二区| 欧美日韩国产一级二级| 一本色道a无线码一区v| 99热这里都是精品| 成人在线视频首页| 国产精品88888| 国产一区二区三区| 久久成人免费电影| 久久av资源网| 九一九一国产精品| 久久99久久久久久久久久久| 午夜精品一区二区三区免费视频| 夜夜精品视频一区二区| 亚洲视频精选在线| 亚洲精品乱码久久久久久黑人| 国产精品不卡在线| 《视频一区视频二区| 亚洲视频一二三| 亚洲黄色免费电影| 亚洲一区二区三区不卡国产欧美| 亚洲精品高清在线| 夜夜精品视频一区二区| 亚洲成人av一区二区三区| 亚洲国产sm捆绑调教视频 | 国产成人av电影在线观看| 国产精品 日产精品 欧美精品| 国产一区二区剧情av在线| 国产成人av一区二区三区在线| 高清不卡在线观看av| 91猫先生在线| 欧美日韩一区中文字幕| 91精品中文字幕一区二区三区| 欧美一级理论片| 国产亚洲人成网站| 亚洲欧美一区二区三区极速播放| 一区二区成人在线| 麻豆精品精品国产自在97香蕉| 国产在线精品免费av| 91蜜桃在线观看| 欧美乱妇一区二区三区不卡视频| 日韩欧美不卡一区| 国产日韩欧美电影| 亚洲一区日韩精品中文字幕| 裸体歌舞表演一区二区| 成人免费视频视频| 欧美日韩一区视频| 久久久综合视频| 亚洲卡通动漫在线| 免费成人美女在线观看.| 成人18视频在线播放| 欧美日韩大陆一区二区| 日本一区二区三区久久久久久久久不| 国产精品久久99| 七七婷婷婷婷精品国产| 成人精品视频.| 91麻豆精品国产91久久久久久久久| 久久精品综合网| 日韩高清在线电影| 国产成人av电影在线| 在线观看91av| 亚洲裸体xxx| 国产99久久久国产精品免费看 | 国产乱码字幕精品高清av| 欧美最新大片在线看|