vector.hmul.inc

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

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

; <fold векторное верхнее умножение с насыщением>
    ; <fold приватные макросы — должны использоваться только этим текстом исходного кода>
        macro _hmulb {
                        local       .L.0000
                        add         dsc0, $7f
                        sar         dsc0, $07
                        cmp         dsc0, $7f
                        jle         .L.0000
                        mov         dsc0, $7f
            .L.0000:
        }

        macro _hmuls {
                        local       .L.0000
                        add         dsc0, $7fff
                        sar         dsc0, $0f
                        cmp         dsc0, $7fff
                        jle         .L.0000
                        mov         dsc0, $7fff
            .L.0000:
        }
    ; </fold>

    ; <fold первый операнд — на стаке, второй операнд — на аккумуляторе, результат — на аккумуляторе>
        macro vhmulb {
                        imul        dsc0, [rsp+$00]
                        _hmulb
                        __pop       $01
        }

        macro vhmulb2 {
                        vpmovsxbw   xmm1, [rsp+$00]
                        call        inst$vhmulb2
                        __pop       $01
        }

        macro vhmulb4 {
                        vpmovsxbw   xmm1, [rsp+$00]
                        call        inst$vhmulb4
                        __pop       $01
        }

        macro vhmulb8 {
                        vpmovsxbw   xmm1, [rsp+$00]
                        call        inst$vhmulb8
                        __pop       $01
        }

        macro vhmuls {
                        imul        dsc0, [rsp+$00]
                        _hmuls
                        __pop       $01
        }

        macro vhmuls2 {
                        vpmovsxwd   xmm1, [rsp+$00]
                        call        inst$vhmuls2
                        __pop       $01
        }

        macro vhmuls4 {
                        vpmovsxwd   xmm1, [rsp+$00]
                        call        inst$vhmuls4
                        __pop       $01
        }

        macro vhmuls8 {
                        vpmovsxwd   ymm1, [rsp+$00]
                        call        inst$vhmuls8
                        __pop       $01
        }
    ; </fold>

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

        macro vhmulb2_p {
                        vpmovsxbw   xmm1, [rsp+$00]
                        call        inst$vhmulb2
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro vhmulb4_p {
                        vpmovsxbw   xmm1, [rsp+$00]
                        call        inst$vhmulb4
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro vhmulb8_p {
                        vpmovsxbw   xmm1, [rsp+$00]
                        call        inst$vhmulb8
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro vhmuls_p {
                        imul        dsc0, [rsp+$00]
                        _hmuls
                        mov         dword [rsp+$00], dsc0
        }

        macro vhmuls2_p {
                        vpmovsxwd   xmm1, [rsp+$00]
                        call        inst$vhmuls2
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro vhmuls4_p {
                        vpmovsxwd   xmm1, [rsp+$00]
                        call        inst$vhmuls4
                        vmovdqa     xword [rsp+$00], xmm0
        }

        macro vhmuls8_p {
                        vpmovsxwd   ymm1, [rsp+$00]
                        call        inst$vhmuls8
                        vmovdqa     xword [rsp+$00], xmm0
        }
    ; </fold>

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

        macro vhmulb2_l localvarName* {
                        vpmovsxbw   xmm1, [.#localvarName]
                        call        inst$vhmulb2
        }

        macro vhmulb4_l localvarName* {
                        vpmovsxbw   xmm1, [.#localvarName]
                        call        inst$vhmulb4
        }

        macro vhmulb8_l localvarName* {
                        vpmovsxbw   xmm1, [.#localvarName]
                        call        inst$vhmulb8
        }

        macro vhmuls_l localvarName* {
                        imul        dsc0, [.#localvarName]
                        _hmuls
        }

        macro vhmuls2_l localvarName* {
                        vpmovsxwd   xmm1, [.#localvarName]
                        call        inst$vhmuls2
        }

        macro vhmuls4_l localvarName* {
                        vpmovsxwd   xmm1, [.#localvarName]
                        call        inst$vhmuls4
        }

        macro vhmuls8_l localvarName* {
                        vpmovsxwd   ymm1, [.#localvarName]
                        call        inst$vhmuls8
        }
    ; </fold>

    ; <fold первый операнд — на аккумуляторе, второй операнд — глобальный член, результат — на аккумуляторе>
        macro vhmulb_g globalmember* {
            if(globalmember eqtype 0)
                            imul        dsc0, dsc0, globalmember
            else
                            imul        dsc0, globalmember
            end if
                        _hmulb
        }

        macro vhmulb2_g globalmember* {
                        vpmovsxbw   xmm1, globalmember
                        call        inst$vhmulb2
        }

        macro vhmulb4_g globalmember* {
                        vpmovsxbw   xmm1, globalmember
                        call        inst$vhmulb4
        }

        macro vhmulb8_g globalmember* {
                        vpmovsxbw   xmm1, globalmember
                        call        inst$vhmulb8
        }

        macro vhmuls_g globalmember* {
            if(globalmember eqtype 0)
                            imul        dsc0, dsc0, globalmember
            else
                            imul        dsc0, globalmember
            end if
                        _hmuls
        }

        macro vhmuls2_g globalmember* {
                        vpmovsxwd   xmm1, globalmember
                        call        inst$vhmuls2
        }

        macro vhmuls4_g globalmember* {
                        vpmovsxwd   xmm1, globalmember
                        call        inst$vhmuls4
        }

        macro vhmuls8_g globalmember* {
                        vpmovsxwd   ymm1, globalmember
                        call        inst$vhmuls8
        }
    ; </fold>
; </fold>