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

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

?? dma54xx.h

?? 數字I/O實驗主要完成的功能: 在此實驗中
?? H
?? 第 1 頁 / 共 2 頁
字號:
        DMA_SUBREG_BITWRITE(chan, DMSEFC_SUBADDR, FRAMECOUNT,\
        					FRAMECOUNT_SZ, value)
	

/******************************************************************/
/* DMA_INTMASK_ENABLE - enable DMA interrupt                      */
/*                                                                */
/******************************************************************/
#define DMA_INTMASK_ENABLE(chan) \
		DMA_SUBREG_BITWRITE(chan, DMMCR_SUBADDR, DINM, DINM_SZ, DINM_ENABLE)


/******************************************************************/
/* DMA_INTMASK_DISABLE - disable DMA interrupt                    */
/*                                                                */
/******************************************************************/
#define DMA_INTMASK_DISABLE(chan) \
		DMA_SUBREG_BITWRITE(chan, DMMCR_SUBADDR, DINM, DINM_SZ, DINM_DISABLE)


/******************************************************************/
/* DMA_DMS_SELECT - set Source Space Select                       */
/*                                                                */
/******************************************************************/
#define DMA_DMS_SELECT(chan, value) \
		DMA_SUBREG_BITWRITE(chan, DMMCR_SUBADDR, DMS, DMS_SZ, value)

		        
/******************************************************************/
/* DMA_DMD_SELECT - set Destination Space Select                  */
/*                                                                */
/******************************************************************/
#define DMA_DMD_SELECT(chan, value) \
		DMA_SUBREG_BITWRITE(chan, DMMCR_SUBADDR, DMD, DMD_SZ, value)

        
/*-----------------------------------------------------------------------------*/
/* FUNCTION DEFINITIONS                                                        */
/*-----------------------------------------------------------------------------*/

/******************************************************************************/
/* dma_init -  Initialize channel specific control registers.                 */
/*                                                                            */
/*     This function is responsible for setting the DMA control registers,    */
/*     source address, destination address and the corresponding pages        */
/*     transfer count for the specified DMA channel.                          */
/*                                                                            */
/******************************************************************************/

__INLINE void    dma_init(             /*RET: OK or ERROR (invalid channel)  */
             unsigned int channel      /*IN: DMA channel number              */
            ,unsigned int dmsefc       /*IN: Value to set sync & fr reg      */
            ,unsigned int dmmcr        /*IN: Value to set mode control reg   */
		,unsigned int dmctr	   /*IN: Value to set element count reg  */
            ,unsigned int src_page     /*IN: Value to set source page reg    */
            ,unsigned int src_addr     /*IN: Value to set source addr reg    */
            ,unsigned int dst_page     /*IN: Value to set dest page reg      */
            ,unsigned int dst_addr     /*IN: Value to set dest addr reg      */
                );

/******************************************************************************/
/* dma_global_init -  Initialize global control registers.                    */
/*                                                                            */
/*     This function is responsible for setting the DMA global control        */
/*     registers                                                              */
/*     Notice: DMDSTP and DMSRCP are used in DMA_GLOBAL_INIT and DMA_INIT     */
/*             necessity should be reconsidered                               */
/******************************************************************************/
__INLINE void     dma_global_init(     /*RET: VOID function                  */
              unsigned int dmpre       /*IN:Value for priority and enable reg*/
             ,unsigned int dmsrcp      /*IN:Value for source page reg        */
             ,unsigned int dmdstp      /*IN:Value for dest page reg          */
             ,unsigned int dmidx0      /*IN:Value for element index reg 0    */
             ,unsigned int dmidx1      /*IN:Value for element index reg 1    */
             ,unsigned int dmfri0      /*IN:Value for frame index reg 0      */
             ,unsigned int dmfri1      /*IN:Value for frame index reg 1      */
             ,unsigned int dmgsa       /*IN:Value for global src addr reload */
             ,unsigned int dmgda       /*IN:Value for global dst addr reload */
             ,unsigned int dmgcr       /*IN:Value for global count reload reg*/
             ,unsigned int dmgfr       /*IN:Value for global frame reload reg*/
                        );

/******************************************************************************/
/* dma_reset_all -  Reset DMA channel.                                            */
/*                                                                            */
/*     This function resets the specified DMA channel by initializing         */
/*     channel control registers to their default values                      */
/*                                                                            */
/*                                                                            */
/******************************************************************************/
__INLINE void     dma_reset_all(void);
__INLINE void     dma_reset(unsigned int channel);


      
#if _INLINE
static inline void   dma_init(
             unsigned int channel      /*IN: DMA channel number              */
            ,unsigned int dmsefc       /*IN: Value to set sync & fr reg      */
            ,unsigned int dmmcr        /*IN: Value to set mode control reg   */
		       ,unsigned int dmctr	   /*IN: Value to set element count reg  */
            ,unsigned int src_page     /*IN: Value to set source page reg    */
            ,unsigned int src_addr     /*IN: Value to set source addr reg    */
            ,unsigned int dst_page     /*IN: Value to set dest page reg      */
            ,unsigned int dst_addr     /*IN: Value to set dest addr reg      */
                )
{
  DMA_SUBREG_WRITE(channel, DMSRC_SUBADDR, src_addr); 
  REG_WRITE(DMSAI_ADDR, dst_addr);
  REG_WRITE(DMSAI_ADDR, dmctr);
  REG_WRITE(DMSAI_ADDR, dmsefc);
  REG_WRITE(DMSAI_ADDR, dmmcr);
  
  DMA_SUBREG_WRITE(channel, DMSRCP_SUBADDR, src_page);
  REG_WRITE(DMSAI, dst_page);
  
}

static inline void dma_global_init(
              unsigned int dmpre       /*IN:Value for priority and enable reg*/
             ,unsigned int dmsrcp      /*IN:Value for source page reg        */
             ,unsigned int dmdstp      /*IN:Value for dest page reg          */
             ,unsigned int dmidx0      /*IN:Value for element index reg 0    */
             ,unsigned int dmidx1      /*IN:Value for element index reg 1    */
             ,unsigned int dmfri0      /*IN:Value for frame index reg 0      */
             ,unsigned int dmfri1      /*IN:Value for frame index reg 1      */
             ,unsigned int dmgsa       /*IN:Value for global src addr reload */
             ,unsigned int dmgda       /*IN:Value for global dst addr reload */
             ,unsigned int dmgcr       /*IN:Value for global count reload reg*/
             ,unsigned int dmgfr)      /*IN:Value for global frame reload reg*/
{
  REG_WRITE(DMPRE_ADDR, dmpre);

  DMA_SUBREG_WRITE(0, DMSRCP_SUBADDR, dmsrcp);
  REG_WRITE(DMSAI_ADDR, dmdstp);
  
  REG_WRITE(DMSAI_ADDR, dmidx0);
  REG_WRITE(DMSAI_ADDR, dmidx1);
  REG_WRITE(DMSAI_ADDR, dmfri0);
  REG_WRITE(DMSAI_ADDR, dmfri1);
  REG_WRITE(DMSAI_ADDR, dmgsa);
  REG_WRITE(DMSAI_ADDR, dmgda);
  REG_WRITE(DMSAI_ADDR, dmgcr);
  REG_WRITE(DMSAI_ADDR, dmgfr);

}

static inline void dma_reset_all( void )
{
  int channel;

  REG_WRITE(DMPRE_ADDR, 0x00);

  for (channel= 0;channel < 5; channel++)
  {
      DMA_SUBREG_WRITE(channel, DMSRC_SUBADDR, 0x00);

      REG_WRITE(DMSAI_ADDR, 0x00); //src
      REG_WRITE(DMSAI_ADDR, 0x00); //dst
      REG_WRITE(DMSAI_ADDR, 0x00); //ctr
      REG_WRITE(DMSAI_ADDR, 0x00); //sefc
      REG_WRITE(DMSAI_ADDR, 0x00); //mcr
  }         
                                  

  DMA_SUBREG_WRITE(channel, DMSRCP_SUBADDR, 0x00);
  REG_WRITE(DMSAI_ADDR, 0x00);  /*DMDSTP*/
  
  REG_WRITE(DMSAI_ADDR, 0x00);  /*DMIDX0*/
  REG_WRITE(DMSAI_ADDR, 0x00);  /*DMIDX1*/
  REG_WRITE(DMSAI_ADDR, 0x00);  /*DMFRI0*/
  REG_WRITE(DMSAI_ADDR, 0x00);  /*DMFRI1*/          
  REG_WRITE(DMSAI_ADDR, 0x00);  /*DMGSA*/
  REG_WRITE(DMSAI_ADDR, 0x00);  /*DMGDA*/
  REG_WRITE(DMSAI_ADDR, 0x00);  /*DMGCR*/
  REG_WRITE(DMSAI_ADDR, 0x00);  /*DMGRF*/
}          

