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

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

?? rem.s

?? glibc 庫, 不僅可以學(xué)習(xí)使用庫函數(shù),還可以學(xué)習(xí)函數(shù)的具體實現(xiàn),是提高功力的好資料
?? S
字號:
   /* This file is generated from divrem.m4; DO NOT EDIT! *//* * Division and remainder, from Appendix E of the Sparc Version 8 * Architecture Manual, with fixes from Gordon Irlam. *//* * Input: dividend and divisor in %o0 and %o1 respectively. * * m4 parameters: *  .rem	name of function to generate *  rem		rem=div => %o0 / %o1; rem=rem => %o0 % %o1 *  true		true=true => signed; true=false => unsigned * * Algorithm parameters: *  N		how many bits per iteration we try to get (4) *  WORDSIZE	total number of bits (32) * * Derived constants: *  TOPBITS	number of bits in the top decade of a number * * Important variables: *  Q		the partial quotient under development (initially 0) *  R		the remainder so far, initially the dividend *  ITER	number of main division loop iterations required; *		equal to ceil(log2(quotient) / N).  Note that this *		is the log base (2^N) of the quotient. *  V		the current comparand, initially divisor*2^(ITER*N-1) * * Cost: *  Current estimate for non-large dividend is *	ceil(log2(quotient) / N) * (10 + 7N/2) + C *  A large dividend is one greater than 2^(31-TOPBITS) and takes a *  different path, as the upper bits of the quotient must be developed *  one bit at a time. */#include <sysdep.h>#include <sys/trap.h>ENTRY(.rem)	! compute sign of result; if neither is negative, no problem	orcc	%o1, %o0, %g0	! either negative?	bge	2f			! no, go do the divide	mov	%o0, %g3		! sign of remainder matches %o0	tst	%o1	bge	1f	tst	%o0	! %o1 is definitely negative; %o0 might also be negative	bge	2f			! if %o0 not negative...	sub	%g0, %o1, %o1	! in any case, make %o1 nonneg1:	! %o0 is negative, %o1 is nonnegative	sub	%g0, %o0, %o0	! make %o0 nonnegative2:	! Ready to divide.  Compute size of quotient; scale comparand.	orcc	%o1, %g0, %o5	bne	1f	mov	%o0, %o3		! Divide by zero trap.  If it returns, return 0 (about as		! wrong as possible, but that is what SunOS does...).		ta	ST_DIV0		retl		clr	%o01:	cmp	%o3, %o5			! if %o1 exceeds %o0, done	blu	LOC(got_result)		! (and algorithm fails otherwise)	clr	%o2	sethi	%hi(1 << (32 - 4 - 1)), %g1	cmp	%o3, %g1	blu	LOC(not_really_big)	clr	%o4	! Here the dividend is >= 2**(31-N) or so.  We must be careful here,	! as our usual N-at-a-shot divide step will cause overflow and havoc.	! The number of bits in the result here is N*ITER+SC, where SC <= N.	! Compute ITER in an unorthodox manner: know we need to shift V into	! the top decade: so do not even bother to compare to R.	1:		cmp	%o5, %g1		bgeu	3f		mov	1, %g2		sll	%o5, 4, %o5		b	1b		add	%o4, 1, %o4	! Now compute %g2.	2:	addcc	%o5, %o5, %o5		bcc	LOC(not_too_big)		add	%g2, 1, %g2		! We get here if the %o1 overflowed while shifting.		! This means that %o3 has the high-order bit set.		! Restore %o5 and subtract from %o3.		sll	%g1, 4, %g1	! high order bit		srl	%o5, 1, %o5		! rest of %o5		add	%o5, %g1, %o5		b	LOC(do_single_div)		sub	%g2, 1, %g2	LOC(not_too_big):	3:	cmp	%o5, %o3		blu	2b		nop		be	LOC(do_single_div)		nop	/* NB: these are commented out in the V8-Sparc manual as well */	/* (I do not understand this) */	! %o5 > %o3: went too far: back up 1 step	!	srl	%o5, 1, %o5	!	dec	%g2	! do single-bit divide steps	!	! We have to be careful here.  We know that %o3 >= %o5, so we can do the	! first divide step without thinking.  BUT, the others are conditional,	! and are only done if %o3 >= 0.  Because both %o3 and %o5 may have the high-	! order bit set in the first step, just falling into the regular	! division loop will mess up the first time around.	! So we unroll slightly...	LOC(do_single_div):		subcc	%g2, 1, %g2		bl	LOC(end_regular_divide)		nop		sub	%o3, %o5, %o3		mov	1, %o2		b	LOC(end_single_divloop)		nop	LOC(single_divloop):		sll	%o2, 1, %o2		bl	1f		srl	%o5, 1, %o5		! %o3 >= 0		sub	%o3, %o5, %o3		b	2f		add	%o2, 1, %o2	1:	! %o3 < 0		add	%o3, %o5, %o3		sub	%o2, 1, %o2	2:	LOC(end_single_divloop):		subcc	%g2, 1, %g2		bge	LOC(single_divloop)		tst	%o3		b,a	LOC(end_regular_divide)LOC(not_really_big):1:	sll	%o5, 4, %o5	cmp	%o5, %o3	bleu	1b	addcc	%o4, 1, %o4	be	LOC(got_result)	sub	%o4, 1, %o4	tst	%o3	! set up for initial iterationLOC(divloop):	sll	%o2, 4, %o2		! depth 1, accumulated bits 0	bl	LOC(1.16)	srl	%o5,1,%o5	! remainder is positive	subcc	%o3,%o5,%o3			! depth 2, accumulated bits 1	bl	LOC(2.17)	srl	%o5,1,%o5	! remainder is positive	subcc	%o3,%o5,%o3			! depth 3, accumulated bits 3	bl	LOC(3.19)	srl	%o5,1,%o5	! remainder is positive	subcc	%o3,%o5,%o3			! depth 4, accumulated bits 7	bl	LOC(4.23)	srl	%o5,1,%o5	! remainder is positive	subcc	%o3,%o5,%o3		b	9f		add	%o2, (7*2+1), %o2	LOC(4.23):	! remainder is negative	addcc	%o3,%o5,%o3		b	9f		add	%o2, (7*2-1), %o2		LOC(3.19):	! remainder is negative	addcc	%o3,%o5,%o3			! depth 4, accumulated bits 5	bl	LOC(4.21)	srl	%o5,1,%o5	! remainder is positive	subcc	%o3,%o5,%o3		b	9f		add	%o2, (5*2+1), %o2	LOC(4.21):	! remainder is negative	addcc	%o3,%o5,%o3		b	9f		add	%o2, (5*2-1), %o2			LOC(2.17):	! remainder is negative	addcc	%o3,%o5,%o3			! depth 3, accumulated bits 1	bl	LOC(3.17)	srl	%o5,1,%o5	! remainder is positive	subcc	%o3,%o5,%o3			! depth 4, accumulated bits 3	bl	LOC(4.19)	srl	%o5,1,%o5	! remainder is positive	subcc	%o3,%o5,%o3		b	9f		add	%o2, (3*2+1), %o2	LOC(4.19):	! remainder is negative	addcc	%o3,%o5,%o3		b	9f		add	%o2, (3*2-1), %o2		LOC(3.17):	! remainder is negative	addcc	%o3,%o5,%o3			! depth 4, accumulated bits 1	bl	LOC(4.17)	srl	%o5,1,%o5	! remainder is positive	subcc	%o3,%o5,%o3		b	9f		add	%o2, (1*2+1), %o2	LOC(4.17):	! remainder is negative	addcc	%o3,%o5,%o3		b	9f		add	%o2, (1*2-1), %o2				LOC(1.16):	! remainder is negative	addcc	%o3,%o5,%o3			! depth 2, accumulated bits -1	bl	LOC(2.15)	srl	%o5,1,%o5	! remainder is positive	subcc	%o3,%o5,%o3			! depth 3, accumulated bits -1	bl	LOC(3.15)	srl	%o5,1,%o5	! remainder is positive	subcc	%o3,%o5,%o3			! depth 4, accumulated bits -1	bl	LOC(4.15)	srl	%o5,1,%o5	! remainder is positive	subcc	%o3,%o5,%o3		b	9f		add	%o2, (-1*2+1), %o2	LOC(4.15):	! remainder is negative	addcc	%o3,%o5,%o3		b	9f		add	%o2, (-1*2-1), %o2		LOC(3.15):	! remainder is negative	addcc	%o3,%o5,%o3			! depth 4, accumulated bits -3	bl	LOC(4.13)	srl	%o5,1,%o5	! remainder is positive	subcc	%o3,%o5,%o3		b	9f		add	%o2, (-3*2+1), %o2	LOC(4.13):	! remainder is negative	addcc	%o3,%o5,%o3		b	9f		add	%o2, (-3*2-1), %o2			LOC(2.15):	! remainder is negative	addcc	%o3,%o5,%o3			! depth 3, accumulated bits -3	bl	LOC(3.13)	srl	%o5,1,%o5	! remainder is positive	subcc	%o3,%o5,%o3			! depth 4, accumulated bits -5	bl	LOC(4.11)	srl	%o5,1,%o5	! remainder is positive	subcc	%o3,%o5,%o3		b	9f		add	%o2, (-5*2+1), %o2	LOC(4.11):	! remainder is negative	addcc	%o3,%o5,%o3		b	9f		add	%o2, (-5*2-1), %o2		LOC(3.13):	! remainder is negative	addcc	%o3,%o5,%o3			! depth 4, accumulated bits -7	bl	LOC(4.9)	srl	%o5,1,%o5	! remainder is positive	subcc	%o3,%o5,%o3		b	9f		add	%o2, (-7*2+1), %o2	LOC(4.9):	! remainder is negative	addcc	%o3,%o5,%o3		b	9f		add	%o2, (-7*2-1), %o2					9:LOC(end_regular_divide):	subcc	%o4, 1, %o4	bge	LOC(divloop)	tst	%o3	bl,a	LOC(got_result)	! non-restoring fixup here (one instruction only!)	add	%o3, %o1, %o3LOC(got_result):	! check to see if answer should be < 0	tst	%g3	bl,a	1f	sub %g0, %o3, %o31:	retl	mov %o3, %o0END(.rem)

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
奇米四色…亚洲| 99精品欧美一区二区三区小说| 亚洲成av人片一区二区梦乃| 国产精品国产三级国产普通话蜜臀| 欧美大片顶级少妇| 日韩一区二区影院| 欧美日韩国产成人在线91| 91久久人澡人人添人人爽欧美| 9i看片成人免费高清| 国产69精品久久久久777| 国产精品一级黄| 国产麻豆精品在线观看| 国产一区二区三区免费在线观看| 亚洲午夜在线电影| 亚洲综合色自拍一区| 亚洲国产精品ⅴa在线观看| 成人深夜视频在线观看| 欧美日本在线看| 爽爽淫人综合网网站| 亚洲第一激情av| 日韩极品在线观看| 免费在线视频一区| 日韩精品免费专区| 精品一区二区精品| 国产麻豆精品在线观看| 国产成人午夜精品5599| 天天色天天操综合| 久久激情五月激情| 国产一区二区免费在线| 成人综合日日夜夜| 99精品视频一区二区| 欧美性受极品xxxx喷水| 欧美丝袜自拍制服另类| 日韩亚洲欧美成人一区| 国产三级精品三级在线专区| 国产精品久久久久天堂| 一区二区三区在线影院| 午夜精品久久久久影视| 国产精品一区2区| 99视频超级精品| 国产·精品毛片| 色视频成人在线观看免| 色哟哟精品一区| 91高清在线观看| 欧美在线视频不卡| 欧美夫妻性生活| 日韩精品中文字幕一区二区三区| 51久久夜色精品国产麻豆| 国产欧美日韩不卡免费| 亚洲特黄一级片| 日日骚欧美日韩| 久久精品国产澳门| 91丨porny丨中文| 69精品人人人人| 国产婷婷一区二区| 亚洲一区中文日韩| 国产一区二区三区av电影| 99在线精品免费| 欧美精品第1页| 国产情人综合久久777777| 国产精品久久久久久福利一牛影视| 国产精品电影一区二区| 午夜成人免费电影| 免费高清在线视频一区·| av午夜精品一区二区三区| 欧美日韩免费在线视频| 久久精品欧美一区二区三区不卡 | 亚洲成人av一区二区| 亚洲成人在线网站| 欧美精品在线观看播放| 久久亚洲私人国产精品va媚药| 国产欧美在线观看一区| 日日噜噜夜夜狠狠视频欧美人| 国产一区高清在线| 色噜噜狠狠色综合中国| 久久精品一区二区| 日韩精品福利网| 96av麻豆蜜桃一区二区| 精品毛片乱码1区2区3区| 亚洲精品欧美专区| 国产成人综合精品三级| 5月丁香婷婷综合| 亚洲乱码国产乱码精品精小说| 国产在线视频不卡二| 成人app下载| 久久日韩精品一区二区五区| 亚洲国产欧美一区二区三区丁香婷| 国产91精品露脸国语对白| 日韩一区二区三区免费观看| 亚洲高清三级视频| 色综合久久综合网97色综合| 久久综合av免费| 欧美久久高跟鞋激| 午夜精品久久久久久久久久| 国产亚洲精品bt天堂精选| 久久综合五月天婷婷伊人| 亚洲成人综合网站| 欧美在线色视频| 中文字幕日韩av资源站| 国产剧情一区在线| 精品国产成人在线影院| 亚洲一区二区三区四区五区中文 | 日本va欧美va精品| 91福利区一区二区三区| 亚洲欧美综合色| 成人一区二区三区| 国产精品视频在线看| 亚洲永久免费视频| 欧美亚洲动漫另类| 调教+趴+乳夹+国产+精品| 欧美日韩国产综合视频在线观看| 亚洲国产精品一区二区尤物区| 欧美熟乱第一页| 喷白浆一区二区| 久久久久久99久久久精品网站| 风间由美性色一区二区三区| 国产精品色哟哟| 日本乱码高清不卡字幕| 亚洲国产精品精华液网站| 欧美一区日本一区韩国一区| 久久99久久精品| 国产精品久久久久久久久免费相片| 成人国产一区二区三区精品| 亚洲少妇最新在线视频| 欧美性猛片aaaaaaa做受| 亚洲制服丝袜av| 欧美一级淫片007| 久久狠狠亚洲综合| 国产午夜精品理论片a级大结局| 国产专区欧美精品| 亚洲丝袜美腿综合| 欧美视频在线观看一区二区| 蜜桃视频在线观看一区| 久久精子c满五个校花| 91在线精品一区二区| 亚洲18女电影在线观看| 2022国产精品视频| 91免费看片在线观看| 日本不卡的三区四区五区| 久久久精品免费观看| 91久久精品日日躁夜夜躁欧美| 日韩综合在线视频| 国产精品午夜在线| 91精品婷婷国产综合久久 | 欧美性受xxxx| 免费xxxx性欧美18vr| 中文字幕不卡一区| 9191成人精品久久| 国产精品资源在线看| 中文字幕精品一区二区精品绿巨人 | 久久一夜天堂av一区二区三区| 99久免费精品视频在线观看| 天天影视网天天综合色在线播放| 久久综合视频网| 一本一道波多野结衣一区二区| 久久成人免费网| 亚洲一区二区三区在线看| 国产亚洲精品免费| 这里只有精品99re| 99国产精品久久久久久久久久| 麻豆免费看一区二区三区| 亚洲日本在线视频观看| 久久先锋影音av| 337p亚洲精品色噜噜狠狠| 国产69精品久久99不卡| 喷水一区二区三区| 亚洲自拍另类综合| 中文字幕亚洲一区二区va在线| 日韩一卡二卡三卡四卡| 欧美丝袜第三区| av午夜精品一区二区三区| 国精产品一区一区三区mba视频| 亚洲综合在线免费观看| 欧美国产精品一区二区三区| 欧美一级理论片| 精品视频在线免费看| 91免费看`日韩一区二区| 国产91富婆露脸刺激对白| 麻豆中文一区二区| 图片区小说区区亚洲影院| 亚洲欧美日本韩国| 国产日韩欧美精品电影三级在线| 制服丝袜亚洲色图| 欧美亚州韩日在线看免费版国语版| 成人精品视频网站| 国产精品一级二级三级| 轻轻草成人在线| 天堂va蜜桃一区二区三区| 亚洲欧美日韩人成在线播放| 国产精品另类一区| 欧美电影免费观看完整版| 欧美日韩免费观看一区三区| 91免费视频观看| www.日韩大片| 粉嫩久久99精品久久久久久夜| 国产综合色精品一区二区三区| 日韩中文欧美在线| 亚洲综合视频在线观看| 亚洲综合久久久久| 亚洲激情自拍视频|