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

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

?? jpegencoder2.asm

?? JPEG壓縮編碼在TMS320VC5509的實現代碼
?? ASM
字號:
;JpegEncoder2.asm

	.ARMS_off		;enable assembler for ARMS=0
					;告訴編譯器當前工作狀態為DSP模式
	.CPL_on			;enable assembler for CPL=1
					;告訴編譯器當前工作在SP直接尋址模式(SP與DP對應)
	.mmregs
	
	.include "MyDspDef.inc"
	
	.ref _Rbuf,_Gbuf,_Bbuf
	
	.ref _YDU,_CbDU,_CrDU
	
	.ref _ColorConvMatrix
	
	.asg XAR1,pRbuf;指向R緩沖區的指針
	
	.asg AR1,pRbufShort;指向R緩沖區的指針
	
	.asg XAR2,pGbuf;指向G緩沖區的指針
	
	.asg AR2,pGbufShort;指向G緩沖區的指針

	.asg XAR3,pBbuf;指向B緩沖區的指針
	
	.asg AR3,pBbufShort;指向B緩沖區的指針
	
	.asg XAR4,pYUVbuf;指向YUV緩沖區的指針
	
	.asg AR4,pYUVbufShort;指向YUV緩沖區的指針
	
	.asg XAR5,pConvMatrix;指向ColorConvMatrix緩沖區的指針

	.asg AR5,pConvMatrixShort;指向ColorConvMatrix緩沖區的指針
	
	.asg BSA45, db_base;循環緩沖區的起始地址
	
	.asg BK47, db_sz;循環緩沖區的大小
	
ST2mask  .set  0000000000100000b    ;circular/linear pointers,打開ar5的循環尋址模式 
	
	.global _RGB2YUV,CalcOneComponent

	
_RGB2YUV:
	pshboth(XAR1)
	
	pshboth(XAR2)
	
	pshboth(XAR3)
	
	pshboth(XAR4)
	
	pshboth(XAR5)

    @(ST0_55) &= #01FFh || mmap();清零ACOVx, TC1, TC2, C

    @(ST1_55) |= #04140h || mmap();將CPL(SP直接尋址模式), SXMD, FRCT設置為1

    @(ST1_55) &= #0F9DFh || mmap();清零M40, SATD(飽和標志), 54CM

    @(ST2_55) &= #07A00h || mmap();清零ARMS, RDM(不懂), CDPLC, AR[0-7]LC

    @(ST3_55) &= #0FFDDh || mmap();清零SATA(會影響目的存儲器,正向飽和與負向飽和), SMUL	

    @(ST2_55) |= #ST2mask || mmap();設置circular/linear ARx
    
	nop
	
	nop
	
	nop
		
	pConvMatrixShort = #(-0x80);//暫時借用一下
	
	hi(ac1) = pConvMatrixShort
	
	;ac1 += #0;0x4000
	
	pYUVbuf = #_YDU
	
	pConvMatrix = #_ColorConvMatrix
	
	db_base = #_ColorConvMatrix;計算Y分量
	
	db_sz = #3
		
	pConvMatrixShort = #0;索引變成0
		
	call CalcOneComponent



	pYUVbufShort = #_CbDU;注意Y、Cr、Cb緩沖應該放在一起,一個頁內

	db_base = #(_ColorConvMatrix+3);計算Cb分量
	
	ac1 = #0;0x4000;
	
	call CalcOneComponent



	pYUVbufShort = #_CrDU
	
	db_base = #(_ColorConvMatrix+6);計算Cr分量
	
	ac1 = #0;0x4000;
	
	call CalcOneComponent	
		

	
	;保存C函數運行需要的環境
    bit(ST2, K_FRCT) = #0;清FRCT

    @(ST2_55) &= #0FE00h || mmap();清 CDPLC(關閉循環尋址) 和 AR[7-0]LC

    bit(ST2, K_ARMS) = #1;設置 ARMS = #1 ,恢復為控制模式
	
	bit(ST1,K_FRCT) = #0
	
	XAR5 = popboth()
    
	XAR4 = popboth()
 
	XAR3 = popboth()

	XAR2 = popboth()

	XAR1 = popboth()
	
	return

	
