;
; Реализация среды исполнения языка программирования
; Объектно-ориентированный продвинутый векторный транслятор
;
; Copyright © 2021, 2024 Малик Разработчик
;
; Это свободная программа: вы можете перераспространять ее и/или изменять
; ее на условиях Меньшей Стандартной общественной лицензии GNU в том виде,
; в каком она была опубликована Фондом свободного программного обеспечения;
; либо версии 3 лицензии, либо (по вашему выбору) любой более поздней версии.
;
; Эта программа распространяется в надежде, что она будет полезной,
; но БЕЗО ВСЯКИХ ГАРАНТИЙ; даже без неявной гарантии ТОВАРНОГО ВИДА
; или ПРИГОДНОСТИ ДЛЯ ОПРЕДЕЛЕННЫХ ЦЕЛЕЙ. Подробнее см. в Меньшей Стандартной
; общественной лицензии GNU.
;
; Вы должны были получить копию Меньшей Стандартной общественной лицензии GNU
; вместе с этой программой. Если это не так, см.
; <https://www.gnu.org/licenses/>.
;
; <fold векторное верхнее умножение с насыщением>
; <fold приватные макросы — должны использоваться только этим текстом исходного кода>
macro _hmulb {
local .L.0000
add dsc0, $7f
sar dsc0, $07
cmp dsc0, $7f
jle .L.0000
mov dsc0, $7f
.L.0000:
}
macro _hmuls {
local .L.0000
add dsc0, $7fff
sar dsc0, $0f
cmp dsc0, $7fff
jle .L.0000
mov dsc0, $7fff
.L.0000:
}
; </fold>
; <fold первый операнд — на стаке, второй операнд — на аккумуляторе, результат — на аккумуляторе>
macro vhmulb {
imul dsc0, [rsp+$00]
_hmulb
__pop $01
}
macro vhmulb2 {
vpmovsxbw xmm1, [rsp+$00]
call inst$vhmulb2
__pop $01
}
macro vhmulb4 {
vpmovsxbw xmm1, [rsp+$00]
call inst$vhmulb4
__pop $01
}
macro vhmulb8 {
vpmovsxbw xmm1, [rsp+$00]
call inst$vhmulb8
__pop $01
}
macro vhmuls {
imul dsc0, [rsp+$00]
_hmuls
__pop $01
}
macro vhmuls2 {
vpmovsxwd xmm1, [rsp+$00]
call inst$vhmuls2
__pop $01
}
macro vhmuls4 {
vpmovsxwd xmm1, [rsp+$00]
call inst$vhmuls4
__pop $01
}
macro vhmuls8 {
vpmovsxwd ymm1, [rsp+$00]
call inst$vhmuls8
__pop $01
}
; </fold>
; <fold первый операнд — на стаке, второй операнд — на аккумуляторе, результат — на стаке>
macro vhmulb_p {
imul dsc0, [rsp+$00]
_hmulb
mov dword [rsp+$00], dsc0
}
macro vhmulb2_p {
vpmovsxbw xmm1, [rsp+$00]
call inst$vhmulb2
vmovdqa xword [rsp+$00], xmm0
}
macro vhmulb4_p {
vpmovsxbw xmm1, [rsp+$00]
call inst$vhmulb4
vmovdqa xword [rsp+$00], xmm0
}
macro vhmulb8_p {
vpmovsxbw xmm1, [rsp+$00]
call inst$vhmulb8
vmovdqa xword [rsp+$00], xmm0
}
macro vhmuls_p {
imul dsc0, [rsp+$00]
_hmuls
mov dword [rsp+$00], dsc0
}
macro vhmuls2_p {
vpmovsxwd xmm1, [rsp+$00]
call inst$vhmuls2
vmovdqa xword [rsp+$00], xmm0
}
macro vhmuls4_p {
vpmovsxwd xmm1, [rsp+$00]
call inst$vhmuls4
vmovdqa xword [rsp+$00], xmm0
}
macro vhmuls8_p {
vpmovsxwd ymm1, [rsp+$00]
call inst$vhmuls8
vmovdqa xword [rsp+$00], xmm0
}
; </fold>
; <fold первый операнд — на аккумуляторе, второй операнд — локальная переменная, результат — на аккумуляторе>
macro vhmulb_l localvarName* {
imul dsc0, [.#localvarName]
_hmulb
}
macro vhmulb2_l localvarName* {
vpmovsxbw xmm1, [.#localvarName]
call inst$vhmulb2
}
macro vhmulb4_l localvarName* {
vpmovsxbw xmm1, [.#localvarName]
call inst$vhmulb4
}
macro vhmulb8_l localvarName* {
vpmovsxbw xmm1, [.#localvarName]
call inst$vhmulb8
}
macro vhmuls_l localvarName* {
imul dsc0, [.#localvarName]
_hmuls
}
macro vhmuls2_l localvarName* {
vpmovsxwd xmm1, [.#localvarName]
call inst$vhmuls2
}
macro vhmuls4_l localvarName* {
vpmovsxwd xmm1, [.#localvarName]
call inst$vhmuls4
}
macro vhmuls8_l localvarName* {
vpmovsxwd ymm1, [.#localvarName]
call inst$vhmuls8
}
; </fold>
; <fold первый операнд — на аккумуляторе, второй операнд — глобальный член, результат — на аккумуляторе>
macro vhmulb_g globalmember* {
if(globalmember eqtype 0)
imul dsc0, dsc0, globalmember
else
imul dsc0, globalmember
end if
_hmulb
}
macro vhmulb2_g globalmember* {
vpmovsxbw xmm1, globalmember
call inst$vhmulb2
}
macro vhmulb4_g globalmember* {
vpmovsxbw xmm1, globalmember
call inst$vhmulb4
}
macro vhmulb8_g globalmember* {
vpmovsxbw xmm1, globalmember
call inst$vhmulb8
}
macro vhmuls_g globalmember* {
if(globalmember eqtype 0)
imul dsc0, dsc0, globalmember
else
imul dsc0, globalmember
end if
_hmuls
}
macro vhmuls2_g globalmember* {
vpmovsxwd xmm1, globalmember
call inst$vhmuls2
}
macro vhmuls4_g globalmember* {
vpmovsxwd xmm1, globalmember
call inst$vhmuls4
}
macro vhmuls8_g globalmember* {
vpmovsxwd ymm1, globalmember
call inst$vhmuls8
}
; </fold>
; </fold>