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

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

?? usbhw.c

?? LPC23XX USB測試代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:

/*
 *  Read USB Endpoint Data
 *    Parameters:      EPNum: Endpoint Number
 *                       EPNum.0..3: Address
 *                       EPNum.7:    Dir
 *                     pData: Pointer to Data Buffer
 *    Return Value:    Number of bytes read
 */

DWORD USB_ReadEP (DWORD EPNum, BYTE *pData) {
  DWORD cnt, n;

  USB_CTRL = ((EPNum & 0x0F) << 2) | CTRL_RD_EN;

  do {
    cnt = RX_PLENGTH;
  } while ((cnt & PKT_RDY) == 0);
  cnt &= PKT_LNGTH_MASK;

  for (n = 0; n < (cnt + 3) / 4; n++) {
    *((__packed DWORD *)pData) = RX_DATA;
    pData += 4;
  }

  USB_CTRL = 0;

  if (((EP_MSK_ISO >> EPNum) & 1) == 0) {   /* Non-Isochronous Endpoint */
    WrCmd(CMD_SEL_EP(EPAdr(EPNum)));
    WrCmd(CMD_CLR_BUF);
  }

  return (cnt);
}


/*
 *  Write USB Endpoint Data
 *    Parameters:      EPNum: Endpoint Number
 *                       EPNum.0..3: Address
 *                       EPNum.7:    Dir
 *                     pData: Pointer to Data Buffer
 *                     cnt:   Number of bytes to write
 *    Return Value:    Number of bytes written
 */

DWORD USB_WriteEP (DWORD EPNum, BYTE *pData, DWORD cnt) {
  DWORD n;

  USB_CTRL = ((EPNum & 0x0F) << 2) | CTRL_WR_EN;

  TX_PLENGTH = cnt;

  for (n = 0; n < (cnt + 3) / 4; n++) {
    TX_DATA = *((__packed DWORD *)pData);
    pData += 4;
  }

  USB_CTRL = 0;

  WrCmd(CMD_SEL_EP(EPAdr(EPNum)));
  WrCmd(CMD_VALID_BUF);

  return (cnt);
}


#if USB_DMA

/* DMA Descriptor Memory Layout */
const DWORD DDAdr[2] = { DD_NISO_ADR, DD_ISO_ADR };
const DWORD DDSz [2] = { 16,          20         };

/*
 *  Setup USB DMA Transfer for selected Endpoint
 *    Parameters:      EPNum: Endpoint Number
 *                     pDD: Pointer to DMA Descriptor
 *    Return Value:    TRUE - Success, FALSE - Error
 */

BOOL USB_DMA_Setup(DWORD EPNum, USB_DMA_DESCRIPTOR *pDD) {
  DWORD num, ptr, nxt, iso, n;

  iso = pDD->Cfg.Type.IsoEP;                /* Iso or Non-Iso Descriptor */
  num = EPAdr(EPNum);                       /* Endpoint's Physical Address */

  ptr = 0;                                  /* Current Descriptor */
  nxt = udca[num];                          /* Initial Descriptor */
  while (nxt) {                             /* Go through Descriptor List */
    ptr = nxt;                              /* Current Descriptor */
    if (!pDD->Cfg.Type.Link) {              /* Check for Linked Descriptors */
      n = (ptr - DDAdr[iso]) / DDSz[iso];   /* Descriptor Index */
      DDMemMap[iso] &= ~(1 << n);           /* Unmark Memory Usage */
    }
    nxt = *((DWORD *)ptr);                  /* Next Descriptor */
  }

  for (n = 0; n < 32; n++) {                /* Search for available Memory */
    if ((DDMemMap[iso] & (1 << n)) == 0) {
      break;                                /* Memory found */
    }
  }
  if (n == 32) return (FALSE);              /* Memory not available */

  DDMemMap[iso] |= 1 << n;                  /* Mark Memory Usage */
  nxt = DDAdr[iso] + n * DDSz[iso];         /* Next Descriptor */

  if (ptr && pDD->Cfg.Type.Link) {
    *((DWORD *)(ptr + 0))  = nxt;           /* Link in new Descriptor */
    *((DWORD *)(ptr + 4)) |= 0x00000004;    /* Next DD is Valid */
  } else {
    udca[num] = nxt;                        /* Save new Descriptor */
    UDCA[num] = nxt;                        /* Update UDCA in USB */
  }

  /* Fill in DMA Descriptor */
  *(((DWORD *)nxt)++) =  0;                 /* Next DD Pointer */
  *(((DWORD *)nxt)++) =  pDD->Cfg.Type.ATLE |
                       (pDD->Cfg.Type.IsoEP << 4) |
                       (pDD->MaxSize <<  5) |
                       (pDD->BufLen  << 16);
  *(((DWORD *)nxt)++) =  pDD->BufAdr;
  *(((DWORD *)nxt)++) =  pDD->Cfg.Type.LenPos << 8;
  if (iso) {
    *((DWORD *)nxt) =  pDD->InfoAdr;
  }

  return (TRUE); /* Success */
}


