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

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

?? dma54xx.h

?? 開發平臺ccs5000 tms320vc5416的fft程序
?? 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一区二区三区免费野_久草精品视频
成人a级免费电影| 91麻豆国产精品久久| 亚洲网友自拍偷拍| 国产麻豆精品久久一二三| 午夜亚洲国产au精品一区二区| 亚洲欧美日韩国产综合| 一区二区三区中文在线观看| 亚洲精品va在线观看| 一区二区三区四区精品在线视频| 中文字幕在线一区免费| 国产精品久久久久久久第一福利| 国产片一区二区三区| 中文字幕精品一区二区精品绿巨人| 国产人伦精品一区二区| 最新热久久免费视频| 一区二区免费在线播放| 日韩精品一二区| 九九**精品视频免费播放| 国产成人福利片| 91在线一区二区| 欧美疯狂性受xxxxx喷水图片| 9191久久久久久久久久久| 日韩欧美中文字幕制服| 日本一二三不卡| 亚洲一区二区精品视频| 麻豆免费看一区二区三区| 国产91丝袜在线18| 欧美在线免费观看亚洲| 精品999在线播放| 亚洲精品网站在线观看| 麻豆91免费看| 99re66热这里只有精品3直播| 欧美日韩国产高清一区二区 | 欧美一区国产二区| 国产日韩一级二级三级| 一区二区三区不卡视频| 精品一区二区三区视频 | 色噜噜狠狠色综合欧洲selulu| 欧美中文字幕亚洲一区二区va在线 | 亚洲乱码国产乱码精品精可以看| 亚洲国产精品久久久男人的天堂| 国产一区中文字幕| 欧美日韩一区成人| 亚洲欧美在线aaa| 久久99精品一区二区三区| 91免费观看国产| 精品久久人人做人人爱| 亚洲最大成人网4388xx| 国产69精品久久久久777| 欧美一三区三区四区免费在线看| 中文字幕亚洲电影| 国产精品中文字幕日韩精品| 精品视频在线免费| 136国产福利精品导航| 极品少妇xxxx精品少妇偷拍| 欧美日韩一级视频| 亚洲制服丝袜一区| 97久久久精品综合88久久| 国产人妖乱国产精品人妖| 久久99精品久久久久久国产越南| 欧美色图在线观看| 亚洲综合小说图片| 91免费在线看| 最近日韩中文字幕| 成人激情动漫在线观看| 国产偷国产偷亚洲高清人白洁| 免费看欧美女人艹b| 69堂成人精品免费视频| 亚洲夂夂婷婷色拍ww47| 欧洲一区在线电影| 亚洲一区二区中文在线| 91热门视频在线观看| 亚洲精品中文在线观看| 在线日韩国产精品| 亚洲午夜一区二区| 欧美日韩精品高清| 五月天一区二区| 欧美一区二区三区视频免费播放| 亚洲国产日韩av| 欧美高清一级片在线| 水蜜桃久久夜色精品一区的特点| 91麻豆精品91久久久久久清纯| 午夜激情一区二区三区| 欧美一区在线视频| 国产伦精品一区二区三区视频青涩 | 怡红院av一区二区三区| 91一区在线观看| 一二三区精品视频| 91精品午夜视频| 国产自产2019最新不卡| 国产日韩高清在线| 91麻豆高清视频| 午夜在线成人av| 精品不卡在线视频| 91丝袜美腿高跟国产极品老师 | av一二三不卡影片| 亚洲四区在线观看| 欧美日韩国产123区| 精品一区二区三区免费| 国产精品高清亚洲| 欧美日韩免费观看一区三区| 久久99精品国产麻豆不卡| 亚洲国产高清在线| 欧美视频一区二区| 国产大陆a不卡| 亚洲自拍偷拍综合| 久久综合成人精品亚洲另类欧美| 成人晚上爱看视频| 日韩—二三区免费观看av| 久久久久高清精品| 欧美主播一区二区三区| 精品午夜久久福利影院| 日韩毛片精品高清免费| 777久久久精品| av电影在线观看不卡| 奇米精品一区二区三区在线观看一| 国产香蕉久久精品综合网| 欧美午夜精品久久久| 国产很黄免费观看久久| 亚洲超丰满肉感bbw| 国产精品网站在线观看| 欧美一区二区三区在线观看视频| 国产91精品精华液一区二区三区| 日日骚欧美日韩| 亚洲免费在线视频| 久久婷婷国产综合精品青草| 欧美亚洲一区三区| 99麻豆久久久国产精品免费优播| 免费看精品久久片| 亚洲a一区二区| 日韩理论片一区二区| 国产三级精品视频| 26uuu色噜噜精品一区二区| 欧美日韩国产天堂| 精品视频在线视频| 在线观看视频91| 99国产一区二区三精品乱码| 成人永久免费视频| 国产福利精品一区| 国产乱码精品1区2区3区| 蜜桃91丨九色丨蝌蚪91桃色| 日本伊人色综合网| 亚洲h动漫在线| 五月开心婷婷久久| 亚洲一区二区三区免费视频| 亚洲色图在线播放| 亚洲天堂精品视频| **网站欧美大片在线观看| 国产精品久久久久久久久图文区| 久久久久久久久久久99999| 日韩精品资源二区在线| 精品成人a区在线观看| 久久日韩粉嫩一区二区三区| 久久综合资源网| 久久综合色8888| 久久免费看少妇高潮| 欧美国产成人精品| 亚洲欧美激情一区二区| 亚洲日本丝袜连裤袜办公室| 亚洲精品视频在线看| 亚洲综合激情网| 麻豆精品视频在线观看视频| 久久国产精品第一页| 国产精品99久久久久久久vr| 国产 欧美在线| aaa国产一区| 欧美日韩一级黄| 精品久久久久av影院| 国产三级精品视频| 洋洋av久久久久久久一区| 天天做天天摸天天爽国产一区| 日韩经典中文字幕一区| 国产在线麻豆精品观看| 成人97人人超碰人人99| 欧美午夜精品电影| 久久―日本道色综合久久| 亚洲人成在线播放网站岛国| 午夜精品福利一区二区三区av | 99精品欧美一区二区三区小说| 91免费看视频| 日韩欧美视频一区| 国产精品国产三级国产普通话三级| 亚洲一区中文日韩| 国内精品不卡在线| 色爱区综合激月婷婷| 日韩精品一区二区三区中文不卡 | 日韩一级大片在线观看| 国产欧美一区二区精品仙草咪| 一区二区三区欧美在线观看| 美日韩一级片在线观看| 91日韩精品一区| 欧美精品一区视频| 亚洲在线一区二区三区| 国产精品一二三在| 欧美日韩黄色一区二区| 国产女同性恋一区二区| 秋霞av亚洲一区二区三| 99riav久久精品riav| 亚洲精品一区二区三区香蕉| 亚洲国产综合视频在线观看|