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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? usrp_primes.cc

?? 嵌入式開發(fā)板USB測試
?? CC
?? 第 1 頁 / 共 3 頁
字號:
  return r; 
} 
 
// ---------------------------------------------------------------- 
// load fpga 
 
static bool 
_usrp_load_fpga (struct usb_dev_handle *udh, const char *filename, 
                 unsigned char hash[USRP_HASH_SIZE]) 
{ 
  bool ok = true; 
 
  FILE  *fp = fopen (filename, "rb"); 
  if (fp == 0){ 
    perror (filename); 
    return false; 
  } 
 
  unsigned char buf[MAX_EP0_PKTSIZE];   // 64 is max size of EP0 packet on FX2 
  int n; 
 
  usrp_set_led (udh, 1, 1);             // led 1 on 
 
 
  // reset FPGA (and on rev1 both AD9862's, thus killing clock) 
  usrp_set_fpga_reset (udh, 1);         // hold fpga in reset 
 
  if (write_cmd (udh, VRQ_FPGA_LOAD, 0, FL_BEGIN, 0, 0) != 0) 
    goto fail; 
   
  while ((n = fread (buf, 1, sizeof (buf), fp)) > 0){ 
    if (write_cmd (udh, VRQ_FPGA_LOAD, 0, FL_XFER, buf, n) != n) 
      goto fail; 
  } 
 
  if (write_cmd (udh, VRQ_FPGA_LOAD, 0, FL_END, 0, 0) != 0) 
    goto fail; 
   
  fclose (fp); 
 
  if (!usrp_set_hash (udh, FPGA_HASH_SLOT, hash)) 
    fprintf (stderr, "usrp: failed to write fpga hash slot\n"); 
 
  // On the rev1 USRP, the {tx,rx}_{enable,reset} bits are 
  // controlled over the serial bus, and hence aren't observed until 
  // we've got a good fpga bitstream loaded. 
 
  usrp_set_fpga_reset (udh, 0);         // fpga out of master reset 
 
  // now these commands will work 
   
  ok &= usrp_set_fpga_tx_enable (udh, 0); 
  ok &= usrp_set_fpga_rx_enable (udh, 0); 
 
  ok &= usrp_set_fpga_tx_reset (udh, 1);        // reset tx and rx paths 
  ok &= usrp_set_fpga_rx_reset (udh, 1); 
  ok &= usrp_set_fpga_tx_reset (udh, 0);        // reset tx and rx paths 
  ok &= usrp_set_fpga_rx_reset (udh, 0); 
 
  if (!ok) 
    fprintf (stderr, "usrp: failed to reset tx and/or rx path\n"); 
 
  // Manually reset all regs except master control to zero. 
  // FIXME may want to remove this when we rework FPGA reset strategy. 
  // In the mean while, this gets us reproducible behavior. 
  for (int i = 0; i < FR_USER_0; i++){ 
    if (i == FR_MASTER_CTRL) 
      continue; 
    usrp_write_fpga_reg(udh, i, 0); 
  } 
 
  power_down_9862s (udh);               // on the rev1, power these down! 
  usrp_set_led (udh, 1, 0);             // led 1 off 
 
  return true; 
 
 fail: 
  power_down_9862s (udh);               // on the rev1, power these down! 
  fclose (fp); 
  return false; 
} 
 
// ---------------------------------------------------------------- 
 
bool  
usrp_set_led (struct usb_dev_handle *udh, int which, bool on) 
{ 
  int r = write_cmd (udh, VRQ_SET_LED, on, which, 0, 0); 
 
  return r == 0; 
} 
 
bool 
usrp_set_hash (struct usb_dev_handle *udh, int which, 
               const unsigned char hash[USRP_HASH_SIZE]) 
{ 
  which &= 1; 
   
  // we use the Cypress firmware down load command to jam it in. 
  int r = usb_control_msg (udh, 0x40, 0xa0, hash_slot_addr[which], 0, 
                           (char *) hash, USRP_HASH_SIZE, 1000); 
  return r == USRP_HASH_SIZE; 
} 
 
bool 
usrp_get_hash (struct usb_dev_handle *udh, int which,  
               unsigned char hash[USRP_HASH_SIZE]) 
{ 
  which &= 1; 
   
  // we use the Cypress firmware upload command to fetch it. 
  int r = usb_control_msg (udh, 0xc0, 0xa0, hash_slot_addr[which], 0, 
                           (char *) hash, USRP_HASH_SIZE, 1000); 
  return r == USRP_HASH_SIZE; 
} 
 
