vector.ge.inc

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

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

; <fold векторное больше или равно>
    ; <fold первый операнд — на стаке, второй операнд — на аккумуляторе, результат — на аккумуляторе>
        macro vged {
                        vcmpsd      xmm0, xmm0, [rsp+$00], $02
                        vmovq       qsc0, xmm0
                        __pop       $01
        }

        macro vged2 {
                        vcmppd      xmm0, xmm0, [rsp+$00], $02
                        __pop       $01
        }

        macro vged4 {
                        vmovdqu     ymm1, [rsp+$00]
                        vcmppd      ymm0, ymm0, ymm1, $02
                        __cltag_y   $00
                        __pop       $02
        }

        macro vged8 {
                        vmovdqu64   zmm1, [rsp+$00]
                        vcmppd      msk1, zmm0, zmm1, $02
                        vmovdqa64   zmm0\{k1\}\{z\}, [cons$long8.m1]
                        __cltag_z   $00
                        __pop       $04
        }

        macro vgef {
                        vcmpss      xmm0, xmm0, [rsp+$00], $02
                        vmovd       dsc0, xmm0
                        __pop       $01
        }

        macro vgef2 {
                        vcmpps      xmm0, xmm0, [rsp+$00], $02
                        vpand       xmm0, xmm0, [cons$int8.mask2]
                        __pop       $01
        }

        macro vgef4 {
                        vcmpps      xmm0, xmm0, [rsp+$00], $02
                        __pop       $01
        }

        macro vgef8 {
                        vmovdqu     ymm1, [rsp+$00]
                        vcmpps      ymm0, ymm0, ymm1, $02
                        __cltag_y   $00
                        __pop       $02
        }

        macro vgeb {
                        cmp         dword [rsp+$00], dsc0
                        setnge      bsc0
                        dec         bsc0
                        movsx       dsc0, bsc0
                        __pop       $01
        }

        macro vgeb2 {
                        vpcmpgtb    xmm0, xmm0, [rsp+$00]
                        vpxor       xmm0, xmm0, [cons$byte8.mask2]
                        __pop       $01
        }

        macro vgeb4 {
                        vpcmpgtb    xmm0, xmm0, [rsp+$00]
                        vpxor       xmm0, xmm0, [cons$byte8.mask4]
                        __pop       $01
        }

        macro vgeb8 {
                        vpcmpgtb    xmm0, xmm0, [rsp+$00]
                        vpxor       xmm0, xmm0, [cons$byte8.mask8]
                        __pop       $01
        }

        macro vges {
                        cmp         dword [rsp+$00], dsc0
                        setnge      bsc0
                        dec         bsc0
                        movsx       dsc0, bsc0
                        __pop       $01
        }

        macro vges2 {
                        vpcmpgtw    xmm0, xmm0, [rsp+$00]
                        vpxor       xmm0, xmm0, [cons$short8.mask2]
                        __pop       $01
        }

        macro vges4 {
                        vpcmpgtw    xmm0, xmm0, [rsp+$00]
                        vpxor       xmm0, xmm0, [cons$short8.mask4]
                        __pop       $01
        }

        macro vges8 {
                        vpcmpgtw    xmm0, xmm0, [rsp+$00]
                        vpxor       xmm0, xmm0, [cons$short8.mask8]
                        __pop       $01
        }

        macro vgei {
                        cmp         dword [rsp+$00], dsc0
                        setnge      bsc0
                        dec         bsc0
                        movsx       dsc0, bsc0
                        __pop       $01
        }

        macro vgei2 {
                        vpcmpgtd    xmm0, xmm0, [rsp+$00]
                        vpxor       xmm0, xmm0, [cons$int8.mask2]
                        __pop       $01
        }

        macro vgei4 {
                        vpcmpgtd    xmm0, xmm0, [rsp+$00]
                        vpxor       xmm0, xmm0, [cons$int8.mask4]
                        __pop       $01
        }

        macro vgei8 {
                        vmovdqu     ymm1, [rsp+$00]
                        vpcmpgtd    ymm0, ymm0, ymm1
                        vpxor       ymm0, ymm0, [cons$int8.mask8]
                        __cltag_y   $00
                        __pop       $02
        }

        macro vgel {
                        cmp         qword [rsp+$00], qsc0
                        setnge      bsc0
                        dec         bsc0
                        movsx       qsc0, bsc0
                        __pop       $01
        }

        macro vgel2 {
                        vpcmpgtq    xmm0, xmm0, [rsp+$00]
                        vpxor       xmm0, xmm0, [cons$long8.mask2]
                        __pop       $01
        }

        macro vgel4 {
                        vmovdqu     ymm1, [rsp+$00]
                        vpcmpgtq    ymm0, ymm0, ymm1
                        vpxor       ymm0, ymm0, [cons$long8.mask4]
                        __cltag_y   $00
                        __pop       $02
        }

        macro vgel8 {
                        vmovdqu64   zmm1, [rsp+$00]
                        vpcmpgtq    msk1, zmm0, zmm1
                        knotw       msk1, msk1
                        vmovdqa64   zmm0\{k1\}\{z\}, [cons$long8.m1]
                        __cltag_z   $00
                        __pop       $04
        }
    ; </fold>

    ; <fold первый операнд — на стаке, второй операнд — на аккумуляторе, результат — на стаке>
        macro vged_p {
                        vcmpsd      xmm0, xmm0, [rsp+$00], $02
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro vged2_p {
                        vcmppd      xmm0, xmm0, [rsp+$00], $02
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro vged4_p {
                        vmovdqu     ymm1, [rsp+$00]
                        vcmppd      ymm0, ymm0, ymm1, $02
                        vmovdqu     yword [rsp+$00], ymm0
                        __sttag_y   $00,  TAG_LONG4
        }

        macro vged8_p {
                        vmovdqu64   zmm1, [rsp+$00]
                        vcmppd      msk1, zmm0, zmm1, $02
                        vmovdqa64   zmm0\{k1\}\{z\}, [cons$long8.m1]
                        vmovdqu64   zword [rsp+$00], zmm0
                        __sttag_z   $00,  TAG_LONG8
        }

        macro vgef_p {
                        vcmpss      xmm0, xmm0, [rsp+$00], $02
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro vgef2_p {
                        vcmpps      xmm0, xmm0, [rsp+$00], $02
                        vpand       xmm0, xmm0, [cons$int8.mask2]
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro vgef4_p {
                        vcmpps      xmm0, xmm0, [rsp+$00], $02
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro vgef8_p {
                        vmovdqu     ymm1, [rsp+$00]
                        vcmpps      ymm0, ymm0, ymm1, $02
                        vmovdqu     yword [rsp+$00], ymm0
                        __sttag_y   $00,  TAG_INT8
        }

        macro vgeb_p {
                        cmp         dword [rsp+$00], dsc0
                        setnge      bsc0
                        dec         bsc0
                        movsx       dsc0, bsc0
                        mov         dword [rsp+$00], dsc0
        }

        macro vgeb2_p {
                        vpcmpgtb    xmm0, xmm0, [rsp+$00]
                        vpxor       xmm0, xmm0, [cons$byte8.mask2]
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro vgeb4_p {
                        vpcmpgtb    xmm0, xmm0, [rsp+$00]
                        vpxor       xmm0, xmm0, [cons$byte8.mask4]
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro vgeb8_p {
                        vpcmpgtb    xmm0, xmm0, [rsp+$00]
                        vpxor       xmm0, xmm0, [cons$byte8.mask8]
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro vges_p {
                        cmp         dword [rsp+$00], dsc0
                        setnge      bsc0
                        dec         bsc0
                        movsx       dsc0, bsc0
                        mov         dword [rsp+$00], dsc0
        }

        macro vges2_p {
                        vpcmpgtw    xmm0, xmm0, [rsp+$00]
                        vpxor       xmm0, xmm0, [cons$short8.mask2]
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro vges4_p {
                        vpcmpgtw    xmm0, xmm0, [rsp+$00]
                        vpxor       xmm0, xmm0, [cons$short8.mask4]
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro vges8_p {
                        vpcmpgtw    xmm0, xmm0, [rsp+$00]
                        vpxor       xmm0, xmm0, [cons$short8.mask8]
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro vgei_p {
                        cmp         dword [rsp+$00], dsc0
                        setnge      bsc0
                        dec         bsc0
                        movsx       dsc0, bsc0
                        mov         dword [rsp+$00], dsc0
        }

        macro vgei2_p {
                        vpcmpgtd    xmm0, xmm0, [rsp+$00]
                        vpxor       xmm0, xmm0, [cons$int8.mask2]
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro vgei4_p {
                        vpcmpgtd    xmm0, xmm0, [rsp+$00]
                        vpxor       xmm0, xmm0, [cons$int8.mask4]
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro vgei8_p {
                        vmovdqu     ymm1, [rsp+$00]
                        vpcmpgtd    ymm0, ymm0, ymm1
                        vpxor       ymm0, ymm0, [cons$int8.mask8]
                        vmovdqu     yword [rsp+$00], ymm0
        }

        macro vgel_p {
                        cmp         qword [rsp+$00], qsc0
                        setnge      bsc0
                        dec         bsc0
                        movsx       qsc0, bsc0
                        mov         qword [rsp+$00], qsc0
        }

        macro vgel2_p {
                        vpcmpgtq    xmm0, xmm0, [rsp+$00]
                        vpxor       xmm0, xmm0, [cons$long8.mask2]
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro vgel4_p {
                        vmovdqu     ymm1, [rsp+$00]
                        vpcmpgtq    ymm0, ymm0, ymm1
                        vpxor       ymm0, ymm0, [cons$long8.mask4]
                        vmovdqu     yword [rsp+$00], ymm0
        }

        macro vgel8_p {
                        vmovdqu64   zmm1, [rsp+$00]
                        vpcmpgtq    msk1, zmm0, zmm1
                        knotw       msk1, msk1
                        vmovdqa64   zmm0\{k1\}\{z\}, [cons$long8.m1]
                        vmovdqu64   zword [rsp+$00], zmm0
        }
    ; </fold>

    ; <fold первый операнд — на аккумуляторе, второй операнд — локальная переменная, результат — на аккумуляторе>
        macro vged_l localvarName* {
                        vmovdqa     xmm1, [.#localvarName]
                        vcmpsd      xmm0, xmm1, xmm0, $02
                        vmovq       qsc0, xmm0
        }

        macro vged2_l localvarName* {
                        vmovdqa     xmm1, [.#localvarName]
                        vcmppd      xmm0, xmm1, xmm0, $02
        }

        macro vged4_l localvarName* {
                        vmovdqu     ymm1, [.#localvarName]
                        vcmppd      ymm0, ymm1, ymm0, $02
        }

        macro vged8_l localvarName* {
                        vmovdqu64   zmm1, [.#localvarName]
                        vcmppd      msk1, zmm1, zmm0, $02
                        vmovdqa64   zmm0\{k1\}\{z\}, [cons$long8.m1]
        }

        macro vgef_l localvarName* {
                        vmovdqa     xmm1, [.#localvarName]
                        vcmpss      xmm0, xmm1, xmm0, $02
                        vmovd       dsc0, xmm0
        }

        macro vgef2_l localvarName* {
                        vmovdqa     xmm1, [.#localvarName]
                        vcmpps      xmm0, xmm1, xmm0, $02
                        vpand       xmm0, xmm0, [cons$int8.mask2]
        }

        macro vgef4_l localvarName* {
                        vmovdqa     xmm1, [.#localvarName]
                        vcmpps      xmm0, xmm1, xmm0, $02
        }

        macro vgef8_l localvarName* {
                        vmovdqu     ymm1, [.#localvarName]
                        vcmpps      ymm0, ymm1, ymm0, $02
        }

        macro vgeb_l localvarName* {
                        cmp         dsc0, [.#localvarName]
                        setnge      bsc0
                        dec         bsc0
                        movsx       dsc0, bsc0
        }

        macro vgeb2_l localvarName* {
                        vmovdqa     xmm1, [.#localvarName]
                        vpcmpgtb    xmm0, xmm1, xmm0
                        vpxor       xmm0, xmm0, [cons$byte8.mask2]
        }

        macro vgeb4_l localvarName* {
                        vmovdqa     xmm1, [.#localvarName]
                        vpcmpgtb    xmm0, xmm1, xmm0
                        vpxor       xmm0, xmm0, [cons$byte8.mask4]
        }

        macro vgeb8_l localvarName* {
                        vmovdqa     xmm1, [.#localvarName]
                        vpcmpgtb    xmm0, xmm1, xmm0
                        vpxor       xmm0, xmm0, [cons$byte8.mask8]
        }

        macro vges_l localvarName* {
                        cmp         dsc0, [.#localvarName]
                        setnge      bsc0
                        dec         bsc0
                        movsx       dsc0, bsc0
        }

        macro vges2_l localvarName* {
                        vmovdqa     xmm1, [.#localvarName]
                        vpcmpgtw    xmm0, xmm1, xmm0
                        vpxor       xmm0, xmm0, [cons$short8.mask2]
        }

        macro vges4_l localvarName* {
                        vmovdqa     xmm1, [.#localvarName]
                        vpcmpgtw    xmm0, xmm1, xmm0
                        vpxor       xmm0, xmm0, [cons$short8.mask4]
        }

        macro vges8_l localvarName* {
                        vmovdqa     xmm1, [.#localvarName]
                        vpcmpgtw    xmm0, xmm1, xmm0
                        vpxor       xmm0, xmm0, [cons$short8.mask8]
        }

        macro vgei_l localvarName* {
                        cmp         dsc0, [.#localvarName]
                        setnge      bsc0
                        dec         bsc0
                        movsx       dsc0, bsc0
        }

        macro vgei2_l localvarName* {
                        vmovdqa     xmm1, [.#localvarName]
                        vpcmpgtd    xmm0, xmm1, xmm0
                        vpxor       xmm0, xmm0, [cons$int8.mask2]
        }

        macro vgei4_l localvarName* {
                        vmovdqa     xmm1, [.#localvarName]
                        vpcmpgtd    xmm0, xmm1, xmm0
                        vpxor       xmm0, xmm0, [cons$int8.mask4]
        }

        macro vgei8_l localvarName* {
                        vmovdqu     ymm1, [.#localvarName]
                        vpcmpgtd    ymm0, ymm1, ymm0
                        vpxor       ymm0, ymm0, [cons$int8.mask8]
        }

        macro vgel_l localvarName* {
                        cmp         qsc0, [.#localvarName]
                        setnge      bsc0
                        dec         bsc0
                        movsx       qsc0, bsc0
        }

        macro vgel2_l localvarName* {
                        vmovdqa     xmm1, [.#localvarName]
                        vpcmpgtq    xmm0, xmm1, xmm0
                        vpxor       xmm0, xmm0, [cons$long8.mask2]
        }

        macro vgel4_l localvarName* {
                        vmovdqu     ymm1, [.#localvarName]
                        vpcmpgtq    ymm0, ymm1, ymm0
                        vpxor       ymm0, ymm0, [cons$long8.mask4]
        }

        macro vgel8_l localvarName* {
                        vmovdqu64   zmm1, [.#localvarName]
                        vpcmpgtq    msk1, zmm1, zmm0
                        knotw       msk1, msk1
                        vmovdqa64   zmm0\{k1\}\{z\}, [cons$long8.m1]
        }
    ; </fold>

    ; <fold первый операнд — на аккумуляторе, второй операнд — глобальный член, результат — на аккумуляторе>
        macro vged_g globalmember* {
                        vmovdqa     xmm1, globalmember
                        vcmpsd      xmm0, xmm1, xmm0, $02
                        vmovq       qsc0, xmm0
        }

        macro vged2_g globalmember* {
                        vmovdqa     xmm1, globalmember
                        vcmppd      xmm0, xmm1, xmm0, $02
        }

        macro vged4_g globalmember* {
                        vmovdqa     ymm1, globalmember
                        vcmppd      ymm0, ymm1, ymm0, $02
        }

        macro vged8_g globalmember* {
                        vmovdqa64   zmm1, globalmember
                        vcmppd      msk1, zmm1, zmm0, $02
                        vmovdqa64   zmm0\{k1\}\{z\}, [cons$long8.m1]
        }

        macro vgef_g globalmember* {
                        vmovdqa     xmm1, globalmember
                        vcmpss      xmm0, xmm1, xmm0, $02
                        vmovd       dsc0, xmm0
        }

        macro vgef2_g globalmember* {
                        vmovdqa     xmm1, globalmember
                        vcmpps      xmm0, xmm1, xmm0, $02
                        vpand       xmm0, xmm0, [cons$int8.mask2]
        }

        macro vgef4_g globalmember* {
                        vmovdqa     xmm1, globalmember
                        vcmpps      xmm0, xmm1, xmm0, $02
        }

        macro vgef8_g globalmember* {
                        vmovdqa     ymm1, globalmember
                        vcmpps      ymm0, ymm1, ymm0, $02
        }

        macro vgeb_g globalmember* {
                        cmp         dsc0, globalmember
                        setnge      bsc0
                        dec         bsc0
                        movsx       dsc0, bsc0
        }

        macro vgeb2_g globalmember* {
                        vmovdqa     xmm1, globalmember
                        vpcmpgtb    xmm0, xmm1, xmm0
                        vpxor       xmm0, xmm0, [cons$byte8.mask2]
        }

        macro vgeb4_g globalmember* {
                        vmovdqa     xmm1, globalmember
                        vpcmpgtb    xmm0, xmm1, xmm0
                        vpxor       xmm0, xmm0, [cons$byte8.mask4]
        }

        macro vgeb8_g globalmember* {
                        vmovdqa     xmm1, globalmember
                        vpcmpgtb    xmm0, xmm1, xmm0
                        vpxor       xmm0, xmm0, [cons$byte8.mask8]
        }

        macro vges_g globalmember* {
                        cmp         dsc0, globalmember
                        setnge      bsc0
                        dec         bsc0
                        movsx       dsc0, bsc0
        }

        macro vges2_g globalmember* {
                        vmovdqa     xmm1, globalmember
                        vpcmpgtw    xmm0, xmm1, xmm0
                        vpxor       xmm0, xmm0, [cons$short8.mask2]
        }

        macro vges4_g globalmember* {
                        vmovdqa     xmm1, globalmember
                        vpcmpgtw    xmm0, xmm1, xmm0
                        vpxor       xmm0, xmm0, [cons$short8.mask4]
        }

        macro vges8_g globalmember* {
                        vmovdqa     xmm1, globalmember
                        vpcmpgtw    xmm0, xmm1, xmm0
                        vpxor       xmm0, xmm0, [cons$short8.mask8]
        }

        macro vgei_g globalmember* {
                        cmp         dsc0, globalmember
                        setnge      bsc0
                        dec         bsc0
                        movsx       dsc0, bsc0
        }

        macro vgei2_g globalmember* {
                        vmovdqa     xmm1, globalmember
                        vpcmpgtd    xmm0, xmm1, xmm0
                        vpxor       xmm0, xmm0, [cons$int8.mask2]
        }

        macro vgei4_g globalmember* {
                        vmovdqa     xmm1, globalmember
                        vpcmpgtd    xmm0, xmm1, xmm0
                        vpxor       xmm0, xmm0, [cons$int8.mask4]
        }

        macro vgei8_g globalmember* {
                        vmovdqa     ymm1, globalmember
                        vpcmpgtd    ymm0, ymm1, ymm0
                        vpxor       ymm0, ymm0, [cons$int8.mask8]
        }

        macro vgel_g globalmember* {
                        cmp         qsc0, globalmember
                        setnge      bsc0
                        dec         bsc0
                        movsx       qsc0, bsc0
        }

        macro vgel2_g globalmember* {
                        vmovdqa     xmm1, globalmember
                        vpcmpgtq    xmm0, xmm1, xmm0
                        vpxor       xmm0, xmm0, [cons$long8.mask2]
        }

        macro vgel4_g globalmember* {
                        vmovdqa     ymm1, globalmember
                        vpcmpgtq    ymm0, ymm1, ymm0
                        vpxor       ymm0, ymm0, [cons$long8.mask4]
        }

        macro vgel8_g globalmember* {
                        vmovdqa64   zmm1, globalmember
                        vpcmpgtq    msk1, zmm1, zmm0
                        knotw       msk1, msk1
                        vmovdqa64   zmm0\{k1\}\{z\}, [cons$long8.m1]
        }
    ; </fold>
; </fold>