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

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

?? xds510.cpp

?? dsp 仿真器制作 希望對想研究jtag仿真器的朋友有幫助
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
/*
 * xds510 simulator for Wine
 * Copyright (c) 2001 Blaise Gassend (blaise.gassend@m4x.org)
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License
 * as published by the Free Software Foundation; either version 2
 * of the License, or (at your option) any later version. This program is
 * distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details. You should have received a
 * copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307,
 * USA.
 * */

// This code assumes at least 32-bit ints as does wine.

#define PAR_ADDR (0x378)

#include <stdio.h>

#include "xds510.h"
#include "xds510_io.h"
#ifndef _WINDOWS
#include "debugtools.h"
#else
#include "..\stdafx.h"
#define MESSAGE TRACE
#define WARN TRACE
#define FIXME TRACE
#define DECLARE_DEBUG_CHANNEL(X)
#define DEFAULT_DEBUG_CHANNEL(X)

int state_id(int s)
{
    s &= 0x7;
    if (s < 4) 
		return s / 2;
    else 
		return s - 2;
}

#endif

DECLARE_DEBUG_CHANNEL(xds510);
DEFAULT_DEBUG_CHANNEL(xds510);

#define BTAB "\t\t\t\t"
 
#define INTERFACE_VERSION (6)
static int interface_interrupt;
//static int read800;
static int interface_reset;
static int counter1;
static int counter1_update;
static int counter1_capture;
static int active_command;

#define NUM_LOW_REGISTERS (0xC)
#define NUM_STATUS_REGISTERS (4)
static int low_register_val[NUM_LOW_REGISTERS];
static int status_register[NUM_STATUS_REGISTERS];

static int fifo_buffer;
static unsigned int read_buffer;
static int read_buffer_pos;
static unsigned int write_buffer;
static int write_buffer_pos;

#define TAP_TEST_LOGIC_RESET (0)
#define TAP_RUN_TEST_IDLE (2)
#define TAP_SHIFT_DR (4)
#define TAP_SHIFT_IR (5)
#define TAP_PAUSE_DR (6)
#define TAP_PAUSE_IR (7)

static int tap_state;

//static FILE *debugf; // ####
//static int outdata, indata, indatap, outdatap, databitsp;

int get_outbit()
{
  int outbit;
  
  switch (low_register_val[4] & 0x0300)
  {
    default:
    case 0x0000:
      outbit = 0;
      break;
      
    case 0x0100:
      outbit = 1;
      break;
      
    case 0x0200:
      outbit = fifo_buffer & 1;
      break;

    case 0x0300:
      outbit = write_buffer & 1;
      break;
  }
  
  return outbit;
}

/*static void tap_log(int tms, int tdo, int tdi)
{
  void printbuff(unsigned char *buff, int len)
  {
    int i;
    int bytes = len / 8;
    int bits = len % 8;
    int mask = 1 << bits;
    
    for (i = 0; i < bytes; i++)
    {
      fprintf(debugf, "%02x", (int) buff[i]);
    }

    if (bits > 0)
    {
      buff[bytes] &= mask - 1;
      fprintf(debugf, "%0*x", (bits + 3) / 4, buff[bytes]);
    }
  }
  
  static unsigned char inbuff[256];
  static unsigned char outbuff[256];
  static int buffp = 0;
  static int state = 0; // 0 reset, 1 run, then DR top to bot, ir top to bot.
  static int trans[2][16] = 
  { { 1, 1, 3, 4, 4, 6, 6, 4, 1, 10, 11, 11, 13, 13, 11, 1 },
    { 0, 2, 9, 5, 5, 8, 7, 8, 2, 0, 12, 12, 15, 14, 15, 2 } };

  if (state == 4 || state == 11) // Shifting
  {
    int byte = buffp / 8;
    int bit = buffp % 8;
    int mask = 1 << bit;
    if (buffp < 2048)
    {
      inbuff[byte] = (inbuff[byte] & (mask - 1)) | (tdi ? mask : 0);
      outbuff[byte] = (outbuff[byte] & (mask - 1)) | (tdo ? mask : 0);
      buffp++;
    }
  }
  
  state = trans[tms][state & 0xF];

  switch (state)
  {
    case 0: // reset
      fputs("RESET ", debugf);
      break;

    case 1: // run
      fputs("RUN ", debugf);
      break;

    case 8: // update dr
      fprintf(debugf, "\n              DRU %i ", buffp);
      printbuff(outbuff, buffp);
      fputs(" -> ", debugf);
      printbuff(inbuff, buffp);
      fputc(' ', debugf);
      fflush(debugf);
      buffp = 0;
      break;
       
    case 15: // update ir
      fprintf(debugf, "\nIRU %i ", buffp - 16);
      printbuff(outbuff + 2, buffp - 16);
      fputs(" -> ", debugf);
      printbuff(inbuff, buffp - 16);
      fputc(' ', debugf);
      fflush(debugf);
      buffp = 0;
      break;
  }
}
*/
static int io_cycle(int tms)
{
  int tdo = get_outbit();
  int tdi = xds510_io_write_cycle(tdo, tms);

//  tap_log(tms, tdo, tdi);
  
  return tdi;
}

