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

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

?? ftmcp100.h

?? 基于Linux的ffmepg decoder
?? H
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
#ifndef FTMCP100_H#define FTMCP100_H//---------------------------------------------------------------------------//  Platform Options and Settings//---------------------------------------------------------------------------/** * Since there are different kind of hardware versions, so we define following flag  * here to distinguish between various kind of hardware core. */#define CORE_VERSION_1//#define CORE_VERSION_2#if (!defined(CORE_VERSION_1) && !defined(CORE_VERSION_2))  #error "Please define the hardware core version (either CORE_VERSION_1 or CORE_VERSION_2)"#endif/** *  The JPEG decoder will run on both RTL platform and FPGA platform. For  *  the purpose of one unified single JPEG decoder firmware code, we integrate the  *  codes on both platforms together and define two flags to decide the platform. *  But these two flags will be defined in project setting instead within code  *  body. We just write these flags here for the purpose of reminder. *  Don't define these two flags in program. Define them in project settings. *///#define FPGA_PLATFORM//#define RTL_PLATFORM#if (!defined(FPGA_PLATFORM) && !defined(RTL_PLATFORM))  #error "Please define the the target platform  (either FPGA_PLATFORM or RTL_PLATFORM)"#endif//---------------------------------------------------------------------------//  Platform Options and Settings//---------------------------------------------------------------------------/** *  Various kind of #define constants for compiler preprocessor configuration setting of  *  FTMCP100 media coprocessor. */ // added by Leo for various output controls#ifdef RTL_PLATFORM  #define VPE_OUTPUT  //#define VPE_DUMP_YUV // to enalbe the dumping of YUV data (mp4.yuv file in RTL simulation)#endif#ifdef CORE_VERSION_2  // In core_version_2 , we can use the auto-increment mechanism for DMA engine, so we set   // the following flag to tell the performance difference.  #define USING_AUTO_INCREMNET#endif//---------------------------------------------------------------------------//---------------------------------------------------------------------------/** *  Various kind of #define constants mainly used for FTMCP100 media coprocessor. */#define CKR_RATIO 0#define VPE 		0x90180000#define RTL_DEBUG_OUT(v) *(unsigned int*)VPE=v;/*#ifdef CORE_VERSION_1  #ifdef FPGA_PLATFORM    #define BASE_ADDRESS		0x90700000 // used for Test Chip FIE8100    #elif defined(RTL_PLATFORM)    #define BASE_ADDRESS		0x90700000 // used for RTL simulation  #else    #error "Please define the platfrom flags in project setting (either FPGA_PLATFORM or RTL_PLATFORM)"  #endif	#elif defined(CORE_VERSION_2)  #ifdef FPGA_PLATFORM    #define BASE_ADDRESS		0x90e10000 // used for newer hardware core  #elif defined(RTL_PLATFORM)    #define BASE_ADDRESS		0x90710000 // used for RTL simulation  #else    #error "Please define the platfrom flags in project setting (either FPGA_PLATFORM or RTL_PLATFORM)"  #endif#else  #error "Please define the hardware core version (either CORE_VERSION_1 or CORE_VERSION_2)"#endif*/typedef struct {  #ifdef CORE_VERSION_1    // 10 blocks at most.. and each DMA command set occupies 4 words    // so the allocated space requires 4*10*sizeof(unsigned int)    // the system DMA memory space under CORE_VERSION_1 architecture    // the allocated system DMA memory space requires 4-byte alignment.    unsigned int *pSDMA_virt;    unsigned int *pSDMA_phy;  #endif  unsigned char *pCoreBaseAddr;  void * pfnDmaMalloc; // The function pointer to user-defined DMA memory allocation function.    void * pfnDmaFree; // The function pointer to user-defined DMA free allocation function.    unsigned char *outdata[3]; // the output YUV 8-byte aligned buffer (pyhsical address)    // ping pong buffer between VLD-DZ Engine and DQ-MC Engine  //0000 --- 0400 --- 0800 (10 bolcks + 10 blocks)  // since DZAR and QAR require 1KB aligned  unsigned short *pingpong_buf[2];    unsigned int *pLDMA; // DMA command buffer's begin address in local memory  int buf_descriptor1; // used to select ping pong buffer for VLD output  int buf_descriptor2; // used to select buffer between DQ-MC stage and DMA stage (indicated by MCIADDR for DQ-MC engine output)      #ifdef USE_INTERNAL_CPU        unsigned int *pLDMA_INTERNAL_CPU; // DMA command buffer's begin address in local memory                              // for moving internal CPU code to embedded CPU  #endif  } FTMCP100_CODEC;//---------------------------------------------------------------------------//---------------------------------------------------------------------------//--------------- Bank0 ---------------------//#ifdef CORE_VERSION_1  // ping pong buffer between VLD-DZ Engine and DQ-MC Engine  //0000 --- 0400 --- 0800 (10 bolcks + 10 blocks)  // since DZAR and QAR require 1KB aligned  #define PINGPONG_BUFFER_0_ADDR  0x000  #define PINGPONG_BUFFER_1_ADDR  0x800  // DMA_command  #define DMA_COMMAND_LOCAL_ADDR  0x0d00#elif defined(CORE_VERSION_2)  // ping pong buffer between VLD-DZ Engine and DQ-MC Engine  //0000 --- 0400 --- 0800 (10 bolcks + 10 blocks)  // since DZAR and QAR require 1KB aligned  #define PINGPONG_BUFFER_0_ADDR  0x10000  #define PINGPONG_BUFFER_1_ADDR  0x10800  // DMA_command  #define DMA_COMMAND_LOCAL_ADDR  0x10d00#else  #error "Please define the hardware core version (either CORE_VERSION_1 or CORE_VERSION_2)"#endif#ifdef USE_INTERNAL_CPU  #define DMA_COMMAND_INTERNAL_CPU  0x10f00#endif// vld input buffer for hardware's autobuffer#define VLD_AUTOBUFFER_ADDR 0x500#ifdef CORE_VERSION_2  #define TRANSLATE_LOCAL_MEMORY_BASE_ADDRESS(v) ( (((((unsigned int)v)|0x10000)>>1)&0x0fffffffc) | (((unsigned int)v)&0x03) )  #endif//--------------- Bank1 ---------------------//// storing the pointer of each block in MCU (double buffer)#define CUR_B0  (0x4000)      //4000 -- 4280#define CUR_B1  (0x4040)      //4000 -- 4280#define CUR_B2  (0x4080)      //4000 -- 4280#define CUR_B3  (0x40c0)      //4000 -- 4280#define CUR_B4  (0x4100)      //4000 -- 4280#define CUR_B5  (0x4140)      //4000 -- 4280#define CUR_B6  (0x4180)      //4000 -- 4280#define CUR_B7  (0x41c0)      //4000 -- 4280#define CUR_B8  (0x4200)      //4000 -- 4280#define CUR_B9  (0x4240)      //4000 -- 4280// for double buffer's purpose#define STRIDE_MCU 0x280//--------------- Qtable ---------------------//// storing the qval and invqval in local mem (31k~32k)#ifdef CORE_VERSION_1  #define QTBL0  (0x7c00+pCodec->pCoreBaseAddr) //7c00 -- 7cff  #define QTBL1  (0x7d00+pCodec->pCoreBaseAddr) //7d00 -- 7dff  #define QTBL2  (0x7e00+pCodec->pCoreBaseAddr) //7e00 -- 7eff  #define QTBL3  (0x7f00+pCodec->pCoreBaseAddr) //7f00 -- 7fff#elif defined(CORE_VERSION_2)  #define QTBL0  (0x17c00+pCodec->pCoreBaseAddr) //7c00 -- 7cff  #define QTBL1  (0x17d00+pCodec->pCoreBaseAddr) //7d00 -- 7dff  #define QTBL2  (0x17e00+pCodec->pCoreBaseAddr) //7e00 -- 7eff  #define QTBL3  (0x17f00+pCodec->pCoreBaseAddr) //7f00 -- 7fff		    #else  #error "Please define the hardware core version (either CORE_VERSION_1 or CORE_VERSION_2)"#endif//--------------- Bank2,3 ---------------------//// storing the huffman table in local mem (32k~36.5k)  // the smaller huffman table layout in local mem (32k~36.5k)  // Huffman AC Table 0 : 32K    ~ 34K     (0x8000~0x8800) (512 words, 1024 half-words)  // Huffman AC Table 1 : 34K    ~ 36K     (0x8800~0x9000) (512 words, 1024 half-words)     // Huffman DC Table 0 : 36K    ~ 36.25K  (0x9000~0x9100) (64  words, 128  half-words)  // Huffman DC Table 1 : 36.25K ~ 36.5K   (0x9100~0x9200) (64  words, 128  half-words)#ifdef CORE_VERSION_1  #define HUFTBL0_AC  (0x8000+pCodec->pCoreBaseAddr)	     //0x8000 -- 0x8800  #define HUFTBL1_AC  (0x8800+pCodec->pCoreBaseAddr)      //0x8800 -- 0x9000  #define HUFTBL0_DC  (0x9000+pCodec->pCoreBaseAddr)      //0x9000 -- 0x9100  #define HUFTBL1_DC  (0x9100+pCodec->pCoreBaseAddr)      //0x9100 -- 0x9200  #elif defined(CORE_VERSION_2)  #define HUFTBL0_AC  (0x18000+pCodec->pCoreBaseAddr)	     //0x8000 -- 0x8800  #define HUFTBL1_AC  (0x18800+pCodec->pCoreBaseAddr)      //0x8800 -- 0x9000  #define HUFTBL0_DC  (0x19000+pCodec->pCoreBaseAddr)      //0x9000 -- 0x9100  #define HUFTBL1_DC  (0x19100+pCodec->pCoreBaseAddr)      //0x9100 -- 0x9200#else  #error "Please define the hardware core version (either CORE_VERSION_1 or CORE_VERSION_2)"#endif //---------------------------------------------///* added by Leo, zigzag coef order to natural and transposed order */extern const int jpeg_natural_transpozed_order[];//---------------------------------------------------------------------------// DMA Control Registers Structure Definition//---------------------------------------------------------------------------// well, using the strcutre to do register access is possibly platform specific// we improve it later once we are doing the abstraction of register access.#if defined(CORE_VERSION_1)  typedef struct {    unsigned int *SMaddr;    unsigned int *LMaddr;    unsigned int BlkWidth;    unsigned int Control;    unsigned int CCA;    unsigned int Status;  } MDMA;#elif defined(CORE_VERSION_2)  typedef struct {    unsigned int *SMaddr;    unsigned int *LMaddr;    unsigned int BlkWidth;    unsigned int Control;    unsigned int CCA;    unsigned int Status;    unsigned int CCA2;    unsigned int GRPC;    unsigned int GRPS;  } MDMA;#else  #error "Please define the hardware core version (either CORE_VERSION_1 or CORE_VERSION_2)"#endif//---------------------------------------------------------------------------// Register definition//---------------------------------------------------------------------------	#ifdef CORE_VERSION_1	  #define MDMA1     ((volatile MDMA *)(0x10400 + pCodec->pCoreBaseAddr))	      #define MCUBR	    (0x10008 + pCodec->pCoreBaseAddr)      #define MECADDR   (0x10014 + pCodec->pCoreBaseAddr) // mainly used for setting debugging marker during RTL simulation , note that MECADDR[3:0] is ignored      #define MCCTL     (0x1001c + pCodec->pCoreBaseAddr)      #define MCCADDR   (0x10020 + pCodec->pCoreBaseAddr)          #define CPSTS     (0x10028 + pCodec->pCoreBaseAddr)      #define MCUTIR    (0x1002c + pCodec->pCoreBaseAddr)      #define PYDCR	    (0x10030 + pCodec->pCoreBaseAddr)      #define PUVDCR	(0x10034 + pCodec->pCoreBaseAddr)      #define QAR		(0x10038 + pCodec->pCoreBaseAddr)      #define CKR       (0x1003c + pCodec->pCoreBaseAddr)      #define VADR      (0x10044 + pCodec->pCoreBaseAddr)      #define BADR      (0x1004c + pCodec->pCoreBaseAddr)      #define BALR      (0x10050 + pCodec->pCoreBaseAddr)      #define MCIADDR   (0x10058 + pCodec->pCoreBaseAddr)      #define VLDCTL    (0x1005c + pCodec->pCoreBaseAddr)      #define VOP0      (0x10060 + pCodec->pCoreBaseAddr)      #define SCODE     (0x10068 + pCodec->pCoreBaseAddr)      #define VLASTWORD (0x1006c + pCodec->pCoreBaseAddr)      #define VLDSTS    (0x10074 + pCodec->pCoreBaseAddr)	  #define ABADR     (0x10078 + pCodec->pCoreBaseAddr)      #define READ_MCCTL(v)     v=*(volatile unsigned long*)MCCTL;      #define READ_QAR(v)    	v=*(volatile unsigned long*)QAR;      #define READ_VADR(v)		v=*(volatile unsigned long*)VADR;      #define READ_BADR(v)		v=*(volatile unsigned long*)BADR;      #define READ_VOP0(v)  	v=*(volatile unsigned long*)VOP0;      #define READ_CPSTS(v)		v=*(volatile unsigned long*)CPSTS;      #define READ_BALR(v)		v=*(volatile unsigned long*)BALR;      #define READ_VLDCTL(v)    v=*(volatile unsigned long*)VLDCTL;      #define READ_VLASTWORD(v)	v=*(volatile unsigned long*)VLASTWORD;      #define READ_VLDSTS(v)	v=*(volatile unsigned long*)VLDSTS;	//ABF clean      #define READ_ABADR(v)		v=*(volatile unsigned long*)ABADR;	

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一区二区视频| 日韩—二三区免费观看av| 亚洲国产va精品久久久不卡综合| 奇米精品一区二区三区在线观看一| 国产一区二区三区在线观看免费视频| www.日韩av| 精品sm在线观看| 亚洲综合精品久久| 高清在线观看日韩| 日韩欧美国产高清| 一区二区免费看| 福利电影一区二区| 欧美日韩一级黄| 亚洲私人影院在线观看| 国产乱子伦一区二区三区国色天香| 色狠狠一区二区三区香蕉| 国产午夜亚洲精品理论片色戒| 午夜精品久久久久久久| 91网站在线观看视频| 亚洲国产精品av| 韩国视频一区二区| 欧美精品日韩一区| 一区二区成人在线视频| 99久久精品情趣| 国产日韩精品久久久| 久久97超碰色| 91精品麻豆日日躁夜夜躁| 亚洲自拍与偷拍| 91日韩在线专区| 国产精品免费看片| 丰满少妇在线播放bd日韩电影| 精品国产一区二区精华| 日韩不卡免费视频| 欧美日韩国产三级| 亚洲一区二区精品视频| 在线精品视频一区二区三四 | 琪琪一区二区三区| 欧美日韩一区二区三区在线| 亚洲欧美日韩国产另类专区| 成人免费av资源| 久久亚洲一区二区三区明星换脸| 六月丁香综合在线视频| 欧美va天堂va视频va在线| 婷婷国产v国产偷v亚洲高清| 欧美三级蜜桃2在线观看| 亚洲国产一二三| 在线不卡一区二区| 麻豆精品国产传媒mv男同| 精品国精品国产| 国产不卡视频在线观看| 国产精品第一页第二页第三页| a美女胸又www黄视频久久| 亚洲日本va午夜在线电影| 欧美性xxxxxxxx| 美女脱光内衣内裤视频久久网站| 精品奇米国产一区二区三区| 国产成人免费网站| 综合电影一区二区三区 | 日韩午夜激情视频| 久久 天天综合| 中文一区在线播放| 一本一本大道香蕉久在线精品| 亚洲视频中文字幕| 99久久精品免费看国产免费软件| 久久久久一区二区三区四区| 国产成人激情av| 国产精品久久福利| 三级久久三级久久久| 欧美成人伊人久久综合网| 成人av资源网站| 一区二区在线看| av激情成人网| 亚洲风情在线资源站| 91精品国产入口在线| 国精品**一区二区三区在线蜜桃| 久久久91精品国产一区二区三区| 久草热8精品视频在线观看| 久久女同性恋中文字幕| 高清国产一区二区| 日韩美女精品在线| 欧美精选午夜久久久乱码6080| 日韩不卡免费视频| 国产色产综合色产在线视频| 色综合久久久久久久久| 无码av中文一区二区三区桃花岛| 久久亚洲综合色| jlzzjlzz亚洲女人18| 久久精品国产一区二区| 国产精品久久久久久久久快鸭 | 91麻豆国产精品久久| 亚洲视频资源在线| 日韩视频免费观看高清在线视频| 欧美日韩一区高清| 国产在线一区二区| 一区二区三区 在线观看视频| 日韩区在线观看| 91小视频在线| 精品中文字幕一区二区小辣椒| 久久久久成人黄色影片| 91免费在线视频观看| 久久99久久99| 一区二区三区产品免费精品久久75| 精品国内片67194| 在线观看成人免费视频| 国产精品99久久久久久久vr| 亚洲小说春色综合另类电影| 久久精品男人的天堂| 日韩视频永久免费| 欧美性生交片4| 成人影视亚洲图片在线| 日韩高清国产一区在线| 国产精品水嫩水嫩| 日韩欧美在线123| 欧美色图12p| 99精品黄色片免费大全| 成a人片国产精品| 国产真实精品久久二三区| 天天色 色综合| 一区二区三区精品视频在线| 日本一区二区视频在线观看| 欧美日韩一区二区三区不卡| 99久久精品国产观看| 成人午夜激情影院| 久久成人综合网| 日韩成人精品在线观看| 五月天亚洲婷婷| 亚洲韩国一区二区三区| 国产欧美日韩中文久久| 欧美一区二区三区白人| 欧美日韩一二区| 91精品91久久久中77777| 成人激情校园春色| 成人永久aaa| 不卡视频免费播放| www.亚洲色图.com| 国产精品一级片| 麻豆精品一二三| 亚洲国产精品一区二区尤物区| 亚洲制服丝袜av| 一区二区三区蜜桃| 亚洲第一激情av| 午夜精品一区在线观看| 亚洲成人激情社区| 亚洲国产综合色| 亚洲高清免费观看高清完整版在线观看| 天堂资源在线中文精品| 日韩和欧美一区二区三区| 五月婷婷激情综合| 蜜臀久久99精品久久久久宅男 | 666欧美在线视频| 欧美一级黄色录像| 欧美大胆一级视频| 日韩片之四级片| 亚洲欧美日本韩国| 亚洲综合激情网| 日韩高清电影一区| 国产大陆a不卡| 99在线精品视频| 欧美日韩免费高清一区色橹橹| 亚洲精品成人在线| 香蕉乱码成人久久天堂爱免费| 视频一区中文字幕国产| 精品在线免费观看| 成人精品视频网站| 欧美性一级生活| 欧美日韩欧美一区二区| 日韩免费高清电影| 国产女人水真多18毛片18精品视频| 自拍偷自拍亚洲精品播放| 午夜精品久久久久久久久久久| 久久99精品国产麻豆婷婷洗澡| 成人短视频下载| 欧美伊人久久久久久久久影院 | 欧美精品一区二区三区高清aⅴ| 欧美韩日一区二区三区四区| 亚洲一区二区五区| 国内精品久久久久影院色| 欧洲精品一区二区| 久久久久久久久岛国免费| 亚洲人成电影网站色mp4| 精品一区二区精品| 欧美精品第一页| 亚洲天堂a在线| 激情成人午夜视频| 欧美亚州韩日在线看免费版国语版| 久久麻豆一区二区| 中文字幕中文在线不卡住| 国产精品99久久久| 欧美一区二区三区免费视频| 日韩一区中文字幕| 久久av资源站| 欧美欧美欧美欧美首页| 国产精品传媒在线| 日韩福利电影在线观看| 91精品办公室少妇高潮对白| 久久综合久久综合亚洲| 久久精品国产在热久久| 欧美日韩另类一区| 国产精品传媒入口麻豆| 国产一区二区在线影院|