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

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

?? pci_dma_test.c

?? ADI公司ADSP-TS101S的主機編程
?? C
字號:
//*********************************************************
//
//  pci_dma_test.c : Program to test TPCI_LIB functions for
//  block DMAs over PCI on the TigerSharc platform.
//
//  PROVIDED BY:
//  ------------
//  BittWare, Inc.
//  33 North Main Street
//  Concord, NH  03301
//  Ph: 603-226-0404
//  Fax: 603-226-6667
//  WWW: www.bittware.com
//  E-mail: support@bittware.com
//
//  Copyright (c) 2002
//
//  The user is hereby granted a non-exclusive license to use and or 
//  modify this software provided that it runs on BittWare hardware.  
//  Usage of this software on non-BittWare hardware without the express 
//  written permission of BittWare is strictly prohibited.
//    Ver.  Dates     Author  Changes                                
//    ----  --------  ------  -----------------------------
//    1.0   04/03/02   rpc     Create
//
//*********************************************************
#include <sysreg.h>
#include "tfin.h"
#include "tfin_pci.h"
#include "utils.h"

#define BUF_SIZE   4096

// hardcode the buffer address here if you so choose
//volatile int pci_addr = 0x00432000;
volatile int pci_addr = 0x0;
volatile int done;
unsigned int addr;
int read_ticks, write_ticks;
float read_rate, write_rate, average_read_rate, average_write_rate;

int tx_stat;
int rx_stat;
int xfer_errors[16] = {0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 
                       0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff};
int errors = 0;
int loop;
int loops_to_run = 0x1000;
int src_array[BUF_SIZE];
int dst_array[BUF_SIZE];
volatile int rx_intr_count = 0;

void fin_rx_dma_complete(int sig)
{
    //Fin_PCI_CB_DMA_Clear_Interrupt();
	rx_intr_count++;
}

////////////////////////////////////////////////////////////////////////////////
//               main
////////////////////////////////////////////////////////////////////////////////
void main(void)
{
    int i,j; 

	// Set up Tiger
	init_Tiger();
	done = 0;

	prep_leds();

	// Flag 2 is a done indicator and flag 3 toggles for each completed DMA
	// also, at done Flag 3 is illuminated if there were no errors
	leds_off(FLG2 | FLG3);

	/* Init the source buffer with some static data patterns, breaking it into 16 pieces 
	   and leaving the upper half for counters in each test							*/

	// Alternating bits both within and between bytes
	for (i=0; i<(BUF_SIZE/16); i++)
	{
		src_array[i] = 0xaa55aa55;			
	}

	// Reverse alternating bits
	for (i=(BUF_SIZE/16); i<(2*(BUF_SIZE/16)); i++)
	{
		src_array[i] = 0x55aa55aa;
	}

	// All bits on and off between nibbles
	for (i=(2*(BUF_SIZE/16)); i<(3*(BUF_SIZE/16)); i++)
	{
		src_array[i] = 0x0f0f0f0f;		
	}

	// Reverse all bits on and off betwen nibbles
	for (i=(3*(BUF_SIZE/16)); i<(4*(BUF_SIZE/16)); i++)
	{
		src_array[i] = 0xf0f0f0f0;
	}

	// All bits on and off between bytes
	for (i=(4*(BUF_SIZE/16)); i<(5*(BUF_SIZE/16)); i++)
	{
		src_array[i] = 0x00ff00ff;		
	}

	// Reverse all bits on and off
	for (i=(5*(BUF_SIZE/16)); i<(6*(BUF_SIZE/16)); i++)
	{
		src_array[i] = 0xff00ff00;
	}

	// All bits on and off on link word size (128 bit) boundaries
	for (i=(6*(BUF_SIZE/16)); i<(7*(BUF_SIZE/16)); i+=8)
	{
		for (j=0; j<4; j++)
			src_array[i+j] = 0x0;
		for (j=4; j<8; j++)
			src_array[i+j] = 0xffffffff;
	}

	// All bits on and off on 32 bit link word size boundaries
	for (i=(7*(BUF_SIZE/16)); i<(8*(BUF_SIZE/16)); i+=2)
	{
		src_array[i] = 0x0;
		src_array[i+1] = 0xffffffff;
	}


	// Init the PCI interface
	TigerFin_PCI_Init();

	// If the host hasn't set a pci address, use my own internal memory, which means
	// it goes out the SharcFIN onto the local PCI bus and back in again
	if (pci_addr == 0x0) {
		TigerFin_PCI_CFG_Read(HOST_BAR4_ADDR, (int *)&pci_addr);
		// offset into my internal memory 2 block
		pci_addr &= 0xFFFFFFF0;
		pci_addr += (GetIDC() * 0x200000 + 0x100008) * 4;
		SetFIN(THRESH_PREF_CNTL, 0x1000);            // setup prefetching to move data quickly
	}

	average_read_rate = 0;
	average_write_rate = 0;

	for(loop = 0; loop < loops_to_run; loop++)
	{

		// Fill the rest of the source buffer
		// Put incrementing pattern in half
		for (i=(2*(BUF_SIZE/4));i<(3*(BUF_SIZE/4));i++)
	    {
	        src_array[i] = i + (loop << 16);
	    }
	
		// Put inverse of incrementing pattern in other half
		for (i=(3*(BUF_SIZE/4));i<(4*(BUF_SIZE/4));i++)
	    {
	        src_array[i] = ~(i + (loop << 16));
	    }

		// Time the block transfers and use it to compute average read and write rates

		init_timer(0, 0x0, 0xFFFFFFFF);
		start_timer(0);

		tx_stat = TigerFin_PCI_CB_DMA_Write(src_array, (int *)pci_addr, BUF_SIZE, 1, 0, 0, 1);

		write_ticks = 0xFFFFFFFF - stop_timer(0);

		toggle_leds(FLG3);

		init_timer(0, 0x0, 0xFFFFFFFF);
		start_timer(0);

		rx_stat = TigerFin_PCI_CB_DMA_Read(dst_array, (int *)pci_addr, BUF_SIZE, 1, 0, 0 ,1, 0);

		read_ticks = 0xFFFFFFFF - stop_timer(0);

		toggle_leds(FLG3);
		for(i = 0; i < BUF_SIZE; i++)
		{
		    if(dst_array[i] != src_array[i])
			    errors++;
		}
		// rate = #ofbytes/time 
		// #ofbytes = 4 * #of32bitwords
		// time = ticks*timerpertick
		// timerpertick = 1/250MHz

		read_rate = (4 * BUF_SIZE * 250000000.0) / (float)read_ticks; 
		write_rate = (4 * BUF_SIZE * 250000000.0) / (float)write_ticks; 
		average_read_rate += read_rate;
		average_write_rate += write_rate;
	}

	average_read_rate /= (float)loops_to_run;
	average_write_rate /= (float)loops_to_run;

	/*
	// FlyBy function test.
	init_timer(0, 0x0, 0xFFFFFFFF);
	start_timer(0);

	rx_stat = TigerFin_PCI2SDRAM_Flyby_Read((int *)SDRAM_ADDR, (int *)pci_addr, BUF_SIZE, 1, 0, 1);

	read_ticks = 0xFFFFFFFF - stop_timer(0);

	toggle_flags(FLG3);

	init_timer(0, 0x0, 0xFFFFFFFF);
	start_timer(0);

	tx_stat = TigerFin_SDRAM2PCI_Flyby_Write((int *)SDRAM_ADDR, (int *)(pci_addr + (4*BUF_SIZE)), BUF_SIZE, 1, 0);

	write_ticks = 0xFFFFFFFF - stop_timer(0);

	read_rate = (4 * BUF_SIZE * 250000000.0) / (float)read_ticks; 
	write_rate = (float)(4 * BUF_SIZE * 250000000.0) / (float)write_ticks; 
	*/

	leds_on(FLG2);
	if (errors) leds_off(FLG3);
    else leds_on(FLG3);
	// do not allow the code to end due to compiler probs/TS anomallies
	while (1) done = 1;
}


?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲特黄一级片| 777欧美精品| 最新日韩av在线| 91偷拍与自偷拍精品| 亚洲美女淫视频| 欧美在线观看视频在线| 午夜精品久久久久久久99樱桃| 欧美日韩精品一区二区三区| 日本一区中文字幕| 欧美国产精品劲爆| 在线观看不卡一区| 免费av成人在线| 久久久美女艺术照精彩视频福利播放| 国产传媒欧美日韩成人| 日韩码欧中文字| 欧美老肥妇做.爰bbww| 狠狠色狠狠色综合系列| 亚洲日本在线a| 日韩视频在线永久播放| 高清日韩电视剧大全免费| 亚洲精品久久7777| 欧美一区二区三区视频免费播放 | 久久婷婷久久一区二区三区| 不卡在线视频中文字幕| 日日夜夜免费精品| 国产精品欧美久久久久一区二区 | 欧美丰满美乳xxx高潮www| 精品一区二区成人精品| 亚洲人成电影网站色mp4| 91精品一区二区三区久久久久久 | 懂色av一区二区在线播放| 亚洲女与黑人做爰| 亚洲精品在线电影| 色天天综合久久久久综合片| 六月婷婷色综合| 亚洲乱码国产乱码精品精的特点 | 91看片淫黄大片一级在线观看| 石原莉奈在线亚洲二区| 国产精品麻豆欧美日韩ww| 欧美一区二区福利视频| 99热这里都是精品| 国产主播一区二区三区| 亚洲成av人片一区二区三区| 久久亚洲综合色一区二区三区| 99视频在线精品| 国产精品一区二区久久不卡| 婷婷开心久久网| 亚洲乱码一区二区三区在线观看| 久久这里只有精品6| 日韩一级高清毛片| 欧美日韩一区二区三区在线看| 国产成人av电影在线| 老鸭窝一区二区久久精品| 手机精品视频在线观看| 中文字幕一区二区不卡| 日韩免费性生活视频播放| 一本到三区不卡视频| 大白屁股一区二区视频| 黄页网站大全一区二区| 麻豆精品一区二区av白丝在线| 日韩专区一卡二卡| 亚洲国产日韩a在线播放| 亚洲女同ⅹxx女同tv| 亚洲同性同志一二三专区| 国产日产亚洲精品系列| 久久亚洲精品国产精品紫薇| 精品欧美一区二区久久| 91麻豆精品国产| 欧美男女性生活在线直播观看| 91丨九色丨国产丨porny| 99久久99久久精品免费看蜜桃| 国产精品亚洲一区二区三区妖精 | 男人的j进女人的j一区| 视频一区二区不卡| 免费观看在线综合| 久久se这里有精品| 国产精品中文字幕欧美| 国产高清精品在线| 成人一区二区三区在线观看| 国产不卡视频在线观看| caoporn国产一区二区| av在线综合网| 一本大道av伊人久久综合| 97精品久久久午夜一区二区三区| 成人福利视频网站| 色综合久久精品| 欧美三级电影网站| 日韩欧美不卡一区| 国产欧美精品一区二区色综合| 国产日韩欧美综合在线| 国产精品网站在线播放| 亚洲婷婷在线视频| 三级不卡在线观看| 久久99国产精品免费网站| 国产福利不卡视频| 99久久亚洲一区二区三区青草| 色综合久久综合网欧美综合网| 欧美揉bbbbb揉bbbbb| 精品蜜桃在线看| 国产精品久久二区二区| 亚洲香肠在线观看| 经典一区二区三区| 99精品视频在线观看| 欧美日韩国产高清一区| 久久综合色婷婷| 亚洲卡通欧美制服中文| 日韩av午夜在线观看| 国产99久久久久久免费看农村| 色哟哟欧美精品| 久久亚洲精品小早川怜子| 亚洲精品大片www| 久久66热偷产精品| 91麻豆精东视频| 日韩一区二区视频| 国产精品乱子久久久久| 午夜精品久久久久久| 成人网在线播放| 91精品欧美久久久久久动漫| 中文字幕乱码亚洲精品一区| 午夜精品一区在线观看| 黑人精品欧美一区二区蜜桃 | 欧美一区二区视频在线观看2020 | 国产一区二区三区在线观看免费视频 | 国产精品资源在线观看| 欧洲一区二区三区免费视频| 精品久久国产字幕高潮| 中文字幕亚洲区| 久久99热这里只有精品| 91久久久免费一区二区| 久久久久久久久久久久久夜| 午夜久久久久久久久| 91小视频在线| 国产丝袜欧美中文另类| 美洲天堂一区二卡三卡四卡视频| av电影天堂一区二区在线观看| 日韩欧美精品三级| 日日夜夜免费精品| 欧美天堂一区二区三区| 亚洲国产精品成人久久综合一区| 天堂久久一区二区三区| 9人人澡人人爽人人精品| 久久一日本道色综合| 日本怡春院一区二区| 欧美日韩国产首页在线观看| 亚洲欧美一区二区三区国产精品| 国产精品99久| 久久久久久久久99精品| 久久aⅴ国产欧美74aaa| 91精品国产91久久久久久最新毛片| 1024成人网| av网站一区二区三区| 国产精品美女久久久久久久久 | 亚洲亚洲人成综合网络| 色综合一区二区三区| 国产精品久久免费看| 国产高清无密码一区二区三区| 日韩欧美一级精品久久| 美女一区二区三区在线观看| 884aa四虎影成人精品一区| 亚洲精品成人少妇| 91麻豆福利精品推荐| 亚洲三级免费电影| 色悠悠久久综合| 一区二区三区四区激情| 日本韩国一区二区三区视频| 亚洲老妇xxxxxx| 欧美日韩一区成人| 亚洲国产精品自拍| 欧美日韩免费视频| 午夜久久久久久久久| 在线综合+亚洲+欧美中文字幕| 日韩成人一级大片| 精品国内二区三区| 成人性色生活片免费看爆迷你毛片| 国产精品毛片高清在线完整版| 99精品久久只有精品| 亚洲天堂a在线| 欧美人狂配大交3d怪物一区| 久久激情五月激情| 国产三级精品三级| 色婷婷国产精品久久包臀 | 久久亚洲二区三区| 国产福利一区二区三区视频在线 | 国产成人免费高清| 日韩美女视频19| 欧美精品黑人性xxxx| 久久国产精品99久久人人澡| 久久精品人人做人人爽人人| 91网站在线观看视频| 午夜久久久久久久久久一区二区| 欧美刺激午夜性久久久久久久| 国产一区999| 一二三四区精品视频| 日韩一区二区三区在线视频| 国产成人免费9x9x人网站视频| 亚洲人成网站色在线观看| 日韩一级精品视频在线观看| 成人97人人超碰人人99| 舔着乳尖日韩一区| 国产亚洲一区二区三区四区 |