mirror of
https://github.com/UberGames/ioef.git
synced 2025-01-22 00:41:17 +00:00
160 lines
3 KiB
ArmAsm
160 lines
3 KiB
ArmAsm
/*
|
|
===========================================================================
|
|
Copyright (C) 1999-2005 Id Software, Inc.
|
|
|
|
This file is part of Quake III Arena source code.
|
|
|
|
Quake III Arena source code 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 of the License,
|
|
or (at your option) any later version.
|
|
|
|
Quake III Arena source code 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 Foobar; if not, write to the Free Software
|
|
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
===========================================================================
|
|
*/
|
|
|
|
//
|
|
// qftol -- fast floating point to long conversion.
|
|
//
|
|
|
|
// 23/09/05 Ported to gas by intel2gas, best supporting actor Tim Angus
|
|
// <tim@ngus.net>
|
|
|
|
#include "qasm.h"
|
|
|
|
#if id386
|
|
|
|
.data
|
|
|
|
temp: .single 0.0
|
|
fpucw: .long 0
|
|
|
|
// Precision Control Field , 2 bits / 0x0300
|
|
// PC24 0x0000 Single precision (24 bits).
|
|
// PC53 0x0200 Double precision (53 bits).
|
|
// PC64 0x0300 Extended precision (64 bits).
|
|
|
|
// Rounding Control Field, 2 bits / 0x0C00
|
|
// RCN 0x0000 Rounding to nearest (even).
|
|
// RCD 0x0400 Rounding down (directed, minus).
|
|
// RCU 0x0800 Rounding up (directed plus).
|
|
// RC0 0x0C00 Rounding towards zero (chop mode).
|
|
|
|
|
|
// rounding towards nearest (even)
|
|
cw027F: .long 0x027F
|
|
cw037F: .long 0x037F
|
|
|
|
// rounding towards zero (chop mode)
|
|
cw0E7F: .long 0x0E7F
|
|
cw0F7F: .long 0x0F7F
|
|
|
|
|
|
.text
|
|
|
|
//
|
|
// int qftol( void ) - default control word
|
|
//
|
|
|
|
.globl C(qftol)
|
|
|
|
C(qftol):
|
|
fistpl temp
|
|
movl temp,%eax
|
|
ret
|
|
|
|
|
|
//
|
|
// int qftol027F( void ) - DirectX FPU
|
|
//
|
|
|
|
.globl C(qftol027F)
|
|
|
|
C(qftol027F):
|
|
fnstcw fpucw
|
|
fldcw cw027F
|
|
fistpl temp
|
|
fldcw fpucw
|
|
movl temp,%eax
|
|
ret
|
|
|
|
//
|
|
// int qftol037F( void ) - Linux FPU
|
|
//
|
|
|
|
.globl C(qftol037F)
|
|
|
|
C(qftol037F):
|
|
fnstcw fpucw
|
|
fldcw cw037F
|
|
fistpl temp
|
|
fldcw fpucw
|
|
movl temp,%eax
|
|
ret
|
|
|
|
|
|
//
|
|
// int qftol0F7F( void ) - ANSI
|
|
//
|
|
|
|
.globl C(qftol0F7F)
|
|
|
|
C(qftol0F7F):
|
|
fnstcw fpucw
|
|
fldcw cw0F7F
|
|
fistpl temp
|
|
fldcw fpucw
|
|
movl temp,%eax
|
|
ret
|
|
|
|
//
|
|
// int qftol0E7F( void )
|
|
//
|
|
|
|
.globl C(qftol0E7F)
|
|
|
|
C(qftol0E7F):
|
|
fnstcw fpucw
|
|
fldcw cw0E7F
|
|
fistpl temp
|
|
fldcw fpucw
|
|
movl temp,%eax
|
|
ret
|
|
|
|
|
|
|
|
//
|
|
// long Q_ftol( float q )
|
|
//
|
|
|
|
.globl C(Q_ftol)
|
|
|
|
C(Q_ftol):
|
|
flds 4(%esp)
|
|
fistpl temp
|
|
movl temp,%eax
|
|
ret
|
|
|
|
|
|
//
|
|
// long qftol0F7F( float q ) - Linux FPU
|
|
//
|
|
|
|
.globl C(Q_ftol0F7F)
|
|
|
|
C(Q_ftol0F7F):
|
|
fnstcw fpucw
|
|
flds 4(%esp)
|
|
fldcw cw0F7F
|
|
fistpl temp
|
|
fldcw fpucw
|
|
movl temp,%eax
|
|
ret
|
|
#endif
|