⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 pow32.s

📁 VXWORKS源代码
💻 S
字号:
/* pow32.s - VxWorks conversion from Microtek tools to Sun native *//* Copyright 1984-1992 Wind River Systems, Inc. *//*modification history--------------------01b,13nov92,jwt  added temporary (until USS patch) fix for pow(0.0,0.0) = 0.0.01a,06aug92,jwt  converted.*//*! ! ! ! !!	SPARClite		Floating Point Library!!	Copyright (C) 1992 By!	United States Software Corporation!	14215 N.W. Science Park Drive!	Portland, Oregon 97229!!	This software is furnished under a license and may be used!	and copied only in accordance with the terms of such license!	and with the inclusion of the above copyright notice.!	This software or any other copies thereof may not be provided!	or otherwise made available to any other person.  No title to!	and ownership of the software is hereby transferred.!!	The information in this software is subject to change without !	notice and should not be construed as a commitment by United!	States Software Corporation.!!	First Release:		V1.02	March 26 1992! ! ! ! !	.macro	scan,p1,p2,p3	.word	0x81602000 | (&p3<<25) | (&p1<<14) | p2	.endm	.macro	umul,p1,p2,p3	.word	0x80500000 | (&p3<<25) | (&p1<<14) | &p2	.endm	.macro	divscc,p1,p2,p3	.word	0x80e80000 | (&p3<<25) | (&p1<<14) | &p2	.endm*/#include "arch/sparc/ussSun4.h"	.global	_exlog	.global	_exmul	.global	_exexp	.global	_exdiv	.text	.align	4	.global	_dppow_dppow:	.global	_pow_pow:	save	%sp,-96,%sp	/* Test for positive or negative zero */	set	0x7FF00000,%l4		/* exponent (30-20) */	andcc	%l4,%i0,%g0	bne	powNonZero	andcc	%l4,%i2,%g0	bne	powNonZero	nop	set	0x3FF00000,%i0		/* return 1.0 */	set	0,%i1	ret	restorepowNonZero:	sll     %i0,1,%l4	srl     %l4,21,%l4	sll     %i0,11,%l2	srl     %i1,21,%g1	or      %l2,%g1,%l2	sll     %i1,11,%l3	sethi   %hi(0x80000000),%l0	or      %l2,%l0,%l2	sll     %i2,1,%l7	srl     %l7,21,%l7	sll     %i2,11,%l5	srl     %i3,21,%g1	or      %l5,%g1,%l5	sll     %i3,11,%l6	or      %l5,%l0,%l5	and     %l0,%i0,%l0	sub     %l4,1,%g1	subcc   %g1,0x7fe,%g0	bcc     AspecA         Alab1:	sub     %l7,1,%g1	subcc   %g1,0x7fe,%g0	bcc     AspecB   	NOPAlab2:	sub     %l7,0x3fe,%i4	subcc   %l0,0,%l0	be      i1             	subcc   %i4,0,%i4	ble     Anan           	subcc   %i4,0x40,%g0	ble     i2       	NOP	or      %g0,0,%i5	ba      e2       	or      %g0,%i5,%l1i2:	subcc   %i4,0x20,%g0	ble     i3       	NOP	sub     %i4,0x21,%g1	sll     %l6,%g1,%i5	ba      e2       	sll     %i5,1,%l1i3:	sub     %i4,1,%g1	sll     %l5,%g1,%i5	sll     %i5,1,%l1	or      %l1,%l6,%l1e2:	subcc   %l1,0,%l1	bne     Anan           	subcc   %i5,0,%i5	bpos,a	i1              	or      %g0,0,%l0i1:	subcc   %i4,0xf,%g0	bcc     i5             	sll     %l5,%i4,%g1	orcc    %g1,%l6,%g1	be      Apow20   	NOPi5:	sethi   %hi(0x80000000),%g1	and     %g1,%i2,%i4	subcc   %l4,0x3ff,%g0	bge     i6       	NOP	sethi   %hi(0x80000000),%g1	xor     %i4,%g1,%i4i6:	or      %g0,%l2,%o0	or      %g0,%l3,%o1	call    _exlog	or      %g0,%l4,%o2	or      %g0,%l5,%o3	or      %g0,%l6,%o4	call    _exmul	or      %g0,%l7,%o5	call    _exexp	or      %g0,%i4,%o3	or      %g0,%o0,%l2	or      %g0,%o1,%l3	or      %g0,%o2,%l4Aret2:	sub     %l4,1,%g1	subcc   %g1,0x7fe,%g0	bcc     Aundove  	NOP	srl     %l3,11,%i1	sll     %l2,21,%g1	or      %i1,%g1,%i1	srl     %l2,11,%i0	sethi   %hi(0xfffff),%g1	or      %g1,0x3ff,%g1	and     %i0,%g1,%i0	sll     %l4,20,%g1	or      %i0,%g1,%i0Aret:	or      %i0,%l0,%i0Aret3:A999:	jmpl	%i7+8,%g0	restore	%g0,0,%g0Apow20:	or      %g0,0x20,%g1	sub     %g1,%i4,%g1	srl     %l5,%g1,%l1	or      %g0,%l2,%l5	or      %g0,%l3,%l6	or      %g0,%l4,%l7	andcc   %l1,1,%g1	bne     i7       	NOP	sethi   %hi(0x80000000),%l2	or      %g0,0,%l3	or      %g0,0x3ff,%l4i7:	srl     %l1,1,%l1b8:	subcc   %l1,0,%l1	be      i8             	or      %g0,%l5,%o0	or      %g0,%l6,%o1	or      %g0,%l7,%o2	or      %g0,%l5,%o3	or      %g0,%l6,%o4	call    _exmul	or      %g0,%l7,%o5	or      %g0,%o0,%l5	or      %g0,%o1,%l6	or      %g0,%o2,%l7	andcc   %l1,1,%g1	be      i9             	or      %g0,%l2,%o0	or      %g0,%l3,%o1	or      %g0,%l4,%o2	or      %g0,%l5,%o3	or      %g0,%l6,%o4	call    _exmul	or      %g0,%l7,%o5	or      %g0,%o0,%l2	or      %g0,%o1,%l3	or      %g0,%o2,%l4i9:	ba      b8       	srl     %l1,1,%l1i8:	subcc   %i2,0,%i2	bpos    Aret2          	sethi   %hi(0x80000000),%o0	or      %g0,0,%o1	or      %g0,0x3ff,%o2	or      %g0,%l2,%o3	or      %g0,%l3,%o4	call    _exdiv	or      %g0,%l4,%o5	or      %g0,%o0,%l2	or      %g0,%o1,%l3	ba      Aret2    	or      %g0,%o2,%l4AspecA:	subcc   %l4,0,%l4	bne     i11      	NOP	addcc   %l3,%l3,%l3	addx    %l2,%l2,%l2	orcc    %l2,%l3,%g1	be      i11      	NOP/*	scan	%l2,0,%i4	*/	SCAN | (lo2 << 14) | 0 | (in4 << 25)	subcc	%i4,63,%g0	bne	L1             	NOP	or	%l3,0,%l2	or	%g0,0,%l3	sub	%l4,32,%l4/*	scan	%l2,0,%i4	*/	SCAN | (lo2 << 14) | 0 | (in4 << 25)	subcc	%i4,63,%g0	be,a	L1             	or	%i4,0,%l4L1:	subcc	%g0,%i4,%i5	be	Alab1          	sub	%l4,%i4,%l4	sll	%l2,%i4,%l2	srl	%l3,%i5,%i5	or	%i5,%l2,%l2	sll	%l3,%i4,%l3	ba,a    Alab1    i11:	sll     %i2,1,%g1	orcc    %g1,%i3,%g1	be      Anan           	subcc   %l4,0,%l4	bne     i13            	subcc   %l7,0x7ff,%g0	be      Anan           	subcc   %i2,0,%i2	bneg    Ainf     	NOP	ba,a    Azer     i13:	sll     %l2,1,%g1	orcc    %g1,%l3,%g1	bne     Anan           	subcc   %l7,0x3ff,%g0	bcc     Alab1    	NOP	or      %g0,0x3ff,%l7	ba      Alab1    	or      %g0,-1,%l5AspecB:	subcc   %l7,0,%l7	bne     i15            	sll     %l5,1,%g1	orcc    %g1,%l6,%g1	be      Aone           	subcc   %l0,0,%l0	be      Aone           i15:	sll     %l5,1,%g1	orcc    %g1,%l6,%g1	bne     Anan     	NOP	ba,a    Aovr     Ainf:	sethi   %hi(0x7ff00000),%i0	ba      Aret     	or      %g0,0,%i1Anan:	sethi   %hi(0xfff80000),%i0	ba      Aret3    	or      %g0,0,%i1Azer:	or      %g0,0,%i0	ba      Aret     	or      %g0,0,%i1Aone:	sethi   %hi(0x3ff00000),%i0	ba      Aret3    	or      %g0,0,%i1Aovr:	subcc   %l0,0,%l0	bne     Anan           	subcc   %i2,0,%i2	bpos    i16            	subcc   %l4,0x3ff,%g0	bge     Azer     	NOP	ba,a    Ainf     i16:	subcc   %l4,0x3ff,%g0	bge     Ainf     	NOP	ba,a    Azer     Aundove:	subcc   %l4,0,%l4	bg      Ainf     	NOP	or      %g0,0xc,%i4	sub     %i4,%l4,%i4L3:	subcc	%i4,32,%g0	bcs	L4             	subcc	%g0,%i4,%i5	sub	%i4,32,%i4	orcc	%l2,0,%l3	bne	L3             	or	%g0,0,%l2L4:	be	L5             	sll	%l2,%i5,%i5	srl	%l3,%i4,%l3	srl	%l2,%i4,%l2	or	%l3,%i5,%l3L5:	or      %g0,%l2,%i0	ba      Aret     	or      %g0,%l3,%i1!	.end

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -