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

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

?? mbus.c

?? SigmDesign SMP8634 media decode chip development SDK
?? C
?? 第 1 頁 / 共 2 頁
字號:
#include "../../llad/include/gbus.h"#include "../../llad/include/dmacpy.h"#include "../include/mbus.h"#include "../../emhwlib_hal/include/emhwlib_registers.h"#include "../../emhwlib/include/emhwlib_chipspecific.h"#if 0#define MBUSDBG ENABLE#else#define MBUSDBG DISABLE#endif#define PCI_TIMEOUT_COUNT (1024*2014)static inline RMint32 wait_for_mbus(struct gbus *pgbus, RMuint32 cmd_addr){	RMuint32 mbus_count = 0;	while (gbus_read_uint32(pgbus, cmd_addr) & 7) {		mbus_count ++;		if (mbus_count>PCI_TIMEOUT_COUNT) {			RMDBGLOG((ENABLE, "MBUS FROZEN\n"));			return 1;		}	}	return 0;}static inline RMint32 get_mbus_status(struct gbus *pgbus, RMuint32 cmd_addr){	static RMuint32 mbus_count = 0;	if (gbus_read_uint32(pgbus, cmd_addr) & 7) {		mbus_count ++;		if (mbus_count>PCI_TIMEOUT_COUNT) {			RMDBGLOG((ENABLE, "MBUS FROZEN\n"));			return 1;		}		return -mbus_count;	}	mbus_count = 0;	return 0;}static inline RMint32 wait_for_pci(struct gbus *pgbus, RMuint32 pci_en_addr, RMuint32 pci_cnt_addr){	RMuint32 pci_count = 0, old_pci_count = 0;	RMuint32 i = 0;	if (gbus_read_uint32(pgbus, pci_en_addr)) {		while ((pci_count = gbus_read_uint32(pgbus, pci_cnt_addr))) {			if (old_pci_count == pci_count) 				i++;			else 				i = 0;			old_pci_count = pci_count;			if (i>PCI_TIMEOUT_COUNT) {				RMDBGLOG((ENABLE, "PCI FROZEN\n"));				return -pci_count;			}		}		gbus_write_uint32(pgbus, pci_en_addr, 0);	}	return 0;}static inline RMint32 get_pci_status(struct gbus *pgbus, RMuint32 pci_cnt_addr){	static RMuint32 pci_count = 0;	static RMuint32 old_pci_count = 0;	static RMuint32 i = 0;	if ((pci_count = gbus_read_uint32(pgbus, pci_cnt_addr))) {		if (old_pci_count == pci_count) 			i++;		else 			i = 0;		old_pci_count = pci_count;		if (i>PCI_TIMEOUT_COUNT) {			RMDBGLOG((ENABLE, "PCI FROZEN\n"));			return -pci_count;		}		return 1;	}	i = 0;	return 0;}RMint32 mbus_write_dram(struct llad *pllad, RMuint32 addr, RMuint8 *data, RMuint32 size, RMuint32 max_pci_size){	RMuint32 pci_size = size;    	RMuint32 mbus_size = size;	RMuint32 dma_size, dma_bus_address, half_dma_size, offset;	RMuint32 xfer_dma_size = 0;	RMint32 status = 0;	struct gbus *pgbus;	struct dmacpy *pdmacpy; 	if (max_pci_size > 65532) {		RMDBGLOG((MBUSDBG, "bad value for max_pci_size %lu\n", max_pci_size));		return max_pci_size;	}	pgbus = gbus_open(pllad);	pdmacpy = dmacpy_open(pllad);	dmacpy_get_info(pdmacpy, &dma_size, &dma_bus_address);	half_dma_size = dma_size / 2;	offset = 0;	RMDBGLOG((MBUSDBG, "dma size is %lu bytes at bus address 0x%08x\n", dma_size, dma_bus_address));	// Wait for MBUS interface	if ((status = wait_for_mbus(pgbus, REG_BASE_host_interface+MIF_W1_CMD)))		goto exit_mbus_write_dram;	// Wait for PCI Master	if ((status = wait_for_pci(pgbus, REG_BASE_host_interface+READ_ENABLE, REG_BASE_host_interface+READ_COUNTER)))		goto exit_mbus_write_dram;	// Program the switchbox	hostsbox_pcimaster_channel1(pgbus);	// Program endianness (0 on little-endian systems, 1 on big-endian systems)	gbus_write_uint32(pgbus, REG_BASE_host_interface+READ_REVERSE, 0x0);	gbus_write_uint32(pgbus, REG_BASE_host_interface+MIF_W1_SKIP, 0);    	while (mbus_size || pci_size) {		if ((xfer_dma_size == 0) && (pci_size > 0)) {			xfer_dma_size = RMmin(max_pci_size, RMmin(half_dma_size, pci_size));			dmacpy_write_data(pdmacpy, offset, data, xfer_dma_size);		}					// MBUS side		if (mbus_size > 0) {			status = get_mbus_status(pgbus, REG_BASE_host_interface+MIF_W1_CMD);			if (status == 0) {				RMuint32 xfer_size = RMmin(8191, mbus_size);				RMDBGLOG((MBUSDBG, "program a mbus xfer. addr=0x%08x, size=%lu\n", addr, xfer_size));				gbus_write_uint32(pgbus, REG_BASE_host_interface+MIF_W1_ADD, addr);				gbus_write_uint32(pgbus, REG_BASE_host_interface+MIF_W1_CNT, xfer_size);				gbus_write_uint32(pgbus, REG_BASE_host_interface+MIF_W1_CMD, MBUS_LINEAR);				addr += xfer_size;				mbus_size -= xfer_size;			}			else if (status > 0) 				goto exit_mbus_write_dram;		}				// PCI Master side		if (xfer_dma_size > 0) {			status = get_pci_status(pgbus, REG_BASE_host_interface+READ_COUNTER);			if (status == 0) {				RMDBGLOG((MBUSDBG, "program a pci xfer. addr=0x%08x, size=%lu\n", dma_bus_address + offset, xfer_dma_size));				gbus_write_uint32(pgbus, REG_BASE_host_interface+READ_ENABLE, 0);				gbus_write_uint32(pgbus, REG_BASE_host_interface+READ_ADDRESS, dma_bus_address + offset);				gbus_write_uint32(pgbus, REG_BASE_host_interface+READ_COUNTER, xfer_dma_size);				gbus_write_uint32(pgbus, REG_BASE_host_interface+READ_ENABLE, 1);				data += xfer_dma_size;				pci_size -= xfer_dma_size;				offset = (offset + half_dma_size) & (dma_size - 1); // dma_size is a power of 2				xfer_dma_size = 0;			}			else if (status < 0)				goto exit_mbus_write_dram;		}	}	// Push a void command to the command FIFO and wait for its completion	if ((status = wait_for_mbus(pgbus, REG_BASE_host_interface+MIF_W1_CMD))) 		goto exit_mbus_write_dram;	gbus_write_uint32(pgbus, REG_BASE_host_interface+MIF_W1_CMD, MBUS_VOID);	if ((status = wait_for_mbus(pgbus, REG_BASE_host_interface+MIF_W1_CMD)))		goto exit_mbus_write_dram;		// Wait for PCI to finish	if ((status = wait_for_pci(pgbus, REG_BASE_host_interface+READ_ENABLE, REG_BASE_host_interface+READ_COUNTER)))		goto exit_mbus_write_dram; exit_mbus_write_dram:	dmacpy_close(pdmacpy);	gbus_close(pgbus);	return status;}RMint32 mbus_read_dram(struct llad *pllad, RMuint32 addr, RMuint8 *data, RMuint32 size, RMuint32 max_pci_size){	RMuint32 pci_size = size;	RMuint32 read_size = 0, old_read_size = 0;	RMuint32 dma_size, dma_bus_address, half_dma_size, offset;	RMint32 status = 0;	struct gbus *pgbus;	struct dmacpy *pdmacpy; 	if (size % 4)  {		RMDBGLOG((MBUSDBG, "size not a multiple of 4 bytes %lu\n", size));		return size;	} 	if ((max_pci_size % 4) || (max_pci_size > 65532)) {		RMDBGLOG((MBUSDBG, "bad value for max_pci_size %lu\n", max_pci_size));		return max_pci_size;	}	pgbus = gbus_open(pllad);	pdmacpy = dmacpy_open(pllad);	dmacpy_get_info(pdmacpy, &dma_size, &dma_bus_address);	half_dma_size = dma_size / 2;	offset = 0;	RMDBGLOG((MBUSDBG, "dma size is %lu bytes at bus address 0x%08x\n", dma_size, dma_bus_address));	// Wait for MBUS interface	if ((status = wait_for_mbus(pgbus, REG_BASE_host_interface+MIF_R1_CMD)))		goto exit_mbus_read_dram;	// Wait for PCI Master	if ((status = wait_for_pci(pgbus, REG_BASE_host_interface+WRITE_ENABLE, REG_BASE_host_interface+WRITE_COUNTER)))		goto exit_mbus_read_dram;	// Program the switchbox	hostsbox_pcimaster_channel1(pgbus);	// Program endianness (0 on little-endian systems, 1 on big-endian systems)	gbus_write_uint32(pgbus, REG_BASE_host_interface+READ_REVERSE, 0x0);	gbus_write_uint32(pgbus, REG_BASE_host_interface+MIF_R1_SKIP, 0);	while (pci_size) {		RMuint32 xfer_dma_size;		xfer_dma_size = RMmin(half_dma_size, RMmin(max_pci_size, pci_size));		old_read_size = read_size;		read_size = xfer_dma_size;				RMDBGLOG((MBUSDBG, "program a pci xfer. addr=0x%08x, size=%lu\n", dma_bus_address + offset, xfer_dma_size));		gbus_write_uint32(pgbus, REG_BASE_host_interface+WRITE_ENABLE, 0);		gbus_write_uint32(pgbus, REG_BASE_host_interface+WRITE_ADDRESS, dma_bus_address + offset);		gbus_write_uint32(pgbus, REG_BASE_host_interface+WRITE_COUNTER, xfer_dma_size);		gbus_write_uint32(pgbus, REG_BASE_host_interface+WRITE_ENABLE, 1);		pci_size -= xfer_dma_size;		while (xfer_dma_size > 0) {			RMuint32 mbus_size = RMmin(8191, xfer_dma_size);						RMDBGLOG((MBUSDBG, "program a mbus xfer. addr=0x%08x, size=%lu\n", addr, mbus_size));

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧亚洲嫩模精品一区三区| 成人av电影免费观看| 亚洲精品成人a在线观看| 亚洲国产精品精华液2区45| 久久伊99综合婷婷久久伊| 久久久精品国产免费观看同学| 欧美一区二区三区免费视频| 日韩三级视频在线看| 精品久久久久一区二区国产| 国产人成亚洲第一网站在线播放 | 日本韩国欧美三级| 色天使色偷偷av一区二区| 在线免费观看视频一区| 欧美午夜精品理论片a级按摩| 欧美色综合网站| 日韩三级免费观看| 中文字幕精品一区二区精品绿巨人| 亚洲欧美在线观看| 天堂午夜影视日韩欧美一区二区| 美女网站视频久久| 成人综合婷婷国产精品久久免费| 色婷婷av久久久久久久| 日韩免费高清视频| 一区二区中文字幕在线| 丝袜诱惑制服诱惑色一区在线观看| 精品一区二区综合| 99视频一区二区| 欧美电影精品一区二区| 亚洲视频你懂的| 久久99蜜桃精品| 色综合中文字幕国产| 欧美欧美欧美欧美首页| 国产日韩欧美高清在线| 亚洲成a人片综合在线| 国产伦精品一区二区三区视频青涩 | 国产91精品入口| 欧美色倩网站大全免费| 国产日韩欧美电影| 免费在线观看不卡| 97久久精品人人爽人人爽蜜臀 | 精品国产区一区| 亚洲综合无码一区二区| 国产精品性做久久久久久| 欧美视频一区二区三区在线观看 | 亚洲欧美另类小说| 精品亚洲成a人| 4438x成人网最大色成网站| 亚洲午夜久久久久久久久久久| 激情综合色播激情啊| 欧美日韩dvd在线观看| 亚洲日本一区二区三区| 国产·精品毛片| 日韩女同互慰一区二区| 亚洲电影你懂得| 色美美综合视频| 亚洲婷婷综合久久一本伊一区| 国产在线播放一区三区四| 欧美人妇做爰xxxⅹ性高电影| 亚洲免费大片在线观看| 成人性视频网站| 国产视频一区二区在线观看| 美女一区二区三区在线观看| 9191国产精品| 日本美女视频一区二区| 911国产精品| 日韩成人一级片| 91.麻豆视频| 奇米四色…亚洲| 日韩一区二区麻豆国产| 美女一区二区三区在线观看| 欧美一卡2卡3卡4卡| 秋霞影院一区二区| 日韩欧美亚洲国产精品字幕久久久| 日韩高清不卡一区二区| 91精品国产高清一区二区三区| 亚洲国产裸拍裸体视频在线观看乱了 | 欧美在线免费观看亚洲| 亚洲精品日日夜夜| 在线视频你懂得一区| 午夜精品久久久久久久99樱桃| 欧美亚洲国产一区二区三区| 亚洲精品视频自拍| 欧美精品第一页| 精品中文av资源站在线观看| 久久久噜噜噜久久人人看| 国产一区999| 国产精品久久影院| 在线一区二区三区做爰视频网站| 亚洲一区国产视频| 欧美一区二区三区不卡| 国产一区二区伦理| 亚洲三级免费观看| 制服丝袜在线91| 国产成人精品免费视频网站| 亚洲天堂2016| 日韩视频一区二区三区| zzijzzij亚洲日本少妇熟睡| 亚洲线精品一区二区三区| 精品久久久久一区| av在线一区二区三区| 日韩经典一区二区| 国产精品护士白丝一区av| 欧美亚洲国产一区在线观看网站| 卡一卡二国产精品 | 欧美本精品男人aⅴ天堂| 高清国产一区二区| 午夜视黄欧洲亚洲| 日本一区二区三区四区在线视频| 91麻豆福利精品推荐| 久久成人麻豆午夜电影| 国产精品成人免费精品自在线观看| 色偷偷成人一区二区三区91| 激情六月婷婷久久| 亚洲精品一二三| 国产网站一区二区| 91精品欧美久久久久久动漫| 成人精品免费网站| 蜜桃久久久久久久| 一区二区视频在线| 国产午夜亚洲精品羞羞网站| 欧美男人的天堂一二区| 99久久99久久综合| 国产二区国产一区在线观看 | 精品美女一区二区| 欧美性videosxxxxx| 粉嫩av一区二区三区粉嫩| 青椒成人免费视频| 亚洲成人av一区二区| 亚洲免费电影在线| 中文字幕一区二区三区乱码在线 | 亚洲欧美激情小说另类| 久久五月婷婷丁香社区| 欧美日韩国产欧美日美国产精品| 91亚洲精品久久久蜜桃网站| 国产成a人亚洲精品| 国产真实乱对白精彩久久| 免费成人在线视频观看| 三级一区在线视频先锋| 一区二区三区加勒比av| 国产精品久久久久天堂| 国产亚洲精品aa午夜观看| 久久婷婷久久一区二区三区| 91精品国产全国免费观看| 精品视频在线免费看| 欧美艳星brazzers| 欧美在线视频全部完| 欧美视频日韩视频在线观看| 一本大道综合伊人精品热热 | 亚洲成人福利片| 亚洲高清免费观看高清完整版在线观看 | 亚洲国产日韩一级| 亚洲午夜免费福利视频| 亚洲成av人片在线观看无码| 亚洲成av人片观看| 日韩精品电影在线观看| 久久精品二区亚洲w码| 精品一区中文字幕| 国产91精品一区二区麻豆网站| 国产电影精品久久禁18| 成人免费黄色在线| 色噜噜偷拍精品综合在线| 欧美性视频一区二区三区| 69堂成人精品免费视频| 欧美不卡123| 国产精品国产a| 一区二区三区四区在线| 偷偷要91色婷婷| 经典三级在线一区| av中文字幕亚洲| 欧美二区三区91| 久久久夜色精品亚洲| 国产精品毛片大码女人| 亚洲国产精品久久不卡毛片| 麻豆国产91在线播放| 风间由美一区二区av101 | 国产毛片精品视频| 91丨porny丨首页| 欧美精品日日鲁夜夜添| 久久午夜免费电影| 亚洲一区国产视频| 国产精品一二三区| 欧美午夜精品理论片a级按摩| 精品乱人伦小说| 夜夜夜精品看看| 国产精品资源在线| 欧美午夜不卡视频| 国产亚洲欧洲一区高清在线观看| 亚洲精品v日韩精品| 极品美女销魂一区二区三区| 日本高清不卡在线观看| 久久色.com| 亚洲h在线观看| 91视频观看免费| 精品福利在线导航| 亚洲成人免费观看| 91在线免费看| 欧美激情一区在线| 精品写真视频在线观看| 欧美日韩在线精品一区二区三区激情| 国产午夜精品一区二区三区四区|