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

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

?? media_lb_bw_on_sf_iface_tx.uc

?? 開發Inetl IXP2400平臺所必須的硬件診斷和測試程序。該軟件包支持的功能包括CPU基本功能檢測
?? UC
字號:
/* media_lb_pl_on_sf_iface_tx.uc
 *
 *---------------------------------------------------------------------------
 *                                                                      
 *                  I N T E L   P R O P R I E T A R Y                   
 *                                                                      
 *     COPYRIGHT (c)  2002 BY  INTEL  CORPORATION.  ALL RIGHTS          
 *     RESERVED.   NO  PART  OF THIS PROGRAM  OR  PUBLICATION  MAY      
 *     BE  REPRODUCED,   TRANSMITTED,   TRANSCRIBED,   STORED  IN  A    
 *     RETRIEVAL SYSTEM, OR TRANSLATED INTO ANY LANGUAGE OR COMPUTER    
 *     LANGUAGE IN ANY FORM OR BY ANY MEANS, ELECTRONIC, MECHANICAL,    
 *     MAGNETIC,  OPTICAL,  CHEMICAL, MANUAL, OR OTHERWISE,  WITHOUT    
 *     THE PRIOR WRITTEN PERMISSION OF :                                
 *                                                                      
 *                        INTEL  CORPORATION                            
 *                                                                     
 *                     2200 MISSION COLLEGE BLVD                        
 *                                                                      
 *               SANTA  CLARA,  CALIFORNIA  95052-8119                  
 *                                                                      
 *---------------------------------------------------------------------------
 *
 *
 *  system: IXDP2400
 *  subsystem: DIAG
 *  author: dalsraja, April, 2002
 *  revisions: cmah1, March 11, 2003
 * 
 * 
 * --------------------------------------------------------------------------
 */

#include "common_uc.h"

#define TX_ELEMENT_SIZE				MSF_ELEMENTSIZE_128
#define TX_ENABLE_MASK				0xF
#define TX_MODE						MSF_POS_UTOPIA
#define TX_WIDTH					MSF_WIDTH_4x8
#define TX_SINGLE_PHY				MSF_SINGLE_PHY

#define TBUF_ELEM_COUNT				(1 << (7 - TX_ELEMENT_SIZE))
#define TBUF_ADDR_SHF				(6 + TX_ELEMENT_SIZE)
#define TX_ELEMENTSIZE_BYTE			(1 << TBUF_ADDR_SHF)

#define TBUF_ELEM_COUNT_4PORT		((TBUF_ELEM_COUNT >> 2) - 1)

#define TX_CONTROL_EOP				(1 << 8)
#define TX_CONTROL_SOP				(1 << 9)

#define INTERTHD_SIG_NUM			15

#define POS_PAYLOAD_LENGTH			64
#define DRAM_BASE_SRC				0x1000000

.reg MsfAddress MsfAddress0 MsfAddress1
.reg pci_base get_ring_num put_ring_num @packet_count
.reg port_count
.reg byte_count cur_ctx
.reg TxConfigData0
.reg $TxConfigData0
.reg $TxControlWord0 $TxControlWord1
.reg tbuf_element tbuf_1st_element tbuf_mask
.reg dram_addr tbuf
.sig dram_sig msf_sig interthd_sig

.xfer_order $TxControlWord0 $TxControlWord1

.addr interthd_sig INTERTHD_SIG_NUM
.set_sig interthd_sig

