/* A few TImode functions needed for TFmode emulated arithmetic. Copyright 2002, 2003 Free Software Foundation, Inc. Contributed by Alexandre Oliva This file is part of GCC. GCC 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. GCC 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 GCC; see the file COPYING. If not, write to the Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ #include "tconfig.h" #include "coretypes.h" #include "tm.h" #if _MIPS_SIM == _ABIN32 || _MIPS_SIM == _ABI64 typedef int TItype __attribute__ ((mode (TI))); typedef int DItype __attribute__ ((mode (DI))); typedef int SItype __attribute__ ((mode (SI))); typedef unsigned int UDItype __attribute__ ((mode (DI))); typedef union { struct TIstruct { #if LIBGCC2_WORDS_BIG_ENDIAN DItype high, low; #else DItype low, high; #endif } s; TItype ll; } TIunion; TItype __negti2 (TItype); TItype __ashlti3 (TItype, int); #if 0 TItype __ashrti3 (TItype, int); #endif TItype __lshrti3 (TItype, int); TItype __negti2 (TItype u) { TIunion w; TIunion uu; uu.ll = u; w.s.low = -uu.s.low; w.s.high = -uu.s.high - ((UDItype) w.s.low > 0); return w.ll; } TItype __ashlti3 (TItype u, int b) { TIunion w; int bm; TIunion uu; if (b == 0) return u; uu.ll = u; bm = (sizeof (DItype) * BITS_PER_UNIT) - b; if (bm <= 0) { w.s.low = 0; w.s.high = (UDItype) uu.s.low << -bm; } else { UDItype carries = (UDItype) uu.s.low >> bm; w.s.low = (UDItype) uu.s.low << b; w.s.high = ((UDItype) uu.s.high << b) | carries; } return w.ll; } #if 0 TItype __ashrti3 (TItype u, int b) { TIunion w; int bm; TIunion uu; if (b == 0) return u; uu.ll = u; bm = (sizeof (DItype) * BITS_PER_UNIT) - b; if (bm <= 0) { /* w.s.high = 1..1 or 0..0 */ w.s.high = uu.s.high >> (sizeof (DItype) * BITS_PER_UNIT - 1); w.s.low = uu.s.high >> -bm; } else { UDItype carries = (UDItype) uu.s.high << bm; w.s.high = uu.s.high >> b; w.s.low = ((UDItype) uu.s.low >> b) | carries; } return w.ll; } #endif TItype __lshrti3 (TItype u, int b) { TIunion w; int bm; TIunion uu; if (b == 0) return u; uu.ll = u; bm = (sizeof (DItype) * BITS_PER_UNIT) - b; if (bm <= 0) { w.s.high = 0; w.s.low = (UDItype) uu.s.high >> -bm; } else { UDItype carries = (UDItype) uu.s.high << bm; w.s.high = (UDItype) uu.s.high >> b; w.s.low = ((UDItype) uu.s.low >> b) | carries; } return w.ll; } #endif /* N32 or N64 */