cast.double.inc

Переключить прокрутку окна
Загрузить этот исходный код

;
  ; Реализация среды исполнения языка программирования
  ; Объектно-ориентированный продвинутый векторный транслятор
  ;
  ; Copyright © 2021, 2024 Малик Разработчик
  ;
  ; Это свободная программа: вы можете перераспространять ее и/или изменять
  ; ее на условиях Меньшей Стандартной общественной лицензии GNU в том виде,
  ; в каком она была опубликована Фондом свободного программного обеспечения;
  ; либо версии 3 лицензии, либо (по вашему выбору) любой более поздней версии.
  ;
  ; Эта программа распространяется в надежде, что она будет полезной,
  ; но БЕЗО ВСЯКИХ ГАРАНТИЙ; даже без неявной гарантии ТОВАРНОГО ВИДА
  ; или ПРИГОДНОСТИ ДЛЯ ОПРЕДЕЛЕННЫХ ЦЕЛЕЙ. Подробнее см. в Меньшей Стандартной
  ; общественной лицензии GNU.
  ;
  ; Вы должны были получить копию Меньшей Стандартной общественной лицензии GNU
  ; вместе с этой программой. Если это не так, см.
  ; <https://www.gnu.org/licenses/>.
;

; <fold приведение значения типа double* к другим типам>
    if(used inst$castdtoi) ; <fold returns int>
                    proc        inst$castdtoi
                    vcvttsd2si  dsc0, xmm0
                    vmovd       xmm1, dsc0
                    vmovq       xmm2, [cons$double8.imax]
                    vcmpsd      xmm2, xmm2, xmm0, $02
                    vcmpsd      xmm3, xmm0, xmm0, $07
                    vpsrldq     xmm2, xmm2, $04
                    vpsrldq     xmm3, xmm3, $04
                    vpaddd      xmm0, xmm1, xmm2
                    vpand       xmm0, xmm0, xmm3
                    vmovd       dsc0, xmm0
                    ret
                    end_proc
    end if ; </fold>

    if(used inst$castdtol) ; <fold returns long>
                    proc        inst$castdtol
                    vcvttsd2si  qsc0, xmm0
                    vmovq       xmm1, qsc0
                    vmovq       xmm2, [cons$double8.lmax]
                    vcmpsd      xmm2, xmm2, xmm0, $02
                    vcmpsd      xmm3, xmm0, xmm0, $07
                    vpaddq      xmm0, xmm1, xmm2
                    vpand       xmm0, xmm0, xmm3
                    vmovq       qsc0, xmm0
                    ret
                    end_proc
    end if ; </fold>

    if(used inst$castd2toi2) ; <fold returns int2>
                    proc        inst$castd2toi2
                    vcvttpd2dq  xmm1, xmm0
                    vmovdqa     xmm2, [cons$double8.imax]
                    vmovdqa     xmm3, [cons$int8.m1_0]
                    vcmppd      msk1, xmm2, xmm0, $02
                    vcmppd      msk2, xmm0, xmm0, $07
                    vmovdqa32   xmm2{k1}{z}, xmm3
                    vmovdqa32   xmm3{k2}{z}, xmm3
                    vpaddd      xmm0, xmm1, xmm2
                    vpand       xmm0, xmm0, xmm3
                    ret
                    end_proc
    end if ; </fold>

    if(used inst$castd2tol2) ; <fold returns long2>
                    proc        inst$castd2tol2
                    vcvttpd2qq  xmm1, xmm0
                    vmovdqa     xmm2, [cons$double8.lmax]
                    vcmppd      xmm2, xmm2, xmm0, $02
                    vcmppd      xmm3, xmm0, xmm0, $07
                    vpaddq      xmm0, xmm1, xmm2
                    vpand       xmm0, xmm0, xmm3
                    ret
                    end_proc
    end if ; </fold>

    if(used inst$castd4toi4) ; <fold returns int4>
                    proc        inst$castd4toi4
                    vcvttpd2dq  xmm1, ymm0
                    vmovdqa     ymm2, [cons$double8.imax]
                    vmovdqa     xmm3, [cons$int8.m1]
                    vcmppd      msk1, ymm2, ymm0, $02
                    vcmppd      msk2, ymm0, ymm0, $07
                    vmovdqa32   xmm2{k1}{z}, xmm3
                    vmovdqa32   xmm3{k2}{z}, xmm3
                    vpaddd      xmm0, xmm1, xmm2
                    vpand       xmm0, xmm0, xmm3
                    ret
                    end_proc
    end if ; </fold>

    if(used inst$castd4tol4) ; <fold returns long4>
                    proc        inst$castd4tol4
                    vcvttpd2qq  ymm1, ymm0
                    vmovdqa     ymm2, [cons$double8.lmax]
                    vcmppd      ymm2, ymm2, ymm0, $02
                    vcmppd      ymm3, ymm0, ymm0, $07
                    vpaddq      ymm0, ymm1, ymm2
                    vpand       ymm0, ymm0, ymm3
                    ret
                    end_proc
    end if ; </fold>

    if(used inst$castd8toi8) ; <fold returns int8>
                    proc        inst$castd8toi8
                    vcvttpd2dq  ymm1, zmm0
                    vmovdqa64   zmm2, [cons$double8.imax]
                    vmovdqa     ymm3, [cons$int8.m1]
                    vcmppd      msk1, zmm2, zmm0, $02
                    vcmppd      msk2, zmm0, zmm0, $07
                    vmovdqa32   ymm2{k1}{z}, ymm3
                    vmovdqa32   ymm3{k2}{z}, ymm3
                    vpaddd      ymm0, ymm1, ymm2
                    vpand       ymm0, ymm0, ymm3
                    ret
                    end_proc
    end if ; </fold>

    if(used inst$castd8tol8) ; <fold returns long8>
                    proc        inst$castd8tol8
                    vcvttpd2qq  zmm1, zmm0
                    vmovdqa64   zmm2, [cons$double8.lmax]
                    vmovdqa64   zmm3, [cons$long8.m1]
                    vcmppd      msk1, zmm2, zmm0, $02
                    vcmppd      msk2, zmm0, zmm0, $07
                    vmovdqa64   zmm2{k1}{z}, zmm3
                    vmovdqa64   zmm3{k2}{z}, zmm3
                    vpaddq      zmm0, zmm1, zmm2
                    vpandq      zmm0, zmm0, zmm3
                    ret
                    end_proc
    end if ; </fold>
; </fold>