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

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

?? mvp_dma.c

?? 利用TMS320C6701開(kāi)發(fā)板搭建的移動(dòng)視頻電話平臺(tái)
?? C
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
/*
* File: MVPdma.c
*
* Author: Elliot Hill
*
* Description: This file contains all of the functions used
* for DMA control within the Mobile Videophone (MVP)
* thesis project in the University of Queensland.
*
* Last Modified: 2 October 2001
*/
#include "MVP_dma.h"
/*
* The variables used for the video input DMA.
*/
static volatile uint dma_video_prim_ctrl = 0;
static volatile uint dma_video_sec_ctrl = 0;
static volatile uint dma_video_tcnt = 0;
static volatile uint dma_gcra = 0;
static volatile uint dma_gndxa = 0;
/*
* The variables used for the audio input DMA
*/
static volatile uint dma_audio_prim_ctrl = 0;
static volatile uint dma_audio_sec_ctrl = 0;
static volatile uint dma_audio_tcnt = 0;
/*
* The variables used for the data input DMA
*/
static volatile uint dma_data_prim_ctrl = 0;
static volatile uint dma_data_sec_ctrl = 0;
static volatile uint dma_data_tcnt = 0;
/*
* The variables used for internal data transfer DMA
*/
static volatile uint dma_int_data_prim_ctrl = 0;
static volatile uint dma_int_data_sec_ctrl = 0;
static volatile uint dma_int_data_tcnt = 0;
static volatile uint dma_int_data_src_addr = 0;
static volatile uint dma_int_data_dst_addr = 0;
static volatile uint dma_gcrb = 0;
static volatile uint dma_gndxb = 0;
/*
* Data structures for the holding of data received through the
* serial port
*/
static uint datarecaddr;
static float *datastorage = (float *)DATASTORAGEADDR;
/*
* Global data structures used for the video data address for storage, and the
* audio data address.
*/
uint vid_addr_global;
uint aud_addr_global;
/*
* initialise_DMA() -
*
* This function initialises the DMA for the different sections
* of the MVP.
*/
int initialise_DMA(uint vid_addr0, uint aud_addr)
{
/*
* The first thing needed to be done is to reset the DMA, and disable
* the interrupt system.
*/
dma_reset();
intr_init();
INTR_GLOBAL_DISABLE();
/*
* copy the video and audio addresses over to the global address for each,
* to be used when refreshing.
*/
vid_addr_global = vid_addr0;
aud_addr_global = aud_addr;
/*
* Map the various interrupts generated by the board to
* the CPU.
*/
intr_map(CPU_INT7,ISN_EXT_INT7);
intr_map(CPU_INT8,ISN_DMA_INT0);
intr_map(CPU_INT9,ISN_DMA_INT1);
intr_map(CPU_INT10, ISN_DMA_INT2);
/*
* The interrupts now need to be hooked to the various
* Interrupt Service Routines (ISRs).
*/
intr_hook(start_video_transfer,CPU_INT7);
intr_hook(refresh_video_DMA,CPU_INT8);
intr_hook(refresh_audio_DMA,CPU_INT9);
intr_hook(refresh_and_manip_data_DMA,CPU_INT10);
/*
* Now that our interrupt system is hooked, we can set up the
* DMA for our system.
*
* Video:
* - The source address does not increment after transfer
* - The destination address is loaded from the index
* register. This is due to the need to increment by 32-bits
* after transfer.
* - The TCINT, PRI and RSYNC bits must be set.
*/
LOAD_FIELD(&dma_video_prim_ctrl, DMA_ADDR_NO_MOD, SRC_DIR, SRC_DIR_SZ);
LOAD_FIELD(&dma_video_prim_ctrl, DMA_ADDR_INDX, DST_DIR, DST_DIR_SZ);
LOAD_FIELD(&dma_video_prim_ctrl, SEN_TINT1, RSYNC, RSYNC_SZ);
SET_BIT(&dma_video_prim_ctrl,TCINT);
SET_BIT(&dma_video_prim_ctrl,PRI);
/*
* The only bit of the video dma's secondary register that must
* be set is the block interrupt enable.
*/
SET_BIT(&dma_video_sec_ctrl,BLOCK_IE);
/*
* Setting up the transfer count registers:
*
* Video:
* - 125 lines in the image, with 144 pixels/line (VHDL generated)
*
*/
LOAD_FIELD(&dma_video_tcnt, FRAMES_PER_BLOCK, FRAME_COUNT,
FRAME_COUNT_SZ);
LOAD_FIELD(&dma_video_tcnt, NUM_ELEMENTS, ELEMENT_COUNT,
ELEMENT_COUNT_SZ);
/*
* Setting up the required gcra, gndxa (Video) registers for use
* within the dma_global_init function.
*/
LOAD_FIELD(&dma_gcra, FRAMES_PER_BLOCK, FRAME_COUNT_RELOAD,
FRAME_COUNT_RELOAD_SZ);
LOAD_FIELD(&dma_gcra, NUM_ELEMENTS, ELEMENT_COUNT_RELOAD,
ELEMENT_COUNT_RELOAD_SZ);
LOAD_FIELD(&dma_gndxa, 0x0004, ELEMENT_COUNT_RELOAD,
ELEMENT_COUNT_RELOAD_SZ);
/*
* setup the DMA global init for the video transfer
*/
dma_global_init(
0x0, // aux control reg
dma_gcra, // multiframe video transfers
dma_gcrb, // global count reload B - used in internal transfers.
dma_gndxa, // programmable index for reloading video dst addresses
dma_gndxb, // global index reg B
0x0, // global addr register A - not used
0x0, // global addr register B - not used
0x0, // global addr register C - not used
0x0); // global addr register D - not used
/*
* Audio:
* - The length of a read is 32 bits
* - Destination address is incremented
* - DMA is given priority over CPU
* - RSYNC triggers an interrupts when the McBSP port gets
* data.
* - The Interrupts system for DMA is enabled.
*/
LOAD_FIELD(&dma_audio_prim_ctrl, DMA_ESIZE32, ESIZE, ESIZE_SZ);
LOAD_FIELD(&dma_audio_prim_ctrl, DMA_ADDR_INC, DST_DIR, DST_DIR_SZ);
LOAD_FIELD(&dma_audio_prim_ctrl, DMA_DMA_PRI, PRI, 1);
LOAD_FIELD(&dma_audio_prim_ctrl, SEN_REVT0, RSYNC, RSYNC_SZ);
SET_BIT(&dma_audio_prim_ctrl,TCINT);
/*
* Setting up the Secondary control register for the Audio subsection.
* In this area, we will only need one thing, and that is the ability
* to set and clear the BLOCK_IE (block complete interrupts) so we know
* when to refresh.
*/
SET_BIT(&dma_audio_sec_ctrl, BLOCK_IE);
/*
* Now setting the Transfer count register:
*
* Audio:
* - Element length of 4000 (0.5 seconds worth)
*/
LOAD_FIELD(&dma_audio_tcnt, 1, FRAME_COUNT, FRAME_COUNT_SZ);
LOAD_FIELD(&dma_audio_tcnt, AUD_ELEM_NUM, ELEMENT_COUNT,
ELEMENT_COUNT_SZ);
/*
* Serial Data Transfer Configuration:
* - DMA has priority over CPU
* - Incrementing of Destination address automatically
* - No modification to the source address
* - No DMA interrupts on writing, but trigger one on
* reception
* - 16 bit element size
* - Ability for dma channel to interrupt the CPU
*/
LOAD_FIELD(&dma_data_prim_ctrl, DMA_DMA_PRI, PRI, 1);
LOAD_FIELD(&dma_data_prim_ctrl, DMA_ADDR_NO_MOD, SRC_DIR, SRC_DIR_SZ);
LOAD_FIELD(&dma_data_prim_ctrl, DMA_ADDR_INC, DST_DIR, DST_DIR_SZ);
LOAD_FIELD(&dma_data_prim_ctrl, SEN_REVT0, RSYNC, RSYNC_SZ);
LOAD_FIELD(&dma_data_prim_ctrl, SEN_NONE, WSYNC, WSYNC_SZ);
LOAD_FIELD(&dma_data_prim_ctrl, DMA_ESIZE16, ESIZE, ESIZE_SZ);
SET_BIT(&dma_data_prim_ctrl, TCINT);
// Casting the address of our receive data
datarecaddr = (unsigned int)UARTRECADDR;
/*
* Secondary control register setup for Serial data
*/
SET_BIT(&dma_data_sec_ctrl, BLOCK_IE);
/*
* Serial Data transfer counter setup
*/
LOAD_FIELD(&dma_data_tcnt, 1, FRAME_COUNT, FRAME_COUNT_SZ);
LOAD_FIELD(&dma_data_tcnt, DATA_ELEM_NUM, ELEMENT_COUNT,
ELEMENT_COUNT_SZ);
/*
* Program the auxiliary control register.
*/
SET_BIT(DMA_AUXCR_ADDR,AUXPRI);
/*
* Initialising the DMA video channel with the registers
* altered above.
*/
dma_init(
VIDEO_DMA, // DMA Channel 0
dma_video_prim_ctrl, // Primary control register
dma_video_sec_ctrl, // Secondary control register
DMA_VIDEO_SRC_ADDR, // defined in MVPdma.h
vid_addr_global, // destination address 0
dma_video_tcnt); // transfer counter register
/*
* Initialising the Audio DMA controller
*/
dma_init(
AUDIO_DMA,
dma_audio_prim_ctrl,
dma_audio_sec_ctrl,
MCBSP_DRR_ADDR(1),
aud_addr_global,
dma_audio_tcnt);
/*
* Initialising the Serial Data DMA controller
*/
dma_init(
DATA_DMA,
dma_data_prim_ctrl,
dma_data_sec_ctrl,
MCBSP_DRR_ADDR(0),
datarecaddr,
dma_data_tcnt);
/*
* Initialising and starting the Timer 1
*/
TIMER_INIT(1, 0x100, 0x1, 0);
TIMER_START(0);
/*
* Audio -
*
* Enable the receive and transmit registers, and also
* set the frame sync generator to pulse after 8 CLKG pulses.
*/
SET_BIT(MCBSP_SPCR_ADDR(1), RRST);
SET_BIT(MCBSP_SPCR_ADDR(1), XRST);
SET_BIT(MCBSP_SPCR_ADDR(1), FRST);
/*
* Serial Data -
*
* Enable the receive and transmit registers, and also
* set the frame sync generator (not required for external
* functionality).
*/
SET_BIT(MCBSP_SPCR_ADDR(0), RRST);
SET_BIT(MCBSP_SPCR_ADDR(0), XRST);
SET_BIT(MCBSP_SPCR_ADDR(0), FRST);
/*
* Enable the interrupts
*/
INTR_ENABLE(CPU_INT_NMI);
INTR_ENABLE(CPU_INT7);
INTR_ENABLE(CPU_INT8);
INTR_ENABLE(CPU_INT9);
INTR_ENABLE(CPU_INT10);
INTR_GLOBAL_ENABLE(); // sets the GIE in the CSR register
XCTRL0_HIGH(); // Enable interrupt signal generation on the board.
return 0;
}
/*
* refresh_video_DMA() -
*
* This function refreshes the video_DMA control and transfer counter registers.
*/

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩一区二区高清| 欧美在线三级电影| 日韩1区2区3区| 日韩不卡在线观看日韩不卡视频| 一级特黄大欧美久久久| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ原创 | 精品亚洲欧美一区| 免费成人在线网站| 麻豆精品精品国产自在97香蕉| 日精品一区二区三区| 日本中文字幕不卡| 精品一区二区久久久| 国产乱码精品一区二区三| 国产麻豆91精品| 97久久超碰精品国产| 色婷婷激情综合| 欧美日本乱大交xxxxx| 日韩欧美中文一区| 国产亚洲欧美在线| 亚洲欧美影音先锋| 亚洲国产精品天堂| 久久成人免费日本黄色| 国产成人综合亚洲91猫咪| av福利精品导航| 91精品国产手机| 久久精品夜色噜噜亚洲a∨| 国产精品女主播在线观看| 一区二区三区中文字幕精品精品| 天天做天天摸天天爽国产一区| 免费观看30秒视频久久| 成人午夜碰碰视频| 欧美日韩在线播放| 国产调教视频一区| 亚洲福利视频三区| 成人免费三级在线| 777久久久精品| 欧美激情艳妇裸体舞| 一个色在线综合| 国产精品一区二区三区四区| 91一区在线观看| 久久综合久久综合亚洲| 伊人夜夜躁av伊人久久| 国产精品一区二区视频| 欧美日韩一区二区三区在线| 久久精品一二三| 午夜精品久久久| 97久久超碰国产精品电影| 欧美成人a∨高清免费观看| 国产精品婷婷午夜在线观看| 青青草国产成人99久久| 91色视频在线| 亚洲国产精品成人综合色在线婷婷 | 极品美女销魂一区二区三区免费| 91老司机福利 在线| 久久亚洲精精品中文字幕早川悠里 | 在线免费亚洲电影| 欧美国产综合色视频| 美女视频黄a大片欧美| 欧美在线影院一区二区| 中文字幕一区在线| 国产乱码一区二区三区| 欧美一区二区三区小说| 艳妇臀荡乳欲伦亚洲一区| 成年人国产精品| 国产精品久久久久久久岛一牛影视| 另类小说图片综合网| 91麻豆精品国产91久久久 | 日本中文字幕一区二区有限公司| 91在线视频免费观看| 中文字幕精品一区二区精品绿巨人 | 亚洲综合在线免费观看| 91丝袜美女网| 亚洲色大成网站www久久九九| 国产成人免费在线观看| 国产日韩视频一区二区三区| 久久精品国产精品亚洲精品| 337p亚洲精品色噜噜狠狠| 亚洲成人免费在线观看| 欧美性一区二区| 亚洲一区二区三区四区在线| 色噜噜狠狠一区二区三区果冻| 中文字幕一区二区三区不卡 | 九九精品一区二区| 精品久久久久久无| 国产一区二区三区免费看| 久久久久久久久一| 99久久国产免费看| 一区二区三区免费看视频| 欧美日韩综合一区| 奇米亚洲午夜久久精品| 久久众筹精品私拍模特| 国产91露脸合集magnet| 亚洲人成7777| 91麻豆精品国产| 国产综合久久久久久久久久久久| 久久精品男人的天堂| 91天堂素人约啪| 日韩精品欧美成人高清一区二区| 欧美xxxx在线观看| 成人免费观看视频| 五月天精品一区二区三区| 欧美videos中文字幕| youjizz国产精品| 午夜久久久久久久久| 精品国产乱码久久久久久牛牛| 国产成人精品一区二区三区四区| 亚洲女同一区二区| 欧美一级片在线看| av亚洲产国偷v产偷v自拍| 亚洲综合免费观看高清在线观看| 精品三级av在线| 91日韩精品一区| 免费人成网站在线观看欧美高清| 欧美激情一区二区三区全黄| 欧美日韩一二区| 国产乱国产乱300精品| 亚洲一区二区三区在线| 久久久久高清精品| 欧美视频一区二区三区四区 | 国产精品久久久久桃色tv| 欧美成人官网二区| 欧美亚洲丝袜传媒另类| 国产成人精品综合在线观看 | 国产一区日韩二区欧美三区| 中文字幕中文字幕在线一区| 欧美一区二区三区免费大片| 波多野结衣的一区二区三区| 免费一级片91| 亚洲乱码中文字幕| 国产无一区二区| 欧美一区二区三区影视| 在线亚洲人成电影网站色www| 国内久久婷婷综合| 日韩在线a电影| 亚洲国产欧美另类丝袜| 中文字幕av不卡| 久久综合九色综合欧美就去吻| 欧美人伦禁忌dvd放荡欲情| 不卡的av电影在线观看| 国产一区二区中文字幕| 麻豆成人久久精品二区三区小说| 亚洲午夜在线视频| 亚洲精品成人a在线观看| 国产精品理论片在线观看| 精品国产三级a在线观看| 日韩视频免费观看高清在线视频| 欧美探花视频资源| 欧美网站一区二区| 欧美日韩成人在线| 欧美久久一二三四区| 欧美综合在线视频| 欧美日韩视频第一区| 91黄色在线观看| 在线观看日韩精品| 欧美亚洲禁片免费| 欧美日韩在线三级| 欧美日产国产精品| 555夜色666亚洲国产免| 欧美一区二区三区在线视频| 91精品国产综合久久精品麻豆 | 亚洲男人的天堂在线观看| 国产精品久99| 亚洲婷婷综合久久一本伊一区| 亚洲欧洲在线观看av| 亚洲欧美电影院| 午夜视频在线观看一区| 日本欧美一区二区在线观看| 麻豆久久久久久| 成人丝袜视频网| 色婷婷亚洲一区二区三区| 欧美视频中文字幕| 精品盗摄一区二区三区| 日本一区二区三区电影| 亚洲欧美电影一区二区| 午夜久久福利影院| 国内精品国产成人国产三级粉色 | 久久精品亚洲乱码伦伦中文| 中文字幕欧美国产| 亚洲精品高清在线| 男女视频一区二区| 国产aⅴ综合色| 欧美性大战xxxxx久久久| 欧美本精品男人aⅴ天堂| 国产精品卡一卡二| 蜜臀av性久久久久蜜臀aⅴ四虎 | 99国产精品久| 91精品欧美久久久久久动漫| 久久久一区二区| 亚洲综合区在线| 国产精品亚洲综合一区在线观看| 91亚洲永久精品| 日韩亚洲欧美中文三级| 中文字幕一区二区三区四区| 午夜国产精品一区| 成人精品国产福利| 日韩精品一区二区三区蜜臀| 中文字幕视频一区| 国内精品嫩模私拍在线| 欧美国产欧美综合| 日韩国产精品91|