scalar.rem.inc

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

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

; <fold скалярный остаток от деления>
    if(used inst$sreme) ; <fold returns real>
                    proc        inst$sreme
        .L.0000:    fprem
                    fnstsw      wsc0
                    test        wsc0, $0400
                    jnz         .L.0000
                    fstp        esc1
                    ret
                    end_proc
    end if ; </fold>

    if(used inst$sremd) ; <fold returns double>
                    fast        inst$sremd
                    floc        operand0, float, \
                                operand1, float
                    fenter
                    vmovdqa     xword [.operand1], xmm1
                    vmovdqa     xword [.operand0], xmm0
                    fld         qword [.operand1]
                    fld         qword [.operand0]
        .L.0000:    fprem
                    fnstsw      wsc0
                    test        wsc0, $0400
                    jnz         .L.0000
                    fstp        esc1
                    fstp        qword [.operand0]
                    vmovdqa     xmm0, [.operand0]
                    fleave
    end if ; </fold>

    if(used inst$sremf) ; <fold returns float>
                    fast        inst$sremf
                    floc        operand0, float, \
                                operand1, float
                    fenter
                    vmovdqa     xword [.operand1], xmm1
                    vmovdqa     xword [.operand0], xmm0
                    fld         dword [.operand1]
                    fld         dword [.operand0]
        .L.0000:    fprem
                    fnstsw      wsc0
                    test        wsc0, $0400
                    jnz         .L.0000
                    fstp        esc1
                    fstp        dword [.operand0]
                    vmovdqa     xmm0, [.operand0]
                    fleave
    end if ; </fold>

    if(used inst$sremi) ; <fold returns int>
                    fast        inst$sremi
                    fenter
                    test        dsc1, dsc1
                    jnz         .L.0000
                    fthrow      ArithmeticException
        .L.0000:    cmp         dsc0, -$80000000
                    jne         .L.0001
                    cmp         dsc1, -$00000001
                    je          .L.0002
        .L.0001:    cdq
                    idiv        dsc1
                    mov         dsc0, dsc2
                    freturn
        .L.0002:    xor         dsc0, dsc0
                    fleave
    end if ; </fold>

    if(used inst$sreml) ; <fold returns long>
                    fast        inst$sreml
                    fenter
                    test        qsc1, qsc1
                    jnz         .L.0000
                    fthrow      ArithmeticException
        .L.0000:    cmp         qsc0, [cons$long.min]
                    jne         .L.0001
                    cmp         qsc1, [cons$long.m1]
                    je          .L.0002
        .L.0001:    cqo
                    idiv        qsc1
                    mov         qsc0, qsc2
                    freturn
        .L.0002:    xor         qsc0, qsc0
                    fleave
    end if ; </fold>
; </fold>