;
; Реализация среды исполнения языка программирования
; Объектно-ориентированный продвинутый векторный транслятор
;
; Copyright © 2021, 2024 Малик Разработчик
;
; Это свободная программа: вы можете перераспространять ее и/или изменять
; ее на условиях Меньшей Стандартной общественной лицензии GNU в том виде,
; в каком она была опубликована Фондом свободного программного обеспечения;
; либо версии 3 лицензии, либо (по вашему выбору) любой более поздней версии.
;
; Эта программа распространяется в надежде, что она будет полезной,
; но БЕЗО ВСЯКИХ ГАРАНТИЙ; даже без неявной гарантии ТОВАРНОГО ВИДА
; или ПРИГОДНОСТИ ДЛЯ ОПРЕДЕЛЕННЫХ ЦЕЛЕЙ. Подробнее см. в Меньшей Стандартной
; общественной лицензии GNU.
;
; Вы должны были получить копию Меньшей Стандартной общественной лицензии GNU
; вместе с этой программой. Если это не так, см.
; <https://www.gnu.org/licenses/>.
;
; <fold скалярный беззнаковый сдвиг вправо>
; <fold первый операнд — на стаке, второй операнд — на аккумуляторе, результат — на аккумуляторе>
macro sshrui {
mov dsc1, dsc0
mov dsc0, [rsp+$00]
shr dsc0, bsc1
__pop $01
}
macro sshrui2 {
and dsc0, $1f
vmovd xmm1, dsc0
vmovdqa xmm0, [rsp+$00]
vpsrld xmm0, xmm0, xmm1
__pop $01
}
macro sshrui4 {
and dsc0, $1f
vmovd xmm1, dsc0
vmovdqa xmm0, [rsp+$00]
vpsrld xmm0, xmm0, xmm1
__pop $01
}
macro sshrui8 {
and dsc0, $1f
vmovd xmm1, dsc0
vmovdqu ymm0, [rsp+$00]
vpsrld ymm0, ymm0, xmm1
__cltag_y $00
__pop $02
}
macro sshrul {
mov dsc1, dsc0
mov qsc0, [rsp+$00]
shr qsc0, bsc1
__pop $01
}
macro sshrul2 {
and dsc0, $3f
vmovd xmm1, dsc0
vmovdqa xmm0, [rsp+$00]
vpsrlq xmm0, xmm0, xmm1
__pop $01
}
macro sshrul4 {
and dsc0, $3f
vmovd xmm1, dsc0
vmovdqu ymm0, [rsp+$00]
vpsrlq ymm0, ymm0, xmm1
__cltag_y $00
__pop $02
}
macro sshrul8 {
and dsc0, $3f
vmovd xmm1, dsc0
vmovdqu64 zmm0, [rsp+$00]
vpsrlq zmm0, zmm0, xmm1
__cltag_z $00
__pop $04
}
; </fold>
; <fold первый операнд — на стаке, второй операнд — на аккумуляторе, результат — на стаке>
macro sshrui_p {
mov dsc1, dsc0
shr dword [rsp+$00], bsc1
}
macro sshrui2_p {
and dsc0, $1f
vmovd xmm1, dsc0
vmovdqa xmm0, [rsp+$00]
vpsrld xmm0, xmm0, xmm1
vmovdqa xword [rsp+$00], xmm0
}
macro sshrui4_p {
and dsc0, $1f
vmovd xmm1, dsc0
vmovdqa xmm0, [rsp+$00]
vpsrld xmm0, xmm0, xmm1
vmovdqa xword [rsp+$00], xmm0
}
macro sshrui8_p {
and dsc0, $1f
vmovd xmm1, dsc0
vmovdqu ymm0, [rsp+$00]
vpsrld ymm0, ymm0, xmm1
vmovdqu yword [rsp+$00], ymm0
}
macro sshrul_p {
mov dsc1, dsc0
shr qword [rsp+$00], bsc1
}
macro sshrul2_p {
and dsc0, $3f
vmovd xmm1, dsc0
vmovdqa xmm0, [rsp+$00]
vpsrlq xmm0, xmm0, xmm1
vmovdqa xword [rsp+$00], xmm0
}
macro sshrul4_p {
and dsc0, $3f
vmovd xmm1, dsc0
vmovdqu ymm0, [rsp+$00]
vpsrlq ymm0, ymm0, xmm1
vmovdqu yword [rsp+$00], ymm0
}
macro sshrul8_p {
and dsc0, $3f
vmovd xmm1, dsc0
vmovdqu64 zmm0, [rsp+$00]
vpsrlq zmm0, zmm0, xmm1
vmovdqu64 zword [rsp+$00], zmm0
}
; </fold>
; <fold первый операнд — на аккумуляторе, второй операнд — локальная переменная, результат — на аккумуляторе>
macro sshrui_l localvarName* {
mov dsc1, [.#localvarName]
shr dsc0, bsc1
}
macro sshrui2_l localvarName* {
mov dsc0, [.#localvarName]
and dsc0, $1f
vmovd xmm1, dsc0
vpsrld xmm0, xmm0, xmm1
}
macro sshrui4_l localvarName* {
mov dsc0, [.#localvarName]
and dsc0, $1f
vmovd xmm1, dsc0
vpsrld xmm0, xmm0, xmm1
}
macro sshrui8_l localvarName* {
mov dsc0, [.#localvarName]
and dsc0, $1f
vmovd xmm1, dsc0
vpsrld ymm0, ymm0, xmm1
}
macro sshrul_l localvarName* {
mov dsc1, [.#localvarName]
shr qsc0, bsc1
}
macro sshrul2_l localvarName* {
mov dsc0, [.#localvarName]
and dsc0, $3f
vmovd xmm1, dsc0
vpsrlq xmm0, xmm0, xmm1
}
macro sshrul4_l localvarName* {
mov dsc0, [.#localvarName]
and dsc0, $3f
vmovd xmm1, dsc0
vpsrlq ymm0, ymm0, xmm1
}
macro sshrul8_l localvarName* {
mov dsc0, [.#localvarName]
and dsc0, $3f
vmovd xmm1, dsc0
vpsrlq zmm0, zmm0, xmm1
}
; </fold>
; <fold первый операнд — на аккумуляторе, второй операнд — глобальный член, результат — на аккумуляторе>
macro sshrui_g globalmember* {
if(globalmember eqtype 0)
shr dsc0, (globalmember) and $1f
else
mov dsc1, globalmember
shr dsc0, bsc1
end if
}
macro sshrui2_g globalmember* {
if(globalmember eqtype 0)
mov dsc0, (globalmember) and $1f
else
mov dsc0, globalmember
and dsc0, $1f
end if
vmovd xmm1, dsc0
vpsrld xmm0, xmm0, xmm1
}
macro sshrui4_g globalmember* {
if(globalmember eqtype 0)
mov dsc0, (globalmember) and $1f
else
mov dsc0, globalmember
and dsc0, $1f
end if
vmovd xmm1, dsc0
vpsrld xmm0, xmm0, xmm1
}
macro sshrui8_g globalmember* {
if(globalmember eqtype 0)
mov dsc0, (globalmember) and $1f
else
mov dsc0, globalmember
and dsc0, $1f
end if
vmovd xmm1, dsc0
vpsrld ymm0, ymm0, xmm1
}
macro sshrul_g globalmember* {
if(globalmember eqtype 0)
shr qsc0, (globalmember) and $3f
else
mov dsc1, globalmember
shr qsc0, bsc1
end if
}
macro sshrul2_g globalmember* {
if(globalmember eqtype 0)
mov dsc0, (globalmember) and $3f
else
mov dsc0, globalmember
and dsc0, $3f
end if
vmovd xmm1, dsc0
vpsrlq xmm0, xmm0, xmm1
}
macro sshrul4_g globalmember* {
if(globalmember eqtype 0)
mov dsc0, (globalmember) and $3f
else
mov dsc0, globalmember
and dsc0, $3f
end if
vmovd xmm1, dsc0
vpsrlq ymm0, ymm0, xmm1
}
macro sshrul8_g globalmember* {
if(globalmember eqtype 0)
mov dsc0, (globalmember) and $3f
else
mov dsc0, globalmember
and dsc0, $3f
end if
vmovd xmm1, dsc0
vpsrlq zmm0, zmm0, xmm1
}
; </fold>
; </fold>