static bool 
usrp_set_switch (struct usb_dev_handle *udh, int cmd_byte, bool on) 
{ 
  return write_cmd (udh, cmd_byte, on, 0, 0, 0) == 0; 
} 
 
 
static bool 
usrp1_fpga_write (struct usb_dev_handle *udh, 
                  int regno, int value) 
{ 
  // on the rev1 usrp, we use the generic spi_write interface 
 
  unsigned char buf[4]; 
 
  buf[0] = (value >> 24) & 0xff;        // MSB first 
  buf[1] = (value >> 16) & 0xff; 
  buf[2] = (value >>  8) & 0xff; 
  buf[3] = (value >>  0) & 0xff; 
   
  return usrp_spi_write (udh, 0x00 | (regno & 0x7f), 
                         SPI_ENABLE_FPGA, 
                         SPI_FMT_MSB | SPI_FMT_HDR_1, 
                         buf, sizeof (buf)); 
} 
 
static bool 
usrp1_fpga_read (struct usb_dev_handle *udh, 
                 int regno, int *value) 
{ 
  *value = 0; 
  unsigned char buf[4]; 
 
  bool ok = usrp_spi_read (udh, 0x80 | (regno & 0x7f), 
                           SPI_ENABLE_FPGA, 
                           SPI_FMT_MSB | SPI_FMT_HDR_1, 
                           buf, sizeof (buf)); 
 
  if (ok) 
    *value = (buf[0] << 24) | (buf[1] << 16) | (buf[2] << 8) | buf[3]; 
 
  return ok; 
} 
 
 
bool 
usrp_write_fpga_reg (struct usb_dev_handle *udh, int reg, int value) 
{ 
  switch (usrp_hw_rev (dev_handle_to_dev (udh))){ 
  case 0:                       // not supported ;) 
    abort();     
 
  default: 
    return usrp1_fpga_write (udh, reg, value); 
  } 
} 
 
bool 
usrp_read_fpga_reg (struct usb_dev_handle *udh, int reg, int *value) 
{ 
  switch (usrp_hw_rev (dev_handle_to_dev (udh))){ 
  case 0:               // not supported ;) 
    abort(); 
     
  default: 
    return usrp1_fpga_read (udh, reg, value); 
  } 
} 
 
bool  
usrp_set_fpga_reset (struct usb_dev_handle *udh, bool on) 
{ 
  return usrp_set_switch (udh, VRQ_FPGA_SET_RESET, on); 
} 
 
bool  
usrp_set_fpga_tx_enable (struct usb_dev_handle *udh, bool on) 
{ 
  return usrp_set_switch (udh, VRQ_FPGA_SET_TX_ENABLE, on); 
} 
 
bool  
usrp_set_fpga_rx_enable (struct usb_dev_handle *udh, bool on) 
{ 
  return usrp_set_switch (udh, VRQ_FPGA_SET_RX_ENABLE, on); 
} 
 
bool  
usrp_set_fpga_tx_reset (struct usb_dev_handle *udh, bool on) 
{ 
  return usrp_set_switch (udh, VRQ_FPGA_SET_TX_RESET, on); 
} 
 
bool  
usrp_set_fpga_rx_reset (struct usb_dev_handle *udh, bool on) 
{ 
  return usrp_set_switch (udh, VRQ_FPGA_SET_RX_RESET, on); 
} 
 
 
// ---------------------------------------------------------------- 
// conditional load stuff 
 
static bool 
compute_hash (const char *filename, unsigned char hash[USRP_HASH_SIZE]) 
{ 
  assert (USRP_HASH_SIZE == 16); 
  memset (hash, 0, USRP_HASH_SIZE); 
 
  FILE *fp = fopen (filename, "rb"); 
  if (fp == 0){ 
    perror (filename); 
    return false; 
  } 
  int r = md5_stream (fp, hash); 
  fclose (fp); 
   
  return r == 0; 
} 
 