/*
 *  Enable USB DMA Endpoint
 *    Parameters:      EPNum: Endpoint Number
 *                       EPNum.0..3: Address
 *                       EPNum.7:    Dir
 *    Return Value:    None
 */

void USB_DMA_Enable (DWORD EPNum) {
  EP_DMA_EN = 1 << EPAdr(EPNum);
}


/*
 *  Disable USB DMA Endpoint
 *    Parameters:      EPNum: Endpoint Number
 *                       EPNum.0..3: Address
 *                       EPNum.7:    Dir
 *    Return Value:    None
 */

void USB_DMA_Disable (DWORD EPNum) {
  EP_DMA_DIS = 1 << EPAdr(EPNum);
}


/*
 *  Get USB DMA Endpoint Status
 *    Parameters:      EPNum: Endpoint Number
 *                       EPNum.0..3: Address
 *                       EPNum.7:    Dir
 *    Return Value:    DMA Status
 */

DWORD USB_DMA_Status (DWORD EPNum) {
  DWORD ptr, val;

  ptr = UDCA[EPAdr(EPNum)];                 /* Current Descriptor */
  if (ptr == 0) return (USB_DMA_INVALID);

  val = *((DWORD *)(ptr + 3*4));            /* Status Information */
  switch ((val >> 1) & 0x0F) {
    case 0x00:                              /* Not serviced */
      return (USB_DMA_IDLE);
    case 0x01:                              /* Being serviced */
      return (USB_DMA_BUSY);
    case 0x02:                              /* Normal Completition */
      return (USB_DMA_DONE);
    case 0x03:                              /* Data Under Run */
      return (USB_DMA_UNDER_RUN);
    case 0x08:                              /* Data Over Run */
      return (USB_DMA_OVER_RUN);
    case 0x09:                              /* System Error */
      return (USB_DMA_ERROR);
  }

  return (USB_DMA_UNKNOWN);
}


/*
 *  Get USB DMA Endpoint Current Buffer Address
 *    Parameters:      EPNum: Endpoint Number
 *                       EPNum.0..3: Address
 *                       EPNum.7:    Dir
 *    Return Value:    DMA Address (or -1 when DMA is Invalid)
 */

DWORD USB_DMA_BufAdr (DWORD EPNum) {
  DWORD ptr, val;

  ptr = UDCA[EPAdr(EPNum)];                 /* Current Descriptor */
  if (ptr == 0) return (-1);                /* DMA Invalid */

  val = *((DWORD *)(ptr + 2*4));            /* Buffer Address */

  return (val);                             /* Current Address */
}


/*
 *  Get USB DMA Endpoint Current Buffer Count
 *   Number of transfered Bytes or Iso Packets
 *    Parameters:      EPNum: Endpoint Number
 *                       EPNum.0..3: Address
 *                       EPNum.7:    Dir
 *    Return Value:    DMA Count (or -1 when DMA is Invalid)
 */

DWORD USB_DMA_BufCnt (DWORD EPNum) {
  DWORD ptr, val;

  ptr = UDCA[EPAdr(EPNum)];                 /* Current Descriptor */
  if (ptr == 0) return (-1);                /* DMA Invalid */

  val = *((DWORD *)(ptr + 3*4));            /* Status Information */

  return (val >> 16);                       /* Current Count */
}


#endif /* USB_DMA */


/*
 *  Get USB Last Frame Number
 *    Parameters:      None
 *    Return Value:    Frame Number
 */

