fsignal.fi

来自「开放源码的编译器open watcom 1.6.0版的源代码」· FI 代码 · 共 225 行

FI
225
字号
c$noreference

        integer SIG_IGN
        parameter (SIG_IGN = 1)
        integer SIG_DFL
        parameter (SIG_DFL = 2)
        integer SIG_ERR
        parameter (SIG_ERR = 3)

        integer SIGABRT
        parameter (SIGABRT = 1)
        integer SIGFPE
        parameter (SIGFPE = 2)
        integer SIGILL
        parameter (SIGILL = 3)
        integer SIGINT
        parameter (SIGINT = 4)
        integer SIGSEGV
        parameter (SIGSEGV = 5)
        integer SIGTERM
        parameter (SIGTERM = 6)
        integer SIGBREAK
        parameter (SIGBREAK = 7)
        ! following are OS/2 1.x process flag A,B and C
        integer SIGUSR1
        parameter (SIGUSR1 = 8)
        integer SIGUSR2
        parameter (SIGUSR2 = 9)
        integer SIGUSR3
        parameter (SIGUSR3 = 10)
        integer SIGIDIVZ
        parameter (SIGIDIVZ = 11)
        integer SIGIOVFL
        parameter (SIGIOVFL = 12)

        integer FLOAT_RADIX
        parameter (FLOAT_RADIX  = 2)

! number of base-FLT_RADIX digits in the floating point mantissa

        integer SINGLE_MANT_DIG
        parameter (SINGLE_MANT_DIG      = 23)
        integer DOUBLE_MANT_DIG
        parameter (DOUBLE_MANT_DIG      = 53)

! number of decimal digits of precision

        integer SINGLE_DIG
        parameter (SINGLE_DIG   = 6)
        integer DOUBLE_DIG
        parameter (DOUBLE_DIG   = 15)

! minimum negative integer such that FLT_RADIX raised to that power minus 1
! is a normalized floating point number

        integer SINGLE_MIN_EXP
        parameter (SINGLE_MIN_EXP       = -127)
        integer DOUBLE_MIN_EXP
        parameter (DOUBLE_MIN_EXP       = -1023)

! minimum negative integer such that 10 raised to that power is in the
! range of normalized floating point numbers

        integer SINGLE_MIN_10_EXP
        parameter (SINGLE_MIN_10_EXP    = -38)
        integer DOUBLE_MIN_10_EXP
        parameter (DOUBLE_MIN_10_EXP    = -307)

! maximum integer such that FLT_RADIX raised to that power minus 1 is a
! representable floating point number

        integer SINGLE_MAX_EXP
        parameter (SINGLE_MAX_EXP       = 127)
        integer DOUBLE_MAX_EXP
        parameter (DOUBLE_MAX_EXP       = 1023)

! maximum integer such that 10 raised to that power is in the range of
! representable floating point numbers

        integer SINGLE_MAX_10_EXP
        parameter (SINGLE_MAX_10_EXP    = 38 )
        integer DOUBLE_MAX_10_EXP
        parameter (DOUBLE_MAX_10_EXP    = 308 )

! maximum representable floating-point number

        real SINGLE_MAX
        parameter (SINGLE_MAX   = 3.402823e+38)
        double precision DOUBLE_MAX
        parameter (DOUBLE_MAX   = 1.79769313486231d+308)

! minimum positive floating point number x such that 1.0 + x .ne. 1.0

        real SINGLE_EPSILON
        parameter (SINGLE_EPSILON       = 1.192092896e-7)
        double precision DOUBLE_EPSILON
        parameter (DOUBLE_EPSILON       = 2.2204460492503131d-16)

! minimum representable positive floating point number

        real SINGLE_MIN
        parameter (SINGLE_MIN   = 1.175495e-38)
        double precision DOUBLE_MIN
        parameter (DOUBLE_MIN   = 2.22507385850721d-308)


! 8087/80287/80387 math co-processor control information

