ARMSTMvs.ARMNEON的内存复制
创始人
2024-09-14 00:30:32
0

对于内存复制,ARM SIMD指令集提供了两种不同的指令,即单个传输模式(STM)和多个传输模式(NEON),对于大量内存复制,与使用内部存储器和SDRAM访问相比,具有更高的效率和性能。

这里我们介绍如何使用ARM NEON做内存复制,并给出代码示例:

void neon_memcpy(void* dst, const void* src, size_t size)
{
    int64_t* dst64 = reinterpret_cast(dst);
    const int64_t* src64 = reinterpret_cast(src);
    int64x2_t reg64;
    size_t cnt64 = size / 16;
    for (size_t i = 0; i < cnt64; i++)
    {
        reg64 = vld1q_s64(src64 + i*2);
        vst1q_s64(dst64 + i*2, reg64);
    }

    int32_t* dst32 = reinterpret_cast(dst64 + cnt64*2);
    const int32_t* src32 = reinterpret_cast(src64 + cnt64*2);
    int32x4_t reg32;
    size_t cnt32 = (size-cnt64*16)/16;
    for (size_t i = 0; i < cnt32; i++)
    {
        reg32 = vld1q_s32(src32 + i*4);
        vst1q_s32(dst32 + i*4, reg32);
    }

    size_t cnt8 = size-cnt64*16-cnt32*16;
    memcpy(dst32 + cnt32*4, src32 + cnt32*4, cnt8);
}

这里将目标和源都解释为void*,允许复制不同类型的数据。以此方式使用必须对源指针进行对应类型的重解释和读强制类型转换,这里使用了reinterpret cast。最好也这样处理目标指

相关内容

热门资讯

2分钟大纲!wepoker怎么... 2分钟大纲!wepoker怎么发冤家牌(透视)一贯是真的有辅助神器(哔哩哔哩)1、wepoker怎么...
第十分钟技法!wepoker私... 第十分钟技法!wepoker私人局怎么玩(透视)竟然真的是有辅助辅助(哔哩哔哩)1)wepoker私...
第十分钟方式!哈糖大菠萝开挂(... 第十分钟方式!哈糖大菠萝开挂(透视)其实存在有辅助工具(哔哩哔哩)1、实时哈糖大菠萝开挂透视辅助更新...
三分钟机巧!wepoker科技... 三分钟机巧!wepoker科技辅助器(透视)果然有辅助安装(哔哩哔哩)1、上手简单,内置详细流程视频...
8分钟技法!wepoker辅助... 8分钟技法!wepoker辅助插件功能(透视)切实有辅助透视(哔哩哔哩)wepoker辅助插件功能辅...
第4分钟手段!wepoker好... 第4分钟手段!wepoker好友局透视(透视)都是有辅助开挂(哔哩哔哩)1、下载好wepoker好友...
2分钟要领!wpk透视辅助方法... 2分钟要领!wpk透视辅助方法(透视)一直有辅助教程(哔哩哔哩)1、金币登录送、破产送、升级送、活动...
第一分钟模块!wepoker透... 第一分钟模块!wepoker透视底牌脚本(透视)切实真的是有辅助辅助(哔哩哔哩)一、wepoker透...
第9分钟绝活儿!红龙poker... 第9分钟绝活儿!红龙poker作必弊指令(透视)竟然存在有辅助工具(哔哩哔哩)一、红龙poker作必...
第3分钟办法!哈糖大菠萝破解器... 第3分钟办法!哈糖大菠萝破解器(透视)总是是有辅助教程(哔哩哔哩)1、进入到哈糖大菠萝破解器是否有挂...