scalar.shru.inc

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

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

; <fold скалярный беззнаковый сдвиг вправо>
    ; <fold первый операнд — на стаке, второй операнд — на аккумуляторе, результат — на аккумуляторе>
        macro sshrui {
                        mov         dsc1, dsc0
                        mov         dsc0, [rsp+$00]
                        shr         dsc0, bsc1
                        __pop       $01
        }

        macro sshrui2 {
                        and         dsc0, $1f
                        vmovd       xmm1, dsc0
                        vmovdqa     xmm0, [rsp+$00]
                        vpsrld      xmm0, xmm0, xmm1
                        __pop       $01
        }

        macro sshrui4 {
                        and         dsc0, $1f
                        vmovd       xmm1, dsc0
                        vmovdqa     xmm0, [rsp+$00]
                        vpsrld      xmm0, xmm0, xmm1
                        __pop       $01
        }

        macro sshrui8 {
                        and         dsc0, $1f
                        vmovd       xmm1, dsc0
                        vmovdqu     ymm0, [rsp+$00]
                        vpsrld      ymm0, ymm0, xmm1
                        __cltag_y   $00
                        __pop       $02
        }

        macro sshrul {
                        mov         dsc1, dsc0
                        mov         qsc0, [rsp+$00]
                        shr         qsc0, bsc1
                        __pop       $01
        }

        macro sshrul2 {
                        and         dsc0, $3f
                        vmovd       xmm1, dsc0
                        vmovdqa     xmm0, [rsp+$00]
                        vpsrlq      xmm0, xmm0, xmm1
                        __pop       $01
        }

        macro sshrul4 {
                        and         dsc0, $3f
                        vmovd       xmm1, dsc0
                        vmovdqu     ymm0, [rsp+$00]
                        vpsrlq      ymm0, ymm0, xmm1
                        __cltag_y   $00
                        __pop       $02
        }

        macro sshrul8 {
                        and         dsc0, $3f
                        vmovd       xmm1, dsc0
                        vmovdqu64   zmm0, [rsp+$00]
                        vpsrlq      zmm0, zmm0, xmm1
                        __cltag_z   $00
                        __pop       $04
        }
    ; </fold>

    ; <fold первый операнд — на стаке, второй операнд — на аккумуляторе, результат — на стаке>
        macro sshrui_p {
                        mov         dsc1, dsc0
                        shr         dword [rsp+$00], bsc1
        }

        macro sshrui2_p {
                        and         dsc0, $1f
                        vmovd       xmm1, dsc0
                        vmovdqa     xmm0, [rsp+$00]
                        vpsrld      xmm0, xmm0, xmm1
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro sshrui4_p {
                        and         dsc0, $1f
                        vmovd       xmm1, dsc0
                        vmovdqa     xmm0, [rsp+$00]
                        vpsrld      xmm0, xmm0, xmm1
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro sshrui8_p {
                        and         dsc0, $1f
                        vmovd       xmm1, dsc0
                        vmovdqu     ymm0, [rsp+$00]
                        vpsrld      ymm0, ymm0, xmm1
                        vmovdqu     yword [rsp+$00], ymm0
        }

        macro sshrul_p {
                        mov         dsc1, dsc0
                        shr         qword [rsp+$00], bsc1
        }

        macro sshrul2_p {
                        and         dsc0, $3f
                        vmovd       xmm1, dsc0
                        vmovdqa     xmm0, [rsp+$00]
                        vpsrlq      xmm0, xmm0, xmm1
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro sshrul4_p {
                        and         dsc0, $3f
                        vmovd       xmm1, dsc0
                        vmovdqu     ymm0, [rsp+$00]
                        vpsrlq      ymm0, ymm0, xmm1
                        vmovdqu     yword [rsp+$00], ymm0
        }

        macro sshrul8_p {
                        and         dsc0, $3f
                        vmovd       xmm1, dsc0
                        vmovdqu64   zmm0, [rsp+$00]
                        vpsrlq      zmm0, zmm0, xmm1
                        vmovdqu64   zword [rsp+$00], zmm0
        }
    ; </fold>

    ; <fold первый операнд — на аккумуляторе, второй операнд — локальная переменная, результат — на аккумуляторе>
        macro sshrui_l localvarName* {
                        mov         dsc1, [.#localvarName]
                        shr         dsc0, bsc1
        }

        macro sshrui2_l localvarName* {
                        mov         dsc0, [.#localvarName]
                        and         dsc0, $1f
                        vmovd       xmm1, dsc0
                        vpsrld      xmm0, xmm0, xmm1
        }

        macro sshrui4_l localvarName* {
                        mov         dsc0, [.#localvarName]
                        and         dsc0, $1f
                        vmovd       xmm1, dsc0
                        vpsrld      xmm0, xmm0, xmm1
        }

        macro sshrui8_l localvarName* {
                        mov         dsc0, [.#localvarName]
                        and         dsc0, $1f
                        vmovd       xmm1, dsc0
                        vpsrld      ymm0, ymm0, xmm1
        }

        macro sshrul_l localvarName* {
                        mov         dsc1, [.#localvarName]
                        shr         qsc0, bsc1
        }

        macro sshrul2_l localvarName* {
                        mov         dsc0, [.#localvarName]
                        and         dsc0, $3f
                        vmovd       xmm1, dsc0
                        vpsrlq      xmm0, xmm0, xmm1
        }

        macro sshrul4_l localvarName* {
                        mov         dsc0, [.#localvarName]
                        and         dsc0, $3f
                        vmovd       xmm1, dsc0
                        vpsrlq      ymm0, ymm0, xmm1
        }

        macro sshrul8_l localvarName* {
                        mov         dsc0, [.#localvarName]
                        and         dsc0, $3f
                        vmovd       xmm1, dsc0
                        vpsrlq      zmm0, zmm0, xmm1
        }
    ; </fold>

    ; <fold первый операнд — на аккумуляторе, второй операнд — глобальный член, результат — на аккумуляторе>
        macro sshrui_g globalmember* {
            if(globalmember eqtype 0)
                            shr         dsc0, (globalmember) and $1f
            else
                            mov         dsc1, globalmember
                            shr         dsc0, bsc1
            end if
        }

        macro sshrui2_g globalmember* {
            if(globalmember eqtype 0)
                            mov         dsc0, (globalmember) and $1f
            else
                            mov         dsc0, globalmember
                            and         dsc0, $1f
            end if
                        vmovd       xmm1, dsc0
                        vpsrld      xmm0, xmm0, xmm1
        }

        macro sshrui4_g globalmember* {
            if(globalmember eqtype 0)
                            mov         dsc0, (globalmember) and $1f
            else
                            mov         dsc0, globalmember
                            and         dsc0, $1f
            end if
                        vmovd       xmm1, dsc0
                        vpsrld      xmm0, xmm0, xmm1
        }

        macro sshrui8_g globalmember* {
            if(globalmember eqtype 0)
                            mov         dsc0, (globalmember) and $1f
            else
                            mov         dsc0, globalmember
                            and         dsc0, $1f
            end if
                        vmovd       xmm1, dsc0
                        vpsrld      ymm0, ymm0, xmm1
        }

        macro sshrul_g globalmember* {
            if(globalmember eqtype 0)
                            shr         qsc0, (globalmember) and $3f
            else
                            mov         dsc1, globalmember
                            shr         qsc0, bsc1
            end if
        }

        macro sshrul2_g globalmember* {
            if(globalmember eqtype 0)
                            mov         dsc0, (globalmember) and $3f
            else
                            mov         dsc0, globalmember
                            and         dsc0, $3f
            end if
                        vmovd       xmm1, dsc0
                        vpsrlq      xmm0, xmm0, xmm1
        }

        macro sshrul4_g globalmember* {
            if(globalmember eqtype 0)
                            mov         dsc0, (globalmember) and $3f
            else
                            mov         dsc0, globalmember
                            and         dsc0, $3f
            end if
                        vmovd       xmm1, dsc0
                        vpsrlq      ymm0, ymm0, xmm1
        }

        macro sshrul8_g globalmember* {
            if(globalmember eqtype 0)
                            mov         dsc0, (globalmember) and $3f
            else
                            mov         dsc0, globalmember
                            and         dsc0, $3f
            end if
                        vmovd       xmm1, dsc0
                        vpsrlq      zmm0, zmm0, xmm1
        }
    ; </fold>
; </fold>