;
; Реализация среды исполнения языка программирования
; Объектно-ориентированный продвинутый векторный транслятор
;
; Copyright © 2021, 2024 Малик Разработчик
;
; Это свободная программа: вы можете перераспространять ее и/или изменять
; ее на условиях Меньшей Стандартной общественной лицензии GNU в том виде,
; в каком она была опубликована Фондом свободного программного обеспечения;
; либо версии 3 лицензии, либо (по вашему выбору) любой более поздней версии.
;
; Эта программа распространяется в надежде, что она будет полезной,
; но БЕЗО ВСЯКИХ ГАРАНТИЙ; даже без неявной гарантии ТОВАРНОГО ВИДА
; или ПРИГОДНОСТИ ДЛЯ ОПРЕДЕЛЕННЫХ ЦЕЛЕЙ. Подробнее см. в Меньшей Стандартной
; общественной лицензии GNU.
;
; Вы должны были получить копию Меньшей Стандартной общественной лицензии GNU
; вместе с этой программой. Если это не так, см.
; <https://www.gnu.org/licenses/>.
;
; <fold векторный сдвиг вправо>
; <fold первый операнд — на стаке, второй операнд — на аккумуляторе, результат — на аккумуляторе>
macro vshrb {
mov dsc1, dsc0
mov dsc0, [rsp+$00]
sar dsc0, bsc1
__pop $01
}
macro vshrb2 {
vpmovsxbw xmm0, [rsp+$00]
call inst$vshrb2
__pop $01
}
macro vshrb4 {
vpmovsxbw xmm0, [rsp+$00]
call inst$vshrb4
__pop $01
}
macro vshrb8 {
vpmovsxbw xmm0, [rsp+$00]
call inst$vshrb8
__pop $01
}
macro vshrs {
mov dsc1, dsc0
mov dsc0, [rsp+$00]
sar dsc0, bsc1
__pop $01
}
macro vshrs2 {
and dsc0, $1f
vmovd xmm1, dsc0
vmovdqa xmm0, [rsp+$00]
vpsraw xmm0, xmm0, xmm1
__pop $01
}
macro vshrs4 {
and dsc0, $1f
vmovd xmm1, dsc0
vmovdqa xmm0, [rsp+$00]
vpsraw xmm0, xmm0, xmm1
__pop $01
}
macro vshrs8 {
and dsc0, $1f
vmovd xmm1, dsc0
vmovdqa xmm0, [rsp+$00]
vpsraw xmm0, xmm0, xmm1
__pop $01
}
macro vshri {
sshri
}
macro vshri2 {
sshri2
}
macro vshri4 {
sshri4
}
macro vshri8 {
sshri8
}
macro vshrl {
sshrl
}
macro vshrl2 {
sshrl2
}
macro vshrl4 {
sshrl4
}
macro vshrl8 {
sshrl8
}
; </fold>
; <fold первый операнд — на стаке, второй операнд — на аккумуляторе, результат — на стаке>
macro vshrb_p {
mov dsc1, dsc0
sar dword [rsp+$00], bsc1
}
macro vshrb2_p {
vpmovsxbw xmm0, [rsp+$00]
call inst$vshrb2
vmovdqa xword [rsp+$00], xmm0
}
macro vshrb4_p {
vpmovsxbw xmm0, [rsp+$00]
call inst$vshrb4
vmovdqa xword [rsp+$00], xmm0
}
macro vshrb8_p {
vpmovsxbw xmm0, [rsp+$00]
call inst$vshrb8
vmovdqa xword [rsp+$00], xmm0
}
macro vshrs_p {
mov dsc1, dsc0
sar dword [rsp+$00], bsc1
}
macro vshrs2_p {
and dsc0, $1f
vmovd xmm1, dsc0
vmovdqa xmm0, [rsp+$00]
vpsraw xmm0, xmm0, xmm1
vmovdqa xword [rsp+$00], xmm0
}
macro vshrs4_p {
and dsc0, $1f
vmovd xmm1, dsc0
vmovdqa xmm0, [rsp+$00]
vpsraw xmm0, xmm0, xmm1
vmovdqa xword [rsp+$00], xmm0
}
macro vshrs8_p {
and dsc0, $1f
vmovd xmm1, dsc0
vmovdqa xmm0, [rsp+$00]
vpsraw xmm0, xmm0, xmm1
vmovdqa xword [rsp+$00], xmm0
}
macro vshri_p {
sshri_p
}
macro vshri2_p {
sshri2_p
}
macro vshri4_p {
sshri4_p
}
macro vshri8_p {
sshri8_p
}
macro vshrl_p {
sshrl_p
}
macro vshrl2_p {
sshrl2_p
}
macro vshrl4_p {
sshrl4_p
}
macro vshrl8_p {
sshrl8_p
}
; </fold>
; <fold первый операнд — на аккумуляторе, второй операнд — локальная переменная, результат — на аккумуляторе>
macro vshrb_l localvarName* {
mov dsc1, [.#localvarName]
sar dsc0, bsc1
}
macro vshrb2_l localvarName* {
mov dsc0, [.#localvarName]
vpmovsxbw xmm0, xmm0
call inst$vshrb2
}
macro vshrb4_l localvarName* {
mov dsc0, [.#localvarName]
vpmovsxbw xmm0, xmm0
call inst$vshrb4
}
macro vshrb8_l localvarName* {
mov dsc0, [.#localvarName]
vpmovsxbw xmm0, xmm0
call inst$vshrb8
}
macro vshrs_l localvarName* {
mov dsc1, [.#localvarName]
sar dsc0, bsc1
}
macro vshrs2_l localvarName* {
mov dsc0, [.#localvarName]
and dsc0, $1f
vmovd xmm1, dsc0
vpsraw xmm0, xmm0, xmm1
}
macro vshrs4_l localvarName* {
mov dsc0, [.#localvarName]
and dsc0, $1f
vmovd xmm1, dsc0
vpsraw xmm0, xmm0, xmm1
}
macro vshrs8_l localvarName* {
mov dsc0, [.#localvarName]
and dsc0, $1f
vmovd xmm1, dsc0
vpsraw xmm0, xmm0, xmm1
}
macro vshri_l localvarName* {
sshri_l localvarName
}
macro vshri2_l localvarName* {
sshri2_l localvarName
}
macro vshri4_l localvarName* {
sshri4_l localvarName
}
macro vshri8_l localvarName* {
sshri8_l localvarName
}
macro vshrl_l localvarName* {
sshrl_l localvarName
}
macro vshrl2_l localvarName* {
sshrl2_l localvarName
}
macro vshrl4_l localvarName* {
sshrl4_l localvarName
}
macro vshrl8_l localvarName* {
sshrl8_l localvarName
}
; </fold>
; <fold первый операнд — на аккумуляторе, второй операнд — глобальный член, результат — на аккумуляторе>
macro vshrb_g globalmember* {
if(globalmember eqtype 0)
sar dsc0, (globalmember) and $1f
else
mov dsc1, globalmember
sar dsc0, bsc1
end if
}
macro vshrb2_g globalmember* {
if(globalmember eqtype 0)
mov dsc0, (globalmember) and $1f
else
mov dsc0, globalmember
end if
vpmovsxbw xmm0, xmm0
call inst$vshrb2
}
macro vshrb4_g globalmember* {
if(globalmember eqtype 0)
mov dsc0, (globalmember) and $1f
else
mov dsc0, globalmember
end if
vpmovsxbw xmm0, xmm0
call inst$vshrb4
}
macro vshrb8_g globalmember* {
if(globalmember eqtype 0)
mov dsc0, (globalmember) and $1f
else
mov dsc0, globalmember
end if
vpmovsxbw xmm0, xmm0
call inst$vshrb8
}
macro vshrs_g globalmember* {
if(globalmember eqtype 0)
sar dsc0, (globalmember) and $1f
else
mov dsc1, globalmember
sar dsc0, bsc1
end if
}
macro vshrs2_g globalmember* {
if(globalmember eqtype 0)
mov dsc0, (globalmember) and $1f
else
mov dsc0, globalmember
and dsc0, $1f
end if
vmovd xmm1, dsc0
vpsraw xmm0, xmm0, xmm1
}
macro vshrs4_g globalmember* {
if(globalmember eqtype 0)
mov dsc0, (globalmember) and $1f
else
mov dsc0, globalmember
and dsc0, $1f
end if
vmovd xmm1, dsc0
vpsraw xmm0, xmm0, xmm1
}
macro vshrs8_g globalmember* {
if(globalmember eqtype 0)
mov dsc0, (globalmember) and $1f
else
mov dsc0, globalmember
and dsc0, $1f
end if
vmovd xmm1, dsc0
vpsraw xmm0, xmm0, xmm1
}
macro vshri_g globalmember* {
sshri_g globalmember
}
macro vshri2_g globalmember* {
sshri2_g globalmember
}
macro vshri4_g globalmember* {
sshri4_g globalmember
}
macro vshri8_g globalmember* {
sshri8_g globalmember
}
macro vshrl_g globalmember* {
sshrl_g globalmember
}
macro vshrl2_g globalmember* {
sshrl2_g globalmember
}
macro vshrl4_g globalmember* {
sshrl4_g globalmember
}
macro vshrl8_g globalmember* {
sshrl8_g globalmember
}
; </fold>
; </fold>