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

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

?? xds510.cpp

?? TDS510USB2.0接口DSP仿真器.rar
?? 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一区二区三区免费野_久草精品视频
欧美日韩激情一区二区三区| 国产女人18毛片水真多成人如厕| 欧美电影免费观看高清完整版在| 国产精品天美传媒沈樵| 亚洲一区二区四区蜜桃| 国产精品99久久久久久有的能看 | 裸体健美xxxx欧美裸体表演| 不卡在线视频中文字幕| 日韩一区二区免费高清| 亚洲综合免费观看高清完整版| 国产一区二区电影| 91精品婷婷国产综合久久性色| 中文字幕一区二区三区蜜月| 狠狠色狠狠色合久久伊人| 欧美色图在线观看| 亚洲色图一区二区三区| 国产成人欧美日韩在线电影| 91精品国产品国语在线不卡| 亚洲一线二线三线久久久| 91欧美一区二区| 国产精品乱子久久久久| 国产乱码精品一区二区三区av| 欧美一区二区在线视频| 亚洲一二三四久久| 在线精品观看国产| 亚洲曰韩产成在线| 色www精品视频在线观看| 国产精品久久久久影院色老大| 国产一区二区三区视频在线播放| 欧美岛国在线观看| 日韩二区三区四区| 日韩一区二区在线免费观看| 日韩不卡一区二区三区| 欧美军同video69gay| 亚洲gay无套男同| 欧美三级三级三级| 午夜精品久久久久久久久久| 欧美美女直播网站| 日韩电影一区二区三区四区| 91麻豆精品国产综合久久久久久| 亚洲成人综合视频| 欧美一区永久视频免费观看| 麻豆成人免费电影| 久久久久久综合| 成人综合在线观看| 亚洲欧洲另类国产综合| 91无套直看片红桃| 亚洲午夜电影在线| 日韩一区二区三区视频| 国产一区亚洲一区| 亚洲欧洲成人精品av97| 在线视频一区二区免费| 视频一区中文字幕国产| 日韩一区二区三区在线观看| 国产成人亚洲精品青草天美| 国产精品久久久久影院色老大| 91麻豆文化传媒在线观看| 亚洲国产精品久久一线不卡| 日韩在线a电影| 成人免费观看男女羞羞视频| www.99精品| 中文子幕无线码一区tr| 日韩欧美国产一区二区三区| 色天天综合久久久久综合片| 在线看日韩精品电影| 中文字幕免费一区| 欧美r级在线观看| 国产日韩影视精品| 91啦中文在线观看| av在线一区二区| 亚洲五码中文字幕| 亚洲精品一区二区三区精华液| 国产精品一二三四区| 亚洲一区二区在线观看视频| 日韩欧美一区中文| 99精品偷自拍| 亚洲不卡av一区二区三区| 久久久午夜精品理论片中文字幕| 99精品视频在线免费观看| 免播放器亚洲一区| 亚洲码国产岛国毛片在线| 日韩精品一区二区在线观看| 色女孩综合影院| 国产精品综合一区二区| 日韩国产在线一| 亚洲美女偷拍久久| 国产色产综合色产在线视频| 欧美揉bbbbb揉bbbbb| 成人精品国产免费网站| 久久99热国产| 亚洲成年人网站在线观看| 国产精品青草久久| 欧美videossexotv100| 欧美日韩黄色一区二区| 91啪在线观看| 成人av网站在线| 国产精品综合av一区二区国产馆| 日韩av电影天堂| 亚洲国产成人va在线观看天堂| 国产精品久久毛片a| 久久精品亚洲乱码伦伦中文| 日韩欧美国产三级电影视频| 欧美日韩在线一区二区| 色婷婷国产精品久久包臀| 成人av电影在线网| 国产一区二区三区| 免费人成在线不卡| 蜜桃一区二区三区四区| 日韩va亚洲va欧美va久久| 亚洲成人资源网| 亚洲午夜国产一区99re久久| 一区二区免费在线播放| 亚洲影视资源网| 亚洲成人自拍一区| 日韩av电影免费观看高清完整版 | 成人国产精品免费网站| 国产制服丝袜一区| 国模无码大尺度一区二区三区| 蜜臀av性久久久久蜜臀aⅴ| 日本vs亚洲vs韩国一区三区二区| 婷婷夜色潮精品综合在线| 无码av中文一区二区三区桃花岛| 一区二区三区在线观看网站| 亚洲激情五月婷婷| 亚洲高清视频的网址| 天天射综合影视| 麻豆视频观看网址久久| 国产一区二三区| 成人国产亚洲欧美成人综合网| 成人av资源下载| 色天使久久综合网天天| 欧美群妇大交群中文字幕| 欧美疯狂性受xxxxx喷水图片| 7799精品视频| 久久久亚洲精品石原莉奈| 欧美国产亚洲另类动漫| 亚洲视频综合在线| 日韩在线一区二区| 丝袜亚洲另类欧美综合| 国内精品免费**视频| 成人午夜私人影院| 欧美偷拍一区二区| 欧美刺激脚交jootjob| 亚洲国产精品精华液2区45| 一区二区三区电影在线播| 日本美女视频一区二区| 国产一区二区电影| 欧美性极品少妇| 欧美精品一区在线观看| 亚洲日本丝袜连裤袜办公室| 日韩专区欧美专区| 国产盗摄视频一区二区三区| 一本在线高清不卡dvd| 日韩欧美在线123| 亚洲欧美日韩在线不卡| 久久精品免费观看| 不卡视频免费播放| 欧美一区二区三区视频在线| 久久久不卡网国产精品一区| 亚洲欧美日韩成人高清在线一区| 免费高清不卡av| 国产99久久久国产精品免费看| 欧美性色aⅴ视频一区日韩精品| 久久久不卡网国产精品二区| 亚洲狠狠爱一区二区三区| 成人免费毛片aaaaa**| 欧美一区二区三区系列电影| 亚洲另类一区二区| 国产精品香蕉一区二区三区| 欧美一区二区在线免费播放| 一区二区三区资源| 懂色av一区二区三区蜜臀| 7777精品伊人久久久大香线蕉超级流畅 | 欧美精品vⅰdeose4hd| 国产精品不卡在线观看| 麻豆一区二区三区| 欧美群妇大交群中文字幕| 综合亚洲深深色噜噜狠狠网站| 久久精品国产99国产精品| 欧美日韩一区久久| 亚洲视频一二区| 国产ts人妖一区二区| 久久婷婷成人综合色| 奇米888四色在线精品| 欧美日韩你懂得| 亚洲在线观看免费| 欧美性大战久久| 亚洲日本乱码在线观看| 91网站最新地址| 亚洲欧美自拍偷拍色图| 成人性生交大合| 国产欧美中文在线| 国产乱码字幕精品高清av| 久久久久久久免费视频了| 理论电影国产精品| 欧美变态tickling挠脚心| 日韩国产一二三区| 日韩一区二区中文字幕| 久久国产三级精品| 精品久久久久久久久久久久久久久 |