;
; Реализация среды исполнения языка программирования
; Объектно-ориентированный продвинутый векторный транслятор
;
; Copyright © 2021, 2024 Малик Разработчик
;
; Это свободная программа: вы можете перераспространять ее и/или изменять
; ее на условиях Меньшей Стандартной общественной лицензии GNU в том виде,
; в каком она была опубликована Фондом свободного программного обеспечения;
; либо версии 3 лицензии, либо (по вашему выбору) любой более поздней версии.
;
; Эта программа распространяется в надежде, что она будет полезной,
; но БЕЗО ВСЯКИХ ГАРАНТИЙ; даже без неявной гарантии ТОВАРНОГО ВИДА
; или ПРИГОДНОСТИ ДЛЯ ОПРЕДЕЛЕННЫХ ЦЕЛЕЙ. Подробнее см. в Меньшей Стандартной
; общественной лицензии GNU.
;
; Вы должны были получить копию Меньшей Стандартной общественной лицензии GNU
; вместе с этой программой. Если это не так, см.
; <https://www.gnu.org/licenses/>.
;
; <fold векторное деление>
; <fold первый операнд — на стаке, второй операнд — на аккумуляторе, результат — на аккумуляторе>
macro vdivd {
sdivd
}
macro vdivd2 {
vmovdqa xmm1, [rsp+$00]
vdivpd xmm0, xmm1, xmm0
__pop $01
}
macro vdivd4 {
vmovdqu ymm1, [rsp+$00]
vdivpd ymm0, ymm1, ymm0
__cltag_y $00
__pop $02
}
macro vdivd8 {
vmovdqu64 zmm1, [rsp+$00]
vdivpd zmm0, zmm1, zmm0
__cltag_z $00
__pop $04
}
macro vdivf {
sdivf
}
macro vdivf2 {
vmovdqa xmm1, [rsp+$00]
vdivps xmm0, xmm1, xmm0
vpand xmm0, xmm0, [cons$int8.m1_0]
__pop $01
}
macro vdivf4 {
vmovdqa xmm1, [rsp+$00]
vdivps xmm0, xmm1, xmm0
__pop $01
}
macro vdivf8 {
vmovdqu ymm1, [rsp+$00]
vdivps ymm0, ymm1, ymm0
__cltag_y $00
__pop $02
}
; </fold>
; <fold первый операнд — на стаке, второй операнд — на аккумуляторе, результат — на стаке>
macro vdivd_p {
sdivd_p
}
macro vdivd2_p {
vmovdqa xmm1, [rsp+$00]
vdivpd xmm0, xmm1, xmm0
vmovdqa xword [rsp+$00], xmm0
}
macro vdivd4_p {
vmovdqu ymm1, [rsp+$00]
vdivpd ymm0, ymm1, ymm0
vmovdqu yword [rsp+$00], ymm0
}
macro vdivd8_p {
vmovdqu64 zmm1, [rsp+$00]
vdivpd zmm0, zmm1, zmm0
vmovdqu64 zword [rsp+$00], zmm0
}
macro vdivf_p {
sdivf_p
}
macro vdivf2_p {
vmovdqa xmm1, [rsp+$00]
vdivps xmm0, xmm1, xmm0
vpand xmm0, xmm0, [cons$int8.m1_0]
vmovdqa xword [rsp+$00], xmm0
}
macro vdivf4_p {
vmovdqa xmm1, [rsp+$00]
vdivps xmm0, xmm1, xmm0
vmovdqa xword [rsp+$00], xmm0
}
macro vdivf8_p {
vmovdqu ymm1, [rsp+$00]
vdivps ymm0, ymm1, ymm0
vmovdqu yword [rsp+$00], ymm0
}
; </fold>
; <fold первый операнд — на аккумуляторе, второй операнд — локальная переменная, результат — на аккумуляторе>
macro vdivd_l localvarName* {
sdivd_l localvarName
}
macro vdivd2_l localvarName* {
vdivpd xmm0, xmm0, [.#localvarName]
}
macro vdivd4_l localvarName* {
vmovdqu ymm1, [.#localvarName]
vdivpd ymm0, ymm0, ymm1
}
macro vdivd8_l localvarName* {
vmovdqu64 zmm1, [.#localvarName]
vdivpd zmm0, zmm0, zmm1
}
macro vdivf_l localvarName* {
sdivf_l localvarName
}
macro vdivf2_l localvarName* {
vdivps xmm0, xmm0, [.#localvarName]
vpand xmm0, xmm0, [cons$int8.m1_0]
}
macro vdivf4_l localvarName* {
vdivps xmm0, xmm0, [.#localvarName]
}
macro vdivf8_l localvarName* {
vmovdqu ymm1, [.#localvarName]
vdivps ymm0, ymm0, ymm1
}
; </fold>
; <fold первый операнд — на аккумуляторе, второй операнд — глобальный член, результат — на аккумуляторе>
macro vdivd_g globalmember* {
sdivd_g globalmember
}
macro vdivd2_g globalmember* {
vdivpd xmm0, xmm0, globalmember
}
macro vdivd4_g globalmember* {
vdivpd ymm0, ymm0, globalmember
}
macro vdivd8_g globalmember* {
vdivpd zmm0, zmm0, globalmember
}
macro vdivf_g globalmember* {
sdivf_g globalmember
}
macro vdivf2_g globalmember* {
vdivps xmm0, xmm0, globalmember
vpand xmm0, xmm0, [cons$int8.m1_0]
}
macro vdivf4_g globalmember* {
vdivps xmm0, xmm0, globalmember
}
macro vdivf8_g globalmember* {
vdivps ymm0, ymm0, globalmember
}
; </fold>
; </fold>