Long4.inc

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

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

; <fold avt.lang.Long4 — родной код>
    if(used avt.lang.Long4$toInt8Bits$long4$) ; <fold returns int8>
                    fast        avt.lang.Long4$toInt8Bits$long4$, \
                                value, long4
                    fenter
                    vmovdqu     ymm0, [.value]
                    fcltag_y    value
                    fleave
    end if ; </fold>

    if(used avt.lang.Long4$low$long4$) ; <fold returns long2>
                    fast        avt.lang.Long4$low$long4$, \
                                value, long4
                    fenter
                    vmovdqa     xmm0, [.value+$00]
                    fcltag_y    value
                    fleave
    end if ; </fold>

    if(used avt.lang.Long4$high$long4$) ; <fold returns long2>
                    fast        avt.lang.Long4$high$long4$, \
                                value, long4
                    fenter
                    vmovdqa     xmm0, [.value+$10]
                    fcltag_y    value
                    fleave
    end if ; </fold>

    if(used avt.lang.Long4$create$long2$long2$) ; <fold returns long4>
                    fast        avt.lang.Long4$create$long2$long2$, \
                                value0, long2, \
                                value1, long2
                    fenter
                    vmovdqa     xmm0, [.value0]
                    vinserti128 ymm0, ymm0, [.value1], $01
                    fleave
    end if ; </fold>

    if(used avt.lang.Long4$max$long4$long4$) ; <fold returns long4>
                    fast        avt.lang.Long4$max$long4$long4$, \
                                value0, long4, \
                                value1, long4
                    fenter
                    vmovdqu     ymm0, [.value0]
                    vmovdqu     ymm1, [.value1]
                    vpmaxsq     ymm0, ymm0, ymm1
                    fcltag_y    value0, value1
                    fleave
    end if ; </fold>

    if(used avt.lang.Long4$maxUnsigned$long4$long4$) ; <fold returns long4>
                    fast        avt.lang.Long4$maxUnsigned$long4$long4$, \
                                value0, long4, \
                                value1, long4
                    fenter
                    vmovdqu     ymm0, [.value0]
                    vmovdqu     ymm1, [.value1]
                    vpmaxuq     ymm0, ymm0, ymm1
                    fcltag_y    value0, value1
                    fleave
    end if ; </fold>

    if(used avt.lang.Long4$min$long4$long4$) ; <fold returns long4>
                    fast        avt.lang.Long4$min$long4$long4$, \
                                value0, long4, \
                                value1, long4
                    fenter
                    vmovdqu     ymm0, [.value0]
                    vmovdqu     ymm1, [.value1]
                    vpminsq     ymm0, ymm0, ymm1
                    fcltag_y    value0, value1
                    fleave
    end if ; </fold>

    if(used avt.lang.Long4$minUnsigned$long4$long4$) ; <fold returns long4>
                    fast        avt.lang.Long4$minUnsigned$long4$long4$, \
                                value0, long4, \
                                value1, long4
                    fenter
                    vmovdqu     ymm0, [.value0]
                    vmovdqu     ymm1, [.value1]
                    vpminuq     ymm0, ymm0, ymm1
                    fcltag_y    value0, value1
                    fleave
    end if ; </fold>

    if(used avt.lang.Long4$rotateLeft$long4$int$) ; <fold returns long4>
                    fast        avt.lang.Long4$rotateLeft$long4$int$, \
                                value, long4, \
                                bits, int
                    fenter
                    mov         r01d, [.bits]
                    and         r01d, $3f
                    mov         r02d, $40
                    sub         r02d, r01d
                    vmovdqu     ymm1, [.value]
                    vmovd       xmm2, r01d
                    vmovd       xmm3, r02d
                    vpsllq      ymm0, ymm1, xmm2
                    vpsrlq      ymm1, ymm1, xmm3
                    vpor        ymm0, ymm0, ymm1
                    fcltag_y    value
                    fleave
    end if ; </fold>

    if(used avt.lang.Long4$rotateRight$long4$int$) ; <fold returns long4>
                    fast        avt.lang.Long4$rotateRight$long4$int$, \
                                value, long4, \
                                bits, int
                    fenter
                    mov         r01d, [.bits]
                    and         r01d, $3f
                    mov         r02d, $40
                    sub         r02d, r01d
                    vmovdqu     ymm1, [.value]
                    vmovd       xmm2, r01d
                    vmovd       xmm3, r02d
                    vpsrlq      ymm0, ymm1, xmm2
                    vpsllq      ymm1, ymm1, xmm3
                    vpor        ymm0, ymm0, ymm1
                    fcltag_y    value
                    fleave
    end if ; </fold>

    if(used avt.lang.Long4$setElement$long4$int$long$) ; <fold returns long4>
                    fast        avt.lang.Long4$setElement$long4$int$long$, \
                                value, long4, \
                                index, int, \
                                element, long
                    fenter
                    mov         r01d, [.index]
                    cmp         r01d, $04
                    jb          @F
                    fthrow      VectorIndexOutOfBoundsException
             @@:    mov         r00q, [.element]
                    mov         qword [.value+r01*8+$00], r00q
                    vmovdqu     ymm0, [.value]
                    fcltag_y    value
                    fleave
    end if ; </fold>

    if(used avt.lang.Long4$toDouble4Bits$long4$) ; <fold returns double4>
                    fast        avt.lang.Long4$toDouble4Bits$long4$, \
                                value, long4
                    fenter
                    vmovdqu     ymm0, [.value]
                    fcltag_y    value
                    fleave
    end if ; </fold>
; </fold>