Real.inc

Переключить прокрутку окна
Загрузить этот исходный код

;
  ; Реализация среды исполнения языка программирования
  ; Объектно-ориентированный продвинутый векторный транслятор
  ;
  ; Copyright © 2021, 2024 Малик Разработчик
  ;
  ; Это свободная программа: вы можете перераспространять ее и/или изменять
  ; ее на условиях Меньшей Стандартной общественной лицензии GNU в том виде,
  ; в каком она была опубликована Фондом свободного программного обеспечения;
  ; либо версии 3 лицензии, либо (по вашему выбору) любой более поздней версии.
  ;
  ; Эта программа распространяется в надежде, что она будет полезной,
  ; но БЕЗО ВСЯКИХ ГАРАНТИЙ; даже без неявной гарантии ТОВАРНОГО ВИДА
  ; или ПРИГОДНОСТИ ДЛЯ ОПРЕДЕЛЕННЫХ ЦЕЛЕЙ. Подробнее см. в Меньшей Стандартной
  ; общественной лицензии GNU.
  ;
  ; Вы должны были получить копию Меньшей Стандартной общественной лицензии GNU
  ; вместе с этой программой. Если это не так, см.
  ; <https://www.gnu.org/licenses/>.
;

; <fold avt.lang.Real — родной код>
    if(used avt.lang.Real$toLong2Bits$real$) ; <fold returns long2>
                    fast        avt.lang.Real$toLong2Bits$real$, \
                                value, real
                    fenter
                    movsx       r00q, word  [.value+$08]
                    vmovq       xmm0, [.value+$00]
                    vmovq       xmm1, r00
                    vpslldq     xmm1, xmm1, $08
                    vpor        xmm0, xmm0, xmm1
                    fleave
    end if ; </fold>

    if(used avt.lang.Real$nextAfter$real$) ; <fold returns real>
                    fast        avt.lang.Real$nextAfter$real$, \
                                value, real
                    floc        addend, real
                    fenter
                    mov         r00q, [.value+$00]
                    mov         r08q, [.value+$08]
                    fld         tbyte [.value+$00]
                    ; не-число
                    fcomi       esc0, esc0
                    jnp         @F
                    freturn
             @@:    ; –∞
                    fld         tbyte [avt.lang.Real$NEGATIVE_INFINITY+$00]
                    fcomip      esc0, esc1
                    jne         @F
                    ffree       esc0
                    fincstp
                    fld         tbyte [avt.lang.Real$NEGATIVE_MAX_VALUE+$00]
                    freturn
             @@:    ; –MIN_VALUE
                    cmp         r00q, [avt.lang.Real$NEGATIVE_MIN_VALUE+$00]
                    jne         @F
                    cmp         r08w, [avt.lang.Real$NEGATIVE_MIN_VALUE+$08]
                    jne         @F
                    ffree       esc0
                    fincstp
                    fld         tbyte [avt.lang.Real$NEGATIVE_ZERO+$00]
                    freturn
             @@:    ; –0
                    cmp         r00q, [avt.lang.Real$NEGATIVE_ZERO+$00]
                    jne         @F
                    cmp         r08w, [avt.lang.Real$NEGATIVE_ZERO+$08]
                    jne         @F
                    ffree       esc0
                    fincstp
                    fldz
                    freturn
             @@:    ; остальные значения
                    mov         r01d, r08d
                    and         r01d, $7fff
                    test        r01d, r01d
                    jnz         .L.0000
                    mov         r02d, $01
                    xor         r09d, r09d
                    jmp         .L.0002
        .L.0000:    cmp         r01d, $3f
                    jg          .L.0001
                    lea         r01d, [r01d-$01]
                    mov         r02d, $01
                    shl         r02q, r01b
                    xor         r09d, r09d
                    jmp         .L.0002
        .L.0001:    mov         r02q, [avt.lang.Real$EMPTY_SIGNIFICAND+$00]
                    lea         r09d, [r01d-$3f]
        .L.0002:    mov         qword [.addend+$00], r02q
                    mov         qword [.addend+$08], r09q
                    test        r08w, [avt.lang.Real$NEGATIVE_ZERO_BITS+$08]
                    jz          .L.0003
                    test        r00q, [avt.lang.Real$SIGNIFICAND_MASK+$00]
                    jnz         .L.0003
                    fld         tbyte [.addend+$00]
                    fld         tbyte [avt.lang.Real$HALF+$00]
                    fmulp       esc1, esc0
                    faddp       esc1, esc0
                    freturn
        .L.0003:    fld         tbyte [.addend+$00]
                    faddp       esc1, esc0
                    fleave
    end if ; </fold>

    if(used avt.lang.Real$nextBefore$real$) ; <fold returns real>
                    fast        avt.lang.Real$nextBefore$real$, \
                                value, real
                    floc        addend, real
                    fenter
                    mov         r00q, [.value+$00]
                    mov         r08q, [.value+$08]
                    fld         tbyte [.value+$00]
                    ; не-число
                    fcomi       esc0, esc0
                    jnp         @F
                    freturn
             @@:    ; +∞
                    fld         tbyte [avt.lang.Real$POSITIVE_INFINITY+$00]
                    fcomip      esc0, esc1
                    jne         @F
                    ffree       esc0
                    fincstp
                    fld         tbyte [avt.lang.Real$MAX_VALUE+$00]
                    freturn
             @@:    ; +MIN_VALUE
                    cmp         r00q, [avt.lang.Real$MIN_VALUE+$00]
                    jne         @F
                    cmp         r08w, [avt.lang.Real$MIN_VALUE+$08]
                    jne         @F
                    ffree       esc0
                    fincstp
                    fldz
                    freturn
             @@:    ; +0
                    cmp         r00q, $00
                    jne         @F
                    cmp         r08w, $00
                    jne         @F
                    ffree       esc0
                    fincstp
                    fld         tbyte [avt.lang.Real$NEGATIVE_ZERO+$00]
                    freturn
             @@:    ; остальные значения
                    mov         r01d, r08d
                    and         r01d, $7fff
                    test        r01d, r01d
                    jnz         .L.0000
                    mov         r02d, $01
                    xor         r09d, r09d
                    jmp         .L.0002
        .L.0000:    cmp         r01d, $3f
                    jg          .L.0001
                    lea         r01d, [r01d-$01]
                    mov         r02d, $01
                    shl         r02q, r01b
                    xor         r09d, r09d
                    jmp         .L.0002
        .L.0001:    mov         r02q, [avt.lang.Real$EMPTY_SIGNIFICAND+$00]
                    lea         r09d, [r01d-$3f]
        .L.0002:    mov         qword [.addend+$00], r02q
                    mov         qword [.addend+$08], r09q
                    test        r08w, [avt.lang.Real$NEGATIVE_ZERO_BITS+$08]
                    jnz         .L.0003
                    test        r00q, [avt.lang.Real$SIGNIFICAND_MASK+$00]
                    jnz         .L.0003
                    fld         tbyte [.addend+$00]
                    fld         tbyte [avt.lang.Real$HALF+$00]
                    fmulp       esc1, esc0
                    fsubp       esc1, esc0
                    freturn
        .L.0003:    fld         tbyte [.addend+$00]
                    fsubp       esc1, esc0
                    fleave
    end if ; </fold>
; </fold>