static usrp_load_status_t 
usrp_conditionally_load_something (struct usb_dev_handle *udh, 
                                   const char *filename, 
                                   bool force, 
                                   int slot, 
                                   bool loader (struct usb_dev_handle *, 
                                                const char *, 
                                                unsigned char [USRP_HASH_SIZE])) 
{ 
  unsigned char file_hash[USRP_HASH_SIZE]; 
  unsigned char usrp_hash[USRP_HASH_SIZE]; 
   
  if (access (filename, R_OK) != 0){ 
    perror (filename); 
    return ULS_ERROR; 
  } 
 
  if (!compute_hash (filename, file_hash)) 
    return ULS_ERROR; 
 
  if (!force 
      && usrp_get_hash (udh, slot, usrp_hash) 
      && memcmp (file_hash, usrp_hash, USRP_HASH_SIZE) == 0) 
    return ULS_ALREADY_LOADED; 
 
  bool r = loader (udh, filename, file_hash); 
 
  if (!r) 
    return ULS_ERROR; 
 
  return ULS_OK; 
} 
 
usrp_load_status_t 
usrp_load_firmware (struct usb_dev_handle *udh, 
                    const char *filename, 
                    bool force) 
{ 
  return usrp_conditionally_load_something (udh, filename, force, 
                                            FIRMWARE_HASH_SLOT, 
                                            _usrp_load_firmware); 
} 
 
usrp_load_status_t 
usrp_load_fpga (struct usb_dev_handle *udh, 
                const char *filename, 
                bool force) 
{ 
  return usrp_conditionally_load_something (udh, filename, force, 
                                            FPGA_HASH_SLOT, 
                                            _usrp_load_fpga); 
} 
 
static usb_dev_handle * 
open_nth_cmd_interface (int nth) 
{ 
  struct usb_device *udev = usrp_find_device (nth); 
  if (udev == 0){ 
    fprintf (stderr, "usrp: failed to find usrp[%d]\n", nth); 
    return 0; 
  } 
 
  struct usb_dev_handle *udh; 
 
  udh = usrp_open_cmd_interface (udev); 
  if (udh == 0){ 
    // FIXME this could be because somebody else has it open. 
    // We should delay and retry... 
    fprintf (stderr, "open_nth_cmd_interface: open_cmd_interface failed\n"); 
    usb_strerror (); 
    return 0; 
  } 
 
  return udh; 
 } 
 
static bool 
our_nanosleep (const struct timespec *delay) 
{ 
  struct timespec       new_delay = *delay; 
  struct timespec       remainder; 
 
  while (1){ 
    int r = nanosleep (&new_delay, &remainder); 
    if (r == 0) 
      return true; 
    if (errno == EINTR) 
      new_delay = remainder; 
    else { 
      perror ("nanosleep"); 
      return false; 
    } 
  } 
} 
 
static bool 
mdelay (int millisecs) 
{ 
  struct timespec       ts; 
  ts.tv_sec = millisecs / 1000; 
  ts.tv_nsec = (millisecs - (1000 * ts.tv_sec)) * 1000000; 
  return our_nanosleep (&ts); 
} 
 
usrp_load_status_t 
usrp_load_firmware_nth (int nth, const char *filename, bool force){ 
  struct usb_dev_handle *udh = open_nth_cmd_interface (nth); 
  if (udh == 0) 
    return ULS_ERROR; 
 
  usrp_load_status_t s = usrp_load_firmware (udh, filename, force); 
  usrp_close_interface (udh); 
 
  switch (s){ 
 
  case ULS_ALREADY_LOADED:              // nothing changed... 
    return ULS_ALREADY_LOADED; 
    break; 
 
  case ULS_OK: 
    // we loaded firmware successfully. 
 
    // It's highly likely that the board will renumerate (simulate a 
    // disconnect/reconnect sequence), invalidating our current 
    // handle. 
 
    // FIXME.  Turn this into a loop that rescans until we refind ourselves 
     
    struct timespec     t;      // delay for 1 second 
    t.tv_sec = 2; 
    t.tv_nsec = 0; 
    our_nanosleep (&t); 
 
    usb_find_busses ();         // rescan busses and devices 
    usb_find_devices (); 
 
    return ULS_OK; 
 
  default: 
  case ULS_ERROR:               // some kind of problem 
    return ULS_ERROR; 
  } 
} 
 
