;
; Реализация среды исполнения языка программирования
; Объектно-ориентированный продвинутый векторный транслятор
;
; Copyright © 2021, 2024 Малик Разработчик
;
; Это свободная программа: вы можете перераспространять ее и/или изменять
; ее на условиях Меньшей Стандартной общественной лицензии GNU в том виде,
; в каком она была опубликована Фондом свободного программного обеспечения;
; либо версии 3 лицензии, либо (по вашему выбору) любой более поздней версии.
;
; Эта программа распространяется в надежде, что она будет полезной,
; но БЕЗО ВСЯКИХ ГАРАНТИЙ; даже без неявной гарантии ТОВАРНОГО ВИДА
; или ПРИГОДНОСТИ ДЛЯ ОПРЕДЕЛЕННЫХ ЦЕЛЕЙ. Подробнее см. в Меньшей Стандартной
; общественной лицензии GNU.
;
; Вы должны были получить копию Меньшей Стандартной общественной лицензии GNU
; вместе с этой программой. Если это не так, см.
; <https://www.gnu.org/licenses/>.
;
; <fold приведение значения типа long* к другим типам>
if(used inst$castl2tob2) ; <fold returns byte2>
proc inst$castl2tob2
vpand xmm0, xmm0, [cons$long8.maskb]
vshufps xmm0, xmm0, xmm0, $d8
vpxor xmm1, xmm0, xmm0
vpackusdw xmm0, xmm0, xmm1
vpackuswb xmm0, xmm0, xmm1
ret
end_proc
end if ; </fold>
if(used inst$castl2tos2) ; <fold returns short2>
proc inst$castl2tos2
vpand xmm0, xmm0, [cons$long8.maskw]
vshufps xmm0, xmm0, xmm0, $d8
vpxor xmm1, xmm0, xmm0
vpackusdw xmm0, xmm0, xmm1
ret
end_proc
end if ; </fold>
if(used inst$castl2toi2) ; <fold returns int2>
proc inst$castl2toi2
vpand xmm0, xmm0, [cons$long8.maskd]
vshufps xmm0, xmm0, xmm0, $d8
ret
end_proc
end if ; </fold>
if(used inst$castl4tob4) ; <fold returns byte4>
proc inst$castl4tob4
vpand ymm0, ymm0, [cons$long8.maskb]
vshufps ymm0, ymm0, ymm0, $d8
vextracti128 xmm1, ymm0, $01
vpslldq xmm1, xmm1, $08
vpor xmm0, xmm0, xmm1
vpxor xmm1, xmm0, xmm0
vpackusdw xmm0, xmm0, xmm1
vpackuswb xmm0, xmm0, xmm1
ret
end_proc
end if ; </fold>
if(used inst$castl4tos4) ; <fold returns short4>
proc inst$castl4tos4
vpand ymm0, ymm0, [cons$long8.maskw]
vshufps ymm0, ymm0, ymm0, $d8
vextracti128 xmm1, ymm0, $01
vpslldq xmm1, xmm1, $08
vpor xmm0, xmm0, xmm1
vpxor xmm1, xmm0, xmm0
vpackusdw xmm0, xmm0, xmm1
ret
end_proc
end if ; </fold>
if(used inst$castl4toi4) ; <fold returns int4>
proc inst$castl4toi4
vpand ymm0, ymm0, [cons$long8.maskd]
vshufps ymm0, ymm0, ymm0, $d8
vextracti128 xmm1, ymm0, $01
vpslldq xmm1, xmm1, $08
vpor xmm0, xmm0, xmm1
ret
end_proc
end if ; </fold>
if(used inst$castl8tob8) ; <fold returns byte8>
proc inst$castl8tob8
vpandq zmm0, zmm0, [cons$long8.maskb]
vshufps zmm0, zmm0, zmm0, $d8
vshufi64x2 zmm0, zmm0, zmm0, $d8
vextracti64x4 ymm1, zmm0, $01
vpslldq ymm1, ymm1, $08
vpor ymm0, ymm0, ymm1
vextracti128 xmm1, ymm0, $01
vpackusdw xmm0, xmm0, xmm1
vpxor xmm1, xmm0, xmm0
vpackuswb xmm0, xmm0, xmm1
ret
end_proc
end if ; </fold>
if(used inst$castl8tos8) ; <fold returns short8>
proc inst$castl8tos8
vpandq zmm0, zmm0, [cons$long8.maskw]
vshufps zmm0, zmm0, zmm0, $d8
vshufi64x2 zmm0, zmm0, zmm0, $d8
vextracti64x4 ymm1, zmm0, $01
vpslldq ymm1, ymm1, $08
vpor ymm0, ymm0, ymm1
vextracti128 xmm1, ymm0, $01
vpackusdw xmm0, xmm0, xmm1
ret
end_proc
end if ; </fold>
if(used inst$castl8toi8) ; <fold returns int8>
proc inst$castl8toi8
vpandq zmm0, zmm0, [cons$long8.maskd]
vshufps zmm0, zmm0, zmm0, $d8
vshufi64x2 zmm0, zmm0, zmm0, $d8
vextracti64x4 ymm1, zmm0, $01
vpslldq ymm1, ymm1, $08
vpor ymm0, ymm0, ymm1
ret
end_proc
end if ; </fold>
; </fold>