vector.hmulu.inc

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

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

; <fold векторное беззнаковое верхнее умножение с насыщением>
    if(used inst$vhmulub2) ; <fold returns byte2>
                    proc        inst$vhmulub2
                    vpmovzxbw   xmm0, xmm0
                    vpmullw     xmm0, xmm0, xmm1
                    vpaddw      xmm0, xmm0, [cons$short2.$00ff]
                    vpsrlw      xmm0, xmm0, $08
                    vpxor       xmm1, xmm0, xmm0
                    vpackuswb   xmm0, xmm0, xmm1
                    ret
                    end_proc
    end if ; </fold>

    if(used inst$vhmulub4) ; <fold returns byte4>
                    proc        inst$vhmulub4
                    vpmovzxbw   xmm0, xmm0
                    vpmullw     xmm0, xmm0, xmm1
                    vpaddw      xmm0, xmm0, [cons$short4.$00ff]
                    vpsrlw      xmm0, xmm0, $08
                    vpxor       xmm1, xmm0, xmm0
                    vpackuswb   xmm0, xmm0, xmm1
                    ret
                    end_proc
    end if ; </fold>

    if(used inst$vhmulub8) ; <fold returns byte8>
                    proc        inst$vhmulub8
                    vpmovzxbw   xmm0, xmm0
                    vpmullw     xmm0, xmm0, xmm1
                    vpaddw      xmm0, xmm0, [cons$short8.$00ff]
                    vpsrlw      xmm0, xmm0, $08
                    vpxor       xmm1, xmm0, xmm0
                    vpackuswb   xmm0, xmm0, xmm1
                    ret
                    end_proc
    end if ; </fold>

    if(used inst$vhmulus2) ; <fold returns short2>
                    proc        inst$vhmulus2
                    vpmovzxwd   xmm0, xmm0
                    vpmulld     xmm0, xmm0, xmm1
                    vpaddd      xmm0, xmm0, [cons$int2.$ffff]
                    vpsrld      xmm0, xmm0, $10
                    vpxor       xmm1, xmm0, xmm0
                    vpackusdw   xmm0, xmm0, xmm1
                    ret
                    end_proc
    end if ; </fold>

    if(used inst$vhmulus4) ; <fold returns short4>
                    proc        inst$vhmulus4
                    vpmovzxwd   xmm0, xmm0
                    vpmulld     xmm0, xmm0, xmm1
                    vpaddd      xmm0, xmm0, [cons$int4.$ffff]
                    vpsrld      xmm0, xmm0, $10
                    vpxor       xmm1, xmm0, xmm0
                    vpackusdw   xmm0, xmm0, xmm1
                    ret
                    end_proc
    end if ; </fold>

    if(used inst$vhmulus8) ; <fold returns short8>
                    proc        inst$vhmulus8
                    vpmovzxwd   ymm0, xmm0
                    vpmulld     ymm0, ymm0, ymm1
                    vpaddd      ymm0, ymm0, [cons$int8.$ffff]
                    vpsrld      ymm0, ymm0, $10
                    vextracti128 xmm1, ymm0, $01
                    vpackusdw   xmm0, xmm0, xmm1
                    ret
                    end_proc
    end if ; </fold>
; </fold>