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

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

?? ieee754-sf.s

?? Mac OS X 10.4.9 for x86 Source Code gcc 實現源代碼
?? S
?? 第 1 頁 / 共 2 頁
字號:
/* ieee754-sf.S single-precision floating point support for ARM   Copyright (C) 2003, 2004  Free Software Foundation, Inc.   Contributed by Nicolas Pitre (nico@cam.org)   This file is free software; you can redistribute it and/or modify it   under the terms of the GNU General Public License as published by the   Free Software Foundation; either version 2, or (at your option) any   later version.   In addition to the permissions in the GNU General Public License, the   Free Software Foundation gives you unlimited permission to link the   compiled version of this file into combinations with other programs,   and to distribute those combinations without any restriction coming   from the use of this file.  (The General Public License restrictions   do apply in other respects; for example, they cover modification of   the file, and distribution when not linked into a combine   executable.)   This file is distributed in the hope that it will be useful, but   WITHOUT ANY WARRANTY; without even the implied warranty of   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU   General Public License for more details.   You should have received a copy of the GNU General Public License   along with this program; see the file COPYING.  If not, write to   the Free Software Foundation, 59 Temple Place - Suite 330,   Boston, MA 02111-1307, USA.  *//* * Notes: * * The goal of this code is to be as fast as possible.  This is * not meant to be easy to understand for the casual reader. * * Only the default rounding mode is intended for best performances. * Exceptions aren't supported yet, but that can be added quite easily * if necessary without impacting performances. */#ifdef L_negsf2	ARM_FUNC_START negsf2ARM_FUNC_ALIAS aeabi_fneg negsf2	eor	r0, r0, #0x80000000	@ flip sign bit	RET	FUNC_END aeabi_fneg	FUNC_END negsf2#endif#ifdef L_addsubsf3ARM_FUNC_START aeabi_frsub	eor	r0, r0, #0x80000000	@ flip sign bit of first arg	b	1fARM_FUNC_START subsf3ARM_FUNC_ALIAS aeabi_fsub subsf3	eor	r1, r1, #0x80000000	@ flip sign bit of second arg#if defined(__INTERWORKING_STUBS__)	b	1f			@ Skip Thumb-code prologue#endifARM_FUNC_START addsf3ARM_FUNC_ALIAS aeabi_fadd addsf31:	@ Look for zeroes, equal values, INF, or NAN.	movs	r2, r0, lsl #1	movnes	r3, r1, lsl #1	teqne	r2, r3	mvnnes	ip, r2, asr #24	mvnnes	ip, r3, asr #24	beq	LSYM(Lad_s)	@ Compute exponent difference.  Make largest exponent in r2,	@ corresponding arg in r0, and positive exponent difference in r3.	mov	r2, r2, lsr #24	rsbs	r3, r2, r3, lsr #24	addgt	r2, r2, r3	eorgt	r1, r0, r1	eorgt	r0, r1, r0	eorgt	r1, r0, r1	rsblt	r3, r3, #0	@ If exponent difference is too large, return largest argument	@ already in r0.  We need up to 25 bit to handle proper rounding	@ of 0x1p25 - 1.1.	cmp	r3, #25	RETc(hi)	@ Convert mantissa to signed integer.	tst	r0, #0x80000000	orr	r0, r0, #0x00800000	bic	r0, r0, #0xff000000	rsbne	r0, r0, #0	tst	r1, #0x80000000	orr	r1, r1, #0x00800000	bic	r1, r1, #0xff000000	rsbne	r1, r1, #0	@ If exponent == difference, one or both args were denormalized.	@ Since this is not common case, rescale them off line.	teq	r2, r3	beq	LSYM(Lad_d)LSYM(Lad_x):	@ Compensate for the exponent overlapping the mantissa MSB added later	sub	r2, r2, #1	@ Shift and add second arg to first arg in r0.	@ Keep leftover bits into r1.	adds	r0, r0, r1, asr r3	rsb	r3, r3, #32	mov	r1, r1, lsl r3	@ Keep absolute value in r0-r1, sign in r3 (the n bit was set above)	and	r3, r0, #0x80000000	bpl	LSYM(Lad_p)	rsbs	r1, r1, #0	rsc	r0, r0, #0	@ Determine how to normalize the result.LSYM(Lad_p):	cmp	r0, #0x00800000	bcc	LSYM(Lad_a)	cmp	r0, #0x01000000	bcc	LSYM(Lad_e)	@ Result needs to be shifted right.	movs	r0, r0, lsr #1	mov	r1, r1, rrx	add	r2, r2, #1	@ Make sure we did not bust our exponent.	cmp	r2, #254	bhs	LSYM(Lad_o)	@ Our result is now properly aligned into r0, remaining bits in r1.	@ Pack final result together.	@ Round with MSB of r1. If halfway between two numbers, round towards	@ LSB of r0 = 0. LSYM(Lad_e):	cmp	r1, #0x80000000	adc	r0, r0, r2, lsl #23	biceq	r0, r0, #1	orr	r0, r0, r3	RET	@ Result must be shifted left and exponent adjusted.LSYM(Lad_a):	movs	r1, r1, lsl #1	adc	r0, r0, r0	tst	r0, #0x00800000	sub	r2, r2, #1	bne	LSYM(Lad_e)		@ No rounding necessary since r1 will always be 0 at this point.LSYM(Lad_l):#if __ARM_ARCH__ < 5	movs	ip, r0, lsr #12	moveq	r0, r0, lsl #12	subeq	r2, r2, #12	tst	r0, #0x00ff0000	moveq	r0, r0, lsl #8	subeq	r2, r2, #8	tst	r0, #0x00f00000	moveq	r0, r0, lsl #4	subeq	r2, r2, #4	tst	r0, #0x00c00000	moveq	r0, r0, lsl #2	subeq	r2, r2, #2	cmp	r0, #0x00800000	movcc	r0, r0, lsl #1	sbcs	r2, r2, #0#else	clz	ip, r0	sub	ip, ip, #8	subs	r2, r2, ip	mov	r0, r0, lsl ip#endif	@ Final result with sign	@ If exponent negative, denormalize result.	addge	r0, r0, r2, lsl #23	rsblt	r2, r2, #0	orrge	r0, r0, r3	orrlt	r0, r3, r0, lsr r2	RET	@ Fixup and adjust bit position for denormalized arguments.	@ Note that r2 must not remain equal to 0.LSYM(Lad_d):	teq	r2, #0	eor	r1, r1, #0x00800000	eoreq	r0, r0, #0x00800000	addeq	r2, r2, #1	subne	r3, r3, #1	b	LSYM(Lad_x)LSYM(Lad_s):	mov	r3, r1, lsl #1	mvns	ip, r2, asr #24	mvnnes	ip, r3, asr #24	beq	LSYM(Lad_i)	teq	r2, r3	beq	1f	@ Result is x + 0.0 = x or 0.0 + y = y.	teq	r2, #0	moveq	r0, r1	RET1:	teq	r0, r1	@ Result is x - x = 0.	movne	r0, #0	RETc(ne)	@ Result is x + x = 2x.	tst	r2, #0xff000000	bne	2f	movs	r0, r0, lsl #1	orrcs	r0, r0, #0x80000000	RET2:	adds	r2, r2, #(2 << 24)	addcc	r0, r0, #(1 << 23)	RETc(cc)	and	r3, r0, #0x80000000	@ Overflow: return INF.LSYM(Lad_o):	orr	r0, r3, #0x7f000000	orr	r0, r0, #0x00800000	RET	@ At least one of r0/r1 is INF/NAN.	@   if r0 != INF/NAN: return r1 (which is INF/NAN)	@   if r1 != INF/NAN: return r0 (which is INF/NAN)	@   if r0 or r1 is NAN: return NAN	@   if opposite sign: return NAN	@   otherwise return r0 (which is INF or -INF)LSYM(Lad_i):	mvns	r2, r2, asr #24	movne	r0, r1	mvneqs	r3, r3, asr #24	movne	r1, r0	movs	r2, r0, lsl #9	moveqs	r3, r1, lsl #9	teqeq	r0, r1	orrne	r0, r0, #0x00400000	@ quiet NAN	RET	FUNC_END aeabi_frsub	FUNC_END aeabi_fadd	FUNC_END addsf3	FUNC_END aeabi_fsub	FUNC_END subsf3ARM_FUNC_START floatunsisfARM_FUNC_ALIAS aeabi_ui2f floatunsisf			mov	r3, #0	b	1fARM_FUNC_START floatsisfARM_FUNC_ALIAS aeabi_i2f floatsisf		ands	r3, r0, #0x80000000	rsbmi	r0, r0, #01:	movs	ip, r0	RETc(eq)	@ Add initial exponent to sign	orr	r3, r3, #((127 + 23) << 23)	.ifnc	ah, r0	mov	ah, r0	.endif	mov	al, #0	b	2f	FUNC_END aeabi_i2f	FUNC_END floatsisf	FUNC_END aeabi_ui2f	FUNC_END floatunsisfARM_FUNC_START floatundisfARM_FUNC_ALIAS aeabi_ul2f floatundisf	orrs	r2, r0, r1#if !defined (__VFP_FP__) && !defined(__SOFTFP__)	mvfeqs	f0, #0.0#endif	RETc(eq)	mov	r3, #0	b	1fARM_FUNC_START floatdisfARM_FUNC_ALIAS aeabi_l2f floatdisf	orrs	r2, r0, r1#if !defined (__VFP_FP__) && !defined(__SOFTFP__)	mvfeqs	f0, #0.0#endif	RETc(eq)	ands	r3, ah, #0x80000000	@ sign bit in r3	bpl	1f	rsbs	al, al, #0	rsc	ah, ah, #01:#if !defined (__VFP_FP__) && !defined(__SOFTFP__)	@ For hard FPA code we want to return via the tail below so that	@ we can return the result in f0 as well as in r0 for backwards	@ compatibility.	str	lr, [sp, #-4]!	adr	lr, LSYM(f0_ret)#endif	movs	ip, ah	moveq	ip, al	moveq	ah, al	moveq	al, #0	@ Add initial exponent to sign	orr	r3, r3, #((127 + 23 + 32) << 23)	subeq	r3, r3, #(32 << 23)2:	sub	r3, r3, #(1 << 23)#if __ARM_ARCH__ < 5	mov	r2, #23	cmp	ip, #(1 << 16)	movhs	ip, ip, lsr #16	subhs	r2, r2, #16	cmp	ip, #(1 << 8)	movhs	ip, ip, lsr #8	subhs	r2, r2, #8	cmp	ip, #(1 << 4)	movhs	ip, ip, lsr #4	subhs	r2, r2, #4	cmp	ip, #(1 << 2)	subhs	r2, r2, #2	sublo	r2, r2, ip, lsr #1	subs	r2, r2, ip, lsr #3#else	clz	r2, ip	subs	r2, r2, #8#endif	sub	r3, r3, r2, lsl #23	blt	3f	add	r3, r3, ah, lsl r2	mov	ip, al, lsl r2	rsb	r2, r2, #32	cmp	ip, #0x80000000	adc	r0, r3, al, lsr r2	biceq	r0, r0, #1	RET3:	add	r2, r2, #32	mov	ip, ah, lsl r2	rsb	r2, r2, #32	orrs	al, al, ip, lsl #1	adc	r0, r3, ah, lsr r2	biceq	r0, r0, ip, lsr #31	RET#if !defined (__VFP_FP__) && !defined(__SOFTFP__)LSYM(f0_ret):	str	r0, [sp, #-4]!	ldfs	f0, [sp], #4	RETLDM#endif	FUNC_END floatdisf	FUNC_END aeabi_l2f	FUNC_END floatundisf	FUNC_END aeabi_ul2f#endif /* L_addsubsf3 */#ifdef L_muldivsf3ARM_FUNC_START mulsf3ARM_FUNC_ALIAS aeabi_fmul mulsf3	@ Mask out exponents, trap any zero/denormal/INF/NAN.	mov	ip, #0xff	ands	r2, ip, r0, lsr #23	andnes	r3, ip, r1, lsr #23	teqne	r2, ip	teqne	r3, ip	beq	LSYM(Lml_s)LSYM(Lml_x):	@ Add exponents together	add	r2, r2, r3	@ Determine final sign.	eor	ip, r0, r1	@ Convert mantissa to unsigned integer.	@ If power of two, branch to a separate path.	@ Make up for final alignment.	movs	r0, r0, lsl #9	movnes	r1, r1, lsl #9	beq	LSYM(Lml_1)	mov	r3, #0x08000000	orr	r0, r3, r0, lsr #5	orr	r1, r3, r1, lsr #5#if __ARM_ARCH__ < 4	@ Put sign bit in r3, which will be restored into r0 later.	and	r3, ip, #0x80000000	@ Well, no way to make it shorter without the umull instruction.	stmfd	sp!, {r3, r4, r5}	mov	r4, r0, lsr #16	mov	r5, r1, lsr #16	bic	r0, r0, r4, lsl #16	bic	r1, r1, r5, lsl #16	mul	ip, r4, r5	mul	r3, r0, r1	mul	r0, r5, r0	mla	r0, r4, r1, r0	adds	r3, r3, r0, lsl #16	adc	r1, ip, r0, lsr #16	ldmfd	sp!, {r0, r4, r5}#else	@ The actual multiplication.	umull	r3, r1, r0, r1	@ Put final sign in r0.	and	r0, ip, #0x80000000#endif	@ Adjust result upon the MSB position.	cmp	r1, #(1 << 23)	movcc	r1, r1, lsl #1	orrcc	r1, r1, r3, lsr #31	movcc	r3, r3, lsl #1	@ Add sign to result.	orr	r0, r0, r1	@ Apply exponent bias, check for under/overflow.	sbc	r2, r2, #127	cmp	r2, #(254 - 1)	bhi	LSYM(Lml_u)	@ Round the result, merge final exponent.	cmp	r3, #0x80000000	adc	r0, r0, r2, lsl #23	biceq	r0, r0, #1	RET	@ Multiplication by 0x1p*: let''s shortcut a lot of code.LSYM(Lml_1):	teq	r0, #0	and	ip, ip, #0x80000000	moveq	r1, r1, lsl #9	orr	r0, ip, r0, lsr #9	orr	r0, r0, r1, lsr #9	subs	r2, r2, #127

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩欧美激情在线| 三级在线观看一区二区| 亚洲一区二区三区在线看| 日本亚洲三级在线| caoporen国产精品视频| 91精品视频网| 亚洲欧美一区二区三区极速播放 | 日韩片之四级片| 国产精品久久久久9999吃药| 亚洲成人黄色小说| 国产宾馆实践打屁股91| 91精品国产综合久久久蜜臀粉嫩| 国产精品女同互慰在线看| 免费在线观看视频一区| 色94色欧美sute亚洲线路二| 中国色在线观看另类| 精品亚洲免费视频| 欧美丰满一区二区免费视频| 亚洲乱码日产精品bd| 成人性视频网站| 国产精品午夜春色av| 国产老女人精品毛片久久| 日韩午夜在线影院| 日本特黄久久久高潮| 日本乱码高清不卡字幕| 亚洲免费在线看| 色欧美乱欧美15图片| 亚洲色图制服诱惑| 99精品视频在线播放观看| 中文字幕成人网| 成人丝袜高跟foot| 国产精品国模大尺度视频| 福利电影一区二区三区| 国产欧美精品一区二区三区四区| 国产精品影音先锋| 国产欧美日韩综合精品一区二区 | 亚洲第一狼人社区| 欧美色网一区二区| 日韩av中文字幕一区二区| 欧美日韩国产美女| 日韩影视精彩在线| 日韩欧美亚洲国产精品字幕久久久| 亚洲网友自拍偷拍| 欧美久久久影院| 毛片一区二区三区| 国产亚洲欧美一区在线观看| 国产精品中文字幕欧美| 国产精品乱子久久久久| 日本大香伊一区二区三区| 亚洲一区二区三区三| 欧美日韩成人一区| 久久精品国产精品亚洲精品| 久久久不卡网国产精品一区| www.成人网.com| 一区二区三区日韩精品视频| 精品视频免费看| 国产麻豆精品95视频| 18成人在线观看| 欧美视频中文字幕| 久久99精品久久只有精品| 国产精品久久久久久久裸模| 91视频免费看| 日本vs亚洲vs韩国一区三区| 久久精品夜色噜噜亚洲aⅴ| 99久久免费视频.com| 日韩精品一二三| 欧美国产精品劲爆| 欧美日韩国产成人在线91| 国产乱码一区二区三区| 亚洲人成7777| 欧美videofree性高清杂交| 成人精品免费网站| 亚洲国产婷婷综合在线精品| 久久人人爽人人爽| 欧美三级日本三级少妇99| 国产盗摄一区二区| 五月天激情小说综合| 中文无字幕一区二区三区| 69成人精品免费视频| 成人福利视频在线看| 日韩国产在线观看一区| 欧美国产精品一区二区三区| 欧美精品v国产精品v日韩精品| 国产精品一二三在| 亚洲3atv精品一区二区三区| 久久天天做天天爱综合色| 欧美日韩国产综合草草| 成人av资源网站| 久久99精品久久久久婷婷| 午夜欧美大尺度福利影院在线看| 国产精品高清亚洲| 久久亚洲精精品中文字幕早川悠里| 欧美三级日韩在线| 91网址在线看| 成人黄色一级视频| 国产一区二区三区四区五区美女 | 亚洲图片你懂的| 国产日韩v精品一区二区| 91精品国产麻豆| 欧美日韩国产综合一区二区三区 | 亚洲精品一区二区三区影院| 欧美丝袜自拍制服另类| 91影院在线免费观看| 粗大黑人巨茎大战欧美成人| 激情六月婷婷综合| 久久国产精品露脸对白| 午夜精品一区二区三区电影天堂| 一区二区三区自拍| 一区二区三区免费在线观看| 国产精品乱码久久久久久 | 日韩欧美综合在线| 日韩午夜激情视频| 91精品国产福利| 日韩欧美亚洲另类制服综合在线| 欧美一区二区免费观在线| 91精品黄色片免费大全| 在线成人小视频| 欧美人伦禁忌dvd放荡欲情| 欧美日韩一区二区在线观看视频 | 精品久久久久久无| 日韩精品一区二区三区视频| 精品久久久久久久久久久久久久久 | 成人avav在线| 91在线视频播放地址| 色香色香欲天天天影视综合网| 99久久国产综合精品女不卡| 91免费国产在线观看| 精品1区2区3区| 日韩视频中午一区| 欧美精品一区二区三区高清aⅴ| 精品国产一区二区三区久久影院 | 日韩欧美在线一区二区三区| 欧美一区二区三区在线看| 日韩亚洲欧美综合| 欧美经典三级视频一区二区三区| 亚洲免费观看高清完整版在线观看熊| 伊人色综合久久天天| 天天色天天操综合| 国产在线播放一区三区四| 成人一区二区三区视频在线观看| 91免费观看国产| 日韩一区二区免费在线电影| 久久亚洲欧美国产精品乐播| 国产精品传媒在线| 亚洲成人动漫在线观看| 韩国av一区二区三区四区| 91视频你懂的| 91精品国产综合久久国产大片| 久久久久久久电影| 亚洲午夜在线视频| 国产一区二区美女诱惑| 色一区在线观看| 久久麻豆一区二区| 亚洲国产毛片aaaaa无费看 | 国产欧美一区二区三区沐欲| 亚洲欧美欧美一区二区三区| 日本不卡的三区四区五区| 成人晚上爱看视频| 91精品国产91热久久久做人人| 国产精品久久久一区麻豆最新章节| 亚洲成人久久影院| 9i在线看片成人免费| 日韩一区二区免费电影| 亚洲免费在线看| 国产v综合v亚洲欧| 欧美一区欧美二区| 亚洲精选视频在线| 国产精品99久久不卡二区| 欧美老人xxxx18| 成人免费一区二区三区在线观看| 美日韩一区二区| 欧美午夜视频网站| 中文字幕一区二区不卡| 美女精品一区二区| 欧美体内she精视频| 国产精品女同一区二区三区| 捆绑调教一区二区三区| 欧美影视一区二区三区| 一色屋精品亚洲香蕉网站| 国产一区二区精品久久99| 欧美欧美午夜aⅴ在线观看| 亚洲人吸女人奶水| 成人不卡免费av| 久久久亚洲精华液精华液精华液 | 精品福利一二区| 日韩高清不卡一区| 欧美日韩在线一区二区| 一区二区在线免费观看| 色一区在线观看| 亚洲精品国产品国语在线app| 国产激情一区二区三区四区| 精品美女被调教视频大全网站| 午夜影院久久久| 欧美精品在线视频| 亚洲v日本v欧美v久久精品| 在线一区二区视频| 亚洲永久免费av| 欧美三级中文字| 视频一区在线视频| 4438x亚洲最大成人网|