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

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

?? mvp_dma.c

?? 新買的書
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*
* 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.
*/

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91最新地址在线播放| 亚洲精品一区二区三区四区高清 | 日韩精品资源二区在线| 欧美国产日产图区| 免费观看久久久4p| 在线国产亚洲欧美| 国产精品美女久久久久久久| 久久爱www久久做| 777亚洲妇女| 亚洲一二三四在线观看| 成人高清免费观看| 国产三级三级三级精品8ⅰ区| 亚洲aⅴ怡春院| 91行情网站电视在线观看高清版| 国产精品蜜臀av| 国产成人av影院| 久久久精品蜜桃| 国产一区二区在线看| 亚洲精品一区在线观看| 麻豆精品一区二区综合av| 欧美老肥妇做.爰bbww| 亚洲午夜三级在线| 欧美在线高清视频| 最新热久久免费视频| 99久久久精品| 自拍视频在线观看一区二区| 懂色av一区二区在线播放| 国产亚洲精品中文字幕| 国产中文字幕精品| 久久精品一区二区三区av| 韩国av一区二区| 久久久不卡网国产精品一区| 国产一区视频导航| 国产亚洲综合av| 成人深夜视频在线观看| 国产精品视频第一区| 成人福利视频在线| 国产麻豆精品久久一二三| 日韩一卡二卡三卡| 精品一区二区三区免费视频| 精品精品国产高清a毛片牛牛| 国产一区二区三区日韩| 久久九九久久九九| 99精品久久久久久| 亚洲一区二区偷拍精品| 91精品国产综合久久福利| 青草国产精品久久久久久| 亚洲精品一区二区三区在线观看| 国产精品原创巨作av| 中文字幕日本不卡| 欧美婷婷六月丁香综合色| 天天av天天翘天天综合网色鬼国产 | 日韩精品电影一区亚洲| 日韩一区二区不卡| 国产91精品露脸国语对白| 国产精品不卡在线| 欧美日韩一区二区在线视频| 久久精品国产成人一区二区三区| 久久精品免费在线观看| 91成人网在线| 国产一区二区三区不卡在线观看 | 99视频一区二区| 亚洲成a人在线观看| 亚洲精品在线观| 91理论电影在线观看| 天使萌一区二区三区免费观看| 久久综合色综合88| 在线亚洲+欧美+日本专区| 久久er99精品| 一区二区三区蜜桃| 国产亚洲1区2区3区| 在线免费av一区| 国产**成人网毛片九色| 亚洲大片精品永久免费| 国产精品免费网站在线观看| 欧美猛男gaygay网站| 风间由美一区二区三区在线观看 | 欧美一区二区三区思思人| 国产不卡在线播放| 日韩—二三区免费观看av| 18成人在线视频| 国产无遮挡一区二区三区毛片日本 | 日韩欧美国产小视频| 91免费版在线| 国产成人在线影院| 麻豆精品国产传媒mv男同 | 老鸭窝一区二区久久精品| 亚洲另类中文字| 国产亚洲一区二区三区四区| 欧美一区二区三区日韩| 欧美性生交片4| 99精品国产热久久91蜜凸| 国产精品一区免费视频| 天堂在线亚洲视频| 黑人精品欧美一区二区蜜桃 | 国产精品二三区| 久久新电视剧免费观看| 欧美一区三区四区| 欧美日韩日本视频| 91福利国产成人精品照片| 成人av电影在线观看| 国产**成人网毛片九色| 国产乱码精品一区二区三区av | 日韩免费电影一区| 欧美日本一道本| 欧美日韩高清影院| 欧美精品一卡二卡| 欧美日韩视频一区二区| 欧美色老头old∨ideo| 色婷婷av一区二区三区大白胸 | 日韩视频免费直播| 欧美一卡二卡三卡| 精品日韩一区二区三区免费视频| 日韩一区二区三区在线视频| 欧美一区二区视频免费观看| 日韩一级高清毛片| 精品久久一区二区| 国产日韩欧美精品电影三级在线 | 亚洲一区二区三区在线播放| 一区二区三区 在线观看视频 | 国产精品理论在线观看| 国产精品嫩草影院com| 成人免费小视频| 亚洲成人av在线电影| 日韩av不卡在线观看| 精品综合久久久久久8888| 国产一区日韩二区欧美三区| 成人综合日日夜夜| 色综合久久天天综合网| 欧美日韩二区三区| 日韩精品最新网址| 亚洲国产精品成人久久综合一区| 亚洲婷婷在线视频| 亚洲va中文字幕| 国产在线视频一区二区| 成人开心网精品视频| 欧美中文字幕久久| 精品少妇一区二区三区视频免付费| 国产欧美日本一区视频| 亚洲精品视频观看| 久久精品国产网站| 99精品在线观看视频| 91麻豆精品国产综合久久久久久| 久久在线免费观看| 一个色妞综合视频在线观看| 久久成人综合网| 99r国产精品| 日韩欧美aaaaaa| 成人欧美一区二区三区白人| 图片区小说区区亚洲影院| 国产一区91精品张津瑜| 在线视频你懂得一区二区三区| 欧美刺激午夜性久久久久久久| 亚洲欧洲在线观看av| 日精品一区二区| 99精品视频在线免费观看| 91精品国产美女浴室洗澡无遮挡| 欧美激情一区二区三区在线| 日精品一区二区三区| 99久久精品费精品国产一区二区| 日韩午夜在线观看| 亚洲免费资源在线播放| 欧美日韩一区二区三区高清| 国产亚洲精品bt天堂精选| 亚洲一区欧美一区| 成人av在线观| 久久一日本道色综合| 视频一区中文字幕| 色综合久久久久| 欧美激情一区二区在线| 久久精品国产第一区二区三区| 91麻豆视频网站| 中文字幕精品在线不卡| 久久99日本精品| 欧美日韩精品免费观看视频| 国产精品久久久久久久久动漫 | 欧美激情在线免费观看| 石原莉奈在线亚洲三区| 色综合久久中文字幕综合网| 欧美国产精品专区| 韩国中文字幕2020精品| 日韩欧美一区二区免费| 亚洲一区二区三区四区五区中文| 成人18视频在线播放| 久久久影院官网| 国产一区二区久久| 日韩欧美一区二区免费| 日韩福利电影在线观看| 欧美日韩国产高清一区二区三区| 亚洲亚洲精品在线观看| 色噜噜狠狠色综合中国| 亚洲三级在线免费观看| a级精品国产片在线观看| 国产日本一区二区| 成人一级视频在线观看| 国产精品视频看| 91亚洲午夜精品久久久久久| 亚洲情趣在线观看| 欧美网站一区二区| 日韩电影网1区2区|