static void 
load_status_msg (usrp_load_status_t s, const char *type, const char *filename) 
{ 
  char *e = getenv("USRP_VERBOSE"); 
  bool verbose = e != 0; 
   
  switch (s){ 
  case ULS_ERROR: 
    fprintf (stderr, "usrp: failed to load %s %s.\n", type, filename); 
    break; 
     
  case ULS_ALREADY_LOADED: 
    if (verbose) 
      fprintf (stderr, "usrp: %s %s already loaded.\n", type, filename); 
    break; 
 
  case ULS_OK: 
    if (verbose) 
      fprintf (stderr, "usrp: %s %s loaded successfully.\n", type, filename); 
    break; 
  } 
} 
 
bool 
usrp_load_standard_bits (int nth, bool force, 
                         const std::string fpga_filename, 
                         const std::string firmware_filename) 
{ 
  usrp_load_status_t    s; 
  const char            *filename; 
  const char            *proto_filename; 
  int hw_rev; 
 
  // first, figure out what hardware rev we're dealing with 
  { 
    struct usb_device *udev = usrp_find_device (nth); 
    if (udev == 0){ 
      fprintf (stderr, "usrp: failed to find usrp[%d]\n", nth); 
      return false; 
    } 
    hw_rev = usrp_hw_rev (udev); 
  } 
 
  // start by loading the firmware 
 
  proto_filename = get_proto_filename(firmware_filename, "USRP_FIRMWARE", 
                                      default_firmware_filename); 
  filename = find_file(proto_filename, hw_rev); 
  if (filename == 0){ 
    fprintf (stderr, "Can't find firmware: %s\n", proto_filename); 
    return false; 
  } 
 
  s = usrp_load_firmware_nth (nth, filename, force); 
  load_status_msg (s, "firmware", filename); 
 
  if (s == ULS_ERROR) 
    return false; 
 
  // if we actually loaded firmware, we must reload fpga ... 
  if (s == ULS_OK) 
    force = true; 
 
  // now move on to the fpga configuration bitstream 
 
  proto_filename = get_proto_filename(fpga_filename, "USRP_FPGA", 
                                      default_fpga_filename); 
  filename = find_file (proto_filename, hw_rev); 
  if (filename == 0){ 
    fprintf (stderr, "Can't find fpga bitstream: %s\n", proto_filename); 
    return false; 
  } 
 

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美精品一区二区三区蜜臀| 国产在线看一区| 日韩精品在线一区| 99九九99九九九视频精品| 五月综合激情日本mⅴ| 国产日韩欧美a| 欧美精品自拍偷拍动漫精品| 国产91在线|亚洲| 蜜臀精品一区二区三区在线观看| 亚洲人快播电影网| 国产亚洲视频系列| 日韩欧美黄色影院| 欧美日韩黄色影视| bt欧美亚洲午夜电影天堂| 久草热8精品视频在线观看| 亚洲综合一二区| 国产精品久久久久久一区二区三区| 制服丝袜国产精品| 欧美影院一区二区三区| 成人免费毛片高清视频| 黄色日韩三级电影| 日韩电影在线免费观看| 亚洲自拍偷拍九九九| 国产精品久久久久久久午夜片| 精品电影一区二区| 欧美一级高清大全免费观看| 欧美午夜精品久久久久久孕妇| 成人听书哪个软件好| 国产精品一区二区你懂的| 美女网站在线免费欧美精品| 午夜不卡在线视频| 亚洲成人7777| 亚洲福利视频导航| 一区二区欧美视频| 亚洲精品国产a久久久久久| 国产精品盗摄一区二区三区| 国产精品美女久久久久av爽李琼| 国产亚洲婷婷免费| 久久久99久久精品欧美| 欧美精品一区二区久久久| 日韩欧美在线网站| 日韩欧美国产一区二区三区 | 欧美日韩精品一区视频| 色综合色综合色综合| 91在线视频免费观看| av男人天堂一区| av一区二区三区| 99国产精品一区| 色噜噜狠狠一区二区三区果冻| 99热精品一区二区| 日本高清不卡在线观看| 欧洲精品在线观看| 欧美日韩国产美女| 91麻豆精品国产91久久久使用方法 | 26uuu欧美| 国产女人18毛片水真多成人如厕| 日本一区二区三区免费乱视频| 国产日韩在线不卡| 中文字幕欧美一| 一区二区激情视频| 亚洲va欧美va人人爽午夜| 天天综合天天综合色| 日韩不卡一二三区| 国产麻豆视频一区二区| 成人h动漫精品| 色哟哟日韩精品| 4438x亚洲最大成人网| 欧美大片在线观看一区二区| 国产亚洲一区二区三区四区| 成人欧美一区二区三区小说| 亚洲香肠在线观看| 美女精品一区二区| 成av人片一区二区| 7777精品久久久大香线蕉| 91在线精品一区二区三区| 欧美酷刑日本凌虐凌虐| 日韩欧美在线123| 国产婷婷精品av在线| 一区二区三区视频在线看| 日韩电影一二三区| 国产高清视频一区| 欧美色精品在线视频| 精品久久人人做人人爽| 136国产福利精品导航| 午夜成人在线视频| 国产电影精品久久禁18| 日本伦理一区二区| 2021久久国产精品不只是精品| 国产精品乱码妇女bbbb| 亚洲成人综合在线| 高清beeg欧美| 91精品国产色综合久久ai换脸| 久久理论电影网| 亚洲国产精品久久人人爱| 国产一区欧美二区| 欧美色爱综合网| 中文字幕免费不卡| 美女视频第一区二区三区免费观看网站| 成人中文字幕合集| 欧美一区二区三区四区在线观看 | 激情欧美一区二区| 在线国产电影不卡| 国产欧美在线观看一区| 日韩精品成人一区二区三区| av不卡在线播放| 久久综合色天天久久综合图片| 一个色妞综合视频在线观看| 懂色一区二区三区免费观看| 制服丝袜激情欧洲亚洲| 亚洲精品欧美综合四区| 粉嫩欧美一区二区三区高清影视| 在线不卡中文字幕播放| 夜夜揉揉日日人人青青一国产精品 | 欧美国产一区二区| 麻豆免费看一区二区三区| 欧洲人成人精品| 综合在线观看色| 成人在线一区二区三区| 精品国产伦一区二区三区观看方式| 午夜精品福利在线| 色视频一区二区| 综合电影一区二区三区| 国产成人午夜视频| 久久免费国产精品| 久久91精品国产91久久小草| 欧美一区二区福利在线| 亚洲成a人片在线不卡一二三区| 91香蕉视频污| 日韩美女久久久| 99久久精品国产一区二区三区 | 日韩三级电影网址| 日韩二区三区四区| 91精品国产综合久久久久久| 香蕉久久夜色精品国产使用方法| 色欧美片视频在线观看在线视频| 国产精品久久久久久久久图文区| 成人免费看片app下载| 国产日韩欧美高清| 成人福利视频在线| 中文字幕一区二区三区在线不卡| 成人午夜激情在线| 综合久久国产九一剧情麻豆| 91浏览器入口在线观看| 亚洲人被黑人高潮完整版| 色综合久久综合| 夜色激情一区二区| 欧美日韩激情在线| 青青草原综合久久大伊人精品 | 最新热久久免费视频| 91视频观看视频| 亚洲综合视频在线| 欧美日韩成人综合在线一区二区| 亚洲高清免费在线| 欧美一区二区三区免费| 精品一区二区国语对白| 国产日韩欧美综合一区| 成人av午夜影院| 一区二区三区精品久久久| 欧美精品成人一区二区三区四区| 麻豆国产91在线播放| 国产人成亚洲第一网站在线播放| 成人丝袜高跟foot| 亚洲综合色成人| 91精品国模一区二区三区| 国产在线观看一区二区| 国产精品入口麻豆九色| 在线观看欧美日本| 老司机午夜精品99久久| 久久久www成人免费无遮挡大片| 不卡的电影网站| 亚洲成人免费电影| 精品日产卡一卡二卡麻豆| 成人免费视频网站在线观看| 亚洲国产sm捆绑调教视频| 精品入口麻豆88视频| 不卡的av电影| 午夜电影网一区| 国产亚洲一区二区在线观看| 在线视频你懂得一区| 久久激情综合网| 日韩一区欧美小说| 欧美一区二区三区精品| 国产91精品一区二区| 亚洲国产精品一区二区www | 丁香婷婷综合色啪| 亚洲一区二区三区在线播放| 久久夜色精品国产噜噜av| 91丨国产丨九色丨pron| 裸体一区二区三区| 国产精品不卡视频| 日韩你懂的在线播放| 91啪在线观看| 国产揄拍国内精品对白| 亚洲国产精品久久久久婷婷884| 国产欧美日韩综合| 欧美一区二区三区视频免费播放| 91在线你懂得| 国产成人在线视频网站| 免费高清在线一区| 一区二区成人在线|