CalcOneComponent:
		
	pRbuf = #_Rbuf
	
	pGbuf = #_Gbuf
	
	pBbuf = #_Bbuf
	
	brc0 = #63;循環64次
	
	localrepeat{

		ac0 = (*pRbufShort+) * (*pConvMatrixShort+)

		ac0 += ((*pGbufShort+) * (*pConvMatrixShort+))

		ac0 += ((*pBbufShort+) * (*pConvMatrixShort+))
		
		ac0 = rnd(ac0);4舍5入
		
		ac0 += ac1
		
		(*pYUVbufShort+) = hi(ac0);
	}
	
	return
	

	.asg XAR0,pInputBuf;指向Input緩沖區的指針
	.asg AR0,pInputBufShort;指向Input緩沖區的指針
	.asg XAR3,pOutputBuf;指向Output緩沖區的指針
	.asg AR3,pOutputBufShort;指向Output緩沖區的指針
	.asg XAR2,pQtableBuf;指向_Q_table緩沖區的指針
	.asg AR2,pQtableBufShort;指向_Q_table緩沖區的指針
	.asg XAR1,pZigzagBuf;指向zigzag緩沖區的指針
	.asg AR1,pZigzagBufShort;指向zigzag緩沖區的指針
	.global _DctBlockQuantize
	
