Rumah > pembangunan bahagian belakang > Golang > Bagaimana untuk memuatkan data global ke dalam daftar NEON dengan lebih cekap dalam pemasang Go?

Bagaimana untuk memuatkan data global ke dalam daftar NEON dengan lebih cekap dalam pemasang Go?

PHPz
Lepaskan: 2024-02-12 20:39:08
ke hadapan
644 orang telah melayarinya

Bagaimana untuk memuatkan data global ke dalam daftar NEON dengan lebih cekap dalam pemasang Go?

php小编百草为您带来了关于在Go的汇编器中如何更高效地将全局数据加载到NEON寄存器的解决方案。Go语言在底层使用汇编器来优化性能,而NEON寄存器是ARM架构中的一种特殊寄存器,用于加速多媒体和信号处理操作。本文将介绍如何使用适当的指令和技巧,以提高数据加载到NEON寄存器的效率,从而优化Go程序的性能。让我们一起来看看吧!

问题内容

arm64 asm代码中有p256one全局数据作为示例:

DATA p256one<>+0x00(SB)/8, $0x0000000000000001
DATA p256one<>+0x08(SB)/8, $0xffffffff00000000
DATA p256one<>+0x10(SB)/8, $0xffffffffffffffff
DATA p256one<>+0x18(SB)/8, $0x00000000fffffffe

GLOBL p256one<>(SB), 8, $32
Salin selepas log masuk

我需要将 p256one<>(SB) 加载到 V0 和 V1 寄存器中。目前我使用以下方法:

LDP p256one<>+0x00(SB), (R0, R1)
    LDP p256one<>+0x10(SB), (R2, R3)
    VMOV R0, V0.D[0]
    VMOV R1, V0.D[1]
    VMOV R2, V1.D[0]
    VMOV R3, V1.D[1]
Salin selepas log masuk

这里总共使用了六个指令。我们知道我们可以加载内存数据,如下所示:

VLD1 (R0), [V0.B16, V1.B16]
Salin selepas log masuk

但是我们似乎无法用同样的方法加载全局数据。

那么,在Go的汇编代码中是否有更高效的方式将全局数据加载到NEON寄存器中呢?

解决方法

尝试将地址加载到寄存器中,然后从该地址加载:

MOVD $p256one<>(SB), R0
    VLD1 (R0), [V0.B16, V1.B16]
Salin selepas log masuk

Atas ialah kandungan terperinci Bagaimana untuk memuatkan data global ke dalam daftar NEON dengan lebih cekap dalam pemasang Go?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:stackoverflow.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan