微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

linux – SD卡写性能

我正在编写一个小应用程序,它在SD卡上以恒定速率写入jpeg图像.
我选择了一个EXT3文件系统,但是在EXT2文件系统中观察到了相同的行为.

我的写循环看起来像这样:

get_image()
fwrite()
fsync()

或者像这样:

get_image()
fopen() 
fwrite()
fsync()
fclose()

我还显示了一些时序统计信息,我可以看到我的程序有时会被阻止几秒钟.
平均速率仍然很好,因为如果我将传入的图像保持为fifo,那么我将在这样的停顿之后的短时间内写出许多图像.您知道操作系统是否存在问题,或者它是否与SD卡本身有关?
我怎么能接近实时?我不需要强大的实时性,但是停滞几秒钟是不可接受的.

一些精度:
是的,每个文件后都需要fsync,因为我希望图像在磁盘上,而不是在某些用户或内核缓冲区中.没有fsyncing,我有更好的吞吐量,
但仍然是不可接受的失速.我不认为这是一个缓冲区问题,因为第一次失速发生在写入50 MB之后.根据手册页,fsync正是为了确保没有数据缓冲.

关于平均写入速率的精确度:
我正在以我正在使用的卡片可持续的速度写作.如果我在等待fsync完成时堆叠传入的图像,那么在此停顿之后写入传输速率将增加,我将很快回到平均速率.
平均传输速率约为1.4 MB / s.

系统是一台现代笔记本电脑运行ubuntu 8.04与库存记录(2.6.24.19)

最佳答案
尝试使用O_DIRECT打开文件并在应用程序级别执行缓存.

当我们在STB Box中实现PVR(个人视频记录)功能时,我们遇到了类似的问题. O_DIRECT技巧最终满足了我们的需求.(*)

没有O_DIRECT. write()的数据首先缓存在内核缓冲区中,然后在调用fsync或内核缓存缓冲区已满时刷新到媒体.(**).

使用O_DIRECT.Th内核将DMA直接作为参数传递给写入系统调用用户空间缓冲区指向的物理内存.因此,在用户空间内存和内核缓存之间的副本中不会占用cpu和内存带宽,并且在内核中不会花费cpu时间来管理缓存(如缓存查找,每页锁等). (从here复制)

不确定它是否也可以解决您的问题,但您可能想尝试一下.

*尽管Linus的O_DIRECT是critize,它确实解决了我们的问题.

**假设您没有使用O_DSYNC或O_SYNC打开文件

原文地址:https://www.jb51.cc/linux/440086.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