static void XDS510_reset()
{
  int i;
  
  TRACE("XDS510_reset\n");

  counter1 = 0;
  counter1_update = 0;
  counter1_capture = 0;
  interface_interrupt = 0;
//  read800 = 0;
  active_command = 0;
  
  fifo_buffer = 0xFFFFFFFF;
  read_buffer = 0;
  read_buffer_pos = 0;
  write_buffer = 0;
  write_buffer_pos = 0;

/*  for (i = 0; i < 6; i++)
  {
    io_cycle(1); 
  }
  io_cycle(0); */
  tap_state = TAP_TEST_LOGIC_RESET;
  
  for (i = 0; i < NUM_LOW_REGISTERS; i++)
    low_register_val[i] = 0;    
  
  for (i = 0; i < NUM_STATUS_REGISTERS; i++)
    status_register[i] = 0;    

  TRACE("returning\n\n");
}

void XDS510_init()
{
  TRACE("XDS510_init\n");
  
  if (xds510_io_init(PAR_ADDR))
  {
    MESSAGE("\n\n***** Root privileges necessary to access XDS510.\n\n");
  }
  else
  {
    MESSAGE("\n\n***** XDS510 on port 0x%03x.\n\n", PAR_ADDR);
  }
  
//  if (debugf == NULL)
//    debugf = /*stderr; /*/fopen("debug.txt", "w");
  
  xds510_io_write_trst(0);
  io_cycle(1);
  xds510_io_write_trst(1);
  io_cycle(1);
  
  XDS510_reset();
}

static void go_tap_state(int state)
{
  // The order is RESET, RUN, S-DR, S-IR, P-DR, P-IR
  
  static const char *transitions[6][6] = { // [from][to]
    { "11111", "0",   "0100",  "01100",  "01010",  "011010"  },
    { "11111", "0",   "100",   "1100",   "1010",   "11010"   },
    { "11111", "110", "0",     "111100", "10",     "1111010" },
    { "11111", "110", "11100", "0",      "111010", "10"      },
    { "11111", "110", "10",    "111100", "0",      "1111010" },
    { "11111", "110", "11100", "10",     "111010", "0"    }  };
  int i;

#ifndef _WINDOWS
  int state_id(int s)
  {
    s &= 0x7;
    if (s < 4) 
      return s / 2;
    else 
      return s - 2;
  }
#endif

  const char *trans = transitions[state_id(tap_state)][state_id(state)];
  
//  printf("Goto Tap %i From %i\n", state, tap_state);
  
  while (*trans)
  {
    io_cycle(*trans - '0');
    trans++;
  }

  if ((state & 0x6) == 2)
    for (i = 0; i < 10; i++)
      io_cycle(0);  

  tap_state = state & 0x7;
}

