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

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

?? area.c.svn-base

?? 模擬多核狀態下龍芯處理器的功能
?? SVN-BASE
?? 第 1 頁 / 共 5 頁
字號:

  conservative_NSER = 0;

  //Added by Shyam to make area model sensitive to "change tag" feature

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

  noof_rows = (C / (B * A * Ntdbl * Ntspd));
  noof_colns = (Tagbits * A * Ntspd / Ntdwl);
  tagarea.height = ceil((double)(noof_rows)/16.0)*stitch_ramv+(BitHeight1x1+Widthtrack*2*(RWP+ERP+EWP-1))*noof_rows;
  tagarea.width  = noof_colns*(BitWidth1x1+(Widthtrack*2*(RWP+(ERP-conservative_NSER)+EWP-1)+Widthtrack*conservative_NSER));
  /*
  was:
  tagarea.height = ceil((double)(noof_rows)/16.0)*stitch_ramv+(BitHeight16x2+2*Widthtrack*2*(RWP+ERP+EWP-1))*ceil((double)(noof_rows)/2.0);
  tagarea.width = ceil((double)(noof_colns)/16.0)*(BitWidth16x2+16*(Widthtrack*2*(RWP+(ERP-conservative_NSER)+EWP-1)+Widthtrack*conservative_NSER));
  now:
  using single cell for width and height
  */

  //area_all_tagramcells =
    //Ntdwl * Ntdbl * calculate_area (tagarea,
				    //techscaling_factor) * CONVERT_TO_MMSQUARE;
  area_all_tagramcells =  Ntdwl * Ntdbl * tagarea.height *tagarea.width * CONVERT_TO_MMSQUARE;
  return (tagarea);
}

area_type
decodetag_row (int baddr,int C,int B,int A,int Ntdbl,int Ntspd,int Ntdwl,double NSubbanks,int RWP,int ERP,int EWP)	/* returns area of post decode */
{
  int numstack, Tagbits;
  double decodeNORwidth;
  area_type decinv, worddriveinv, postdecodearea;

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

  //v4.1: using integer casting below 
  //numstack =
    //ceil ((1.0 / 3.0) *
	  //logtwo_area ((double)
		       //((double) C / (double) (B * A * Ntdbl * Ntspd))));
  numstack =
    (int) (ceil ((1.0 / 3.0) *
	  logtwo_area ((double)
		       ((double) C / (double) (B * A * Ntdbl * Ntspd)))));
  if (numstack == 0)
    numstack = 1;
  if (numstack > 5)
    numstack = 5;
  switch (numstack)
    {
    case 1:
      decodeNORwidth = WidthNOR1;
      break;
    case 2:
      decodeNORwidth = WidthNOR2;
      break;
    case 3:
      decodeNORwidth = WidthNOR3;
      break;
    case 4:
      decodeNORwidth = WidthNOR4;
      break;
    case 5:
      decodeNORwidth = WidthNOR4;
      break;
    default:
      printf ("error:numstack=%d\n", numstack);
      printf ("Cacti does not support a series stack of %d transistors !\n",
	      numstack);
      exit (0);
      break;

    }
  decinv = inverter_area (Wdecinvp, Wdecinvn);
  worddriveinv = inverter_area (Wdecinvp, Wdecinvn);
  /*
  postdecodearea.height = (BitHeight16x2+2*Widthtrack*2*(RWP+ERP+EWP-1));
  */
  postdecodearea.height = (2*BitHeight1x1+2*Widthtrack*2*(RWP+ERP+EWP-1));
  postdecodearea.width =
    (decodeNORwidth + decinv.height + worddriveinv.height) * (RWP + ERP +
							      EWP);
  return (postdecodearea);
}

area_type
comparatorbit (int RWP,int ERP,int EWP)
{
  area_type compbit_area;
  compbit_area.width = 3 * Widthcontact + 2 * (3 * Wpoly + 2 * ptocontact);
  compbit_area.height = (Wcompn + 2 * (2 * Widthcontact + 1 / FUDGEFACTOR)) * (RWP + ERP);
  return (compbit_area);
}