static inline void dma_reset( unsigned int channel )
{
   RESET_BIT(DMPRE_ADDR, channel); //disable channel
   RESET_BIT(DMPRE_ADDR, channel+8); //set priority low
  
   DMA_SUBREG_WRITE(channel, DMSRC_SUBADDR, 0x00);

   REG_WRITE(DMSAI_ADDR, 0x00); //src
   REG_WRITE(DMSAI_ADDR, 0x00); //dst
   REG_WRITE(DMSAI_ADDR, 0x00); //ctr
   REG_WRITE(DMSAI_ADDR, 0x00); //sefc
   REG_WRITE(DMSAI_ADDR, 0x00); //mcr
}                         
               

#endif /* _INLINE */
#undef __INLINE

#endif /* _DMA_H_ */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产色产综合色产在线视频 | 精品乱码亚洲一区二区不卡| 久久久久久麻豆| 一区二区成人在线视频| 国产在线视频不卡二| 欧美在线观看视频一区二区| 国产午夜精品一区二区三区嫩草| 亚洲一区二区三区三| 成人av集中营| 久久亚洲一区二区三区明星换脸 | 欧美性猛交一区二区三区精品| 欧美α欧美αv大片| 一区二区三区中文字幕| 福利一区福利二区| 欧美成人艳星乳罩| 日欧美一区二区| 色一情一乱一乱一91av| 国产精品欧美极品| 国产一区二区不卡| 精品国内片67194| 热久久国产精品| 欧美精品丝袜中出| 亚洲一区二区三区中文字幕| 成人动漫一区二区在线| 欧美高清一级片在线观看| 久久91精品久久久久久秒播| 555www色欧美视频| 亚洲电影一区二区| 欧美伊人久久大香线蕉综合69| 国产精品成人在线观看| 国产成人av网站| 久久精品在线免费观看| 国产美女精品人人做人人爽| 久久久777精品电影网影网| 精品午夜一区二区三区在线观看| 欧美日韩在线电影| 亚洲国产精品精华液网站| 一本久久a久久精品亚洲| 亚洲精品免费看| 欧美最新大片在线看| 亚洲自拍偷拍麻豆| 欧美偷拍一区二区| 视频在线观看一区二区三区| 欧美美女一区二区| 免费观看一级欧美片| 精品毛片乱码1区2区3区| 国产一区久久久| 国产精品午夜久久| 91在线视频播放| 亚洲精品视频在线观看网站| 欧美日韩一区高清| 人人爽香蕉精品| 精品国产电影一区二区| 成人一区二区视频| 亚洲欧美国产三级| 欧美日韩一二区| 国内精品伊人久久久久av影院| 久久综合中文字幕| 99久久综合国产精品| 亚洲va中文字幕| 久久免费视频一区| 91蝌蚪porny九色| 午夜免费欧美电影| 2020国产精品自拍| 色综合久久综合网| 免费成人在线观看视频| 中文字幕av资源一区| 欧美性感一区二区三区| 国产精品一区免费视频| 一区二区三区欧美视频| 精品国产一区二区在线观看| 92精品国产成人观看免费| 日韩成人免费电影| 国产精品成人网| 日韩欧美成人激情| 91视频国产资源| 久久国产视频网| 亚洲日本在线a| 日韩一级免费一区| 91麻豆福利精品推荐| 青青国产91久久久久久| 亚洲视频1区2区| 精品国产乱码久久| 亚洲精品在线免费播放| 色噜噜狠狠成人中文综合| 久久99久久99精品免视看婷婷| 中文字幕亚洲成人| 日韩欧美国产电影| 欧美午夜精品电影| 99久久伊人网影院| 精品制服美女丁香| 亚洲v日本v欧美v久久精品| 中文字幕在线观看一区| 久久嫩草精品久久久久| 91精品国产免费久久综合| 91美女福利视频| 国产成a人亚洲精品| 麻豆91精品91久久久的内涵| 香蕉av福利精品导航| 亚洲激情综合网| 中文字幕一区二区三区四区| 精品国产伦一区二区三区免费 | 99久久精品免费看国产免费软件| 免费美女久久99| 日韩精品成人一区二区在线| 亚洲三级小视频| 国产精品久久久久影院亚瑟| 久久精品亚洲精品国产欧美kt∨| 在线播放欧美女士性生活| 在线亚洲一区二区| 色综合久久久久久久| 91一区二区在线| 99久久综合99久久综合网站| jizzjizzjizz欧美| www.成人网.com| 9l国产精品久久久久麻豆| 国产一区二区福利视频| 韩国精品一区二区| 国产精品一区二区久激情瑜伽| 激情综合色综合久久| 狠狠久久亚洲欧美| 国产成人在线视频免费播放| 豆国产96在线|亚洲| av成人动漫在线观看| 色呦呦国产精品| 欧美色电影在线| 欧美一区二区三区免费视频| 欧美成人伊人久久综合网| 精品三级av在线| 久久亚洲春色中文字幕久久久| 精品成人免费观看| 国产偷国产偷精品高清尤物| 国产精品久久久久久福利一牛影视| 国产女人18水真多18精品一级做| 美腿丝袜亚洲色图| 91色porny| 狠狠v欧美v日韩v亚洲ⅴ| 国产成人免费av在线| 99久久精品免费精品国产| 欧美午夜视频网站| 日韩美女视频一区二区在线观看| 久久久久9999亚洲精品| 亚洲人成亚洲人成在线观看图片| 亚洲乱码国产乱码精品精98午夜| 亚洲国产综合在线| 国产美女精品一区二区三区| av中文字幕不卡| 欧美精品乱码久久久久久按摩| 精品免费国产一区二区三区四区| 国产日韩精品一区| 国产永久精品大片wwwapp | 成人av电影在线| 欧美日韩视频在线观看一区二区三区| 欧美区视频在线观看| 26uuu国产日韩综合| 日韩理论电影院| 蜜桃传媒麻豆第一区在线观看| 粉嫩aⅴ一区二区三区四区五区| 91理论电影在线观看| 日韩一区和二区| 亚洲男人的天堂在线aⅴ视频| 免费在线成人网| 色哟哟欧美精品| 久久精品欧美一区二区三区不卡 | 在线观看一区二区视频| 久久亚洲免费视频| 亚洲国产综合视频在线观看| 成人精品小蝌蚪| 日韩美女视频在线| 亚洲一区二区欧美| 成人毛片视频在线观看| 91精品国产综合久久精品图片| 国产精品美日韩| 精品一区二区三区视频在线观看 | 懂色av中文一区二区三区| 4438x亚洲最大成人网| 亚洲欧美日韩精品久久久久| 国产一区二区福利| 日韩午夜中文字幕| 亚洲一区二区免费视频| 成人禁用看黄a在线| 26uuu精品一区二区| 六月丁香综合在线视频| 欧美日韩精品是欧美日韩精品| 综合色天天鬼久久鬼色| 国产a精品视频| 国产亚洲一本大道中文在线| 欧美aa在线视频| 欧美日本一区二区在线观看| 一二三区精品福利视频| 色综合天天性综合| 中文字幕一区av| 成人av影视在线观看| 国产精品人人做人人爽人人添| 国产一区二区三区| 日韩精品影音先锋| 另类综合日韩欧美亚洲| 欧美大尺度电影在线| 美日韩一区二区三区| 欧美成人aa大片|