;
; Реализация среды исполнения языка программирования
; Объектно-ориентированный продвинутый векторный транслятор
;
; Copyright © 2021, 2024 Малик Разработчик
;
; Это свободная программа: вы можете перераспространять ее и/или изменять
; ее на условиях Меньшей Стандартной общественной лицензии GNU в том виде,
; в каком она была опубликована Фондом свободного программного обеспечения;
; либо версии 3 лицензии, либо (по вашему выбору) любой более поздней версии.
;
; Эта программа распространяется в надежде, что она будет полезной,
; но БЕЗО ВСЯКИХ ГАРАНТИЙ; даже без неявной гарантии ТОВАРНОГО ВИДА
; или ПРИГОДНОСТИ ДЛЯ ОПРЕДЕЛЕННЫХ ЦЕЛЕЙ. Подробнее см. в Меньшей Стандартной
; общественной лицензии GNU.
;
; Вы должны были получить копию Меньшей Стандартной общественной лицензии GNU
; вместе с этой программой. Если это не так, см.
; <https://www.gnu.org/licenses/>.
;
; <fold векторное беззнаковое верхнее умножение с насыщением>
; <fold приватные макросы — должны использоваться только этим текстом исходного кода>
macro _hmulub {
imul dsc0, dsc1
add dsc0, $ff
movsx dsc0, ah
}
macro _hmulus {
imul dsc0, dsc1
add dsc0, $ffff
sar dsc0, $10
}
; </fold>
; <fold первый операнд — на стаке, второй операнд — на аккумуляторе, результат — на аккумуляторе>
macro vhmulub {
movzx dsc0, bsc0
movzx dsc1, byte [rsp+$00]
_hmulub
__pop $01
}
macro vhmulub2 {
vpmovzxbw xmm1, [rsp+$00]
call inst$vhmulub2
__pop $01
}
macro vhmulub4 {
vpmovzxbw xmm1, [rsp+$00]
call inst$vhmulub4
__pop $01
}
macro vhmulub8 {
vpmovzxbw xmm1, [rsp+$00]
call inst$vhmulub8
__pop $01
}
macro vhmulus {
movzx dsc0, wsc0
movzx dsc1, word [rsp+$00]
_hmulus
__pop $01
}
macro vhmulus2 {
vpmovzxwd xmm1, [rsp+$00]
call inst$vhmulus2
__pop $01
}
macro vhmulus4 {
vpmovzxwd xmm1, [rsp+$00]
call inst$vhmulus4
__pop $01
}
macro vhmulus8 {
vpmovzxwd ymm1, [rsp+$00]
call inst$vhmulus8
__pop $01
}
; </fold>
; <fold первый операнд — на стаке, второй операнд — на аккумуляторе, результат — на стаке>
macro vhmulub_p {
movzx dsc0, bsc0
movzx dsc1, byte [rsp+$00]
_hmulub
mov dword [rsp+$00], dsc0
}
macro vhmulub2_p {
vpmovzxbw xmm1, [rsp+$00]
call inst$vhmulub2
vmovdqa xword [rsp+$00], xmm0
}
macro vhmulub4_p {
vpmovzxbw xmm1, [rsp+$00]
call inst$vhmulub4
vmovdqa xword [rsp+$00], xmm0
}
macro vhmulub8_p {
vpmovzxbw xmm1, [rsp+$00]
call inst$vhmulub8
vmovdqa xword [rsp+$00], xmm0
}
macro vhmulus_p {
movzx dsc0, wsc0
movzx dsc1, word [rsp+$00]
_hmulus
mov dword [rsp+$00], dsc0
}
macro vhmulus2_p {
vpmovzxwd xmm1, [rsp+$00]
call inst$vhmulus2
vmovdqa xword [rsp+$00], xmm0
}
macro vhmulus4_p {
vpmovzxwd xmm1, [rsp+$00]
call inst$vhmulus4
vmovdqa xword [rsp+$00], xmm0
}
macro vhmulus8_p {
vpmovzxwd ymm1, [rsp+$00]
call inst$vhmulus8
vmovdqa xword [rsp+$00], xmm0
}
; </fold>
; <fold первый операнд — на аккумуляторе, второй операнд — локальная переменная, результат — на аккумуляторе>
macro vhmulub_l localvarName* {
movzx dsc0, bsc0
movzx dsc1, byte [.#localvarName]
_hmulub
}
macro vhmulub2_l localvarName* {
vpmovzxbw xmm1, [.#localvarName]
call inst$vhmulub2
}
macro vhmulub4_l localvarName* {
vpmovzxbw xmm1, [.#localvarName]
call inst$vhmulub4
}
macro vhmulub8_l localvarName* {
vpmovzxbw xmm1, [.#localvarName]
call inst$vhmulub8
}
macro vhmulus_l localvarName* {
movzx dsc0, wsc0
movzx dsc1, word [.#localvarName]
_hmulus
}
macro vhmulus2_l localvarName* {
vpmovzxwd xmm1, [.#localvarName]
call inst$vhmulus2
}
macro vhmulus4_l localvarName* {
vpmovzxwd xmm1, [.#localvarName]
call inst$vhmulus4
}
macro vhmulus8_l localvarName* {
vpmovzxwd ymm1, [.#localvarName]
call inst$vhmulus8
}
; </fold>
; <fold первый операнд — на аккумуляторе, второй операнд — глобальный член, результат — на аккумуляторе>
macro vhmulub_g globalmember* {
movzx dsc0, bsc0
if(globalmember eqtype 0)
mov dsc1, (globalmember) and $ff
else
movzx dsc1, byte globalmember
end if
_hmulub
}
macro vhmulub2_g globalmember* {
vpmovzxbw xmm1, globalmember
call inst$vhmulub2
}
macro vhmulub4_g globalmember* {
vpmovzxbw xmm1, globalmember
call inst$vhmulub4
}
macro vhmulub8_g globalmember* {
vpmovzxbw xmm1, globalmember
call inst$vhmulub8
}
macro vhmulus_g globalmember* {
movzx dsc0, wsc0
if(globalmember eqtype 0)
mov dsc1, (globalmember) and $ffff
else
movzx dsc1, word globalmember
end if
_hmulus
}
macro vhmulus2_g globalmember* {
vpmovzxwd xmm1, globalmember
call inst$vhmulus2
}
macro vhmulus4_g globalmember* {
vpmovzxwd xmm1, globalmember
call inst$vhmulus4
}
macro vhmulus8_g globalmember* {
vpmovzxwd ymm1, globalmember
call inst$vhmulus8
}
; </fold>
; </fold>