area_type
muxdriverdecode (int B,int b0,int RWP,int ERP,int EWP)
{
  int noof_rows;
  area_type muxdrvdecode_area, predecode, postdecode;
  noof_rows = (8 * B) / b0;
  predecode = predecode_area (noof_rows, RWP, ERP, EWP);
  postdecode = postdecode_area (noof_rows, RWP, ERP, EWP);
  muxdrvdecode_area.width =
    predecode.height + postdecode.width + noof_rows * Widthtrack * (RWP +
								    ERP +
								    EWP);
  muxdrvdecode_area.height = MAX (predecode.width, postdecode.height);
  return (muxdrvdecode_area);
}

area_type
muxdrvsig (int A,int B,int b0)		/* generates the 8B/b0*A signals */
{
  int noof_rows;
  area_type outdrvsig_area;
  area_type muxdrvsig_area;
  noof_rows = (8 * B) / b0;
  //debug
  muxdrvsig_area.height = 0;
  muxdrvsig_area.width = 0;

  outdrvsig_area.height =
    0.5 * (WmuxdrvNORn + WmuxdrvNORp) + 9 * Widthcontact + 0.5 * (Wmuxdrv3n +
								  Wmuxdrv3p) +
    Widthptondiff + 3 * Widthcontact; 
  outdrvsig_area.width =
    (3 * Widthcontact + 2 * (3 * Wpoly + 2 * ptocontact)) * noof_rows;
  switch (A)
    {
    case 1:
      muxdrvsig_area.height =
	outdrvsig_area.height + noof_rows * Widthtrack * 2 + A * Widthtrack;
      muxdrvsig_area.width =
	outdrvsig_area.width + noof_rows * Widthtrack + A * Widthtrack;
      break;
    case 2:
      muxdrvsig_area.height =
	outdrvsig_area.height * 2 + noof_rows * Widthtrack * 3 +
	A * Widthtrack;
      muxdrvsig_area.width =
	outdrvsig_area.width + noof_rows * Widthtrack + A * Widthtrack;
      break;
    case 4:
      muxdrvsig_area.height =
	outdrvsig_area.height * 2 + noof_rows * Widthtrack * 5 +
	A * Widthtrack;
      muxdrvsig_area.width =
	outdrvsig_area.width * 2 + noof_rows * Widthtrack + A * Widthtrack;
      break;
    case 8:
      muxdrvsig_area.height =
	outdrvsig_area.height * 2 + noof_rows * Widthtrack * 9 +
	A * Widthtrack;
      muxdrvsig_area.width =
	outdrvsig_area.width * 4 + noof_rows * Widthtrack + A * Widthtrack;
      break;
    case 16:
      muxdrvsig_area.height =
	outdrvsig_area.height * 4 + noof_rows * Widthtrack * 18 +
	A * Widthtrack;
      muxdrvsig_area.width =
	outdrvsig_area.width * 4 + noof_rows * Widthtrack + A * Widthtrack;
      break;
    case 32:
      muxdrvsig_area.height =
	outdrvsig_area.height * 4 + noof_rows * Widthtrack * 35 +
	2 * A * Widthtrack;
      muxdrvsig_area.width =
	2 * (outdrvsig_area.width * 4 + noof_rows * Widthtrack +
	     A * Widthtrack);
      break;
    default:
      printf ("error:Associativity=%d\n", A);
    }

  return (muxdrvsig_area);
}


area_type
datasubarray (int C,int B,int A,int Ndbl,int Ndwl,double Nspd,int RWP,int ERP,int EWP,int NSER,
	      double techscaling_factor)
{

  //area_type datasubarray_area, mem_area, postdecode_area, colmux_area,
    //precharge_area, senseamp_area, outdrv_area;
  area_type datasubarray_area, mem_area, postdecode_area, colmux_area,
    precharge_area, senseamp_area;
  mem_area =
    subarraymem_area (C, B, A, Ndbl, Ndwl, Nspd, RWP, ERP, EWP, NSER,
		      techscaling_factor);
  postdecode_area = decodemem_row (C, B, A, Ndbl, Nspd, Ndwl, RWP, ERP, EWP);
  colmux_area = colmux (Ndbl, Nspd, RWP, ERP, EWP, NSER);
  precharge_area = precharge (Ndbl, Nspd, RWP, ERP, EWP, NSER);
  senseamp_area = senseamp (Ndbl, Nspd, RWP, ERP, EWP, NSER);
  datasubarray_area.height =
    mem_area.height + colmux_area.height + precharge_area.height +
    senseamp_area.height + DatainvHeight * (RWP + EWP) +
    OutdriveHeight * (RWP + ERP);
  datasubarray_area.width = mem_area.width + postdecode_area.width;

  return (datasubarray_area);
}