Init_Value#:
	br=ctx[0, init_all#]
	br=ctx[1, init_all#]
	br=ctx[2, init_all#]
	br=ctx[3, init_all#]
	ctx_arb[kill]

init_all#:
	.local temp
	local_csr_rd[ACTIVE_CTX_STS]
	immed[temp, 0]
	alu[cur_ctx, MASK_3BIT, AND, temp]		// Extract the current context number
	.endlocal

	immed[tbuf, RBUF_TBUF]
	immed[tbuf_mask, ((TBUF_ELEM_COUNT >> 2) - 1)]
	immed[@packet_count, 0]
	immed[port_count, 0]

	alu[tbuf_1st_element, --, B, cur_ctx, <<4]
	alu[get_ring_num , --, B, cur_ctx, <<2]
	alu[put_ring_num , --, B, RING_4, <<2]

	.if (cur_ctx > 0)
		ctx_arb[interthd_sig]
		br[start#]
	.endif


//****************************************************
// Configure TX Control
//****************************************************
	immed[MsfAddress, MSF_TX_CONTROL]
	immed[TxConfigData0, (TX_ELEMENT_SIZE << 2)]	// put control and data into diff freelist
	immed_w1[TxConfigData0, ((TX_ENABLE_MASK << 8) | (TX_MODE << 6) | (TX_WIDTH << 4) | (TX_SINGLE_PHY << 3) | (0<<1)|(0<<0))]
	alu[$TxConfigData0, --, B, TxConfigData0]
	msf[write, $TxConfigData0, MsfAddress, 0, 1], ctx_swap[msf_sig]


//****************************************************
// Configure TX_UP_Control_# (# = 0 - 3)
//****************************************************
//	immed[TxConfigData0, (UP_CTRL_CP_MODE | UP_CTRL_PARITY_ODD | UP_CTRL_CELLSIZE | UP_CTRL_DRTIME)]
	immed[TxConfigData0, (UP_CTRL_CP_MODE | UP_CTRL_PARITY | UP_CTRL_CELLSIZE | UP_CTRL_DRTIME)]
	alu[$TxConfigData0, --, B, TxConfigData0]
	immed[MsfAddress, TX_UP_CONTROL_0]
	msf[write, $TxConfigData0, MsfAddress, 0, 1], ctx_swap[msf_sig]
	immed[MsfAddress, TX_UP_CONTROL_1]
	msf[write, $TxConfigData0, MsfAddress, 0, 1], ctx_swap[msf_sig]
	immed[MsfAddress, TX_UP_CONTROL_2]
	msf[write, $TxConfigData0, MsfAddress, 0, 1], ctx_swap[msf_sig]
	immed[MsfAddress, TX_UP_CONTROL_3]
	msf[write, $TxConfigData0, MsfAddress, 0, 1], ctx_swap[msf_sig]


//****************************************************
// Configure TX Control
//****************************************************
	immed[MsfAddress, MSF_TX_CONTROL]
	immed[TxConfigData0, (TX_ELEMENT_SIZE << 2)]	// put control and data into diff freelist
	immed_w1[TxConfigData0, ((TX_ENABLE_MASK << 12) | (TX_ENABLE_MASK << 8) | (TX_MODE << 6) | (TX_WIDTH << 4) | (TX_SINGLE_PHY << 3) | (0<<1)|(0<<0))]
	alu[$TxConfigData0, --, B, TxConfigData0]
	msf[write, $TxConfigData0, MsfAddress, 0, 1], ctx_swap[msf_sig]


//**************************************************
// Configure Scratch Ring
//**************************************************
.begin
	.reg $scratch_base $scratch_head $scratch_tail
	.sig scratch_sig1 scratch_sig2 scratch_sig3

	immed[$scratch_head,0]
	immed[$scratch_tail,0]

	alu[$scratch_base, --, B, 0]			// Use ring size of 128 lw and base 0x0
	cap[write,$scratch_base,SCRATCH_RING_BASE_0],sig_done[scratch_sig1]
	cap[write,$scratch_head,SCRATCH_RING_HEAD_0],sig_done[scratch_sig2]
	cap[write,$scratch_tail,SCRATCH_RING_TAIL_0],sig_done[scratch_sig3]
	ctx_arb[scratch_sig1, scratch_sig2, scratch_sig3]

	alu[$scratch_base, --, B, 1, <<9]		// Use ring size of 128 lw and base 0x200
	cap[write,$scratch_base,SCRATCH_RING_BASE_1],sig_done[scratch_sig1]
	cap[write,$scratch_head,SCRATCH_RING_HEAD_1],sig_done[scratch_sig2]
	cap[write,$scratch_tail,SCRATCH_RING_TAIL_1],sig_done[scratch_sig3]
	ctx_arb[scratch_sig1, scratch_sig2, scratch_sig3]

	alu[$scratch_base, --, B, 2, <<9]		// Use ring size of 128 lw and base 0x400
	cap[write,$scratch_base,SCRATCH_RING_BASE_2],sig_done[scratch_sig1]
	cap[write,$scratch_head,SCRATCH_RING_HEAD_2],sig_done[scratch_sig2]
	cap[write,$scratch_tail,SCRATCH_RING_TAIL_2],sig_done[scratch_sig3]
	ctx_arb[scratch_sig1, scratch_sig2, scratch_sig3]

	alu[$scratch_base, --, B, 3, <<9]		// Use ring size of 128 lw and base 0x600
	cap[write,$scratch_base,SCRATCH_RING_BASE_3],sig_done[scratch_sig1]
	cap[write,$scratch_head,SCRATCH_RING_HEAD_3],sig_done[scratch_sig2]
	cap[write,$scratch_tail,SCRATCH_RING_TAIL_3],sig_done[scratch_sig3]
	ctx_arb[scratch_sig1, scratch_sig2, scratch_sig3]

	alu[$scratch_base, --, B, 4, <<9]		// Use ring size of 128 lw and base 0x800
	cap[write,$scratch_base,SCRATCH_RING_BASE_4],sig_done[scratch_sig1]
	cap[write,$scratch_head,SCRATCH_RING_HEAD_4],sig_done[scratch_sig2]
	cap[write,$scratch_tail,SCRATCH_RING_TAIL_4],sig_done[scratch_sig3]
	ctx_arb[scratch_sig1, scratch_sig2, scratch_sig3]
.end

	local_csr_wr[SAME_ME_SIGNAL, ((INTERTHD_SIG_NUM << 3) | 1)]
	local_csr_wr[SAME_ME_SIGNAL, ((INTERTHD_SIG_NUM << 3) | 2)]
	local_csr_wr[SAME_ME_SIGNAL, ((INTERTHD_SIG_NUM << 3) | 3)]

start#:
next_packet#:
.begin
	.reg $packet_info mask
	.sig scratch_sig
	
	immed[mask, MASK_16BIT]

wait_for_packet_data#:
	scratch[get, $packet_info, get_ring_num, 0, 1], ctx_swap[scratch_sig]
	alu[byte_count, --, B, $packet_info]
	beq[wait_for_packet_data#]
.end

//	immed[byte_count, 0x3C]
	immed[dram_addr, (DRAM_BASE_SRC & MASK_16BIT)]
	immed_w1[dram_addr, ((DRAM_BASE_SRC >> 16) & MASK_16BIT)]
	alu[dram_addr, dram_addr, OR, cur_ctx, <<7]

.begin
	.reg tmp_addr $tmp_data
	.sig tmp_scratch_sig

	immed[tmp_addr, 0x2000]
	alu[tmp_addr, tmp_addr, OR, cur_ctx, <<2]

	alu[$tmp_data, --, B, byte_count]
	scratch[write, $tmp_data, tmp_addr, 0, 1], ctx_swap[tmp_scratch_sig]

	alu[$tmp_data, --, B, dram_addr]
	scratch[write, $tmp_data, tmp_addr, 0x10, 1], ctx_swap[tmp_scratch_sig]
.end

//****************************************************
// Move data to TBUF from DRAM
//****************************************************
.begin
	.reg tbuf_addr refcnt

	alu[tbuf_element, tbuf_1st_element, +, port_count]
	alu[port_count, port_count, +, 1]
	alu[port_count, tbuf_mask, AND, port_count]

	alu[tbuf_addr, --, B, tbuf_element, <<TBUF_ADDR_SHF]
	alu[tbuf_addr, tbuf, +, tbuf_addr]

	alu[tbuf_addr, --, B, tbuf_addr, <<5]
	alu[--, tbuf_addr, OR, 1, <<4]		// set the overwrite bit for the TBUF addr

	alu[refcnt, --, B, byte_count, >>3]
	alu[--, byte_count, AND, 0x7]
	bne[refcnt_calc_done#]
	alu[refcnt, refcnt, -, 1]			// Calculate the refcnt for indirect ref

refcnt_calc_done#:
	alu[refcnt, --, B, refcnt, <<21]	// Shift to appropriate bit
	alu[refcnt, refcnt, OR, 1, <<25]	// Set the overwrite bit for refcnt

	alu[--, tbuf_addr, OR, refcnt]	// indirect ref

	dram[tbuf_wr, --, dram_addr, 0, 8], indirect_ref, sig_done[dram_sig]

.begin
	.reg tmp_addr $tmp_data
	.sig tmp_scratch_sig

	immed[tmp_addr, 0x2000]
	alu[tmp_addr, tmp_addr, OR, cur_ctx, <<2]

	alu[$tmp_data, tbuf_addr, OR, refcnt]
	scratch[write, $tmp_data, tmp_addr, 0x20, 1], ctx_swap[tmp_scratch_sig]
.end

	ctx_arb[dram_sig]	
.end

//*******************************************************
// Write the Transmit Control Word with appropriate data
//*******************************************************
.begin
	.reg temp

	immed[MsfAddress, TBUF_ELEMENT_CONTROL_V]
	alu[MsfAddress, MsfAddress, OR, tbuf_element, <<3]

	immed[temp, (TX_CONTROL_SOP | TX_CONTROL_EOP)]
	alu[$TxControlWord0, temp, OR, byte_count, <<24]

	immed[$TxControlWord1, 0]

	msf[write, $TxControlWord0, MsfAddress, 0, 2], ctx_swap[msf_sig]
.end

	alu[@packet_count, @packet_count, +, 1]


//*****************************************************************************
//  Write to scratch ring with the tx packet count
//*****************************************************************************
.begin
	.reg $scratch_data temp
	.sig scratch_sig

//	alu[temp, --, B, @packet_count]
//	alu[$scratch_data, temp, OR, cur_ctx, <<16]
	alu[temp, 0x3, AND, @packet_count]
	.if (temp == 0)
		alu[$scratch_data, --, B, @packet_count]
		scratch[put, $scratch_data, put_ring_num, 0, 1], ctx_swap[scratch_sig]
	.endif
.end

	br[next_packet#]

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
美女视频一区在线观看| 色综合久久中文综合久久牛| 白白色亚洲国产精品| 欧美日韩免费视频| 国产精品女主播av| 日本v片在线高清不卡在线观看| 国产麻豆成人精品| 欧美一级午夜免费电影| 亚洲色图19p| 国产69精品一区二区亚洲孕妇| 欧美视频三区在线播放| 国产精品对白交换视频| 国产麻豆午夜三级精品| 欧美一级高清大全免费观看| 伊人一区二区三区| 大美女一区二区三区| 26uuu色噜噜精品一区二区| 亚洲第一狼人社区| 在线视频一区二区免费| 国产精品福利一区二区| 成人视屏免费看| 久久亚洲私人国产精品va媚药| 日韩国产精品91| 欧美三级一区二区| 亚洲精品第一国产综合野| www.色综合.com| 国产精品久久久久久久久图文区 | 欧美一区二区高清| 亚洲国产精品久久艾草纯爱| 日本精品视频一区二区| 亚洲靠逼com| 欧美视频在线一区| 亚洲国产成人av好男人在线观看| 91美女蜜桃在线| 亚洲黄色免费电影| 欧美少妇性性性| 日韩精品视频网| 欧美成人猛片aaaaaaa| 六月丁香婷婷色狠狠久久| 精品区一区二区| 国产精品一区在线| 亚洲欧美怡红院| 欧美系列亚洲系列| 热久久免费视频| 久久新电视剧免费观看| 国产**成人网毛片九色 | 夜夜精品浪潮av一区二区三区| 91精品1区2区| 午夜不卡在线视频| 精品成人一区二区三区| 国产v日产∨综合v精品视频| 亚洲色欲色欲www| 欧美色图在线观看| 精品一区二区三区在线播放| 久久久久久一二三区| av不卡在线播放| 亚洲成人av免费| 久久久午夜精品| 91毛片在线观看| 久久国内精品视频| 中文字幕日韩一区二区| 欧美私人免费视频| 国产麻豆精品一区二区| 亚洲自拍欧美精品| 日韩一区二区免费电影| 成人国产亚洲欧美成人综合网| 艳妇臀荡乳欲伦亚洲一区| 日韩久久久精品| 色哟哟一区二区在线观看| 日本美女一区二区三区视频| 中文字幕免费一区| 91精品国产欧美一区二区| www.成人在线| 青青草国产精品97视觉盛宴| 国产精品视频你懂的| 欧美美女黄视频| 波多野洁衣一区| 免费成人在线影院| 一个色妞综合视频在线观看| 久久久久久久久99精品| 欧美日韩午夜在线| 成人综合婷婷国产精品久久免费| 五月天激情综合网| 亚洲激情中文1区| 国产亚洲综合色| 日韩一区二区三区av| 在线视频欧美精品| 成人精品视频一区二区三区| 免费观看91视频大全| 一区二区不卡在线播放 | 国产人成亚洲第一网站在线播放 | 色婷婷av一区二区三区软件| 精品一区二区三区影院在线午夜 | 91精品在线麻豆| 日本高清不卡一区| 不卡av电影在线播放| 国产精品自拍三区| 日韩成人dvd| 日韩av电影天堂| 亚洲成人av电影| 亚洲一区二区三区国产| 亚洲人成电影网站色mp4| 国产精品久久777777| 国产午夜精品一区二区三区四区| 欧美白人最猛性xxxxx69交| 欧美精品v国产精品v日韩精品| 在线视频欧美区| 欧美天堂亚洲电影院在线播放| 日本韩国欧美三级| 色综合天天综合给合国产| 99九九99九九九视频精品| 懂色av一区二区夜夜嗨| 成人av午夜电影| 成人理论电影网| 91麻豆精品视频| 色狠狠色狠狠综合| 色婷婷久久综合| 在线观看成人小视频| 91伊人久久大香线蕉| av中文字幕一区| 一本一道久久a久久精品综合蜜臀| 99在线视频精品| 91福利在线免费观看| 欧美日韩综合在线免费观看| 欧美麻豆精品久久久久久| 欧美一级视频精品观看| 欧美精品一区二区三区很污很色的| 2020日本不卡一区二区视频| 国产欧美视频一区二区三区| 国产精品电影一区二区| 亚洲在线中文字幕| 日韩精品久久久久久| 国产综合成人久久大片91| 国产精品羞羞答答xxdd| av激情综合网| 欧美人动与zoxxxx乱| 精品99999| 亚洲欧洲www| 无吗不卡中文字幕| 国产尤物一区二区在线| 东方欧美亚洲色图在线| 91国内精品野花午夜精品| 日韩欧美中文字幕制服| 国产午夜三级一区二区三| 亚洲欧美电影院| 日本成人在线视频网站| 国产99久久久久久免费看农村| 91视频在线观看免费| 欧美一区二区成人| 国产精品久久久久四虎| 日本欧美一区二区三区乱码| 国产69精品一区二区亚洲孕妇| 欧美三级三级三级爽爽爽| 久久先锋影音av鲁色资源网| 亚洲色图.com| 精品一区二区国语对白| 色呦呦国产精品| 久久人人爽爽爽人久久久| 亚洲中国最大av网站| 国产精品一品视频| 欧美日本在线看| 中文字幕精品一区二区精品绿巨人| 亚洲第一福利视频在线| 国产·精品毛片| 日韩精品一区二区三区在线播放| 亚洲色欲色欲www在线观看| 经典三级视频一区| 欧美夫妻性生活| 中文字幕一区二区三区av| 国产在线精品免费av| 欧美一区二区三区视频在线| 亚洲色图一区二区三区| 国产精品一级黄| 欧美电视剧在线观看完整版| 亚洲一区二区视频| jlzzjlzz欧美大全| 日本一区二区三区视频视频| 麻豆久久一区二区| 欧美精品久久一区二区三区| 综合久久一区二区三区| 国产成人av电影在线| 欧美va亚洲va香蕉在线| 三级亚洲高清视频| 欧美性三三影院| 一区二区三区中文字幕精品精品| 国产91丝袜在线18| 久久先锋影音av| 国产专区欧美精品| 日韩精品一区在线观看| 青草国产精品久久久久久| 欧美日韩三级在线| 亚洲影院免费观看| 91精彩视频在线| 亚洲一区二区视频| 欧美日韩高清一区二区三区| 亚洲一区影音先锋| 在线免费视频一区二区| 亚洲一区二区三区国产| 欧美精品 日韩| 免费成人av资源网|