static void go_tap_state2(int state)
{
  // The order is RESET, RUN, S-DR, S-IR, P-DR, P-IR
  
  static const char *transitions[6][6] = { // [from][to]
    { "11111", "0",   "0100",  "01100",  "01010",  "011010"  },
    { "11111", "0",   "100",   "1100",   "1010",   "11010"   },
    { "11111", "110", "0",     "111100", "10",     "1111010" },
    { "11111", "110", "11100", "0",      "111010", "10"      },
    { "11111", "110", "10",    "111100", "111010", "1111010" },
    { "11111", "110", "11100", "10",     "111010", "1111010" }  };
  int i;

#ifndef _WINDOWS  
  int state_id(int s)
  {
    s &= 0x7;
    if (s < 4) 
      return s / 2;
    else 
      return s - 2;
  }
#endif

  const char *trans = transitions[state_id(tap_state)][state_id(state)];
  
//  printf("Goto Tap 2 %i From %i\n", state, tap_state);
  
  while (*trans)
  {
    io_cycle(*trans - '0');
    trans++;
  }

  if ((state & 0x6) == 2)
    for (i = 0; i < 10; i++)
      io_cycle(0);  

  tap_state = state & 0x7;
}

static void minor_command(int value)
{

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
青青草成人在线观看| 国产精品全国免费观看高清| 另类综合日韩欧美亚洲| 日韩午夜激情电影| 国产成人综合在线观看| 最好看的中文字幕久久| 欧美肥胖老妇做爰| 国精产品一区一区三区mba桃花 | 亚洲成人自拍偷拍| 91精品国产麻豆国产自产在线 | 国产在线观看一区二区| 欧美激情中文字幕一区二区| 色综合久久综合网欧美综合网| 亚洲国产婷婷综合在线精品| 国产精品久久久久三级| 日韩欧美国产综合一区| 在线视频中文字幕一区二区| 丁香激情综合国产| 久久97超碰国产精品超碰| 视频一区中文字幕| 亚洲影院理伦片| 亚洲日本在线视频观看| 国产精品入口麻豆九色| 国产日韩欧美精品在线| 精品国产乱码久久久久久牛牛 | 一区二区三区在线影院| 国产精品青草久久| 国产欧美日韩视频在线观看| 久久综合狠狠综合久久综合88| 日韩一区二区三区免费观看| 欧美日韩dvd在线观看| 欧美三级中文字幕在线观看| 欧美视频中文一区二区三区在线观看| 日本韩国一区二区三区| 欧美人伦禁忌dvd放荡欲情| 欧美揉bbbbb揉bbbbb| 日韩欧美激情四射| 欧美变态tickle挠乳网站| 精品区一区二区| 国产精品欧美极品| 亚洲一区二区综合| 日本aⅴ免费视频一区二区三区| 蜜桃精品视频在线观看| 国产伦理精品不卡| 91激情五月电影| 精品日产卡一卡二卡麻豆| 久久精品欧美日韩精品| 樱花草国产18久久久久| 无码av免费一区二区三区试看 | 欧美精品亚洲二区| 精品嫩草影院久久| 一区二区三区四区视频精品免费 | 欧美日韩精品一区二区天天拍小说| 欧美蜜桃一区二区三区| 国产色爱av资源综合区| 亚洲精品成人在线| 懂色av一区二区三区蜜臀| 在线看日本不卡| 国产精品久久久久四虎| 老司机免费视频一区二区| 99精品视频在线观看| 久久免费美女视频| 性做久久久久久| 91影院在线免费观看| 国产亚洲精品超碰| 美女视频黄久久| 精品视频1区2区| 亚洲午夜私人影院| 色视频一区二区| 亚洲日本va在线观看| 国产成人欧美日韩在线电影| 日韩一区二区三区在线视频| 亚洲激情校园春色| 色吊一区二区三区| 亚洲精选一二三| 在线观看亚洲精品| 亚洲成人福利片| 欧美日韩欧美一区二区| 午夜精品爽啪视频| 555www色欧美视频| 久久综合综合久久综合| 这里是久久伊人| 美女mm1313爽爽久久久蜜臀| 555www色欧美视频| 乱一区二区av| 久久嫩草精品久久久精品一| 国产一区激情在线| 久久久久久免费| 一本色道综合亚洲| 日韩国产在线观看| 久久精品亚洲一区二区三区浴池| 精品一区二区在线看| 国产欧美综合色| 欧美日韩国产精品成人| 欧美视频日韩视频| 26uuu亚洲婷婷狠狠天堂| 婷婷综合久久一区二区三区| 91精品国产一区二区三区| 蜜桃视频在线一区| 国产欧美日韩亚州综合| 欧美性生活大片视频| 蜜臀精品久久久久久蜜臀| 国产三级一区二区三区| 欧美影片第一页| 国产成人午夜视频| 夜夜嗨av一区二区三区中文字幕| 精品国精品国产尤物美女| 91丨porny丨国产入口| 蜜臀久久久久久久| 亚洲男同性恋视频| 国产清纯白嫩初高生在线观看91| 欧美日韩在线免费视频| 成人久久18免费网站麻豆| 奇米综合一区二区三区精品视频| 成人免费在线视频观看| 精品国产乱码91久久久久久网站| 色系网站成人免费| 福利一区二区在线| 国产在线精品一区二区不卡了| 亚洲一区二区三区四区的 | 亚洲一区精品在线| 1024国产精品| 国产视频一区二区三区在线观看| 欧美一区二区三区的| 51久久夜色精品国产麻豆| 色综合久久天天| 欧美日韩一区三区| 国产成人8x视频一区二区| 国产一区二区在线观看视频| 日韩av电影免费观看高清完整版在线观看 | 国产a久久麻豆| 国产精品99久久久久久久女警| 蜜桃精品视频在线| 日本在线不卡视频一二三区| 亚洲成av人影院| 日精品一区二区| 免费欧美高清视频| 免费亚洲电影在线| 国内精品伊人久久久久av影院 | 成人美女视频在线看| av不卡在线播放| 欧美日韩中文字幕一区| 欧美日韩国产三级| 欧美一区二区精品| 国产日韩欧美一区二区三区综合| 久久亚洲一级片| 国产精品成人网| 亚洲成a人v欧美综合天堂下载| 麻豆91精品视频| 99在线视频精品| 日韩亚洲欧美成人一区| 国产精品你懂的在线| 亚洲午夜久久久久久久久电影网 | 日本一道高清亚洲日美韩| 国产一区二区美女诱惑| 在线观看欧美黄色| 精品国产免费人成电影在线观看四季 | 亚洲欧美激情视频在线观看一区二区三区 | 最新久久zyz资源站| 日本大胆欧美人术艺术动态| 成人小视频免费在线观看| 欧美日韩国产成人在线91| 国产午夜精品理论片a级大结局| 亚洲资源在线观看| 国产福利一区二区三区视频在线| 欧美特级限制片免费在线观看| 久久综合视频网| 肉色丝袜一区二区| 色婷婷久久久久swag精品| 国产亚洲欧美日韩在线一区| 日韩国产精品大片| 欧美三级电影网| 综合激情成人伊人| av激情亚洲男人天堂| 久久久精品一品道一区| 另类欧美日韩国产在线| 欧美一激情一区二区三区| 亚洲最色的网站| 在线视频一区二区三| 一二三区精品视频| 色素色在线综合| 一区二区国产视频| 99久久er热在这里只有精品15 | 国产91富婆露脸刺激对白| 26uuu亚洲综合色| 国产精品亚洲一区二区三区妖精| 日韩精品一区二区三区在线观看| 日韩电影在线一区二区| 欧美一级二级在线观看| 狠狠色2019综合网| 久久久亚洲午夜电影| 成人教育av在线| 亚洲乱码国产乱码精品精小说| 欧美在线一二三四区| 五月婷婷综合在线| 久久久综合视频| www.亚洲免费av| 五月天精品一区二区三区| 91精品在线观看入口| 国产一区二区三区四区五区入口|