linux中是否有asynchronousmemcpy函数? 我希望它与DMA一起工作,并在完成时通知我。
如何确定一个过程的完整性水平?
客户端服务器使用命名pipe道聊天
为什么Windows Search会查询我的IFilter是否有一些奇怪的接口?
如何在C ++中检查用户的系统权限
据我所知,cpu不能/不能做自己的DMA。 所以你需要在总线上的外部硬件为你做的伎俩。
然而,大多数硬件不能处理所有的物理内存,所以一个确切的memcpy克隆是不可能的,除非你在用例中对内存地址范围有非常严格的定义。 否则内核将不得不将块存入自己的内存块本身,这将首先克隆memcpy的目的:)
但是,如果你想在不使用memcpy的情况下创建一个内存块的“克隆”(由于DMA内存访问速度通常比cpu慢),你可以将内存块发送到视频卡并将其拉回来到另一个缓冲区。 您甚至可以将该块放在视频内存(putbitmap()?:))中,然后执行硬件加速的bitblt()来即时创建副本。
你介意分享你的实际目标,也许人们可以想出更聪明/更好的技巧?
在多核处理器上,甚至是只有超线程的处理器上,通过在单独的线程中执行通常的(同步) memcpy ,您可以拥有自己想要的东西。 我不是说这是一个好主意,只是指出显而易见的。
你可以用mremap做一些游戏。 或者你可以破解FFmpeg为不同的帧使用不同的缓冲区。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。