! 80(x)87 Control Word Mask and bit definitions

        integer MCW_EM
        parameter (MCW_EM               = '003f'x) ! interrupt Exception Masks */
        integer EM_INVALID
        parameter (EM_INVALID           = '0001'x) !   invalid
        integer EM_DENORMAL
        parameter (EM_DENORMAL          = '0002'x) !   denormal
        integer EM_ZERODIVIDE
        parameter (EM_ZERODIVIDE        = '0004'x) !   zero divide
        integer EM_OVERFLOW
        parameter (EM_OVERFLOW          = '0008'x) !   overflow
        integer EM_UNDERFLOW
        parameter (EM_UNDERFLOW         = '0010'x) !   underflow
        integer EM_PRECISION
        parameter (EM_PRECISION         = '0020'x) !   inexact result

        integer MCW_IC
        parameter (MCW_IC               = '1000'x) ! Infinity Control
        integer IC_AFFINE
        parameter (IC_AFFINE            = '1000'x) !   affine
        integer IC_PROJECTIVE
        parameter (IC_PROJECTIVE        = '0000'x) !   projective

        integer MCW_RC
        parameter (MCW_RC               = '0c00'x) ! Rounding Control
        integer RC_NEAR
        parameter (RC_NEAR              = '0000'x) !   near
        integer RC_DOWN
        parameter (RC_DOWN              = '0400'x) !   down
        integer RC_UP
        parameter (RC_UP                = '0800'x) !   up
        integer RC_CHOP
        parameter (RC_CHOP              = '0c00'x) !   chop

        integer MCW_PC
        parameter (MCW_PC               = '0300'x) ! Precision Control
        integer PC_24
        parameter (PC_24                = '0000'x) !    24 bits
        integer PC_53
        parameter (PC_53                = '0200'x) !    53 bits
        integer PC_64
        parameter (PC_64                = '0300'x) !    64 bits

! 80(x)87 Status Word bit definitions

        integer SW_INVALID
        parameter (SW_INVALID           = '0001'x)      ! invalid
        integer SW_DENORMAL
        parameter (SW_DENORMAL          = '0002'x)      ! denormal
        integer SW_ZERODIVIDE
        parameter (SW_ZERODIVIDE        = '0004'x)      ! zero divide
        integer SW_OVERFLOW
        parameter (SW_OVERFLOW          = '0008'x)      ! overflow
        integer SW_UNDERFLOW
        parameter (SW_UNDERFLOW         = '0010'x)      ! underflow
        integer SW_INEXACT
        parameter (SW_INEXACT           = '0020'x)      ! inexact (precision)

! Floating-point error codes

        integer FPE_INVALID
        parameter (FPE_INVALID          = '81'x)
        integer FPE_DENORMAL
        parameter (FPE_DENORMAL         = '82'x)
        integer FPE_ZERODIVIDE
        parameter (FPE_ZERODIVIDE       = '83'x)
        integer FPE_OVERFLOW
        parameter (FPE_OVERFLOW         = '84'x)
        integer FPE_UNDERFLOW
        parameter (FPE_UNDERFLOW        = '85'x)
        integer FPE_INEXACT
        parameter (FPE_INEXACT          = '86'x)
        integer FPE_UNEMULATED
        parameter (FPE_UNEMULATED       = '87'x)
        integer FPE_SQRTNEG
        parameter (FPE_SQRTNEG          = '88'x)
        integer FPE_STACKOVERFLOW
        parameter (FPE_STACKOVERFLOW    = '8a'x)
        integer FPE_STACKUNDERFLOW
        parameter (FPE_STACKUNDERFLOW   = '8b'x)
        integer FPE_EXPLICITGEN
        parameter (FPE_EXPLICITGEN      = '8c'x)
        integer FPE_IOVERFLOW
        parameter (FPE_IOVERFLOW        = '8d'x)

        integer fsignal
        external fsignal

c$pragma aux fsignal parm( value )

        integer _control87
        external _control87

c$ifdef __386__
c$ifdef __stack_conventions__
c$pragma aux _control87 "!" parm( value )
c$else
c$pragma aux _control87 "!_" parm( value )
c$endif
c$else
c$pragma aux _control87 "!_" parm( value*2 )
c$endif

        integer _clear87
        external _clear87

c$ifdef __386__
c$ifdef __stack_conventions__
c$pragma aux _clear87 "!"
c$else
c$pragma aux _clear87 "!_"
c$endif
c$else
c$pragma aux _clear87 "!_"
c$endif

⌨️ 快捷键说明

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