;
; Реализация среды исполнения языка программирования
; Объектно-ориентированный продвинутый векторный транслятор
;
; Copyright © 2021, 2024 Малик Разработчик
;
; Это свободная программа: вы можете перераспространять ее и/или изменять
; ее на условиях Меньшей Стандартной общественной лицензии GNU в том виде,
; в каком она была опубликована Фондом свободного программного обеспечения;
; либо версии 3 лицензии, либо (по вашему выбору) любой более поздней версии.
;
; Эта программа распространяется в надежде, что она будет полезной,
; но БЕЗО ВСЯКИХ ГАРАНТИЙ; даже без неявной гарантии ТОВАРНОГО ВИДА
; или ПРИГОДНОСТИ ДЛЯ ОПРЕДЕЛЕННЫХ ЦЕЛЕЙ. Подробнее см. в Меньшей Стандартной
; общественной лицензии GNU.
;
; Вы должны были получить копию Меньшей Стандартной общественной лицензии GNU
; вместе с этой программой. Если это не так, см.
; <https://www.gnu.org/licenses/>.
;
; <fold векторное не равно>
; <fold первый операнд — на стаке, второй операнд — на аккумуляторе, результат — на аккумуляторе>
macro vned {
vcmpsd xmm0, xmm0, [rsp+$00], $04
vmovq qsc0, xmm0
__pop $01
}
macro vned2 {
vcmppd xmm0, xmm0, [rsp+$00], $04
__pop $01
}
macro vned4 {
vmovdqu ymm1, [rsp+$00]
vcmppd ymm0, ymm0, ymm1, $04
__cltag_y $00
__pop $02
}
macro vned8 {
vmovdqu64 zmm1, [rsp+$00]
vcmppd msk1, zmm0, zmm1, $04
vmovdqa64 zmm0\{k1\}\{z\}, [cons$long8.m1]
__cltag_z $00
__pop $04
}
macro vnef {
vcmpss xmm0, xmm0, [rsp+$00], $04
vmovd dsc0, xmm0
__pop $01
}
macro vnef2 {
vcmpps xmm0, xmm0, [rsp+$00], $04
__pop $01
}
macro vnef4 {
vcmpps xmm0, xmm0, [rsp+$00], $04
__pop $01
}
macro vnef8 {
vmovdqu ymm1, [rsp+$00]
vcmpps ymm0, ymm0, ymm1, $04
__cltag_y $00
__pop $02
}
macro vneb {
cmp dword [rsp+$00], dsc0
sete bsc0
dec bsc0
movsx dsc0, bsc0
__pop $01
}
macro vneb2 {
vpcmpeqb xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$byte8.m1]
__pop $01
}
macro vneb4 {
vpcmpeqb xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$byte8.m1]
__pop $01
}
macro vneb8 {
vpcmpeqb xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$byte8.m1]
__pop $01
}
macro vnes {
cmp dword [rsp+$00], dsc0
sete bsc0
dec bsc0
movsx dsc0, bsc0
__pop $01
}
macro vnes2 {
vpcmpeqw xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$short8.m1]
__pop $01
}
macro vnes4 {
vpcmpeqw xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$short8.m1]
__pop $01
}
macro vnes8 {
vpcmpeqw xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$short8.m1]
__pop $01
}
macro vnei {
cmp dword [rsp+$00], dsc0
sete bsc0
dec bsc0
movsx dsc0, bsc0
__pop $01
}
macro vnei2 {
vpcmpeqd xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$int8.m1]
__pop $01
}
macro vnei4 {
vpcmpeqd xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$int8.m1]
__pop $01
}
macro vnei8 {
vmovdqu ymm1, [rsp+$00]
vpcmpeqd ymm0, ymm0, ymm1
vpxor ymm0, ymm0, [cons$int8.m1]
__cltag_y $00
__pop $02
}
macro vnel {
cmp qword [rsp+$00], qsc0
sete bsc0
dec bsc0
movsx qsc0, bsc0
__pop $01
}
macro vnel2 {
vpcmpeqq xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$long8.m1]
__pop $01
}
macro vnel4 {
vmovdqu ymm1, [rsp+$00]
vpcmpeqq ymm0, ymm0, ymm1
vpxor ymm0, ymm0, [cons$long8.m1]
__cltag_y $00
__pop $02
}
macro vnel8 {
vmovdqu64 zmm1, [rsp+$00]
vpcmpeqq msk1, zmm0, zmm1
knotw msk1, msk1
vmovdqa64 zmm0\{k1\}\{z\}, [cons$long8.m1]
__cltag_z $00
__pop $04
}
; </fold>
; <fold первый операнд — на стаке, второй операнд — на аккумуляторе, результат — на стаке>
macro vned_p {
vcmpsd xmm0, xmm0, [rsp+$00], $04
vmovdqa xword [rsp+$00], xmm0
}
macro vned2_p {
vcmppd xmm0, xmm0, [rsp+$00], $04
vmovdqa xword [rsp+$00], xmm0
}
macro vned4_p {
vmovdqu ymm1, [rsp+$00]
vcmppd ymm0, ymm0, ymm1, $04
vmovdqu yword [rsp+$00], ymm0
__sttag_y $00, TAG_LONG4
}
macro vned8_p {
vmovdqu64 zmm1, [rsp+$00]
vcmppd msk1, zmm0, zmm1, $04
vmovdqa64 zmm0\{k1\}\{z\}, [cons$long8.m1]
vmovdqu64 zword [rsp+$00], zmm0
__sttag_z $00, TAG_LONG8
}
macro vnef_p {
vcmpss xmm0, xmm0, [rsp+$00], $04
vmovdqa xword [rsp+$00], xmm0
}
macro vnef2_p {
vcmpps xmm0, xmm0, [rsp+$00], $04
vmovdqa xword [rsp+$00], xmm0
}
macro vnef4_p {
vcmpps xmm0, xmm0, [rsp+$00], $04
vmovdqa xword [rsp+$00], xmm0
}
macro vnef8_p {
vmovdqu ymm1, [rsp+$00]
vcmpps ymm0, ymm0, ymm1, $04
vmovdqu yword [rsp+$00], ymm0
__sttag_y $00, TAG_INT8
}
macro vneb_p {
cmp dword [rsp+$00], dsc0
sete bsc0
dec bsc0
movsx dsc0, bsc0
mov dword [rsp+$00], dsc0
}
macro vneb2_p {
vpcmpeqb xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$byte8.m1]
vmovdqa xword [rsp+$00], xmm0
}
macro vneb4_p {
vpcmpeqb xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$byte8.m1]
vmovdqa xword [rsp+$00], xmm0
}
macro vneb8_p {
vpcmpeqb xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$byte8.m1]
vmovdqa xword [rsp+$00], xmm0
}
macro vnes_p {
cmp dword [rsp+$00], dsc0
sete bsc0
dec bsc0
movsx dsc0, bsc0
mov dword [rsp+$00], dsc0
}
macro vnes2_p {
vpcmpeqw xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$short8.m1]
vmovdqa xword [rsp+$00], xmm0
}
macro vnes4_p {
vpcmpeqw xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$short8.m1]
vmovdqa xword [rsp+$00], xmm0
}
macro vnes8_p {
vpcmpeqw xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$short8.m1]
vmovdqa xword [rsp+$00], xmm0
}
macro vnei_p {
cmp dword [rsp+$00], dsc0
sete bsc0
dec bsc0
movsx dsc0, bsc0
mov dword [rsp+$00], dsc0
}
macro vnei2_p {
vpcmpeqd xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$int8.m1]
vmovdqa xword [rsp+$00], xmm0
}
macro vnei4_p {
vpcmpeqd xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$int8.m1]
vmovdqa xword [rsp+$00], xmm0
}
macro vnei8_p {
vmovdqu ymm1, [rsp+$00]
vpcmpeqd ymm0, ymm0, ymm1
vpxor ymm0, ymm0, [cons$int8.m1]
vmovdqu yword [rsp+$00], ymm0
}
macro vnel_p {
cmp qword [rsp+$00], qsc0
sete bsc0
dec bsc0
movsx qsc0, bsc0
mov qword [rsp+$00], qsc0
}
macro vnel2_p {
vpcmpeqq xmm0, xmm0, [rsp+$00]
vpxor xmm0, xmm0, [cons$long8.m1]
vmovdqa xword [rsp+$00], xmm0
}
macro vnel4_p {
vmovdqu ymm1, [rsp+$00]
vpcmpeqq ymm0, ymm0, ymm1
vpxor ymm0, ymm0, [cons$long8.m1]
vmovdqu yword [rsp+$00], ymm0
}
macro vnel8_p {
vmovdqu64 zmm1, [rsp+$00]
vpcmpeqq msk1, zmm0, zmm1
knotw msk1, msk1
vmovdqa64 zmm0\{k1\}\{z\}, [cons$long8.m1]
vmovdqu64 zword [rsp+$00], zmm0
}
; </fold>
; <fold первый операнд — на аккумуляторе, второй операнд — локальная переменная, результат — на аккумуляторе>
macro vned_l localvarName* {
vcmpsd xmm0, xmm0, [.#localvarName], $04
vmovq qsc0, xmm0
}
macro vned2_l localvarName* {
vcmppd xmm0, xmm0, [.#localvarName], $04
}
macro vned4_l localvarName* {
vmovdqu ymm1, [.#localvarName]
vcmppd ymm0, ymm0, ymm1, $04
}
macro vned8_l localvarName* {
vmovdqu64 zmm1, [.#localvarName]
vcmppd msk1, zmm0, zmm1, $04
vmovdqa64 zmm0\{k1\}\{z\}, [cons$long8.m1]
}
macro vnef_l localvarName* {
vcmpss xmm0, xmm0, [.#localvarName], $04
vmovd dsc0, xmm0
}
macro vnef2_l localvarName* {
vcmpps xmm0, xmm0, [.#localvarName], $04
}
macro vnef4_l localvarName* {
vcmpps xmm0, xmm0, [.#localvarName], $04
}
macro vnef8_l localvarName* {
vmovdqu ymm1, [.#localvarName]
vcmpps ymm0, ymm0, ymm1, $04
}
macro vneb_l localvarName* {
cmp dsc0, [.#localvarName]
sete bsc0
dec bsc0
movsx dsc0, bsc0
}
macro vneb2_l localvarName* {
vpcmpeqb xmm0, xmm0, [.#localvarName]
vpxor xmm0, xmm0, [cons$byte8.m1]
}
macro vneb4_l localvarName* {
vpcmpeqb xmm0, xmm0, [.#localvarName]
vpxor xmm0, xmm0, [cons$byte8.m1]
}
macro vneb8_l localvarName* {
vpcmpeqb xmm0, xmm0, [.#localvarName]
vpxor xmm0, xmm0, [cons$byte8.m1]
}
macro vnes_l localvarName* {
cmp dsc0, [.#localvarName]
sete bsc0
dec bsc0
movsx dsc0, bsc0
}
macro vnes2_l localvarName* {
vpcmpeqw xmm0, xmm0, [.#localvarName]
vpxor xmm0, xmm0, [cons$short8.m1]
}
macro vnes4_l localvarName* {
vpcmpeqw xmm0, xmm0, [.#localvarName]
vpxor xmm0, xmm0, [cons$short8.m1]
}
macro vnes8_l localvarName* {
vpcmpeqw xmm0, xmm0, [.#localvarName]
vpxor xmm0, xmm0, [cons$short8.m1]
}
macro vnei_l localvarName* {
cmp dsc0, [.#localvarName]
sete bsc0
dec bsc0
movsx dsc0, bsc0
}
macro vnei2_l localvarName* {
vpcmpeqd xmm0, xmm0, [.#localvarName]
vpxor xmm0, xmm0, [cons$int8.m1]
}
macro vnei4_l localvarName* {
vpcmpeqd xmm0, xmm0, [.#localvarName]
vpxor xmm0, xmm0, [cons$int8.m1]
}
macro vnei8_l localvarName* {
vmovdqu ymm1, [.#localvarName]
vpcmpeqd ymm0, ymm0, ymm1
vpxor ymm0, ymm0, [cons$int8.m1]
}
macro vnel_l localvarName* {
cmp qsc0, [.#localvarName]
sete bsc0
dec bsc0
movsx qsc0, bsc0
}
macro vnel2_l localvarName* {
vpcmpeqq xmm0, xmm0, [.#localvarName]
vpxor xmm0, xmm0, [cons$long8.m1]
}
macro vnel4_l localvarName* {
vmovdqu ymm1, [.#localvarName]
vpcmpeqq ymm0, ymm0, ymm1
vpxor ymm0, ymm0, [cons$long8.m1]
}
macro vnel8_l localvarName* {
vmovdqu64 zmm1, [.#localvarName]
vpcmpeqq msk1, zmm0, zmm1
knotw msk1, msk1
vmovdqa64 zmm0\{k1\}\{z\}, [cons$long8.m1]
}
; </fold>
; <fold первый операнд — на аккумуляторе, второй операнд — глобальный член, результат — на аккумуляторе>
macro vned_g globalmember* {
vcmpsd xmm0, xmm0, globalmember, $04
vmovq qsc0, xmm0
}
macro vned2_g globalmember* {
vcmppd xmm0, xmm0, globalmember, $04
}
macro vned4_g globalmember* {
vcmppd ymm0, ymm0, globalmember, $04
}
macro vned8_g globalmember* {
vcmppd msk1, zmm0, globalmember, $04
vmovdqa64 zmm0\{k1\}\{z\}, [cons$long8.m1]
}
macro vnef_g globalmember* {
vcmpss xmm0, xmm0, globalmember, $04
vmovd dsc0, xmm0
}
macro vnef2_g globalmember* {
vcmpps xmm0, xmm0, globalmember, $04
}
macro vnef4_g globalmember* {
vcmpps xmm0, xmm0, globalmember, $04
}
macro vnef8_g globalmember* {
vcmpps ymm0, ymm0, globalmember, $04
}
macro vneb_g globalmember* {
cmp dsc0, globalmember
sete bsc0
dec bsc0
movsx dsc0, bsc0
}
macro vneb2_g globalmember* {
vpcmpeqb xmm0, xmm0, globalmember
vpxor xmm0, xmm0, [cons$byte8.m1]
}
macro vneb4_g globalmember* {
vpcmpeqb xmm0, xmm0, globalmember
vpxor xmm0, xmm0, [cons$byte8.m1]
}
macro vneb8_g globalmember* {
vpcmpeqb xmm0, xmm0, globalmember
vpxor xmm0, xmm0, [cons$byte8.m1]
}
macro vnes_g globalmember* {
cmp dsc0, globalmember
sete bsc0
dec bsc0
movsx dsc0, bsc0
}
macro vnes2_g globalmember* {
vpcmpeqw xmm0, xmm0, globalmember
vpxor xmm0, xmm0, [cons$short8.m1]
}
macro vnes4_g globalmember* {
vpcmpeqw xmm0, xmm0, globalmember
vpxor xmm0, xmm0, [cons$short8.m1]
}
macro vnes8_g globalmember* {
vpcmpeqw xmm0, xmm0, globalmember
vpxor xmm0, xmm0, [cons$short8.m1]
}
macro vnei_g globalmember* {
cmp dsc0, globalmember
sete bsc0
dec bsc0
movsx dsc0, bsc0
}
macro vnei2_g globalmember* {
vpcmpeqd xmm0, xmm0, globalmember
vpxor xmm0, xmm0, [cons$int8.m1]
}
macro vnei4_g globalmember* {
vpcmpeqd xmm0, xmm0, globalmember
vpxor xmm0, xmm0, [cons$int8.m1]
}
macro vnei8_g globalmember* {
vpcmpeqd ymm0, ymm0, globalmember
vpxor ymm0, ymm0, [cons$int8.m1]
}
macro vnel_g globalmember* {
cmp qsc0, globalmember
sete bsc0
dec bsc0
movsx qsc0, bsc0
}
macro vnel2_g globalmember* {
vpcmpeqq xmm0, xmm0, globalmember
vpxor xmm0, xmm0, [cons$long8.m1]
}
macro vnel4_g globalmember* {
vpcmpeqq ymm0, ymm0, globalmember
vpxor ymm0, ymm0, [cons$long8.m1]
}
macro vnel8_g globalmember* {
vpcmpeqq msk1, zmm0, globalmember
knotw msk1, msk1
vmovdqa64 zmm0\{k1\}\{z\}, [cons$long8.m1]
}
; </fold>
; </fold>