VirtualBox

source: vbox/trunk/src/VBox/Runtime/common/math/sinl.asm@ 5606

Last change on this file since 5606 was 4071, checked in by vboxsync, 17 years ago

Biggest check-in ever. New source code headers for all (C) innotek files.

  • Property svn:keywords set to Id
File size: 1.2 KB
Line 
1; $Id: sinl.asm 4071 2007-08-07 17:07:59Z vboxsync $
2;; @file
3; innotek Portable Runtime - No-CRT sinl - AMD64 & X86.
4;
5
6;
7; Copyright (C) 2006-2007 innotek GmbH
8;
9; This file is part of VirtualBox Open Source Edition (OSE), as
10; available from http://www.virtualbox.org. This file is free software;
11; you can redistribute it and/or modify it under the terms of the GNU
12; General Public License as published by the Free Software Foundation,
13; in version 2 as it comes in the "COPYING" file of the VirtualBox OSE
14; distribution. VirtualBox OSE is distributed in the hope that it will
15; be useful, but WITHOUT ANY WARRANTY of any kind.
16
17
18%include "iprt/asmdefs.mac"
19
20BEGINCODE
21
22%ifdef RT_ARCH_AMD64
23 %define _SP rsp
24 %define _BP rbp
25 %define _S 8
26%else
27 %define _SP esp
28 %define _BP ebp
29 %define _S 4
30%endif
31
32;;
33; Compute the sine of lrd
34; @returns st(0)
35; @param lrd [_SP + _S*2]
36BEGINPROC RT_NOCRT(sinl)
37 push _BP
38 mov _BP, _SP
39 sub _SP, 10h
40
41 fld tword [_BP + _S*2]
42 fsin
43 fnstsw ax
44 test ah, 04h
45 jz .done
46
47 fldpi
48 fadd st0
49 fxch st1
50.again:
51 fprem1
52 fnstsw ax
53 test ah, 04h
54 jnz .again
55 fstp st1
56 fsin
57
58.done:
59 leave
60 ret
61ENDPROC RT_NOCRT(sinl)
62
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette