⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 range.h

📁 体系机构仿真
💻 H
字号:
/* * range.h - program execution range definitions and interfaces * * 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 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: range.h,v 1.1 1997/03/11 01:32:44 taustin Exp taustin $ * * $Log: range.h,v $ * Revision 1.1  1997/03/11  01:32:44  taustin * Initial revision * * */#ifndef RANGE_H#define RANGE_H#include <stdio.h>#include "ss.h"enum range_ptype_t {  pt_addr = 0,			/* address position */  pt_inst,			/* instruction count position */  pt_cycle,			/* cycle count position */  pt_NUM};/* * an execution position * *   by addr:		@<addr> *   by inst count:	<icnt> *   by cycle count:	#<cycle> * */struct range_pos_t {  enum range_ptype_t ptype;	/* type of position */  SS_COUNTER_TYPE pos;		/* position */};/* an execution range */struct range_range_t {  struct range_pos_t start;  struct range_pos_t end;};/* parse execution position *PSTR to *POS */char *						/* error string, or NULL */range_parse_pos(char *pstr,			/* execution position string */		struct range_pos_t *pos);	/* position return buffer *//* print execution position *POS */voidrange_print_pos(struct range_pos_t *pos,	/* execution position */		FILE *stream);			/* output stream *//* parse execution range *RSTR to *RANGE */char *						/* error string, or NULL */range_parse_range(char *rstr,			/* execution range string */		  struct range_range_t *range);	/* range return buffer *//* print execution range *RANGE */voidrange_print_range(struct range_range_t *range,	/* execution range */		  FILE *stream);		/* output stream *//* determine if inputs match execution position */int						/* relation to position */range_cmp_pos(struct range_pos_t *pos,		/* execution position */	      SS_COUNTER_TYPE val);		/* position value *//* determine if inputs are in range */int						/* relation to range */range_cmp_range(struct range_range_t *range,	/* execution range */		SS_COUNTER_TYPE val);		/* position value *//* determine if inputs are in range, passes all possible info needed */int						/* relation to range */range_cmp_range1(struct range_range_t *range,	/* execution range */		 SS_ADDR_TYPE addr,		/* address value */		 SS_COUNTER_TYPE icount,	/* instruction count */		 SS_COUNTER_TYPE cycle);	/* cycle count *//* * * <range> := {<start_val>}:{<end>} * <end>   := <end_val> *            | +<delta> * */#endif /* RANGE_H */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -