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

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

?? area.c.svn-base

?? 模擬多核狀態下龍芯處理器的功能
?? SVN-BASE
?? 第 1 頁 / 共 5 頁
字號:
	      if (i == iter_height)
		{
		  total_height =
		    2 * inter_height + data / blocks * multiplier +
		    fixed_tracks_external;
		  total_width =
		    2 * inter_width + data / (2 * blocks) * multiplier +
		    fixed_tracks_internal;}
	      else
		{
		  total_height =
		    2 * inter_height + data / blocks * multiplier +
		    fixed_tracks_internal;
		  total_width =
		    2 * inter_width + data / (2 * blocks) * multiplier +
		    fixed_tracks_internal;
		  inter_height = total_height;
		  inter_width = total_width;
		  multiplier = multiplier * 4;
		}
	    }
	}
      else
	{
	  htree_half = htree - 1;
	  iter_height = htree_half / 2;
	  for (i = 0; i <= iter_height; i++)
	    {
	      total_height =
		2 * inter_height + data / blocks * multiplier +
		fixed_tracks_internal;
	      total_width =
		2 * inter_width + data / (2 * blocks) * multiplier +
		fixed_tracks_internal;
	      inter_height = total_height;
	      inter_width = total_width;
	      multiplier = multiplier * 4;
	    }
	  total_width =
	    2 * inter_width + data / (2 * blocks) * multiplier +
	    fixed_tracks_external;
	}
    }

  dataarray_area.width = total_width;
  dataarray_area.height = total_height;

  temp.height = dataarray_area.width;
  temp.width = dataarray_area.height;

  temp_aspect =
    ((temp.height / temp.width) >
     1.0) ? (temp.height / temp.width) : 1.0 / (temp.height / temp.width);
  aspect_ratio_data =
    ((dataarray_area.height / dataarray_area.width) >
     1.0) ? (dataarray_area.height / dataarray_area.width) : 1.0 /
    (dataarray_area.height / dataarray_area.width);
  if (aspect_ratio_data > temp_aspect)
    {
      dataarray_area.height = temp.height;
      dataarray_area.width = temp.width;
    }

  aspect_ratio_data =
    ((dataarray_area.height / dataarray_area.width) >
     1.0) ? (dataarray_area.height / dataarray_area.width) : 1.0 /
    (dataarray_area.height / dataarray_area.width);

  return (dataarray_area);
}

area_type
tagsubarray (int baddr,int C,int B,int A,int Ndbl,int Ndwl,double Nspd,double NSubbanks,int RWP,int ERP,int EWP,int NSER,
	     double techscaling_factor)
{
  int conservative_NSER;
  area_type tagsubarray_area, tag_area, postdecode_area, colmux_area,
    precharge_area, senseamp_area, comp_area;

  conservative_NSER = 0;
  tag_area =
    subarraytag_area (baddr, C, B, A, Ndbl, Ndwl, Nspd, NSubbanks, RWP, ERP,
		      EWP, conservative_NSER, techscaling_factor);
  postdecode_area =
    decodetag_row (baddr, C, B, A, Ndbl, Nspd, Ndwl, NSubbanks, RWP, ERP,
		   EWP);
  colmux_area = colmux (Ndbl, Nspd, RWP, ERP, EWP, conservative_NSER);
  precharge_area = precharge (Ndbl, Nspd, RWP, ERP, EWP, conservative_NSER);
  senseamp_area = senseamp (Ndbl, Nspd, RWP, ERP, EWP, conservative_NSER);
  comp_area = comparatorbit (RWP, ERP, EWP);
  tagsubarray_area.height =
    tag_area.height + colmux_area.height + precharge_area.height +
    senseamp_area.height + comp_area.height;
  tagsubarray_area.width = tag_area.width + postdecode_area.width;

  return (tagsubarray_area);
}