DWORD USB_GetFrame (void) {
  DWORD val;

  WrCmd(CMD_RD_FRAME);
  val = RdCmdDat(DAT_RD_FRAME);
  val = val | (RdCmdDat(DAT_RD_FRAME) << 8);

  return (val);
}


/*
 *  USB Interrupt Service Routine
 */

void USB_ISR (void) __irq
{
  DWORD disr, val, n, m;

  disr = DEV_INT_STAT;                      /* Device Interrupt Status */
  DEV_INT_CLR = disr;                       /* A known issue on LPC214x */
  DeviceStatusValue = disr;

  /* Device Status Interrupt (Reset, Suspend/Resume, Connect change) */
  if (disr & DEV_STAT_INT) {
	DeviceInterruptCount++;

    WrCmd(CMD_GET_DEV_STAT);
    val = RdCmdDat(DAT_GET_DEV_STAT);       /* Device Status */
  	if ( val & DEV_RST )
		DevStatusReset++;
	if ( val & DEV_CON_CH )
		DevStatusConnectChange++;
	if ( val & DEV_CON )
		DevStatusConnect++;
	if ( val & DEV_SUS_CH ) {
	    DevStatusSuspendChange++;
	if ( val & DEV_SUS )
		DevStatusSuspend++;
	else
		DevStatusResume++;
	}

    if (val & DEV_RST) {                    /* Reset */
      USB_Reset();
#if   USB_RESET_EVENT
      USB_Reset_Event();
#endif
//      goto isr_end;
    }

    if (val & DEV_SUS_CH) {                 /* Suspend/Resume */
      if (val & DEV_SUS) {                  /* Suspend */
        USB_Suspend();
#if     USB_SUSPEND_EVENT
        USB_Suspend_Event();
#endif
      } else {                              /* Resume */
		USB_Resume();
#if     USB_RESUME_EVENT
        USB_Resume_Event();
#endif
      }
//      goto isr_end;
    }
    
    if (val & DEV_CON_CH ) {                 /* Connect change */
#if   USB_POWER_EVENT
      USB_Power_Event(val & DEV_CON);
#endif
//      goto isr_end;
    }
    goto isr_end;
  }

#if USB_SOF_EVENT
  /* Start of Frame Interrupt */
  if (disr & FRAME_INT) {
    USB_SOF_Event();
  }
#endif

#if USB_ERROR_EVENT
  /* Error Interrupt */
  if (disr & ERR_INT) {
    WrCmd(CMD_RD_ERR_STAT);
    val = RdCmdDat(DAT_RD_ERR_STAT);
    USB_Error_Event(val);
    goto isr_end;
  }
#endif

  /* Endpoint's Slow Interrupt */
  if (disr & EP_SLOW_INT) {

    while (EP_INT_STAT) {                   /* Endpoint Interrupt Status */

      for (n = 0; n < USB_EP_NUM; n++) {    /* Check All Endpoints */
        if (EP_INT_STAT & (1 << n)) {
          m = n >> 1;

          EP_INT_CLR = 1 << n;
          while ((DEV_INT_STAT & CDFULL_INT) == 0);
          val = CMD_DATA;

          if ((n & 1) == 0) {               /* OUT Endpoint */
            if (n == 0) {                   /* Control OUT Endpoint */
              if (val & EP_SEL_STP) {       /* Setup Packet */
                if (USB_P_EP[0]) {
                  USB_P_EP[0](USB_EVT_SETUP);
                  continue;
                }
              }
            }
            if (USB_P_EP[m]) {
              USB_P_EP[m](USB_EVT_OUT);
            }
          } else {                          /* IN Endpoint */
            if (USB_P_EP[m]) {
              USB_P_EP[m](USB_EVT_IN);
            }
          }
        }
      }
    }
  }

#if USB_DMA

  if (DMA_INT_STAT & 0x00000001) {          /* End of Transfer Interrupt */
    val = EOT_INT_STAT;
    for (n = 2; n < USB_EP_NUM; n++) {      /* Check All Endpoints */
      if (val & (1 << n)) {
        m = n >> 1;
        if ((n & 1) == 0) {                 /* OUT Endpoint */
          if (USB_P_EP[m]) {
            USB_P_EP[m](USB_EVT_OUT_DMA_EOT);
          }
        } else {                            /* IN Endpoint */
          if (USB_P_EP[m]) {
            USB_P_EP[m](USB_EVT_IN_DMA_EOT);
          }
        }
      }
    }
    EOT_INT_CLR = val;
  }

  if (DMA_INT_STAT & 0x00000002) {          /* New DD Request Interrupt */
    val = NDD_REQ_INT_STAT;
    for (n = 2; n < USB_EP_NUM; n++) {      /* Check All Endpoints */
      if (val & (1 << n)) {
        m = n >> 1;
        if ((n & 1) == 0) {                 /* OUT Endpoint */
          if (USB_P_EP[m]) {
            USB_P_EP[m](USB_EVT_OUT_DMA_NDR);
          }
        } else {                            /* IN Endpoint */
          if (USB_P_EP[m]) {
            USB_P_EP[m](USB_EVT_IN_DMA_NDR);
          }
        }
      }
    }
    NDD_REQ_INT_CLR = val;
  }

  if (DMA_INT_STAT & 0x00000004) {          /* System Error Interrupt */
    val = SYS_ERR_INT_STAT;
    for (n = 2; n < USB_EP_NUM; n++) {      /* Check All Endpoints */
      if (val & (1 << n)) {
        m = n >> 1;
        if ((n & 1) == 0) {                 /* OUT Endpoint */
          if (USB_P_EP[m]) {
            USB_P_EP[m](USB_EVT_OUT_DMA_ERR);
          }
        } else {                            /* IN Endpoint */
          if (USB_P_EP[m]) {
            USB_P_EP[m](USB_EVT_IN_DMA_ERR);
          }
        }
      }
    }
    SYS_ERR_INT_CLR = val;
  }
#endif /* USB_DMA */

isr_end:
//  DEV_INT_CLR = disr;
  VICVectAddr = 0;		/* Acknowledge Interrupt */
  return;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日日夜夜精品视频天天综合网| 成人毛片在线观看| 国产乱码精品一区二区三区av | 欧美性videosxxxxx| 欧美成人猛片aaaaaaa| 亚洲综合丝袜美腿| 成人开心网精品视频| 日韩欧美色综合| 午夜欧美电影在线观看| 成人福利视频在线| 久久精品一区八戒影视| 蜜臀精品久久久久久蜜臀| 色天使色偷偷av一区二区| 国产三区在线成人av| 九九精品视频在线看| 欧美日韩国产精品成人| 《视频一区视频二区| 国产麻豆精品theporn| 欧美一级免费大片| 午夜精品福利久久久| 在线观看欧美日本| 一区二区三区日本| 色呦呦一区二区三区| 欧美激情在线免费观看| 国产精品自在欧美一区| 精品乱人伦小说| 精品一区二区三区在线观看| 欧美一级高清片| 日本免费在线视频不卡一不卡二| 欧美影院一区二区| 亚洲成av人片一区二区梦乃| 欧美性三三影院| 亚洲成人在线网站| 欧美在线观看一二区| 亚洲国产一区二区在线播放| 欧美三级午夜理伦三级中视频| 亚洲精品视频自拍| 欧美日韩一区二区三区免费看| 一区二区成人在线视频| 欧美性生交片4| 日韩黄色一级片| 精品三级av在线| 国产成人啪午夜精品网站男同| 欧美激情一区二区三区蜜桃视频| 国产成人啪免费观看软件 | 成人福利在线看| 国产精品久久久久久久浪潮网站| 97成人超碰视| 亚洲高清免费视频| 日韩欧美高清dvd碟片| 国产在线观看一区二区| 中文字幕精品一区| 欧美亚洲动漫另类| 免费久久精品视频| 国产亚洲成年网址在线观看| www.欧美.com| 午夜欧美在线一二页| 精品av久久707| 99久久久精品| 日本美女一区二区三区视频| 久久免费美女视频| 一本色道久久综合亚洲91| 午夜伊人狠狠久久| 欧美韩国日本不卡| 欧美性受xxxx黑人xyx| 狠狠色狠狠色综合系列| 亚洲欧美中日韩| 91精品国产黑色紧身裤美女| 岛国精品在线观看| 亚洲国产欧美在线| 国产女同互慰高潮91漫画| 欧美最新大片在线看| 激情综合色丁香一区二区| 亚洲特级片在线| 日韩精品影音先锋| 欧洲精品中文字幕| 国产成人午夜片在线观看高清观看| 亚洲观看高清完整版在线观看| 久久久天堂av| 欧美一卡2卡3卡4卡| 972aa.com艺术欧美| 激情综合色播激情啊| 亚洲国产三级在线| 中文在线免费一区三区高中清不卡 | 91丝袜呻吟高潮美腿白嫩在线观看| 日韩国产高清在线| 一区二区三区在线视频免费观看| 精品久久国产97色综合| 欧美日韩一区视频| 91麻豆福利精品推荐| 国精产品一区一区三区mba桃花| 亚洲福利电影网| 日韩码欧中文字| 中文字幕免费一区| 久久综合色8888| 91精品国产综合久久久久久久久久| 99国内精品久久| 大桥未久av一区二区三区中文| 麻豆视频观看网址久久| 日韩av中文在线观看| 夜夜爽夜夜爽精品视频| 1区2区3区欧美| 国产精品毛片久久久久久| 久久久亚洲高清| 久久久夜色精品亚洲| 2022国产精品视频| 精品久久久三级丝袜| 91精品国产综合久久久久久久久久| 在线观看国产91| 欧美伊人精品成人久久综合97| 色综合久久久久综合99| eeuss鲁片一区二区三区在线看| 国产成人免费网站| 高清不卡一区二区在线| 国产麻豆精品视频| 国产传媒一区在线| 成人免费高清在线观看| 国产大陆a不卡| a在线欧美一区| 91小视频免费观看| 在线观看区一区二| 欧美美女网站色| 日韩一二三区不卡| 精品福利一区二区三区免费视频| 久久先锋资源网| 国产精品人成在线观看免费| 亚洲国产精品传媒在线观看| 国产精品久久久久久久浪潮网站| 成人免费小视频| 亚洲成av人片观看| 狠狠狠色丁香婷婷综合激情| 成人听书哪个软件好| 91蜜桃网址入口| 3d动漫精品啪啪| 久久你懂得1024| 亚洲另类春色国产| 日韩精品色哟哟| 国产91丝袜在线播放0| 91小视频免费观看| 欧美一区二区三区喷汁尤物| 精品久久久久久久一区二区蜜臀| 国产欧美日韩久久| 一区二区三区四区激情| 奇米四色…亚洲| av在线一区二区| 91精品国产综合久久久蜜臀图片| 久久嫩草精品久久久精品| 亚洲精品大片www| 久久99在线观看| 色婷婷av一区二区三区gif| 欧美精品高清视频| 亚洲国产电影在线观看| 午夜视频在线观看一区| 成人午夜在线免费| 91精品国产综合久久久久久漫画| 国产嫩草影院久久久久| 调教+趴+乳夹+国产+精品| 国产精品123区| 欧美高清精品3d| 国产精品嫩草影院com| 视频一区欧美精品| 色婷婷久久久亚洲一区二区三区| 精品欧美久久久| 一区二区三区**美女毛片| 久久国产尿小便嘘嘘| 91精彩视频在线观看| 久久天堂av综合合色蜜桃网| 夜夜嗨av一区二区三区中文字幕| 国产精品一区二区三区网站| 欧美色成人综合| 亚洲欧洲制服丝袜| 国产成人精品一区二区三区网站观看| 欧美视频在线观看一区| 日韩美女视频一区二区 | 国产精品入口麻豆九色| 日韩专区欧美专区| 在线看日本不卡| 日韩美女精品在线| 从欧美一区二区三区| 久久伊99综合婷婷久久伊| 日韩精品高清不卡| 精品视频在线免费看| 亚洲同性gay激情无套| 丁香激情综合国产| 国产欧美一区二区在线| 精品一区免费av| 精品少妇一区二区三区在线视频 | 国产精品1区2区| 欧美一级久久久久久久大片| 婷婷中文字幕一区三区| 欧美影院一区二区三区| 亚洲精品久久久蜜桃| 91网站黄www| 亚洲精品国产第一综合99久久 | 精品久久久久久久久久久久久久久 | 亚洲精品国产高清久久伦理二区| 成人精品视频网站| 亚洲视频在线观看一区| 99国产一区二区三精品乱码| 亚洲视频 欧洲视频|