;
; Реализация среды исполнения языка программирования
; Объектно-ориентированный продвинутый векторный транслятор
;
; Copyright © 2021, 2024 Малик Разработчик
;
; Это свободная программа: вы можете перераспространять ее и/или изменять
; ее на условиях Меньшей Стандартной общественной лицензии GNU в том виде,
; в каком она была опубликована Фондом свободного программного обеспечения;
; либо версии 3 лицензии, либо (по вашему выбору) любой более поздней версии.
;
; Эта программа распространяется в надежде, что она будет полезной,
; но БЕЗО ВСЯКИХ ГАРАНТИЙ; даже без неявной гарантии ТОВАРНОГО ВИДА
; или ПРИГОДНОСТИ ДЛЯ ОПРЕДЕЛЕННЫХ ЦЕЛЕЙ. Подробнее см. в Меньшей Стандартной
; общественной лицензии GNU.
;
; Вы должны были получить копию Меньшей Стандартной общественной лицензии GNU
; вместе с этой программой. Если это не так, см.
; <https://www.gnu.org/licenses/>.
;
; <fold векторное больше или равно>
; <fold первый операнд — на стаке, второй операнд — на аккумуляторе, результат — на аккумуляторе>
macro vged {
vcmpsd xmm0, xmm0, [rsp+$00], $02
vmovq qsc0, xmm0
__pop $01
}
macro vged2 {
vcmppd xmm0, xmm0, [rsp+$00], $02
__pop $01
}
macro vged4 {
vmovdqu ymm1, [rsp+$00]
vcmppd ymm0, ymm0, ymm1, $02
__cltag_y $00
__pop $02
}
macro vged8 {
vmovdqu64 zmm1, [rsp+$00]
vcmppd msk1, zmm0, zmm1, $02
vmovdqa64 zmm0\{k1\}\{z\}, [cons$long8.m1]
__cltag_z $00
__pop $04
}
macro vgef {
vcmpss xmm0, xmm0, [rsp+$00], $02
vmovd dsc0, xmm0
__pop $01
}
macro vgef2 {
vcmpps xmm0, xmm0, [rsp+$00], $02
vpand xmm0, xmm0, [cons$int8.mask2]
__pop $01
}
macro vgef4 {
vcmpps xmm0, xmm0, [rsp+$00], $02
__pop $01
}
macro vgef8 {
vmovdqu ymm1, [rsp+$00]
vcmpps ymm0, ymm0, ymm1, $02
__cltag_y $00
__pop $02
}
macro vgeb {
cmp dword [rsp+$00], dsc0
setnge bsc0
dec bsc0
movsx dsc0, bsc0
__pop $01
}
macro vgeb2 {
vpcmpgtb xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$byte8.mask2]
__pop $01
}
macro vgeb4 {
vpcmpgtb xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$byte8.mask4]
__pop $01
}
macro vgeb8 {
vpcmpgtb xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$byte8.mask8]
__pop $01
}
macro vges {
cmp dword [rsp+$00], dsc0
setnge bsc0
dec bsc0
movsx dsc0, bsc0
__pop $01
}
macro vges2 {
vpcmpgtw xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$short8.mask2]
__pop $01
}
macro vges4 {
vpcmpgtw xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$short8.mask4]
__pop $01
}
macro vges8 {
vpcmpgtw xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$short8.mask8]
__pop $01
}
macro vgei {
cmp dword [rsp+$00], dsc0
setnge bsc0
dec bsc0
movsx dsc0, bsc0
__pop $01
}
macro vgei2 {
vpcmpgtd xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$int8.mask2]
__pop $01
}
macro vgei4 {
vpcmpgtd xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$int8.mask4]
__pop $01
}
macro vgei8 {
vmovdqu ymm1, [rsp+$00]
vpcmpgtd ymm0, ymm0, ymm1
vpxor ymm0, ymm0, [cons$int8.mask8]
__cltag_y $00
__pop $02
}
macro vgel {
cmp qword [rsp+$00], qsc0
setnge bsc0
dec bsc0
movsx qsc0, bsc0
__pop $01
}
macro vgel2 {
vpcmpgtq xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$long8.mask2]
__pop $01
}
macro vgel4 {
vmovdqu ymm1, [rsp+$00]
vpcmpgtq ymm0, ymm0, ymm1
vpxor ymm0, ymm0, [cons$long8.mask4]
__cltag_y $00
__pop $02
}
macro vgel8 {
vmovdqu64 zmm1, [rsp+$00]
vpcmpgtq msk1, zmm0, zmm1
knotw msk1, msk1
vmovdqa64 zmm0\{k1\}\{z\}, [cons$long8.m1]
__cltag_z $00
__pop $04
}
; </fold>
; <fold первый операнд — на стаке, второй операнд — на аккумуляторе, результат — на стаке>
macro vged_p {
vcmpsd xmm0, xmm0, [rsp+$00], $02
vmovdqa xword [rsp+$00], xmm0
}
macro vged2_p {
vcmppd xmm0, xmm0, [rsp+$00], $02
vmovdqa xword [rsp+$00], xmm0
}
macro vged4_p {
vmovdqu ymm1, [rsp+$00]
vcmppd ymm0, ymm0, ymm1, $02
vmovdqu yword [rsp+$00], ymm0
__sttag_y $00, TAG_LONG4
}
macro vged8_p {
vmovdqu64 zmm1, [rsp+$00]
vcmppd msk1, zmm0, zmm1, $02
vmovdqa64 zmm0\{k1\}\{z\}, [cons$long8.m1]
vmovdqu64 zword [rsp+$00], zmm0
__sttag_z $00, TAG_LONG8
}
macro vgef_p {
vcmpss xmm0, xmm0, [rsp+$00], $02
vmovdqa xword [rsp+$00], xmm0
}
macro vgef2_p {
vcmpps xmm0, xmm0, [rsp+$00], $02
vpand xmm0, xmm0, [cons$int8.mask2]
vmovdqa xword [rsp+$00], xmm0
}
macro vgef4_p {
vcmpps xmm0, xmm0, [rsp+$00], $02
vmovdqa xword [rsp+$00], xmm0
}
macro vgef8_p {
vmovdqu ymm1, [rsp+$00]
vcmpps ymm0, ymm0, ymm1, $02
vmovdqu yword [rsp+$00], ymm0
__sttag_y $00, TAG_INT8
}
macro vgeb_p {
cmp dword [rsp+$00], dsc0
setnge bsc0
dec bsc0
movsx dsc0, bsc0
mov dword [rsp+$00], dsc0
}
macro vgeb2_p {
vpcmpgtb xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$byte8.mask2]
vmovdqa xword [rsp+$00], xmm0
}
macro vgeb4_p {
vpcmpgtb xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$byte8.mask4]
vmovdqa xword [rsp+$00], xmm0
}
macro vgeb8_p {
vpcmpgtb xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$byte8.mask8]
vmovdqa xword [rsp+$00], xmm0
}
macro vges_p {
cmp dword [rsp+$00], dsc0
setnge bsc0
dec bsc0
movsx dsc0, bsc0
mov dword [rsp+$00], dsc0
}
macro vges2_p {
vpcmpgtw xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$short8.mask2]
vmovdqa xword [rsp+$00], xmm0
}
macro vges4_p {
vpcmpgtw xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$short8.mask4]
vmovdqa xword [rsp+$00], xmm0
}
macro vges8_p {
vpcmpgtw xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$short8.mask8]
vmovdqa xword [rsp+$00], xmm0
}
macro vgei_p {
cmp dword [rsp+$00], dsc0
setnge bsc0
dec bsc0
movsx dsc0, bsc0
mov dword [rsp+$00], dsc0
}
macro vgei2_p {
vpcmpgtd xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$int8.mask2]
vmovdqa xword [rsp+$00], xmm0
}
macro vgei4_p {
vpcmpgtd xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$int8.mask4]
vmovdqa xword [rsp+$00], xmm0
}
macro vgei8_p {
vmovdqu ymm1, [rsp+$00]
vpcmpgtd ymm0, ymm0, ymm1
vpxor ymm0, ymm0, [cons$int8.mask8]
vmovdqu yword [rsp+$00], ymm0
}
macro vgel_p {
cmp qword [rsp+$00], qsc0
setnge bsc0
dec bsc0
movsx qsc0, bsc0
mov qword [rsp+$00], qsc0
}
macro vgel2_p {
vpcmpgtq xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$long8.mask2]
vmovdqa xword [rsp+$00], xmm0
}
macro vgel4_p {
vmovdqu ymm1, [rsp+$00]
vpcmpgtq ymm0, ymm0, ymm1
vpxor ymm0, ymm0, [cons$long8.mask4]
vmovdqu yword [rsp+$00], ymm0
}
macro vgel8_p {
vmovdqu64 zmm1, [rsp+$00]
vpcmpgtq msk1, zmm0, zmm1
knotw msk1, msk1
vmovdqa64 zmm0\{k1\}\{z\}, [cons$long8.m1]
vmovdqu64 zword [rsp+$00], zmm0
}
; </fold>
; <fold первый операнд — на аккумуляторе, второй операнд — локальная переменная, результат — на аккумуляторе>
macro vged_l localvarName* {
vmovdqa xmm1, [.#localvarName]
vcmpsd xmm0, xmm1, xmm0, $02
vmovq qsc0, xmm0
}
macro vged2_l localvarName* {
vmovdqa xmm1, [.#localvarName]
vcmppd xmm0, xmm1, xmm0, $02
}
macro vged4_l localvarName* {
vmovdqu ymm1, [.#localvarName]
vcmppd ymm0, ymm1, ymm0, $02
}
macro vged8_l localvarName* {
vmovdqu64 zmm1, [.#localvarName]
vcmppd msk1, zmm1, zmm0, $02
vmovdqa64 zmm0\{k1\}\{z\}, [cons$long8.m1]
}
macro vgef_l localvarName* {
vmovdqa xmm1, [.#localvarName]
vcmpss xmm0, xmm1, xmm0, $02
vmovd dsc0, xmm0
}
macro vgef2_l localvarName* {
vmovdqa xmm1, [.#localvarName]
vcmpps xmm0, xmm1, xmm0, $02
vpand xmm0, xmm0, [cons$int8.mask2]
}
macro vgef4_l localvarName* {
vmovdqa xmm1, [.#localvarName]
vcmpps xmm0, xmm1, xmm0, $02
}
macro vgef8_l localvarName* {
vmovdqu ymm1, [.#localvarName]
vcmpps ymm0, ymm1, ymm0, $02
}
macro vgeb_l localvarName* {
cmp dsc0, [.#localvarName]
setnge bsc0
dec bsc0
movsx dsc0, bsc0
}
macro vgeb2_l localvarName* {
vmovdqa xmm1, [.#localvarName]
vpcmpgtb xmm0, xmm1, xmm0
vpxor xmm0, xmm0, [cons$byte8.mask2]
}
macro vgeb4_l localvarName* {
vmovdqa xmm1, [.#localvarName]
vpcmpgtb xmm0, xmm1, xmm0
vpxor xmm0, xmm0, [cons$byte8.mask4]
}
macro vgeb8_l localvarName* {
vmovdqa xmm1, [.#localvarName]
vpcmpgtb xmm0, xmm1, xmm0
vpxor xmm0, xmm0, [cons$byte8.mask8]
}
macro vges_l localvarName* {
cmp dsc0, [.#localvarName]
setnge bsc0
dec bsc0
movsx dsc0, bsc0
}
macro vges2_l localvarName* {
vmovdqa xmm1, [.#localvarName]
vpcmpgtw xmm0, xmm1, xmm0
vpxor xmm0, xmm0, [cons$short8.mask2]
}
macro vges4_l localvarName* {
vmovdqa xmm1, [.#localvarName]
vpcmpgtw xmm0, xmm1, xmm0
vpxor xmm0, xmm0, [cons$short8.mask4]
}
macro vges8_l localvarName* {
vmovdqa xmm1, [.#localvarName]
vpcmpgtw xmm0, xmm1, xmm0
vpxor xmm0, xmm0, [cons$short8.mask8]
}
macro vgei_l localvarName* {
cmp dsc0, [.#localvarName]
setnge bsc0
dec bsc0
movsx dsc0, bsc0
}
macro vgei2_l localvarName* {
vmovdqa xmm1, [.#localvarName]
vpcmpgtd xmm0, xmm1, xmm0
vpxor xmm0, xmm0, [cons$int8.mask2]
}
macro vgei4_l localvarName* {
vmovdqa xmm1, [.#localvarName]
vpcmpgtd xmm0, xmm1, xmm0
vpxor xmm0, xmm0, [cons$int8.mask4]
}
macro vgei8_l localvarName* {
vmovdqu ymm1, [.#localvarName]
vpcmpgtd ymm0, ymm1, ymm0
vpxor ymm0, ymm0, [cons$int8.mask8]
}
macro vgel_l localvarName* {
cmp qsc0, [.#localvarName]
setnge bsc0
dec bsc0
movsx qsc0, bsc0
}
macro vgel2_l localvarName* {
vmovdqa xmm1, [.#localvarName]
vpcmpgtq xmm0, xmm1, xmm0
vpxor xmm0, xmm0, [cons$long8.mask2]
}
macro vgel4_l localvarName* {
vmovdqu ymm1, [.#localvarName]
vpcmpgtq ymm0, ymm1, ymm0
vpxor ymm0, ymm0, [cons$long8.mask4]
}
macro vgel8_l localvarName* {
vmovdqu64 zmm1, [.#localvarName]
vpcmpgtq msk1, zmm1, zmm0
knotw msk1, msk1
vmovdqa64 zmm0\{k1\}\{z\}, [cons$long8.m1]
}
; </fold>
; <fold первый операнд — на аккумуляторе, второй операнд — глобальный член, результат — на аккумуляторе>
macro vged_g globalmember* {
vmovdqa xmm1, globalmember
vcmpsd xmm0, xmm1, xmm0, $02
vmovq qsc0, xmm0
}
macro vged2_g globalmember* {
vmovdqa xmm1, globalmember
vcmppd xmm0, xmm1, xmm0, $02
}
macro vged4_g globalmember* {
vmovdqa ymm1, globalmember
vcmppd ymm0, ymm1, ymm0, $02
}
macro vged8_g globalmember* {
vmovdqa64 zmm1, globalmember
vcmppd msk1, zmm1, zmm0, $02
vmovdqa64 zmm0\{k1\}\{z\}, [cons$long8.m1]
}
macro vgef_g globalmember* {
vmovdqa xmm1, globalmember
vcmpss xmm0, xmm1, xmm0, $02
vmovd dsc0, xmm0
}
macro vgef2_g globalmember* {
vmovdqa xmm1, globalmember
vcmpps xmm0, xmm1, xmm0, $02
vpand xmm0, xmm0, [cons$int8.mask2]
}
macro vgef4_g globalmember* {
vmovdqa xmm1, globalmember
vcmpps xmm0, xmm1, xmm0, $02
}
macro vgef8_g globalmember* {
vmovdqa ymm1, globalmember
vcmpps ymm0, ymm1, ymm0, $02
}
macro vgeb_g globalmember* {
cmp dsc0, globalmember
setnge bsc0
dec bsc0
movsx dsc0, bsc0
}
macro vgeb2_g globalmember* {
vmovdqa xmm1, globalmember
vpcmpgtb xmm0, xmm1, xmm0
vpxor xmm0, xmm0, [cons$byte8.mask2]
}
macro vgeb4_g globalmember* {
vmovdqa xmm1, globalmember
vpcmpgtb xmm0, xmm1, xmm0
vpxor xmm0, xmm0, [cons$byte8.mask4]
}
macro vgeb8_g globalmember* {
vmovdqa xmm1, globalmember
vpcmpgtb xmm0, xmm1, xmm0
vpxor xmm0, xmm0, [cons$byte8.mask8]
}
macro vges_g globalmember* {
cmp dsc0, globalmember
setnge bsc0
dec bsc0
movsx dsc0, bsc0
}
macro vges2_g globalmember* {
vmovdqa xmm1, globalmember
vpcmpgtw xmm0, xmm1, xmm0
vpxor xmm0, xmm0, [cons$short8.mask2]
}
macro vges4_g globalmember* {
vmovdqa xmm1, globalmember
vpcmpgtw xmm0, xmm1, xmm0
vpxor xmm0, xmm0, [cons$short8.mask4]
}
macro vges8_g globalmember* {
vmovdqa xmm1, globalmember
vpcmpgtw xmm0, xmm1, xmm0
vpxor xmm0, xmm0, [cons$short8.mask8]
}
macro vgei_g globalmember* {
cmp dsc0, globalmember
setnge bsc0
dec bsc0
movsx dsc0, bsc0
}
macro vgei2_g globalmember* {
vmovdqa xmm1, globalmember
vpcmpgtd xmm0, xmm1, xmm0
vpxor xmm0, xmm0, [cons$int8.mask2]
}
macro vgei4_g globalmember* {
vmovdqa xmm1, globalmember
vpcmpgtd xmm0, xmm1, xmm0
vpxor xmm0, xmm0, [cons$int8.mask4]
}
macro vgei8_g globalmember* {
vmovdqa ymm1, globalmember
vpcmpgtd ymm0, ymm1, ymm0
vpxor ymm0, ymm0, [cons$int8.mask8]
}
macro vgel_g globalmember* {
cmp qsc0, globalmember
setnge bsc0
dec bsc0
movsx qsc0, bsc0
}
macro vgel2_g globalmember* {
vmovdqa xmm1, globalmember
vpcmpgtq xmm0, xmm1, xmm0
vpxor xmm0, xmm0, [cons$long8.mask2]
}
macro vgel4_g globalmember* {
vmovdqa ymm1, globalmember
vpcmpgtq ymm0, ymm1, ymm0
vpxor ymm0, ymm0, [cons$long8.mask4]
}
macro vgel8_g globalmember* {
vmovdqa64 zmm1, globalmember
vpcmpgtq msk1, zmm1, zmm0
knotw msk1, msk1
vmovdqa64 zmm0\{k1\}\{z\}, [cons$long8.m1]
}
; </fold>
; </fold>