scalar.lt.inc

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

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

; <fold скалярное меньше>
    ; <fold приватные макросы — должны использоваться только этим текстом исходного кода>
        macro _setcmpltf {
                        setnb       bsc0
                        dec         bsc0
                        movsx       dsc0, bsc0
        }

        macro _setcmplti {
                        setnl       bsc0
                        dec         bsc0
                        movsx       dsc0, bsc0
        }
    ; </fold>

    ; <fold первый операнд — на стаке, второй операнд — на аккумуляторе, результат — на аккумуляторе>
        macro setslte {
                        fld         tbyte [rsp+$00]
                        __pop       $01
                        fcomip      esc0, esc1
                        releasee
                        _setcmpg
                        _setcmpltf
        }

        macro setsltd {
                        vmovdqa     xmm1, [rsp+$00]
                        __pop       $01
                        vcomisd     xmm1, xmm0
                        _setcmpg
                        _setcmpltf
        }

        macro setsltf {
                        vmovdqa     xmm1, [rsp+$00]
                        __pop       $01
                        vcomiss     xmm1, xmm0
                        _setcmpg
                        _setcmpltf
        }

        macro setslti {
                        mov         dsc1, [rsp+$00]
                        __pop       $01
                        cmp         dsc1, dsc0
                        _setcmplti
        }

        macro setsltl {
                        mov         qsc1, [rsp+$00]
                        __pop       $01
                        cmp         qsc1, qsc0
                        _setcmplti
        }
    ; </fold>

    ; <fold первый операнд — на стаке, второй операнд — на аккумуляторе, результат — на стаке>
        macro setslte_p {
                        fld         tbyte [rsp+$00]
                        fcomip      esc0, esc1
                        releasee
                        _setcmpg
                        _setcmpltf
                        _wrstb
        }

        macro setsltd_p {
                        vmovdqa     xmm1, [rsp+$00]
                        vcomisd     xmm1, xmm0
                        _setcmpg
                        _setcmpltf
                        _wrstb
        }

        macro setsltf_p {
                        vmovdqa     xmm1, [rsp+$00]
                        vcomiss     xmm1, xmm0
                        _setcmpg
                        _setcmpltf
                        _wrstb
        }

        macro setslti_p {
                        cmp         dword [rsp+$00], dsc0
                        _setcmplti
                        _wrstb
        }

        macro setsltl_p {
                        cmp         qword [rsp+$00], qsc0
                        _setcmplti
                        _wrstb
        }
    ; </fold>

    ; <fold первый операнд — на аккумуляторе, второй операнд — локальная переменная, результат — на аккумуляторе>
        macro setslte_l localvarName* {
                        fld         tbyte [.#localvarName]
                        fxch
                        fcomip      esc0, esc1
                        releasee
                        _setcmpg
                        _setcmpltf
        }

        macro setsltd_l localvarName* {
                        vcomisd     xmm0, [.#localvarName]
                        _setcmpg
                        _setcmpltf
        }

        macro setsltf_l localvarName* {
                        vcomiss     xmm0, [.#localvarName]
                        _setcmpg
                        _setcmpltf
        }

        macro setslti_l localvarName* {
                        cmp         dsc0, [.#localvarName]
                        _setcmplti
        }

        macro setsltl_l localvarName* {
                        cmp         qsc0, [.#localvarName]
                        _setcmplti
        }
    ; </fold>

    ; <fold первый операнд — на аккумуляторе, второй операнд — глобальный член, результат — на аккумуляторе>
        macro setslte_g globalmember* {
                        fld         tbyte globalmember
                        fxch
                        fcomip      esc0, esc1
                        releasee
                        _setcmpg
                        _setcmpltf
        }

        macro setsltd_g globalmember* {
                        vcomisd     xmm0, globalmember
                        _setcmpg
                        _setcmpltf
        }

        macro setsltf_g globalmember* {
                        vcomiss     xmm0, globalmember
                        _setcmpg
                        _setcmpltf
        }

        macro setslti_g globalmember* {
                        cmp         dsc0, globalmember
                        _setcmplti
        }

        macro setsltl_g globalmember* {
                        cmp         qsc0, globalmember
                        _setcmplti
        }
    ; </fold>

    ; <fold первый операнд — на стаке, второй операнд — на аккумуляторе, результат — переход>
        macro jsltge labelIsTrue* {
                        fld         tbyte [rsp+$00]
                        __pop       $01
                        fcomip      esc0, esc1
                        releasee
                        _setcmpg
                        jb          labelIsTrue
        }

        macro jsltle labelIsTrue* {
                        fld         tbyte [rsp+$00]
                        __pop       $01
                        fcomip      esc0, esc1
                        releasee
                        _setcmpl
                        jb          labelIsTrue
        }

        macro jsltgd labelIsTrue* {
                        vmovdqa     xmm1, [rsp+$00]
                        __pop       $01
                        vcomisd     xmm1, xmm0
                        _setcmpg
                        jb          labelIsTrue
        }

        macro jsltld labelIsTrue* {
                        vmovdqa     xmm1, [rsp+$00]
                        __pop       $01
                        vcomisd     xmm1, xmm0
                        _setcmpl
                        jb          labelIsTrue
        }

        macro jsltgf labelIsTrue* {
                        vmovdqa     xmm1, [rsp+$00]
                        __pop       $01
                        vcomiss     xmm1, xmm0
                        _setcmpg
                        jb          labelIsTrue
        }

        macro jsltlf labelIsTrue* {
                        vmovdqa     xmm1, [rsp+$00]
                        __pop       $01
                        vcomiss     xmm1, xmm0
                        _setcmpl
                        jb          labelIsTrue
        }

        macro jslti labelIsTrue* {
                        mov         dsc1, [rsp+$00]
                        __pop       $01
                        cmp         dsc1, dsc0
                        jl          labelIsTrue
        }

        macro jsltl labelIsTrue* {
                        mov         qsc1, [rsp+$00]
                        __pop       $01
                        cmp         qsc1, qsc0
                        jl          labelIsTrue
        }
    ; </fold>

    ; <fold первый операнд — на аккумуляторе, второй операнд — локальная переменная, результат — переход>
        macro jsltge_l labelIsTrue*, localvarName* {
                        fld         tbyte [.#localvarName]
                        fxch
                        fcomip      esc0, esc1
                        releasee
                        _setcmpg
                        jb          labelIsTrue
        }

        macro jsltle_l labelIsTrue*, localvarName* {
                        fld         tbyte [.#localvarName]
                        fxch
                        fcomip      esc0, esc1
                        releasee
                        _setcmpl
                        jb          labelIsTrue
        }

        macro jsltgd_l labelIsTrue*, localvarName* {
                        vcomisd     xmm0, [.#localvarName]
                        _setcmpg
                        jb          labelIsTrue
        }

        macro jsltld_l labelIsTrue*, localvarName* {
                        vcomisd     xmm0, [.#localvarName]
                        _setcmpl
                        jb          labelIsTrue
        }

        macro jsltgf_l labelIsTrue*, localvarName* {
                        vcomiss     xmm0, [.#localvarName]
                        _setcmpg
                        jb          labelIsTrue
        }

        macro jsltlf_l labelIsTrue*, localvarName* {
                        vcomiss     xmm0, [.#localvarName]
                        _setcmpl
                        jb          labelIsTrue
        }

        macro jslti_l labelIsTrue*, localvarName* {
                        cmp         dsc0, [.#localvarName]
                        jl          labelIsTrue
        }

        macro jsltl_l labelIsTrue*, localvarName* {
                        cmp         qsc0, [.#localvarName]
                        jl          labelIsTrue
        }
    ; </fold>

    ; <fold первый операнд — на аккумуляторе, второй операнд — глобальный член, результат — переход>
        macro jsltge_g labelIsTrue*, globalmember* {
                        fld         tbyte globalmember
                        fxch
                        fcomip      esc0, esc1
                        releasee
                        _setcmpg
                        jb          labelIsTrue
        }

        macro jsltle_g labelIsTrue*, globalmember* {
                        fld         tbyte globalmember
                        fxch
                        fcomip      esc0, esc1
                        releasee
                        _setcmpl
                        jb          labelIsTrue
        }

        macro jsltgd_g labelIsTrue*, globalmember* {
                        vcomisd     xmm0, globalmember
                        _setcmpg
                        jb          labelIsTrue
        }

        macro jsltld_g labelIsTrue*, globalmember* {
                        vcomisd     xmm0, globalmember
                        _setcmpl
                        jb          labelIsTrue
        }

        macro jsltgf_g labelIsTrue*, globalmember* {
                        vcomiss     xmm0, globalmember
                        _setcmpg
                        jb          labelIsTrue
        }

        macro jsltlf_g labelIsTrue*, globalmember* {
                        vcomiss     xmm0, globalmember
                        _setcmpl
                        jb          labelIsTrue
        }

        macro jslti_g labelIsTrue*, globalmember* {
                        cmp         dsc0, globalmember
                        jl          labelIsTrue
        }

        macro jsltl_g labelIsTrue*, globalmember* {
                        cmp         qsc0, globalmember
                        jl          labelIsTrue
        }
    ; </fold>
; </fold>