area_type
tagsubblock (int baddr,int C,int B,int A,int Ndbl,int Ndwl,double Nspd,double NSubbanks,int SB,int RWP,int ERP,int EWP,
	     int NSER,double techscaling_factor)
{
  int N3to8, T;
  int SB_;
  //int colmuxtracks_rem, writeseltracks_rem;
  int colmuxtracks_rem;
  double tracks_h, tracks_w;
  area_type tagsubarray_area, tagsubblock_area;
  int conservative_NSER;

  conservative_NSER = 0;
  SB_ = SB;
  if (SB_ == 0)
    {
      SB_ = 1;
    }
  //v4.1: using integer casting below 
  //N3to8 =
    //ceil ((1.0 / 3.0) * logtwo_area ((double) (C / (B * A * Ndbl * Nspd))));
  N3to8 =
    (int) (ceil ((1.0 / 3.0) * logtwo_area ((double) (C / (B * A * Ndbl * Nspd)))));
  if (N3to8 == 0)
    {
      N3to8 = 1;
    }

  //v4.1: Fixing double->int type conversion problems. EPSILON is added below to make sure
  //the final int value is the correct one 
  //T =
    //baddr - logtwo_area ((double) (C)) + logtwo_area ((double) (A)) + 2 -
    //logtwo_area ((double) (NSubbanks));
  T =
    (int) (baddr - logtwo_area ((double) (C)) + logtwo_area ((double) (A)) + 2 -
    logtwo_area ((double) (NSubbanks)) + EPSILON);

  colmuxtracks_rem =
    (Ndbl * Nspd >
     tracks_precharge_p) ? (Ndbl * Nspd - tracks_precharge_p) : 0;
  /*writeseltracks_rem = ((2*B*A)/(b0) > tracks_precharge_nx2) ? ((2*B*A)/(b0)-tracks_precharge_nx2) : 0; */

  tracks_h =
    Widthtrack * (N3to8 * 8 * (RWP + ERP + EWP) +
		  (RWP + EWP) * colmuxtracks_rem + Ndbl * Nspd * ERP + (RWP +
									ERP +
									EWP) *
		  T / SB_ + (ERP + RWP) * A);
  tracks_w = Widthtrack * (N3to8 * 8) * (RWP + ERP + EWP);
  tagsubarray_area =
    tagsubarray (baddr, C, B, A, Ndbl, Ndwl, Nspd, NSubbanks, RWP, ERP, EWP,
		 conservative_NSER, techscaling_factor);
  tagsubblock_area.height = 2 * tagsubarray_area.height + tracks_h;
  tagsubblock_area.width = 2 * tagsubarray_area.width + tracks_w;

  return (tagsubblock_area);
}

area_type
tagarray (int baddr,int C,int B,int A,int Ndbl,int Ndwl,double Nspd,double NSubbanks,int RWP,int ERP,int EWP,int NSER,
	  double techscaling_factor)
{
  //int SB, CSB, N3to8, T;
  int SB, N3to8, T;
  area_type tagarray_area, tagsubarray_area, tagsubblock_area;
  area_type temp;
  double temp_aspect;
  int conservative_NSER;

  double fixed_tracks_internal, fixed_tracks_external, variable_tracks;
  double tag, assoc, colmux, predecode, addresslines;
  int blocks, htree, htree_half, i, multiplier, iter_height;
  double inter_height, inter_width, total_height, total_width;

  conservative_NSER = 0;
  SB = Ndwl * Ndbl / 4;
  
  //v4.1: using integer casting below 
  //N3to8 =
    //ceil ((1.0 / 3.0) * logtwo_area ((double) (C / (B * A * Ndbl * Nspd))));
  N3to8 =
    (int) (ceil ((1.0 / 3.0) * logtwo_area ((double) (C / (B * A * Ndbl * Nspd)))));
  if (N3to8 == 0)
    {
      N3to8 = 1;
    }

  //Added by Shyam to make area model sensitive to "change tag" feature
   //v4.1: Fixing double->int type conversion problems. EPSILON is added below to make sure
  //the final int value is the correct one 
  if(!force_tag) {
		//T = ADDRESS_BITS + EXTRA_TAG_BITS-(int)logtwo((double)C)+(int)logtwo((double)A)-(int)(logtwo(NSubbanks));
		T = (int) (ADDRESS_BITS + EXTRA_TAG_BITS-(int)logtwo((double)C)+(int)logtwo((double)A)-(int)(logtwo(NSubbanks)) + EPSILON);
	}
  else {
	    T = force_tag_size;
	}
 
  //Commented by Shyam   T =
    //baddr - logtwo_area ((double) (C)) + logtwo_area ((double) (A)) + 2 -
    //logtwo_area ((double) (NSubbanks));

  tag = T * (RWP + ERP + EWP) * Widthtrack;
  assoc = (RWP + ERP) * A * Widthtrack;
  colmux = Ndbl * Nspd * (RWP + EWP + ERP) * Widthtrack;
  predecode = (RWP + ERP + EWP) * N3to8 * 8 * Widthtrack;
  addresslines = ADDRESS_BITS * (RWP + ERP + EWP) * Widthtrack;

  tagsubarray_area =
    tagsubarray (baddr, C, B, A, Ndbl, Ndwl, Nspd, NSubbanks, RWP, ERP, EWP,
		 conservative_NSER, techscaling_factor);
  tagsubblock_area =
    tagsubblock (baddr, C, B, A, Ndbl, Ndwl, Nspd, NSubbanks, SB, RWP, ERP,
		 EWP, conservative_NSER, techscaling_factor);
  //area_all_tagsubarrays =
    //Ndbl * Ndwl * calculate_area (tagsubarray_area,
				  //techscaling_factor) * CONVERT_TO_MMSQUARE;
  area_all_tagsubarrays = Ndbl * Ndwl * tagsubarray_area.height * tagsubarray_area.width * CONVERT_TO_MMSQUARE;


  fixed_tracks_internal = colmux + predecode + assoc;
  fixed_tracks_external = colmux + assoc + addresslines;
  variable_tracks = tag;

  if (SB == 0)
    {
      if (Ndbl * Ndwl == 1)
	{
	  total_height =
	    tagsubarray_area.height + fixed_tracks_external + tag;
	  total_width = tagsubarray_area.width + predecode;
	}
      else
	{
	  total_height =
	    2 * tagsubarray_area.height + fixed_tracks_external + tag;
	  total_width = tagsubarray_area.width + predecode;
	}
    }
  if (SB == 1)
    {
      total_height = tagsubblock_area.height;
      total_width = tagsubblock_area.width;
    }
  if (SB == 2)
    {
      total_height = tagsubblock_area.height;
      total_width = 2 * tagsubblock_area.width + fixed_tracks_external + tag;
    }
  if (SB == 4)
    {
      total_height =
	2 * tagsubblock_area.height + fixed_tracks_external + tag;
      total_width =
	2 * tagsubblock_area.width + fixed_tracks_internal +
	variable_tracks / 2;
    }
  if (SB == 8)
    {
      total_height =
	2 * tagsubblock_area.height + fixed_tracks_internal +
	variable_tracks / 2;
      total_width =
	2 * (2 * tagsubblock_area.width + variable_tracks / 4) +
	fixed_tracks_external + tag;
    }
  if (SB > 8)
    {
      blocks = SB / 4;
	  //v4.1: Fixing double->int type conversion problems. EPSILON is added below to make sure
      //the final int value is the correct one 
      //htree = (int) (logtwo_area ((double) (blocks)));
	  htree = (int) (logtwo_area ((double) (blocks)) + EPSILON);
      inter_height = tagsubblock_area.height;
      inter_width = tagsubblock_area.width;
      multiplier = 1;

      if (htree % 2 == 0)
	{
	  iter_height = htree / 2;
	}

      if (htree % 2 == 0)
	{
	  for (i = 0; i <= iter_height; i++)
	    {
	      if (i == iter_height)
		{
		  total_height =
		    2 * inter_height + tag / blocks * multiplier +
		    fixed_tracks_external;
		  total_width =
		    2 * inter_width + tag / (2 * blocks) * multiplier +
		    fixed_tracks_internal;}
	      else
		{
		  total_height =
		    2 * inter_height + tag / blocks * multiplier +
		    fixed_tracks_internal;
		  total_width =
		    2 * inter_width + tag / (2 * blocks) * multiplier +
		    fixed_tracks_internal;
		  inter_height = total_height;
		  inter_width = total_width;
		  multiplier = multiplier * 4;
		}
	    }
	}
      else
	{
	  htree_half = htree - 1;
	  iter_height = htree_half / 2;
	  for (i = 0; i <= iter_height; i++)
	    {
	      total_height =
		2 * inter_height + tag / blocks * multiplier +
		fixed_tracks_internal;
	      total_width =
		2 * inter_width + tag / (2 * blocks) * multiplier +
		fixed_tracks_internal;
	      inter_height = total_height;
	      inter_width = total_width;
	      multiplier = multiplier * 4;
	    }
	  total_width =
	    2 * inter_width + tag / (2 * blocks) * multiplier +
	    fixed_tracks_external;
	}
    }

  tagarray_area.width = total_width;
  tagarray_area.height = total_height;

  temp.height = tagarray_area.width;
  temp.width = tagarray_area.height;
  temp_aspect =
    ((temp.height / temp.width) >
     1.0) ? (temp.height / temp.width) : 1.0 / (temp.height / temp.width);
  aspect_ratio_tag =
    ((tagarray_area.height / tagarray_area.width) >
     1.0) ? (tagarray_area.height / tagarray_area.width) : 1.0 /
    (tagarray_area.height / tagarray_area.width);
  if (aspect_ratio_tag > temp_aspect)
    {
      tagarray_area.height = temp.height;
      tagarray_area.width = temp.width;
    }

  aspect_ratio_tag =
    ((tagarray_area.height / tagarray_area.width) >
     1.0) ? (tagarray_area.height / tagarray_area.width) : 1.0 /
    (tagarray_area.height / tagarray_area.width);

  return (tagarray_area);
}

void
area (int baddr,int b0,int Ndbl,int Ndwl,double Nspd,int Ntbl,int Ntwl,int Ntspd,double NSubbanks,parameter_type *parameters,
      arearesult_type *result)
{
  int rows_datasubarray;
  //v4.1. Making colns_datasubarray double datatype since it is dependent on Nspd 
  //which is double. Note that based on its usage below colns_datasubarray is a misnomer. 
  //colns_datasubarray is actually the degree of output muxing. 
  double colns_datasubarray;
  int rows_tagsubarray, colns_tagsubarray;

  rows_datasubarray =
    (parameters->cache_size /
     ((parameters->block_size) * (parameters->data_associativity) * Ndbl * Nspd));
  colns_datasubarray = (Ndbl * Nspd);
  rows_tagsubarray =
    (parameters->cache_size /
     ((parameters->block_size) * (parameters->tag_associativity) * Ntbl * Ntspd));
  colns_tagsubarray = (Ntbl * Ntspd);

  result->dataarray_area =
    dataarray (parameters->cache_size, parameters->block_size,
	       parameters->data_associativity, Ndbl, Ndwl, Nspd, b0,
	       parameters->num_readwrite_ports, parameters->num_read_ports,
	       parameters->num_write_ports,
	       parameters->num_single_ended_read_ports,
	       parameters->fudgefactor);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91蜜桃在线观看| 亚洲日本丝袜连裤袜办公室| 图片区小说区区亚洲影院| 在线亚洲一区二区| 一区二区三区在线观看视频| 99精品欧美一区二区三区综合在线| 国产精品美女一区二区三区| 成人av片在线观看| 樱花草国产18久久久久| 欧美精品99久久久**| 美国十次了思思久久精品导航| 精品国产免费视频| 成人午夜电影网站| 亚洲中国最大av网站| 日韩亚洲欧美一区| 国产精华液一区二区三区| 国产精品久久二区二区| 欧美色图12p| 激情六月婷婷综合| 亚洲乱码国产乱码精品精可以看| 欧美日韩精品三区| 国产99久久久国产精品潘金| 亚洲欧美日韩国产另类专区| 91精品国产综合久久久蜜臀图片| 国产尤物一区二区| 一区二区三区在线观看网站| 日韩欧美视频一区| 97精品久久久久中文字幕| 男人的j进女人的j一区| 国产精品系列在线| 制服.丝袜.亚洲.另类.中文| 国产激情一区二区三区四区| 一区二区三区在线视频观看58| 欧美va亚洲va香蕉在线| 99国产一区二区三精品乱码| 图片区小说区区亚洲影院| 久久久久久久免费视频了| 91成人在线免费观看| 国产一区二三区| 亚洲一线二线三线久久久| 精品少妇一区二区三区日产乱码 | 色噜噜夜夜夜综合网| 亚洲超碰97人人做人人爱| 国产亚洲一二三区| 欧美亚洲日本国产| eeuss鲁片一区二区三区| 亚洲成va人在线观看| 国产精品女同一区二区三区| 欧美久久久一区| 国产一区二区三区黄视频| 亚洲电影一区二区| 国产精品无遮挡| 日韩欧美亚洲国产另类| 欧美性大战xxxxx久久久| 国产一区999| 美脚の诱脚舐め脚责91| 一个色妞综合视频在线观看| 国产亚洲一区字幕| 欧美一二三四区在线| 欧美中文字幕一区| 成人激情免费电影网址| 国产伦精品一区二区三区视频青涩 | 国产一区二区视频在线播放| 亚洲动漫第一页| 亚洲欧美激情小说另类| 国产日韩欧美精品在线| 日韩欧美一区二区视频| 欧美在线短视频| 99精品国产91久久久久久| 午夜影院在线观看欧美| 亚洲欧洲成人精品av97| 欧美图片一区二区三区| av电影在线观看一区| 日韩精品五月天| 亚洲国产欧美一区二区三区丁香婷| 欧美日韩亚洲综合| 99久久99久久精品免费观看| 久久精工是国产品牌吗| 亚洲午夜羞羞片| 国产精品视频麻豆| 国产婷婷色一区二区三区| 日本一区二区视频在线观看| 51精品视频一区二区三区| 欧美综合一区二区| 色婷婷综合在线| 91精品办公室少妇高潮对白| 精品亚洲国产成人av制服丝袜| 五月开心婷婷久久| 亚洲aaa精品| 麻豆精品一区二区av白丝在线| 无码av免费一区二区三区试看| 丝袜美腿高跟呻吟高潮一区| 亚洲国产精品嫩草影院| 日本三级亚洲精品| 免费日本视频一区| 久久超碰97中文字幕| 蜜桃视频免费观看一区| 国产毛片精品视频| 国产91精品欧美| 日本福利一区二区| 欧美日韩专区在线| 日韩一区二区三区视频在线| 精品国产乱码久久久久久蜜臀| 国产亚洲精品bt天堂精选| 国产欧美日韩久久| 一区二区视频在线| 亚洲综合精品久久| 国产精品影音先锋| 国产高清在线观看免费不卡| 91麻豆国产福利在线观看| 日本道精品一区二区三区| 日韩欧美一级片| 国产无人区一区二区三区| 亚洲三级视频在线观看| 亚洲国产成人高清精品| 国产一区二区在线观看视频| 91久久精品日日躁夜夜躁欧美| 欧美一级高清大全免费观看| 亚洲精品在线三区| 亚洲在线视频免费观看| 蜜桃传媒麻豆第一区在线观看| 波多野结衣一区二区三区| 91黄色免费网站| 2020日本不卡一区二区视频| 中文字幕第一区| 日韩中文字幕91| 成人激情电影免费在线观看| 91精品国产综合久久香蕉的特点| 久久色视频免费观看| 夜夜夜精品看看| 九九九精品视频| 欧美高清精品3d| 国产日韩一级二级三级| 免费在线观看日韩欧美| 成人性视频网站| 精品欧美一区二区久久| 亚洲另类在线视频| 春色校园综合激情亚洲| 欧美蜜桃一区二区三区| 亚洲精品美腿丝袜| 国产综合久久久久影院| 6080午夜不卡| 亚洲美女精品一区| 成人h动漫精品一区二| 欧美日韩国产美女| 亚洲精品国产精品乱码不99| 韩国女主播成人在线| 欧美午夜精品久久久久久超碰| 国产精品欧美久久久久无广告 | 蜜臀精品一区二区三区在线观看| 国产精品一区二区黑丝| 精品国产一区二区三区久久久蜜月 | 91麻豆精品国产91久久久资源速度 | 日产国产高清一区二区三区 | 国产一区中文字幕| 日韩欧美一区二区三区在线| 亚洲欧洲一区二区三区| 国产91色综合久久免费分享| 日韩欧美电影在线| 麻豆精品在线看| 欧美最猛性xxxxx直播| 一区二区三区不卡在线观看 | 国产乱码精品一区二区三| 欧美高清性hdvideosex| 午夜精品国产更新| 91精品福利视频| 亚洲午夜久久久久久久久久久| 成人激情视频网站| 中文字幕日本乱码精品影院| 国产麻豆9l精品三级站| 国产亚洲欧美日韩在线一区| 久久99九九99精品| 国产日韩欧美综合一区| 日本vs亚洲vs韩国一区三区| 日韩一区和二区| 久久国内精品视频| 欧美电影免费观看高清完整版在线| 蜜桃av一区二区| 日韩欧美一二区| 成人免费黄色大片| 国产精品久久久爽爽爽麻豆色哟哟 | 欧美艳星brazzers| 亚洲综合自拍偷拍| 欧美精品电影在线播放| 亚洲一区在线观看免费| 91麻豆精品国产91久久久资源速度| 国产精品伦理一区二区| caoporn国产精品| 亚洲大片在线观看| 91精品国产综合久久香蕉的特点| 狠狠色综合日日| 欧美国产精品v| 欧美日韩午夜影院| 天天操天天综合网| 久久精品网站免费观看| 国产成人av资源| 亚洲成人av资源| 色婷婷综合久久久久中文| 日韩高清一区在线| 日韩视频在线一区二区|