;
; Реализация среды исполнения языка программирования
; Объектно-ориентированный продвинутый векторный транслятор
;
; Copyright © 2021, 2024 Малик Разработчик
;
; Это свободная программа: вы можете перераспространять ее и/или изменять
; ее на условиях Меньшей Стандартной общественной лицензии GNU в том виде,
; в каком она была опубликована Фондом свободного программного обеспечения;
; либо версии 3 лицензии, либо (по вашему выбору) любой более поздней версии.
;
; Эта программа распространяется в надежде, что она будет полезной,
; но БЕЗО ВСЯКИХ ГАРАНТИЙ; даже без неявной гарантии ТОВАРНОГО ВИДА
; или ПРИГОДНОСТИ ДЛЯ ОПРЕДЕЛЕННЫХ ЦЕЛЕЙ. Подробнее см. в Меньшей Стандартной
; общественной лицензии GNU.
;
; Вы должны были получить копию Меньшей Стандартной общественной лицензии GNU
; вместе с этой программой. Если это не так, см.
; <https://www.gnu.org/licenses/>.
;
; <fold скалярное вычитание>
; <fold первый операнд — на стаке, второй операнд — на аккумуляторе, результат — на аккумуляторе>
macro ssube {
fld tbyte [rsp+$00]
fsubrp esc1, esc0
__pop $01
}
macro ssubd {
vmovdqa xmm1, [rsp+$00]
vsubsd xmm0, xmm1, xmm0
__pop $01
}
macro ssubd2 {
vmovdqa xmm1, [rsp+$00]
vsubpd xmm0, xmm1, xmm0
__pop $01
}
macro ssubd4 {
vmovdqu ymm1, [rsp+$00]
vsubpd ymm0, ymm1, ymm0
__cltag_y $00
__pop $02
}
macro ssubd8 {
vmovdqu64 zmm1, [rsp+$00]
vsubpd zmm0, zmm1, zmm0
__cltag_z $00
__pop $04
}
macro ssubf {
vmovdqa xmm1, [rsp+$00]
vsubss xmm0, xmm1, xmm0
__pop $01
}
macro ssubf2 {
vmovdqa xmm1, [rsp+$00]
vsubps xmm0, xmm1, xmm0
__pop $01
}
macro ssubf4 {
vmovdqa xmm1, [rsp+$00]
vsubps xmm0, xmm1, xmm0
__pop $01
}
macro ssubf8 {
vmovdqu ymm1, [rsp+$00]
vsubps ymm0, ymm1, ymm0
__cltag_y $00
__pop $02
}
macro ssubi {
mov dsc1, dsc0
mov dsc0, [rsp+$00]
sub dsc0, dsc1
__pop $01
}
macro ssubi2 {
vmovdqa xmm1, [rsp+$00]
vpsubd xmm0, xmm1, xmm0
__pop $01
}
macro ssubi4 {
vmovdqa xmm1, [rsp+$00]
vpsubd xmm0, xmm1, xmm0
__pop $01
}
macro ssubi8 {
vmovdqu ymm1, [rsp+$00]
vpsubd ymm0, ymm1, ymm0
__cltag_y $00
__pop $02
}
macro ssubl {
mov qsc1, qsc0
mov qsc0, [rsp+$00]
sub qsc0, qsc1
__pop $01
}
macro ssubl2 {
vmovdqa xmm1, [rsp+$00]
vpsubq xmm0, xmm1, xmm0
__pop $01
}
macro ssubl4 {
vmovdqu ymm1, [rsp+$00]
vpsubq ymm0, ymm1, ymm0
__cltag_y $00
__pop $02
}
macro ssubl8 {
vmovdqu64 zmm1, [rsp+$00]
vpsubq zmm0, zmm1, zmm0
__cltag_z $00
__pop $04
}
; </fold>
; <fold первый операнд — на стаке, второй операнд — на аккумуляторе, результат — на стаке>
macro ssube_p {
fld tbyte [rsp+$00]
fsubrp esc1, esc0
fstp tbyte [rsp+$00]
}
macro ssubd_p {
vmovdqa xmm1, [rsp+$00]
vsubsd xmm0, xmm1, xmm0
vmovdqa xword [rsp+$00], xmm0
}
macro ssubd2_p {
vmovdqa xmm1, [rsp+$00]
vsubpd xmm0, xmm1, xmm0
vmovdqa xword [rsp+$00], xmm0
}
macro ssubd4_p {
vmovdqu ymm1, [rsp+$00]
vsubpd ymm0, ymm1, ymm0
vmovdqu yword [rsp+$00], ymm0
}
macro ssubd8_p {
vmovdqu64 zmm1, [rsp+$00]
vsubpd zmm0, zmm1, zmm0
vmovdqu64 zword [rsp+$00], zmm0
}
macro ssubf_p {
vmovdqa xmm1, [rsp+$00]
vsubss xmm0, xmm1, xmm0
vmovdqa xword [rsp+$00], xmm0
}
macro ssubf2_p {
vmovdqa xmm1, [rsp+$00]
vsubps xmm0, xmm1, xmm0
vmovdqa xword [rsp+$00], xmm0
}
macro ssubf4_p {
vmovdqa xmm1, [rsp+$00]
vsubps xmm0, xmm1, xmm0
vmovdqa xword [rsp+$00], xmm0
}
macro ssubf8_p {
vmovdqu ymm1, [rsp+$00]
vsubps ymm0, ymm1, ymm0
vmovdqu yword [rsp+$00], ymm0
}
macro ssubi_p {
sub dword [rsp+$00], dsc0
}
macro ssubi2_p {
vmovdqa xmm1, [rsp+$00]
vpsubd xmm0, xmm1, xmm0
vmovdqa xword [rsp+$00], xmm0
}
macro ssubi4_p {
vmovdqa xmm1, [rsp+$00]
vpsubd xmm0, xmm1, xmm0
vmovdqa xword [rsp+$00], xmm0
}
macro ssubi8_p {
vmovdqu ymm1, [rsp+$00]
vpsubd ymm0, ymm1, ymm0
vmovdqu yword [rsp+$00], ymm0
}
macro ssubl_p {
sub qword [rsp+$00], qsc0
}
macro ssubl2_p {
vmovdqa xmm1, [rsp+$00]
vpsubq xmm0, xmm1, xmm0
vmovdqa xword [rsp+$00], xmm0
}
macro ssubl4_p {
vmovdqu ymm1, [rsp+$00]
vpsubq ymm0, ymm1, ymm0
vmovdqu yword [rsp+$00], ymm0
}
macro ssubl8_p {
vmovdqu64 zmm1, [rsp+$00]
vpsubq zmm0, zmm1, zmm0
vmovdqu64 zword [rsp+$00], zmm0
}
; </fold>
; <fold первый операнд — на аккумуляторе, второй операнд — локальная переменная, результат — на аккумуляторе>
macro ssube_l localvarName* {
fld tbyte [.#localvarName]
fsubp esc1, esc0
}
macro ssubd_l localvarName* {
vsubsd xmm0, xmm0, [.#localvarName]
}
macro ssubd2_l localvarName* {
vsubpd xmm0, xmm0, [.#localvarName]
}
macro ssubd4_l localvarName* {
vmovdqu ymm1, [.#localvarName]
vsubpd ymm0, ymm0, ymm1
}
macro ssubd8_l localvarName* {
vmovdqu64 zmm1, [.#localvarName]
vsubpd zmm0, zmm0, zmm1
}
macro ssubf_l localvarName* {
vsubss xmm0, xmm0, [.#localvarName]
}
macro ssubf2_l localvarName* {
vsubps xmm0, xmm0, [.#localvarName]
}
macro ssubf4_l localvarName* {
vsubps xmm0, xmm0, [.#localvarName]
}
macro ssubf8_l localvarName* {
vmovdqu ymm1, [.#localvarName]
vsubps ymm0, ymm0, ymm1
}
macro ssubi_l localvarName* {
sub dsc0, [.#localvarName]
}
macro ssubi2_l localvarName* {
vpsubd xmm0, xmm0, [.#localvarName]
}
macro ssubi4_l localvarName* {
vpsubd xmm0, xmm0, [.#localvarName]
}
macro ssubi8_l localvarName* {
vmovdqu ymm1, [.#localvarName]
vpsubd ymm0, ymm0, ymm1
}
macro ssubl_l localvarName* {
sub qsc0, [.#localvarName]
}
macro ssubl2_l localvarName* {
vpsubq xmm0, xmm0, [.#localvarName]
}
macro ssubl4_l localvarName* {
vmovdqu ymm1, [.#localvarName]
vpsubq ymm0, ymm0, ymm1
}
macro ssubl8_l localvarName* {
vmovdqu64 zmm1, [.#localvarName]
vpsubq zmm0, zmm0, zmm1
}
; </fold>
; <fold первый операнд — на аккумуляторе, второй операнд — глобальный член, результат — на аккумуляторе>
macro ssube_g globalmember* {
fld tbyte globalmember
fsubp esc1, esc0
}
macro ssubd_g globalmember* {
vsubsd xmm0, xmm0, globalmember
}
macro ssubd2_g globalmember* {
vsubpd xmm0, xmm0, globalmember
}
macro ssubd4_g globalmember* {
vsubpd ymm0, ymm0, globalmember
}
macro ssubd8_g globalmember* {
vsubpd zmm0, zmm0, globalmember
}
macro ssubf_g globalmember* {
vsubss xmm0, xmm0, globalmember
}
macro ssubf2_g globalmember* {
vsubps xmm0, xmm0, globalmember
}
macro ssubf4_g globalmember* {
vsubps xmm0, xmm0, globalmember
}
macro ssubf8_g globalmember* {
vsubps ymm0, ymm0, globalmember
}
macro ssubi_g globalmember* {
if(~(globalmember eqtype 0))
sub dsc0, globalmember
else if((globalmember) <> 0)
lea dsc0, [dsc0-(globalmember)]
end if
}
macro ssubi2_g globalmember* {
vpsubd xmm0, xmm0, globalmember
}
macro ssubi4_g globalmember* {
vpsubd xmm0, xmm0, globalmember
}
macro ssubi8_g globalmember* {
vpsubd ymm0, ymm0, globalmember
}
macro ssubl_g globalmember* {
sub qsc0, globalmember
}
macro ssubl2_g globalmember* {
vpsubq xmm0, xmm0, globalmember
}
macro ssubl4_g globalmember* {
vpsubq ymm0, ymm0, globalmember
}
macro ssubl8_g globalmember* {
vpsubq zmm0, zmm0, globalmember
}
; </fold>
; </fold>