_DctBlockQuantize:
	
	push(t0,t1)
	
	bit(ST1,#K_FRCT) = #1
	
	nop
	
	nop
	
	nop

	brc0 = #63;循環64次
	
;	pshboth(XAR1);pInputBuf = #_imageBlock   ;	XAR4 = popboth()
	
;	pshboth(XAR2);pOutputBuf = #_YDCTzigzagQ ;	XAR3 = popboth()
	
;	pshboth(XAR3);pQtableBuf = #_Q_table     ;	XAR2 = popboth()
	
;	pshboth(XAR4);pZigzagBuf = #_zigzag      ;	XAR1 = popboth()
	
	localrepeat{

		t0 = *pZigzagBufShort+
		
		t1 = *pQtableBufShort(t0)
	
		ac0 = rnd(t1 * *pInputBufShort+)

		*pOutputBufShort(t0) = hi(ac0);
	}	

	bit(ST1,#K_FRCT) = #0
	
	t0,t1 = pop()
		
	return
	


	.global _ClearStReg
	
_ClearStReg:

	nop
	
	nop

	@(ST0_55) = #0x1047 || mmap()
	
	@(ST1_55) = #0x6900 || mmap()
	
	@(ST2_55) = #0xf000 || mmap()
	
	@(ST3_55) = #0x1c86 || mmap()
	
	nop
	
	nop
	
	nop
	
	nop
	
	nop
	
	return
	
	
	.ref _ImageWidth
	.asg XAR0,pSourceBuf;指向Source緩沖區的指針
	.asg AR0,pSourceBufShort;指向Source緩沖區的指針
	.asg XAR1,pDistBuf;指向Dist緩沖區的指針
	.asg AR1,pDistBufShort;指向Dist緩沖區的指針	
	.global _Mem8x8Cpy

_Mem8x8Cpy:
	push(t0)
	
	t0 = *(#_ImageWidth)
	
	t0 -= #7
	
	brc0 = #7;外循環8次
	
	csr = #6;內循環7次
		
	localrepeat{
	
	repeat(csr)
		
	*pDistBufShort+ = *pSourceBufShort+

	*pDistBufShort+ = *(pSourceBufShort+t0);
		
	}

	t0 = pop()
	
	return


;	.global _jpe1
;	.asg XAR0,i
;	.asg AR0,i
		
;_jpe1:
;	i = #63;
	
;	return
	.global _ACEncode2
	.asg XAR0,pDCTzigzagQ
	.asg AR0,pDCTzigzagQShort
	.asg XAR1,p_ac_encode_tab
	.asg AR1,p_ac_encode_tabShort
	.asg AR7,tmp
	.asg AR6,tmp1
	.asg t0,i
	;.bss m_bAllAcZero_asm,1
	.bss nrzeroes,1
	.bss endpos,1
	.bss startpos,1
	.bss m_bK_Y_AC,1
	.bss Tmpi,1
	.bss EncodeAc,1
	.ref _AddBits
K_Y_AC	.set 0
K_CbCr_AC	.set 1

_ACEncode2:
	*(m_bK_Y_AC) = t0;保護K_Y_AC/K_CbCr_AC
	
	t0 = #63

ZERO_Detect_NOT_finish:	
	tmp1 = *pDCTzigzagQShort(t0);從右到左
	
	if(tmp1 != #0)goto ZERO_Detect_finish_t0_gt_0;t0大于0的情況
	
	if(t0 == #0)goto ZERO_Detect_finish_t0_eq_0;等于0的情況
	
	t0 -= #1 || goto ZERO_Detect_NOT_finish

ZERO_Detect_finish_t0_eq_0:
	;*(m_bAllAcZero_asm) = #1;等于0的情況
	tmp = *(m_bK_Y_AC)
		
	*(endpos) = t0

	if(tmp != #K_Y_AC)goto ZERO_Detect_finish_t0_eq_0_CbCr_AC
	
	t1 = #4
	
	t0 = #10
	
	pshboth(XAR1)
	
	pshboth(XAR2)
	
	call _AddBits;是K_Y_AC的情況

	XAR2 = popboth()

	XAR1 = popboth()
	
	goto AC_ENCODE_END
	
ZERO_Detect_finish_t0_eq_0_CbCr_AC:
	pshboth(XAR1)
	
	pshboth(XAR2)
	
	t1 = #2
	
	t0 = #0
	
	call _AddBits;是K_CbCr_AC的情況
	
	XAR2 = popboth()

	XAR1 = popboth()
	
	goto AC_ENCODE_END
	
ZERO_Detect_finish_t0_gt_0:
	;*(m_bAllAcZero_asm) = #0;t0大于0的情況
	
	*(endpos) = t0;

	i = #1
	
i_lt_or_equ_endpos:
	tmp = *(endpos) - i
	
	if(tmp < #0)goto i_gt_endpos ;while (i <= endpos)
	
	*(startpos) = i
	
begin_to_dectect_nrzeroes:	
	tmp = *(endpos) - i
	
	if(tmp <= #0)goto nrzeroes_detect_finish
	
	tmp = *pDCTzigzagQShort(i)
	
	if(tmp != 0)goto nrzeroes_detect_finish
	
	i += #1 || goto begin_to_dectect_nrzeroes
	
nrzeroes_detect_finish:
	tmp = i - *(startpos);//連零的數量
	
	tmp1 = #16
	
AC_LESS_OR_MORE_THAN_16:
	tc1 = uns(tmp < tmp1) || nop ;如果連零的數量小于16

	if(tc1)goto nrzeroes_lt_16;連零數量小于16
	
	*(Tmpi) = i ;保護i的值

	tmp -= #16
	
	*(nrzeroes) = tmp
	
	tmp = *(m_bK_Y_AC)
	
	if(tmp != #K_Y_AC)goto CbCr_AC_MORE_THAN_16_ZEROS
Y_AC_MORE_THAN_16_ZEROS:
	t1 = #11
	
	t0 = #2041
	
	pshboth(XAR1)
	
	pshboth(XAR2)
	
	call _AddBits
	
	XAR2 = popboth()

	XAR1 = popboth()
	
	i = *(Tmpi);恢復i
	
	goto AC_LESS_OR_MORE_THAN_16;繼續判斷連零數量是否小于16
		
CbCr_AC_MORE_THAN_16_ZEROS:
	t1 = #10
	
	t0 = #1018
	
	pshboth(XAR1)
	
	pshboth(XAR2)
	
	call _AddBits
	
	XAR2 = popboth()

	XAR1 = popboth()
	
	i = *(Tmpi);恢復i
	
	goto AC_LESS_OR_MORE_THAN_16;繼續判斷連零數量是否小于16
	
nrzeroes_lt_16:;連零數量小于16
	ac1 = tmp || t3 = #10
	
	ac1 = t3 * ac1
	
	t1 = #0;AC編碼的長度
	
	ac0 = *pDCTzigzagQShort(i)
	
	ac0 = |ac0|
	
EncodeAcCalStart:
	if(ac0 == #0)goto EncodeAcCalFinish
	
	ac0 = ac0>>1 || t1 += #1
	
	goto EncodeAcCalStart
	
EncodeAcCalFinish:
	*(EncodeAc) = t1

	ac1 += t1;在AcMapStrTab中的位置
	
	ac1 -= #1

	*(Tmpi) = i ;保護i的值
	
	i = LO(ac1)
	
	t0 = *p_ac_encode_tabShort(i)
	
	i += #160
	
	t1 = *p_ac_encode_tabShort(i)
	
	pshboth(XAR1)
	
	pshboth(XAR2)

	call _AddBits

	XAR2 = popboth()

	XAR1 = popboth()
	
	i = *(Tmpi);恢復i
	
	tmp = *pDCTzigzagQShort(i)
	
	if(tmp >= #0)goto InputBlock_i_gt_or_equ_0
	
	tmp1 = *(EncodeAc)
	
	tmp1 -= #16
	
	if(tmp1 < 0)goto EncodeAc_lt_16
EncodeAc_equ_16:
	;tmp = *pDCTzigzagQShort(i)
	
	ac0 = |tmp|
	
	ac0 ^= #0xffff
	
	t0 = lo(ac0)
	
	t1 = *(EncodeAc)
	
	goto Ac_inv_finish

EncodeAc_lt_16:	
	t1 = *(EncodeAc)
	
	ac0 = #0xffff
		
	ac0 = ac0 <<< t1
	
	ac0 = ~ac0
	
	;tmp = *pDCTzigzagQShort(i)
	
	ac1 = |tmp|
	
	ac0 ^= ac1
	
	t0 = lo(ac0) 
	
Ac_inv_finish:
	goto InputBlock_i_fix_finish
	
InputBlock_i_gt_or_equ_0:
	t0 = *p_ac_encode_tabShort(i)
	
	t1 = *(EncodeAc)
	
InputBlock_i_fix_finish:
	pshboth(XAR1)
	
	pshboth(XAR2)

	call _AddBits
	
	XAR2 = popboth()

	XAR1 = popboth()
	
	i = *(Tmpi);恢復i
	
	i += #1
	
	goto i_lt_or_equ_endpos

i_gt_endpos:
	ac0 = *(endpos)
	
	ac0 -= #63
	
	if(ac0 >= 0)goto AC_ENCODE_END

	tmp = *(m_bK_Y_AC)
	
	if(tmp != #K_Y_AC)goto CbCr_AC_MORE_THAN_16_ZEROS2

	t1 = #11
	
	t0 = #2041
	
	pshboth(XAR1)
	
	pshboth(XAR2)
	
	call _AddBits
	
	XAR2 = popboth()

	XAR1 = popboth()
	
	i = *(Tmpi);恢復i
	
	goto AC_ENCODE_END;
		
CbCr_AC_MORE_THAN_16_ZEROS2:
	t1 = #10
	
	t0 = #1018
	
	pshboth(XAR1)
	
	pshboth(XAR2)
	
	call _AddBits
	
	XAR2 = popboth()

	XAR1 = popboth()
	
	i = *(Tmpi);恢復i
	
AC_ENCODE_END:

	return
	
	

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人午夜视频福利| 欧美日韩亚洲不卡| 亚洲国产高清在线观看视频| 一本久久精品一区二区| 久色婷婷小香蕉久久| 五月婷婷激情综合网| 日本人妖一区二区| 成人午夜电影久久影院| 日韩午夜电影av| 国产精品色噜噜| 日韩主播视频在线| 日本成人中文字幕在线视频| 岛国一区二区三区| 欧美日韩精品欧美日韩精品一综合| 欧美中文字幕一区二区三区 | 成人中文字幕合集| 欧洲日韩一区二区三区| 中文字幕一区在线观看| 日本成人在线电影网| 99久久国产综合精品女不卡| 国产性做久久久久久| 天天av天天翘天天综合网| 成人午夜精品在线| 久久久久久久久久电影| 视频一区视频二区中文| 成人一区二区三区| 欧美精品一区视频| 欧美亚洲国产bt| 久久久噜噜噜久久人人看| 日韩电影一二三区| 91福利在线免费观看| 亚洲日本va在线观看| 国产精品一二一区| 日韩欧美久久一区| 国内精品久久久久影院薰衣草 | 亚洲综合在线电影| 成人黄色在线网站| 欧美男人的天堂一二区| 亚洲欧美日本在线| 成人av网站免费| 日韩理论在线观看| 成人一区二区三区视频在线观看 | av影院午夜一区| 久久美女高清视频| 秋霞午夜鲁丝一区二区老狼| 国产在线精品一区在线观看麻豆| 欧美人伦禁忌dvd放荡欲情| 亚洲人成在线播放网站岛国| a在线播放不卡| 国产精品美女视频| 欧美色网一区二区| 性久久久久久久| 91精品国产91久久综合桃花| 久久国产人妖系列| 精品少妇一区二区三区免费观看| 国产日产精品一区| 99精品国产视频| 亚洲精品乱码久久久久久黑人| 99久久精品一区二区| 亚洲欧美乱综合| 欧美无砖砖区免费| 奇米一区二区三区| 中文字幕在线不卡国产视频| 91免费观看视频| 亚洲美女视频一区| 日韩欧美视频一区| 国产成人免费xxxxxxxx| 亚洲bt欧美bt精品777| 日韩欧美资源站| 国产成人综合在线播放| 亚洲在线免费播放| 欧美电影免费观看高清完整版在线观看| 国产一区视频导航| 亚洲天堂福利av| 欧美日韩一区二区电影| 国产成人aaa| 一区二区三区小说| 欧美日韩中文另类| 成人a级免费电影| 午夜视频在线观看一区二区三区| 久久午夜国产精品| 色吧成人激情小说| 精品一区二区三区视频在线观看| 亚洲免费毛片网站| 日韩精品一区二区三区四区视频 | 一区二区三区波多野结衣在线观看| 欧美在线视频不卡| 国产91在线观看| 丝袜诱惑制服诱惑色一区在线观看| 久久婷婷综合激情| 91麻豆文化传媒在线观看| 国产综合色在线| 久久夜色精品国产噜噜av| 久久精品国产精品亚洲红杏 | 成熟亚洲日本毛茸茸凸凹| 男女男精品视频网| 精品国产免费一区二区三区四区| 亚洲女人小视频在线观看| 99精品国产热久久91蜜凸| 91精品啪在线观看国产60岁| 亚洲h在线观看| 欧美精品777| 久久精品噜噜噜成人88aⅴ| 91色九色蝌蚪| 综合激情网...| 日精品一区二区| 在线亚洲+欧美+日本专区| 国产一区二区三区四| 日韩一区二区三区免费观看| 国产一区二区三区四| 日日欢夜夜爽一区| 亚洲欧美日韩国产成人精品影院 | 亚洲男帅同性gay1069| 日韩视频一区二区三区| 波多野洁衣一区| 老司机午夜精品99久久| 日本一区二区三区在线不卡| 精品一区二区三区av| 一区二区三区国产精品| 成人免费小视频| 欧美国产激情一区二区三区蜜月| 精品国产乱码久久久久久夜甘婷婷| 欧美一区二区三区在线看| 在线视频欧美精品| 国产98色在线|日韩| 国产传媒日韩欧美成人| 激情五月婷婷综合网| 免费在线观看一区| 亚洲欧美一区二区三区国产精品| 欧美xxxx老人做受| 久久中文字幕电影| 精品成人佐山爱一区二区| 日韩欧美第一区| 欧美mv和日韩mv的网站| 久久一区二区视频| 中文字幕在线不卡国产视频| 亚洲日本一区二区| 一区二区国产视频| 亚洲国产精品成人综合色在线婷婷| 国产日韩欧美制服另类| 国产精品久久久一区麻豆最新章节| 最新日韩av在线| 久久国产夜色精品鲁鲁99| 色综合久久中文综合久久97| 欧美日韩在线综合| 国产亚洲一本大道中文在线| 欧美国产日本韩| 欧美午夜一区二区| 国产精品私人自拍| 国产一区中文字幕| 国产三级精品在线| 奇米色777欧美一区二区| 在线影视一区二区三区| 精品国产乱码久久久久久久久| 国产精品国产自产拍高清av王其| 一区二区三区在线看| 国产偷v国产偷v亚洲高清 | 国产不卡视频在线观看| 7777精品伊人久久久大香线蕉超级流畅 | 国产精品天美传媒| 韩国精品主播一区二区在线观看| 欧美一级免费观看| 韩国女主播一区二区三区| xvideos.蜜桃一区二区| 极品尤物av久久免费看| 91丝袜美腿高跟国产极品老师| 久久久久免费观看| 色婷婷精品大视频在线蜜桃视频| 三级一区在线视频先锋 | 26uuu亚洲婷婷狠狠天堂| 天天色天天操综合| 久久久综合视频| 不卡免费追剧大全电视剧网站| 日韩视频在线一区二区| 高清shemale亚洲人妖| 日韩精品专区在线影院观看 | 中文字幕精品在线不卡| 51久久夜色精品国产麻豆| 成人激情午夜影院| 国产精品一区在线观看乱码| 亚洲成人av中文| 亚洲国产欧美另类丝袜| 亚洲成人三级小说| 激情文学综合丁香| av一区二区三区| 懂色av中文一区二区三区| 日韩精品亚洲专区| 亚洲成人动漫在线免费观看| 亚洲欧洲综合另类| 中文字幕一区二区三| 国产欧美日韩视频一区二区| 精品成人免费观看| 久久久国产午夜精品| 国产亚洲精品aa午夜观看| 久久久国产精华| 亚洲国产精品成人综合| 国产精品久久777777| 亚洲私人黄色宅男| 亚洲成人精品一区| 久久精品理论片|