scalar.sub.inc

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

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

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

        macro ssubd {
                        vmovdqa     xmm1, [rsp+$00]
                        vsubsd      xmm0, xmm1, xmm0
                        __pop       $01
        }

        macro ssubd2 {
                        vmovdqa     xmm1, [rsp+$00]
                        vsubpd      xmm0, xmm1, xmm0
                        __pop       $01
        }

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

        macro ssubd8 {
                        vmovdqu64   zmm1, [rsp+$00]
                        vsubpd      zmm0, zmm1, zmm0
                        __cltag_z   $00
                        __pop       $04
        }

        macro ssubf {
                        vmovdqa     xmm1, [rsp+$00]
                        vsubss      xmm0, xmm1, xmm0
                        __pop       $01
        }

        macro ssubf2 {
                        vmovdqa     xmm1, [rsp+$00]
                        vsubps      xmm0, xmm1, xmm0
                        __pop       $01
        }

        macro ssubf4 {
                        vmovdqa     xmm1, [rsp+$00]
                        vsubps      xmm0, xmm1, xmm0
                        __pop       $01
        }

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

        macro ssubi {
                        mov         dsc1, dsc0
                        mov         dsc0, [rsp+$00]
                        sub         dsc0, dsc1
                        __pop       $01
        }

        macro ssubi2 {
                        vmovdqa     xmm1, [rsp+$00]
                        vpsubd      xmm0, xmm1, xmm0
                        __pop       $01
        }

        macro ssubi4 {
                        vmovdqa     xmm1, [rsp+$00]
                        vpsubd      xmm0, xmm1, xmm0
                        __pop       $01
        }

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

        macro ssubl {
                        mov         qsc1, qsc0
                        mov         qsc0, [rsp+$00]
                        sub         qsc0, qsc1
                        __pop       $01
        }

        macro ssubl2 {
                        vmovdqa     xmm1, [rsp+$00]
                        vpsubq      xmm0, xmm1, xmm0
                        __pop       $01
        }

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

        macro ssubl8 {
                        vmovdqu64   zmm1, [rsp+$00]
                        vpsubq      zmm0, zmm1, zmm0
                        __cltag_z   $00
                        __pop       $04
        }
    ; </fold>

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

        macro ssubd_p {
                        vmovdqa     xmm1, [rsp+$00]
                        vsubsd      xmm0, xmm1, xmm0
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro ssubd2_p {
                        vmovdqa     xmm1, [rsp+$00]
                        vsubpd      xmm0, xmm1, xmm0
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro ssubd4_p {
                        vmovdqu     ymm1, [rsp+$00]
                        vsubpd      ymm0, ymm1, ymm0
                        vmovdqu     yword [rsp+$00], ymm0
        }

        macro ssubd8_p {
                        vmovdqu64   zmm1, [rsp+$00]
                        vsubpd      zmm0, zmm1, zmm0
                        vmovdqu64   zword [rsp+$00], zmm0
        }

        macro ssubf_p {
                        vmovdqa     xmm1, [rsp+$00]
                        vsubss      xmm0, xmm1, xmm0
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro ssubf2_p {
                        vmovdqa     xmm1, [rsp+$00]
                        vsubps      xmm0, xmm1, xmm0
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro ssubf4_p {
                        vmovdqa     xmm1, [rsp+$00]
                        vsubps      xmm0, xmm1, xmm0
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro ssubf8_p {
                        vmovdqu     ymm1, [rsp+$00]
                        vsubps      ymm0, ymm1, ymm0
                        vmovdqu     yword [rsp+$00], ymm0
        }

        macro ssubi_p {
                        sub         dword [rsp+$00], dsc0
        }

        macro ssubi2_p {
                        vmovdqa     xmm1, [rsp+$00]
                        vpsubd      xmm0, xmm1, xmm0
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro ssubi4_p {
                        vmovdqa     xmm1, [rsp+$00]
                        vpsubd      xmm0, xmm1, xmm0
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro ssubi8_p {
                        vmovdqu     ymm1, [rsp+$00]
                        vpsubd      ymm0, ymm1, ymm0
                        vmovdqu     yword [rsp+$00], ymm0
        }

        macro ssubl_p {
                        sub         qword [rsp+$00], qsc0
        }

        macro ssubl2_p {
                        vmovdqa     xmm1, [rsp+$00]
                        vpsubq      xmm0, xmm1, xmm0
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro ssubl4_p {
                        vmovdqu     ymm1, [rsp+$00]
                        vpsubq      ymm0, ymm1, ymm0
                        vmovdqu     yword [rsp+$00], ymm0
        }

        macro ssubl8_p {
                        vmovdqu64   zmm1, [rsp+$00]
                        vpsubq      zmm0, zmm1, zmm0
                        vmovdqu64   zword [rsp+$00], zmm0
        }
    ; </fold>

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

        macro ssubd_l localvarName* {
                        vsubsd      xmm0, xmm0, [.#localvarName]
        }

        macro ssubd2_l localvarName* {
                        vsubpd      xmm0, xmm0, [.#localvarName]
        }

        macro ssubd4_l localvarName* {
                        vmovdqu     ymm1, [.#localvarName]
                        vsubpd      ymm0, ymm0, ymm1
        }

        macro ssubd8_l localvarName* {
                        vmovdqu64   zmm1, [.#localvarName]
                        vsubpd      zmm0, zmm0, zmm1
        }

        macro ssubf_l localvarName* {
                        vsubss      xmm0, xmm0, [.#localvarName]
        }

        macro ssubf2_l localvarName* {
                        vsubps      xmm0, xmm0, [.#localvarName]
        }

        macro ssubf4_l localvarName* {
                        vsubps      xmm0, xmm0, [.#localvarName]
        }

        macro ssubf8_l localvarName* {
                        vmovdqu     ymm1, [.#localvarName]
                        vsubps      ymm0, ymm0, ymm1
        }

        macro ssubi_l localvarName* {
                        sub         dsc0, [.#localvarName]
        }

        macro ssubi2_l localvarName* {
                        vpsubd      xmm0, xmm0, [.#localvarName]
        }

        macro ssubi4_l localvarName* {
                        vpsubd      xmm0, xmm0, [.#localvarName]
        }

        macro ssubi8_l localvarName* {
                        vmovdqu     ymm1, [.#localvarName]
                        vpsubd      ymm0, ymm0, ymm1
        }

        macro ssubl_l localvarName* {
                        sub         qsc0, [.#localvarName]
        }

        macro ssubl2_l localvarName* {
                        vpsubq      xmm0, xmm0, [.#localvarName]
        }

        macro ssubl4_l localvarName* {
                        vmovdqu     ymm1, [.#localvarName]
                        vpsubq      ymm0, ymm0, ymm1
        }

        macro ssubl8_l localvarName* {
                        vmovdqu64   zmm1, [.#localvarName]
                        vpsubq      zmm0, zmm0, zmm1
        }
    ; </fold>

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

        macro ssubd_g globalmember* {
                        vsubsd      xmm0, xmm0, globalmember
        }

        macro ssubd2_g globalmember* {
                        vsubpd      xmm0, xmm0, globalmember
        }

        macro ssubd4_g globalmember* {
                        vsubpd      ymm0, ymm0, globalmember
        }

        macro ssubd8_g globalmember* {
                        vsubpd      zmm0, zmm0, globalmember
        }

        macro ssubf_g globalmember* {
                        vsubss      xmm0, xmm0, globalmember
        }

        macro ssubf2_g globalmember* {
                        vsubps      xmm0, xmm0, globalmember
        }

        macro ssubf4_g globalmember* {
                        vsubps      xmm0, xmm0, globalmember
        }

        macro ssubf8_g globalmember* {
                        vsubps      ymm0, ymm0, globalmember
        }

        macro ssubi_g globalmember* {
            if(~(globalmember eqtype 0))
                            sub         dsc0, globalmember
            else if((globalmember) <> 0)
                            lea         dsc0, [dsc0-(globalmember)]
            end if
        }

        macro ssubi2_g globalmember* {
                        vpsubd      xmm0, xmm0, globalmember
        }

        macro ssubi4_g globalmember* {
                        vpsubd      xmm0, xmm0, globalmember
        }

        macro ssubi8_g globalmember* {
                        vpsubd      ymm0, ymm0, globalmember
        }

        macro ssubl_g globalmember* {
                        sub         qsc0, globalmember
        }

        macro ssubl2_g globalmember* {
                        vpsubq      xmm0, xmm0, globalmember
        }

        macro ssubl4_g globalmember* {
                        vpsubq      ymm0, ymm0, globalmember
        }

        macro ssubl8_g globalmember* {
                        vpsubq      zmm0, zmm0, globalmember
        }
    ; </fold>
; </fold>