;
; Реализация среды исполнения языка программирования
; Объектно-ориентированный продвинутый векторный транслятор
;
; Copyright © 2021, 2024 Малик Разработчик
;
; Это свободная программа: вы можете перераспространять ее и/или изменять
; ее на условиях Меньшей Стандартной общественной лицензии GNU в том виде,
; в каком она была опубликована Фондом свободного программного обеспечения;
; либо версии 3 лицензии, либо (по вашему выбору) любой более поздней версии.
;
; Эта программа распространяется в надежде, что она будет полезной,
; но БЕЗО ВСЯКИХ ГАРАНТИЙ; даже без неявной гарантии ТОВАРНОГО ВИДА
; или ПРИГОДНОСТИ ДЛЯ ОПРЕДЕЛЕННЫХ ЦЕЛЕЙ. Подробнее см. в Меньшей Стандартной
; общественной лицензии GNU.
;
; Вы должны были получить копию Меньшей Стандартной общественной лицензии GNU
; вместе с этой программой. Если это не так, см.
; <https://www.gnu.org/licenses/>.
;
; <fold скалярное меньше>
; <fold приватные макросы — должны использоваться только этим текстом исходного кода>
macro _setcmpltf {
setnb bsc0
dec bsc0
movsx dsc0, bsc0
}
macro _setcmplti {
setnl bsc0
dec bsc0
movsx dsc0, bsc0
}
; </fold>
; <fold первый операнд — на стаке, второй операнд — на аккумуляторе, результат — на аккумуляторе>
macro setslte {
fld tbyte [rsp+$00]
__pop $01
fcomip esc0, esc1
releasee
_setcmpg
_setcmpltf
}
macro setsltd {
vmovdqa xmm1, [rsp+$00]
__pop $01
vcomisd xmm1, xmm0
_setcmpg
_setcmpltf
}
macro setsltf {
vmovdqa xmm1, [rsp+$00]
__pop $01
vcomiss xmm1, xmm0
_setcmpg
_setcmpltf
}
macro setslti {
mov dsc1, [rsp+$00]
__pop $01
cmp dsc1, dsc0
_setcmplti
}
macro setsltl {
mov qsc1, [rsp+$00]
__pop $01
cmp qsc1, qsc0
_setcmplti
}
; </fold>
; <fold первый операнд — на стаке, второй операнд — на аккумуляторе, результат — на стаке>
macro setslte_p {
fld tbyte [rsp+$00]
fcomip esc0, esc1
releasee
_setcmpg
_setcmpltf
_wrstb
}
macro setsltd_p {
vmovdqa xmm1, [rsp+$00]
vcomisd xmm1, xmm0
_setcmpg
_setcmpltf
_wrstb
}
macro setsltf_p {
vmovdqa xmm1, [rsp+$00]
vcomiss xmm1, xmm0
_setcmpg
_setcmpltf
_wrstb
}
macro setslti_p {
cmp dword [rsp+$00], dsc0
_setcmplti
_wrstb
}
macro setsltl_p {
cmp qword [rsp+$00], qsc0
_setcmplti
_wrstb
}
; </fold>
; <fold первый операнд — на аккумуляторе, второй операнд — локальная переменная, результат — на аккумуляторе>
macro setslte_l localvarName* {
fld tbyte [.#localvarName]
fxch
fcomip esc0, esc1
releasee
_setcmpg
_setcmpltf
}
macro setsltd_l localvarName* {
vcomisd xmm0, [.#localvarName]
_setcmpg
_setcmpltf
}
macro setsltf_l localvarName* {
vcomiss xmm0, [.#localvarName]
_setcmpg
_setcmpltf
}
macro setslti_l localvarName* {
cmp dsc0, [.#localvarName]
_setcmplti
}
macro setsltl_l localvarName* {
cmp qsc0, [.#localvarName]
_setcmplti
}
; </fold>
; <fold первый операнд — на аккумуляторе, второй операнд — глобальный член, результат — на аккумуляторе>
macro setslte_g globalmember* {
fld tbyte globalmember
fxch
fcomip esc0, esc1
releasee
_setcmpg
_setcmpltf
}
macro setsltd_g globalmember* {
vcomisd xmm0, globalmember
_setcmpg
_setcmpltf
}
macro setsltf_g globalmember* {
vcomiss xmm0, globalmember
_setcmpg
_setcmpltf
}
macro setslti_g globalmember* {
cmp dsc0, globalmember
_setcmplti
}
macro setsltl_g globalmember* {
cmp qsc0, globalmember
_setcmplti
}
; </fold>
; <fold первый операнд — на стаке, второй операнд — на аккумуляторе, результат — переход>
macro jsltge labelIsTrue* {
fld tbyte [rsp+$00]
__pop $01
fcomip esc0, esc1
releasee
_setcmpg
jb labelIsTrue
}
macro jsltle labelIsTrue* {
fld tbyte [rsp+$00]
__pop $01
fcomip esc0, esc1
releasee
_setcmpl
jb labelIsTrue
}
macro jsltgd labelIsTrue* {
vmovdqa xmm1, [rsp+$00]
__pop $01
vcomisd xmm1, xmm0
_setcmpg
jb labelIsTrue
}
macro jsltld labelIsTrue* {
vmovdqa xmm1, [rsp+$00]
__pop $01
vcomisd xmm1, xmm0
_setcmpl
jb labelIsTrue
}
macro jsltgf labelIsTrue* {
vmovdqa xmm1, [rsp+$00]
__pop $01
vcomiss xmm1, xmm0
_setcmpg
jb labelIsTrue
}
macro jsltlf labelIsTrue* {
vmovdqa xmm1, [rsp+$00]
__pop $01
vcomiss xmm1, xmm0
_setcmpl
jb labelIsTrue
}
macro jslti labelIsTrue* {
mov dsc1, [rsp+$00]
__pop $01
cmp dsc1, dsc0
jl labelIsTrue
}
macro jsltl labelIsTrue* {
mov qsc1, [rsp+$00]
__pop $01
cmp qsc1, qsc0
jl labelIsTrue
}
; </fold>
; <fold первый операнд — на аккумуляторе, второй операнд — локальная переменная, результат — переход>
macro jsltge_l labelIsTrue*, localvarName* {
fld tbyte [.#localvarName]
fxch
fcomip esc0, esc1
releasee
_setcmpg
jb labelIsTrue
}
macro jsltle_l labelIsTrue*, localvarName* {
fld tbyte [.#localvarName]
fxch
fcomip esc0, esc1
releasee
_setcmpl
jb labelIsTrue
}
macro jsltgd_l labelIsTrue*, localvarName* {
vcomisd xmm0, [.#localvarName]
_setcmpg
jb labelIsTrue
}
macro jsltld_l labelIsTrue*, localvarName* {
vcomisd xmm0, [.#localvarName]
_setcmpl
jb labelIsTrue
}
macro jsltgf_l labelIsTrue*, localvarName* {
vcomiss xmm0, [.#localvarName]
_setcmpg
jb labelIsTrue
}
macro jsltlf_l labelIsTrue*, localvarName* {
vcomiss xmm0, [.#localvarName]
_setcmpl
jb labelIsTrue
}
macro jslti_l labelIsTrue*, localvarName* {
cmp dsc0, [.#localvarName]
jl labelIsTrue
}
macro jsltl_l labelIsTrue*, localvarName* {
cmp qsc0, [.#localvarName]
jl labelIsTrue
}
; </fold>
; <fold первый операнд — на аккумуляторе, второй операнд — глобальный член, результат — переход>
macro jsltge_g labelIsTrue*, globalmember* {
fld tbyte globalmember
fxch
fcomip esc0, esc1
releasee
_setcmpg
jb labelIsTrue
}
macro jsltle_g labelIsTrue*, globalmember* {
fld tbyte globalmember
fxch
fcomip esc0, esc1
releasee
_setcmpl
jb labelIsTrue
}
macro jsltgd_g labelIsTrue*, globalmember* {
vcomisd xmm0, globalmember
_setcmpg
jb labelIsTrue
}
macro jsltld_g labelIsTrue*, globalmember* {
vcomisd xmm0, globalmember
_setcmpl
jb labelIsTrue
}
macro jsltgf_g labelIsTrue*, globalmember* {
vcomiss xmm0, globalmember
_setcmpg
jb labelIsTrue
}
macro jsltlf_g labelIsTrue*, globalmember* {
vcomiss xmm0, globalmember
_setcmpl
jb labelIsTrue
}
macro jslti_g labelIsTrue*, globalmember* {
cmp dsc0, globalmember
jl labelIsTrue
}
macro jsltl_g labelIsTrue*, globalmember* {
cmp qsc0, globalmember
jl labelIsTrue
}
; </fold>
; </fold>