area_type
datasubblock (int C,int B,int A,int Ndbl,int Ndwl,double Nspd,int SB,int b0,int RWP,int ERP,int EWP,int NSER,
	      double techscaling_factor)
{
  int N3to8;
  int colmuxtracks_rem, outrdrvtracks_rem, writeseltracks_rem;
  int SB_;
  double tracks_h, tracks_w;
  area_type datasubarray_area, datasubblock_area;
  SB_ = SB;
  if (SB_ == 0)
    {
      SB_ = 1;
    }
  colmuxtracks_rem =
    (Ndbl * Nspd >
     tracks_precharge_p) ? (Ndbl * Nspd - tracks_precharge_p) : 0;
  outrdrvtracks_rem =
    ((2 * B * A) / (b0) >
     tracks_outdrvselinv_p) ? ((2 * B * A) / (b0) -
			       tracks_outdrvselinv_p) : 0;
  writeseltracks_rem =
    ((2 * B * A) / (b0) >
     tracks_precharge_nx2) ? ((2 * B * A) / (b0) - tracks_precharge_nx2) : 0;
 //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;
    }

  tracks_h =
    Widthtrack * (N3to8 * 8 * (RWP + ERP + EWP) +
		  (RWP + EWP) * colmuxtracks_rem + Ndbl * Nspd * ERP +
		  4 * outrdrvtracks_rem * (RWP + ERP) +
		  4 * writeseltracks_rem * (RWP + EWP) + (RWP + ERP +
							  EWP) * b0 / SB_);
  tracks_w = Widthtrack * (N3to8 * 8) * (RWP + ERP + EWP);
  datasubarray_area =
    datasubarray (C, B, A, Ndbl, Ndwl, Nspd, RWP, ERP, EWP, NSER,
		  techscaling_factor);
  datasubblock_area.height = 2 * datasubarray_area.height + tracks_h;
  datasubblock_area.width = 2 * datasubarray_area.width + tracks_w;

  return (datasubblock_area);
}

area_type
dataarray (int C,int B,int A,int Ndbl,int Ndwl,double Nspd,int b0,int RWP,int ERP,int EWP,int NSER,
	   double techscaling_factor)
{
  int SB, N3to8;
  area_type dataarray_area, datasubarray_area, datasubblock_area;
  area_type temp;
  double temp_aspect;
  double fixed_tracks_internal, fixed_tracks_external, variable_tracks;
  double data, driver_select, colmux, predecode, addresslines;
  int blocks, htree, htree_half, i, multiplier, iter_height;
  double inter_height, inter_width, total_height, total_width;

  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;
    }

  data = b0 * (RWP + ERP + EWP) * Widthtrack;
  driver_select = (2 * RWP + ERP + EWP) * 8 * B * A / b0 * Widthtrack;
  colmux = Ndbl * Nspd * (RWP + EWP + ERP) * Widthtrack;
  predecode = (RWP + ERP + EWP) * N3to8 * 8 * Widthtrack;
  addresslines = ADDRESS_BITS * (RWP + ERP + EWP) * Widthtrack;

  fixed_tracks_internal = colmux + predecode + driver_select;
  fixed_tracks_external = colmux + driver_select + addresslines;
  variable_tracks = data;

  datasubarray_area =
    datasubarray (C, B, A, Ndbl, Ndwl, Nspd, RWP, ERP, EWP, NSER,
		  techscaling_factor);
  datasubblock_area =
    datasubblock (C, B, A, Ndbl, Ndwl, Nspd, SB, b0, RWP, ERP, EWP, NSER,
		  techscaling_factor);
  //area_all_datasubarrays =
    //Ndbl * Ndwl * calculate_area (datasubarray_area,
				  //techscaling_factor) * CONVERT_TO_MMSQUARE;
  area_all_datasubarrays = Ndbl * Ndwl * datasubarray_area.height * datasubarray_area.width * CONVERT_TO_MMSQUARE;


  if (SB == 0)
    {
      if (Ndbl * Ndwl == 1)
	{
	  total_height =
	    datasubarray_area.height + fixed_tracks_external + data;
	  total_width = datasubarray_area.width + predecode;
	}
      else
	{
	  total_height =
	    2 * datasubarray_area.height + fixed_tracks_external + data;
	  total_width = datasubarray_area.width + predecode;
	}
    }
  else if (SB == 1)
    {
      total_height = datasubblock_area.height;
      total_width = datasubblock_area.width;
    }
  else if (SB == 2)
    {
      total_height = datasubblock_area.height;
      total_width =
	2 * datasubblock_area.width + fixed_tracks_external + data;
    }
  else if (SB == 4)
    {
      total_height =
	2 * datasubblock_area.height + fixed_tracks_external + data;
      total_width =
	2 * datasubblock_area.width + fixed_tracks_internal +
	variable_tracks / 2;
    }
  else if (SB == 8)
    {
      total_height =
	2 * datasubblock_area.height + fixed_tracks_internal +
	variable_tracks / 2;
      total_width =
	2 * (2 * datasubblock_area.width + variable_tracks / 4) +
	fixed_tracks_external + data;
    }

  else 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 = datasubblock_area.height;
      inter_width = datasubblock_area.width;
      multiplier = 1;

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

      if (htree % 2 == 0)
	{
	  for (i = 0; i <= iter_height; i++)
	    {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩一区二区三区四区五区六区| 国产精品情趣视频| 国产欧美日韩久久| 亚洲va韩国va欧美va精品| 国产91富婆露脸刺激对白| 欧美xxxxxxxxx| 亚洲成人免费观看| 91麻豆6部合集magnet| 国产视频一区二区在线观看| 蜜乳av一区二区三区| 欧美性感一区二区三区| 国产精品嫩草99a| 狠狠色丁香婷综合久久| 91精品在线免费观看| 亚洲欧美国产77777| 成人性生交大合| 国产亚洲人成网站| 久久se精品一区精品二区| 91精品婷婷国产综合久久性色| 一区二区三区在线高清| 成人高清视频在线| 国产精品理论片| 福利一区二区在线| 国产欧美日韩久久| 国产成人免费在线观看| 2021国产精品久久精品| 精一区二区三区| 日韩美女一区二区三区四区| 久久国产精品99久久久久久老狼| 欧美日韩精品专区| 亚洲18色成人| 欧美挠脚心视频网站| 午夜久久福利影院| 欧美日韩国产高清一区| 视频一区中文字幕国产| 欧美一区二区播放| 久久69国产一区二区蜜臀| 日韩色视频在线观看| 精一区二区三区| 久久久久久久久久久久久夜| 国产一区福利在线| 欧美高清在线视频| 99久久精品免费看国产免费软件| 亚洲三级视频在线观看| 色哦色哦哦色天天综合| 亚洲一区二区三区四区的| 欧美日产国产精品| 国产在线视频不卡二| 欧美激情在线看| 一本大道久久a久久精二百| 久久99久久久久久久久久久| 久久嫩草精品久久久精品| 成人av网站在线| 亚洲午夜国产一区99re久久| 欧美人体做爰大胆视频| 国内精品视频666| 国产精品另类一区| 欧美日韩精品一区二区三区| 激情另类小说区图片区视频区| 国产精品美日韩| 欧美丰满一区二区免费视频| 国产乱人伦偷精品视频免下载 | 欧美一区二区性放荡片| 精彩视频一区二区| 成人免费小视频| 在线播放日韩导航| 国产成人精品亚洲午夜麻豆| 亚洲曰韩产成在线| 久久久精品国产免大香伊| 99国产精品久久久久| 三级一区在线视频先锋 | 日韩欧美综合一区| 成人av网站免费| 日韩国产一二三区| 国产精品久久久久影院| 欧美一级免费大片| 91小视频免费观看| 激情小说欧美图片| 国产**成人网毛片九色| 亚洲第一会所有码转帖| 国产精品女主播在线观看| 这里只有精品99re| 91浏览器打开| 风间由美性色一区二区三区| 奇米色777欧美一区二区| 亚洲欧洲国产专区| 久久久亚洲午夜电影| 欧美人牲a欧美精品| 91在线视频网址| 国产精品99精品久久免费| 免费看日韩精品| 亚洲国产日产av| 亚洲免费观看高清在线观看| 欧美激情在线一区二区三区| 欧美成人女星排行榜| 欧美日韩黄色影视| 欧美性色欧美a在线播放| 成人黄色国产精品网站大全在线免费观看 | 亚洲国产成人私人影院tom| 91精品国产日韩91久久久久久| 日本精品一区二区三区四区的功能| 国产盗摄精品一区二区三区在线| 久久国产精品72免费观看| 青青草精品视频| 日韩av一区二区三区四区| 亚洲午夜一区二区| 亚洲国产精品麻豆| 一区二区三区日韩欧美精品| 一色屋精品亚洲香蕉网站| 国产欧美日本一区二区三区| 国产日韩欧美激情| 久久蜜桃av一区二区天堂| 26uuu亚洲| 国产亚洲精久久久久久| 久久精品视频一区二区| 久久久久久麻豆| 久久精品免视看| 国产精品污网站| 中文字幕一区二区三区色视频 | 99久久99久久精品免费观看| www.亚洲国产| 91免费版在线| 在线观看一区二区视频| 欧美性淫爽ww久久久久无| 欧美日韩大陆一区二区| 制服丝袜中文字幕一区| 日韩欧美亚洲国产精品字幕久久久| 欧美成人a视频| 国产亚洲欧美色| 一区二区三区小说| 亚洲123区在线观看| 久久国产婷婷国产香蕉| 国产精品资源在线| a级高清视频欧美日韩| 欧美亚洲国产一区在线观看网站 | 久久久蜜桃精品| 国产精品美女一区二区| 亚洲黄一区二区三区| 日韩av中文在线观看| 久久99国产精品成人| 99精品视频在线播放观看| 欧美人伦禁忌dvd放荡欲情| 欧美精品一区二| ㊣最新国产の精品bt伙计久久| 五月天一区二区| 国产精品99久久久久久久女警| 91麻豆高清视频| 精品国产第一区二区三区观看体验 | 视频一区视频二区在线观看| 国产精品资源在线看| 欧美影院午夜播放| 久久综合九色综合97婷婷| 亚洲欧美激情插 | 捆绑调教一区二区三区| 国产成人夜色高潮福利影视| 在线精品视频一区二区| 久久久久一区二区三区四区| 亚洲伦理在线精品| 国产精品一区二区你懂的| 欧美日韩国产片| 国产精品每日更新在线播放网址| 三级久久三级久久| 91视视频在线直接观看在线看网页在线看| 欧美日韩一区二区三区在线| 国产精品视频一二| 裸体一区二区三区| 91九色02白丝porn| 亚洲国产成人一区二区三区| 狂野欧美性猛交blacked| 欧美婷婷六月丁香综合色| 中文字幕亚洲一区二区va在线| 精久久久久久久久久久| 欧美日本一区二区在线观看| 亚洲同性gay激情无套| 国产成人午夜视频| 欧美r级电影在线观看| 五月婷婷综合网| 欧美亚洲综合久久| 亚洲精品网站在线观看| 成人av网在线| 国产精品免费视频一区| 国内精品伊人久久久久av一坑| 91精品国产综合久久香蕉麻豆 | 国模套图日韩精品一区二区| 欧美日本免费一区二区三区| 亚洲乱码国产乱码精品精小说| 成人午夜av在线| 国产日韩精品一区二区浪潮av| 免播放器亚洲一区| 在线不卡一区二区| 五月天一区二区三区| 欧洲亚洲精品在线| 亚洲一区二区美女| 欧美性大战xxxxx久久久| 亚洲一卡二卡三卡四卡| 欧洲精品一区二区| 五月天中文字幕一区二区| 欧美欧美欧美欧美| 日本vs亚洲vs韩国一区三区二区 | 国产成人综合在线观看|