;
; Реализация среды исполнения языка программирования
; Объектно-ориентированный продвинутый векторный транслятор
;
; 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>