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

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

?? main.hh

?? linux下基于c++的處理器仿真平臺。具有處理器流水線
?? HH
字號:
/* * memory.c - flat memory space routines * * This file is a part of the SimpleScalar tool suite written by * Todd M. Austin as a part of the Multiscalar Research Project. *   * The tool suite is currently maintained by Doug Burger and Todd M. Austin. *  * Copyright (C) 1994, 1995, 1996, 1997, 1998 by Todd M. Austin * * This source file is distributed "as is" in the hope that it will be * useful.  The tool set comes with no warranty, and no author or * distributor accepts any responsibility for the consequences of its * use.  *  * Everyone is granted permission to copy, modify and redistribute * this tool set under the following conditions: *  *    This source code is distributed for non-commercial use only.  *    Please contact the maintainer for restrictions applying to  *    commercial use. * *    Permission is granted to anyone to make or distribute copies *    of this source code, either as received or modified, in any *    medium, provided that all copyright notices, permission and *    nonwarranty notices are preserved, and that the distributor *    grants the recipient permission for further redistribution as *    permitted by this document. * *    Permission is granted to distribute this file in compiled *    or executable form under the same conditions that apply for *    source code, provided that either: * *    A. it is accompanied by the corresponding machine-readable *       source code, *    B. it is accompanied by a written offer, with no time limit, *       to give anyone a machine-readable copy of the corresponding *       source code in return for reimbursement of the cost of *       distribution.  This written offer must permit verbatim *       duplication by anyone, or *    C. it is distributed by someone who received only the *       executable form, and is accompanied by a copy of the *       written offer of source code that they received concurrently. * * In other words, you are welcome to use, share and improve this * source file.  You are forbidden to forbid anyone else to use, share * and improve what you give them. * * INTERNET: dburger@cs.wisc.edu * US Mail:  1210 W. Dayton Street, Madison, WI 53706 * * $Id: main.hh 1.53 05/06/05 02:52:51-04:00 rdreslin@zazzer.eecs.umich.edu $ * * $Log: <Not implemented> $ * Revision 1.1.1.1  1999/02/02 19:29:55  sraasch * Import source * * Revision 1.6  1998/08/27 15:38:28  taustin * implemented host interface description in host.h * added target interface support * memory module updated to support 64/32 bit address spaces on 64/32 *       bit machines, now implemented with a dynamically optimized hashed *       page table * added support for quadword's * added fault support * * Revision 1.5  1997/03/11  01:15:25  taustin * updated copyright * mem_valid() added, indicates if an address is bogus, used by DLite! * long/int tweaks made for ALPHA target support * * Revision 1.4  1997/01/06  16:00:51  taustin * stat_reg calls now do not initialize stat variable values * * Revision 1.3  1996/12/27  15:52:46  taustin * updated comments * integrated support for options and stats packages * * Revision 1.1  1996/12/05  18:52:32  taustin * Initial revision * * *//* @file */#ifndef __MAIN_MEMORY_HH__#define __MAIN_MEMORY_HH__#include "mem/functional/functional.hh"#include "base/statistics.hh"#include "sim/stats.hh"// number of entries in page translation hash table (must be power-of-two)#define MEM_PTAB_SIZE		(32*1024)#define MEM_LOG_PTAB_SIZE	15/* * Model of infinite virtual memory for a standalone application */class MainMemory : public FunctionalMemory{  public:    friend class simple_disk;  private:    // prevent copying of a MainMemory object    MainMemory(const MainMemory &specmem);    const MainMemory &operator=(const MainMemory &specmem);    /*     *     */    class LockedAddr {	// on alpha, minimum LL/SC granularity is 16 bytes, so lower	// bits need to masked off.	static const Addr Addr_Mask = 0xf;	Addr addr;			// locked address	ExecContext *xc;	// locking context      public:	// mask off unneeded address bits	static Addr maskAddr(Addr _addr) { return _addr & ~Addr_Mask; }	// change locked address	void setAddr(Addr _addr) { addr = maskAddr(_addr); }	// check for matching reference address	bool matchesAddr(Addr addr2) { return (addr == maskAddr(addr2)); }	// check for matching execution context	bool matchesContext(ExecContext *xc2)	{ return (xc == xc2); }	// return pointer to execution context	ExecContext *getContext() { return xc; }	LockedAddr(Addr _addr, ExecContext *_xc)	    : addr(maskAddr(_addr)), xc(_xc)	{	}    };    std::list<LockedAddr> lockedAddrList;    // helper function for checkLockedAddrs(): we really want to    // inline a quick check for an empty locked addr list (hopefully    // the common case), and do the full list search (if necessary) in    // this out-of-line function    bool checkLockedAddrList(MemReqPtr &req);  protected:    // page table entry    struct entry    {	entry *next;		// next translation in this bucket	Addr tag;			// virtual page number tag	uint8_t *page;		// page pointer    };    entry *ptab[MEM_PTAB_SIZE];	// inverted page table    // memory object stats    bool takeStats;    Stats::Scalar<> page_count;		// total number of pages allocated    Stats::Scalar<> ptab_misses;	// total first level page tbl misses    Stats::Scalar<> ptab_accesses;	// total page table accesses    Stats::Formula page_mem;    Stats::Formula ptab_miss_rate;    static Addr offset(Addr addr);    static Addr ptab_set(Addr addr);    static Addr ptab_tag(Addr addr);    uint8_t *page(Addr addr);    uint8_t *translate(Addr addr);    uint8_t *newpage(Addr addr);    // Check for access faults to page data    Fault page_check(Addr addr, int size) const;    // Read/Write arbitrary amounts of data within a page    Fault page_read(Addr addr, uint8_t *p, int size);    Fault page_write(Addr addr, const uint8_t *p, int size);    Fault page_set(Addr addr, uint8_t val, int size);    // Speed up access for certain data access sizes    template <class T> Fault page_read(Addr addr, T &data);    template <class T> Fault page_write(Addr addr, T data);    // Record the address of a load-locked operation so that we can    // clear the execution context's lock flag if a matching store is    // performed    void trackLoadLocked(MemReqPtr &req);    // Compare a store address with any locked addresses so we can    // clear the lock flag appropriately.  Return value set to 'false'    // if store operation should be suppressed (because it was a    // conditional store and the address was no longer locked by the    // requesting execution context), 'true' otherwise.  Note that    // this method must be called on *all* stores since even    // non-conditional stores must clear any matching lock addresses.    bool checkLockedAddrs(MemReqPtr &req) {	if (lockedAddrList.empty()) {	    // no locked addrs: nothing to check, store_conditional fails	    return !(req->flags & LOCKED);	} else {	    // iterate over list...	    return checkLockedAddrList(req);	}    }  public:    MainMemory(const std::string &n);    virtual ~MainMemory();    // Read/Write arbitrary amounts of data to simulated memory space    virtual void prot_read(Addr addr, uint8_t *p, int size);    virtual void prot_write(Addr addr, const uint8_t *p, int size);    virtual void prot_memset(Addr addr, uint8_t val, int size);    virtual Fault read(MemReqPtr &req, uint8_t *data);    virtual Fault write(MemReqPtr &req, const uint8_t *data);    virtual Fault read(MemReqPtr &req, uint8_t &data);    virtual Fault read(MemReqPtr &req, uint16_t &data);    virtual Fault read(MemReqPtr &req, uint32_t &data);    virtual Fault read(MemReqPtr &req, uint64_t &data);    virtual Fault write(MemReqPtr &req, uint8_t data);    virtual Fault write(MemReqPtr &req, uint16_t data);    virtual Fault write(MemReqPtr &req, uint32_t data);    virtual Fault write(MemReqPtr &req, uint64_t data);  public:    virtual void regStats();    virtual void regFormulas();    virtual void startup();};// compute address of access within a host pageinline AddrMainMemory::offset(Addr addr){ return addr & (VMPageSize - 1); }// compute page table setinline AddrMainMemory::ptab_set(Addr addr){ return (addr >> LogVMPageSize) & (MEM_PTAB_SIZE - 1); }// compute page table taginline AddrMainMemory::ptab_tag(Addr addr){ return addr >> (LogVMPageSize + MEM_LOG_PTAB_SIZE); }inline FaultMainMemory::page_read(Addr addr, uint8_t *data, int size){    uint8_t *p = page(addr);    if (p)	::memcpy(data, p + offset(addr), size);    else	::memset(data, 0, size);    mem_addr_test(addr);    return No_Fault;}inline FaultMainMemory::page_write(Addr addr, const uint8_t *data, int size){    uint8_t *p = page(addr);    // allocate page for address if we don't have one.    if (!p)	p = newpage(addr);    ::memcpy(p + offset(addr), data, size);    mem_addr_test(addr, data);    return No_Fault;}inline FaultMainMemory::page_set(Addr addr, uint8_t val, int size){    uint8_t *p = page(addr);    // allocate page for address if we don't have one.    if (!p)	p = newpage(addr);    ::memset(p + offset(addr), val, size);    mem_addr_test(addr);    return No_Fault;}template <class T>inline FaultMainMemory::page_read(Addr addr, T &data){    uint8_t *p = page(addr);    if (p)	data = *((T *)(p + offset(addr)));    else	// page not yet allocated, return zero value	data = T();    mem_addr_test(addr);    return No_Fault;}template <class T>inline FaultMainMemory::page_write(Addr addr, T data){    uint8_t *p = page(addr);    // allocate page for address if we don't have one.    if (!p)	p = newpage(addr);    *((T *)(page(addr) + offset(addr))) = data;    mem_addr_test(addr);    return No_Fault;}inline FaultMainMemory::read(MemReqPtr &req, uint8_t &data){    mem_block_test(req->paddr);    if (req->flags & LOCKED)	trackLoadLocked(req);    page_read(req->paddr, data);    return No_Fault;}inline FaultMainMemory::read(MemReqPtr &req, uint16_t &data){    mem_block_test(req->paddr);    if (req->paddr & (sizeof(uint16_t) - 1)) return Alignment_Fault;    if (req->flags & LOCKED)	trackLoadLocked(req);    page_read(req->paddr, data);    return No_Fault;}inline FaultMainMemory::read(MemReqPtr &req, uint32_t &data){    mem_block_test(req->paddr);    if (req->paddr & (sizeof(uint32_t) - 1)) return Alignment_Fault;    if (req->flags & LOCKED)	trackLoadLocked(req);    page_read(req->paddr, data);    return No_Fault;}inline FaultMainMemory::read(MemReqPtr &req, uint64_t &data){    mem_block_test(req->paddr);    if (req->paddr & (sizeof(uint64_t) - 1)) return Alignment_Fault;    if (req->flags & LOCKED)	trackLoadLocked(req);    page_read(req->paddr, data);    return No_Fault;}inline FaultMainMemory::write(MemReqPtr &req, uint8_t data){    mem_block_test(req->paddr, &data);    if (checkLockedAddrs(req))	page_write(req->paddr, data);    return No_Fault;}inline FaultMainMemory::write(MemReqPtr &req, uint16_t data){    mem_block_test(req->paddr, &data);    if (req->paddr & (sizeof(uint16_t) - 1)) return Alignment_Fault;    if (checkLockedAddrs(req))	page_write(req->paddr, data);    return No_Fault;}inline FaultMainMemory::write(MemReqPtr &req, uint32_t data){    mem_block_test(req->paddr, &data);    if (req->paddr & (sizeof(uint32_t) - 1)) return Alignment_Fault;    if (checkLockedAddrs(req))	page_write(req->paddr, data);    return No_Fault;}inline FaultMainMemory::write(MemReqPtr &req, uint64_t data){    mem_block_test(req->paddr, &data);    if (req->paddr & (sizeof(uint64_t) - 1)) return Alignment_Fault;    if (checkLockedAddrs(req))	page_write(req->paddr, data);    return No_Fault;}#endif // __MAIN_MEMORY_HH__

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产亚洲精品精华液| av亚洲产国偷v产偷v自拍| 亚洲欧美色图小说| 国产日本欧美一区二区| 日韩三级精品电影久久久 | 久久久精品国产免大香伊| 日韩一区二区在线免费观看| 欧美年轻男男videosbes| 欧美日韩一区 二区 三区 久久精品| 91麻豆精品视频| 欧美午夜精品一区二区三区| 欧美色图激情小说| 欧美一级二级在线观看| 精品国产百合女同互慰| 久久久亚洲综合| 国产精品你懂的| 一区二区三区精品视频| 亚洲成人动漫在线观看| 91麻豆免费观看| 色综合久久中文综合久久牛| 91原创在线视频| 欧美在线观看禁18| 欧美一三区三区四区免费在线看 | 成人性生交大片免费看视频在线| 国产91精品露脸国语对白| 处破女av一区二区| 色婷婷亚洲精品| 日韩一二三区视频| 国产日韩欧美亚洲| 综合精品久久久| 日韩激情一二三区| 国产精品18久久久久久久久 | 免费日本视频一区| 亚洲成人综合网站| 蜜桃免费网站一区二区三区| 国产精品综合久久| 91黄色激情网站| 欧美成人高清电影在线| www成人在线观看| 一区二区在线观看不卡| 日韩精品一二区| 99国产欧美另类久久久精品| 欧美剧情片在线观看| 国产精品久线观看视频| 日韩中文字幕不卡| 91免费视频观看| 久久人人超碰精品| 国产精品黄色在线观看| 国产人成亚洲第一网站在线播放 | 国产精品素人一区二区| 日韩精品1区2区3区| 成人高清伦理免费影院在线观看| 欧美精品久久一区| 亚洲视频在线观看一区| 国产精品一区二区三区四区| 欧美日韩午夜在线视频| 亚洲欧美综合另类在线卡通| 国产在线精品免费| 日韩欧美一二区| 婷婷开心激情综合| 欧美午夜影院一区| 国产精品不卡一区二区三区| 国产在线麻豆精品观看| 日韩午夜精品电影| 午夜欧美在线一二页| 在线观看欧美日本| 亚洲欧美日韩人成在线播放| 成人动漫中文字幕| 国产精品日韩精品欧美在线| 国产乱码精品1区2区3区| 欧美精品一区二区在线播放| 久久精品国产免费看久久精品| 91超碰这里只有精品国产| 一区二区三区在线视频观看| 色先锋aa成人| 亚洲国产裸拍裸体视频在线观看乱了| 91老师片黄在线观看| 亚洲视频一二三区| 欧美伊人精品成人久久综合97| 亚洲人成小说网站色在线| 欧美精品在线视频| 日韩美女视频一区二区| 99re这里只有精品6| 136国产福利精品导航| 91香蕉视频在线| 青青草国产精品亚洲专区无| 日韩午夜精品电影| 国产经典欧美精品| 国产精品国产三级国产aⅴ无密码| 国产成人无遮挡在线视频| 国产日韩欧美在线一区| 91麻豆精品一区二区三区| 一区二区三区日韩欧美精品| 欧美日韩视频专区在线播放| 天天色综合成人网| 欧美精品一区二区三区高清aⅴ | 蜜臀精品一区二区三区在线观看| 日韩一级黄色大片| 波多野结衣亚洲一区| 精品综合久久久久久8888| 精品日本一线二线三线不卡| 黄色小说综合网站| 国产精品久久久久桃色tv| 91成人免费在线视频| 日韩**一区毛片| 国产欧美精品在线观看| 91免费国产在线| 麻豆91在线观看| 国产精品久久久久久亚洲毛片 | 亚洲综合丁香婷婷六月香| 欧洲精品中文字幕| 精品一二线国产| 亚洲丝袜制服诱惑| 91精品综合久久久久久| 岛国一区二区在线观看| 亚洲一卡二卡三卡四卡| 久久久久99精品国产片| 精品国产亚洲一区二区三区在线观看| 麻豆精品国产传媒mv男同| 国产精品久久久一本精品| 在线电影院国产精品| 成人国产精品免费观看| 奇米影视在线99精品| 国产精品久久毛片a| 欧美成人午夜电影| 欧美三级在线看| av一本久道久久综合久久鬼色| 美女看a上一区| 亚洲尤物在线视频观看| 国产精品丝袜一区| 亚洲精品在线三区| 7777精品伊人久久久大香线蕉完整版 | 日本午夜精品一区二区三区电影| 欧美国产激情一区二区三区蜜月| 91精品国产综合久久久久久漫画| 91碰在线视频| 国产精品香蕉一区二区三区| 日韩在线a电影| 亚洲电影中文字幕在线观看| 成人免费在线播放视频| 欧美国产97人人爽人人喊| 欧美大片一区二区三区| 欧美精品xxxxbbbb| 欧美日韩激情在线| 在线观看区一区二| 91成人看片片| 色偷偷成人一区二区三区91| hitomi一区二区三区精品| 成人永久aaa| 成人成人成人在线视频| 大尺度一区二区| 成人avav影音| 97se亚洲国产综合自在线观| 99久久国产免费看| 97精品电影院| 91成人在线精品| 欧美日韩亚洲高清一区二区| 欧美日韩成人综合天天影院| 欧美日韩精品欧美日韩精品一| 欧美三级在线视频| 欧美理论片在线| 欧美r级电影在线观看| 精品国产伦一区二区三区观看方式| 日韩欧美一级在线播放| 欧美v国产在线一区二区三区| 精品国产1区二区| 国产视频一区在线播放| 国产精品伦一区二区三级视频| 国产精品麻豆视频| 亚洲午夜影视影院在线观看| 日韩制服丝袜av| 国产成人av电影在线| av色综合久久天堂av综合| 在线视频综合导航| 欧美一二三四区在线| 久久精品视频一区| 亚洲精品免费电影| 日韩av电影天堂| 成人一二三区视频| 欧美性xxxxxxxx| 久久女同互慰一区二区三区| 亚洲欧洲成人av每日更新| 亚洲成人av在线电影| 国产一区二区三区最好精华液| 粉嫩aⅴ一区二区三区四区五区| 91视频国产资源| 欧美大片免费久久精品三p| 国产精品理论在线观看| 日产国产高清一区二区三区| 成熟亚洲日本毛茸茸凸凹| 欧美日本在线播放| 国产女人18毛片水真多成人如厕 | 亚洲美女视频在线| 日本视频在线一区| 波多野结衣精品在线| 欧美一区二区精品久久911| 亚洲欧洲成人精品av97| 久久精品国产亚洲高清剧情介绍 | 国产日本一区二区| 午夜天堂影视香蕉久久|