Annotation of GNUtools/cc/config/i386/perform.h, revision 1.1

1.1     ! root        1: /* Definitions for AT&T assembler syntax for the Intel 80386.
        !             2:    Copyright (C) 1993 Free Software Foundation, Inc.
        !             3: 
        !             4: This file is part of GNU CC.
        !             5: 
        !             6: GNU CC is free software; you can redistribute it and/or modify
        !             7: it under the terms of the GNU General Public License as published by
        !             8: the Free Software Foundation; either version 2, or (at your option)
        !             9: any later version.
        !            10: 
        !            11: GNU CC is distributed in the hope that it will be useful,
        !            12: but WITHOUT ANY WARRANTY; without even the implied warranty of
        !            13: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
        !            14: GNU General Public License for more details.
        !            15: 
        !            16: You should have received a copy of the GNU General Public License
        !            17: along with GNU CC; see the file COPYING.  If not, write to
        !            18: the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  */
        !            19: 
        !            20: /* Defines to be able to build libgcc.a with GCC.  */
        !            21: 
        !            22: /* It might seem that these are not important, since gcc 2 will never
        !            23:    call libgcc for these functions.  But programs might be linked with
        !            24:    code compiled by gcc 1, and then these will be used.  */
        !            25: 
        !            26: /* The arg names used to be a and b, but `a' appears inside strings
        !            27:    and that confuses non-ANSI cpp.  */
        !            28: 
        !            29: #define perform_udivsi3(arg0,arg1)                                     \
        !            30: {                                                                      \
        !            31:   register int dx asm("dx");                                           \
        !            32:   register int ax asm("ax");                                           \
        !            33:                                                                        \
        !            34:   dx = 0;                                                              \
        !            35:   ax = arg0;                                                           \
        !            36:   asm ("divl %3" : "=a" (ax), "=d" (dx) : "a" (ax), "g" (arg1), "d" (dx)); \
        !            37:   return ax;                                                           \
        !            38: }
        !            39: 
        !            40: #define perform_divsi3(arg0,arg1)                                      \
        !            41: {                                                                      \
        !            42:   register int dx asm("dx");                                           \
        !            43:   register int ax asm("ax");                                           \
        !            44:   register int cx asm("cx");                                           \
        !            45:                                                                        \
        !            46:   ax = arg0;                                                           \
        !            47:   cx = arg1;                                                           \
        !            48:   asm ("cltd\n\tidivl %3" : "=a" (ax), "=&d" (dx) : "a" (ax), "c" (cx)); \
        !            49:   return ax;                                                           \
        !            50: }
        !            51: 
        !            52: #define perform_umodsi3(arg0,arg1)                                     \
        !            53: {                                                                      \
        !            54:   register int dx asm("dx");                                           \
        !            55:   register int ax asm("ax");                                           \
        !            56:                                                                        \
        !            57:   dx = 0;                                                              \
        !            58:   ax = arg0;                                                           \
        !            59:   asm ("divl %3" : "=a" (ax), "=d" (dx) : "a" (ax), "g" (arg1), "d" (dx)); \
        !            60:   return dx;                                                           \
        !            61: }
        !            62: 
        !            63: #define perform_modsi3(arg0,arg1)                                      \
        !            64: {                                                                      \
        !            65:   register int dx asm("dx");                                           \
        !            66:   register int ax asm("ax");                                           \
        !            67:   register int cx asm("cx");                                           \
        !            68:                                                                        \
        !            69:   ax = arg0;                                                           \
        !            70:   cx = arg1;                                                           \
        !            71:   asm ("cltd\n\tidivl %3" : "=a" (ax), "=&d" (dx) : "a" (ax), "c" (cx)); \
        !            72:   return dx;                                                           \
        !            73: }
        !            74: 
        !            75: #define perform_fixdfsi(arg0)                                          \
        !            76: {                                                                      \
        !            77:   auto unsigned short ostatus;                                         \
        !            78:   auto unsigned short nstatus;                                         \
        !            79:   auto int ret;                                                                \
        !            80:   auto double tmp;                                                     \
        !            81:                                                                        \
        !            82:   &ostatus;                    /* guarantee these land in memory */    \
        !            83:   &nstatus;                                                            \
        !            84:   &ret;                                                                        \
        !            85:   &tmp;                                                                        \
        !            86:                                                                        \
        !            87:   asm volatile ("fnstcw %0" : "=m" (ostatus));                         \
        !            88:   nstatus = ostatus | 0x0c00;                                          \
        !            89:   asm volatile ("fldcw %0" : /* no outputs */ : "m" (nstatus));                \
        !            90:   tmp = arg0;                                                          \
        !            91:   asm volatile ("fldl %0" : /* no outputs */ : "m" (tmp));             \
        !            92:   asm volatile ("fistpl %0" : "=m" (ret));                             \
        !            93:   asm volatile ("fldcw %0" : /* no outputs */ : "m" (ostatus));                \
        !            94:                                                                        \
        !            95:   return ret;                                                          \
        !            96: }
        !            97: 

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.