- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我的团队正在为一种产品开发嵌入式 Linux 解决方案,其中中心应用程序从硬件接收和处理数据,并将其发送到数据库和接口(interface)应用程序。为此,我们使用五个线程:
此应用程序不会错过任何来自 UPP 线程的数据包,UPP 线程每 200 毫秒获取一次新数据。 DSP 线程通常花费的时间少于这 200 毫秒(目前大约需要 30 毫秒,但将来会花费更多时间)。 DB 线程通常每 30 秒调用一次,接口(interface)线程以 5 Hz 的频率调用。
我们面临的问题是,线程有时会花费更多时间来完成它们的工作,尤其是 DB 和 DSP 线程。 IOW,虽然系统在每次运行 UPP 时都运行 DSP,但有时 UPP 运行多达 15 次而没有调用 DSP,从而导致接收到的数据丢失。线程中的这些零星“滞后”在所有线程中都会发生,但 DB 和接口(interface)中的滞后不会有问题,只有当它们出现在 UPP 或 DSP 线程中时才会出现问题。
我们尽一切可能尝试在我们的代码中找到问题所在,但没有成功——大多数时候系统运行没有任何滞后。不过,我们注意到了一些模式:
我们开始认为它与 Linux 有关。通常,在 PC 的日常使用中,鼠标或应用程序确实会出现一些延迟,而 Linux 可能正在对我们这样做。我们还考虑过使用 RAM 内存,在主 Omap L138 处理器和 DSP 处理器之间共享,但一些测试为该假设提供了否定证据。
您有什么建议吗? Linux 真的是问题的根源吗?我们如何知道以及如何修复?
任何帮助将不胜感激。
附注:与this相同
最佳答案
这可能有点太基础了,但这是我过去处理与时序和设计相关的错误时考虑过的事情的 list 。
指定可接受的延迟是多少
在时间敏感型应用程序的情况下,过早的优化可能会非常昂贵,确保您了解您的滞后要求是什么(有硬性数字),衡量您观察到的内容,并不断改进直到达到您的目标。
选择合适的硬件
如果您有 n 个线程,请确保您需要合理的时序,并且您有大约 n 个内核。这使得证明您的进程正在使用 CPU 变得轻而易举。即使您不能在生产中执行此操作,在测试期间执行此操作也有助于排除某些类型的错误。
确保您的应用程序不会使用交换空间 - 确保您有足够的 RAM 来满足所有可能的用例和运行时。使用类似 valgrind 的工具以确保您没有泄漏内存。
选择合适的嵌入式 Linux
您的应用程序对时序的要求越高,您就越有可能需要一个提供时序保证的操作系统。在真正的硬实时操作系统上运行与在精简的桌面 linux 上运行会产生截然不同的结果。知道并理解您选择的嵌入式 Linux 的含义。
为您的应用选择合适的优先级
如果您看到零星的延迟,请确保您的系统上没有运行任何可能导致问题的其他程序。我在桌面 Linux 变体上看到了一些可能导致问题的奇怪东西,包括音频驱动程序。
至少在测试期间将您的优先级提高到比其他后台进程高得多(低值)。您可以使用 nice做这个。
了解内核调用发生的位置
如评论中所述,使用像 strace 这样的工具识别正在进行的内核调用是一个非常好的主意。同样,了解一下functions / operations是什么类型将触发系统调用可能非常有帮助(例如,在可能的情况下,重用缓冲区而不是触发频繁的分配和释放)。
这也有助于理解和最小化您的应用程序正在执行的锁定。这包括显而易见的事情,例如以一致的顺序获取锁,最大限度地减少使用锁所花费的时间,以及采用有意义的最轻量级同步原语(您可以使用原子而不是互斥锁吗?)。
选择合适的调度器和线程优先级
如果您的任务多于核心,请考虑您正在使用的调度程序。
通用调度程序(在大多数情况下)不适合性能关键型应用程序。您的 Linux 发行版将提供一些机制来更改 scheduler (尽管这可能需要提升权限)。
Round Robin 调度 (SCHED_RR) 是一个好的开始,因为它使 CPU 利用率数学计算变得非常容易(至少可以给出一个大概的估计)。确保具有最严格时序要求的线程具有最高优先级。请注意,更改优先级可能会导致一些细微的错误 ( priority inversion )
将性能关键线程锁定到特定内核
您可以使用操作系统(或平台特定)调用来设置线程关联(需要留在特定核心上)sched_affinity .在某些情况下,这有助于确保一致的缓存性能
关于c++ - 嵌入式 Linux 应用程序中的期刊 "lags",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27687438/
这个问题困扰了我几天。 这是我的相关 Storyboard布局: 我已经将阳光下的每个布局都设置为所有三个 View Controller ,并且仍然得到一个在横幅 View 上方有一个“间隙”的结果
我正在我的 C++ 程序中嵌入一个网页。我遇到的问题是,在嵌入式页面的 javascript 中,我可以捕获 onkeypress,但不会触发 onkeydown 和 onkeyup。 如果我在非嵌入
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 5年前关闭。 Improve this qu
我有一个 java web 应用程序。我想创建一个嵌入式 LDAP 服务器,当 web 应用程序运行时,我将向 LDAP 插入一些记录,并且有另一个 web 应用程序将访问此 LDAP 以获取信息。可
我正在尝试通过 tomcat maven 插件将 war 部署到嵌入式 tomcat 服务器。控制台显示服务器启动正常。 看来 war 还没有展开。当我访问 http://localhost:9090
假设我有如下函数: bigrams=[(k,v) for (k,v) in dict_bigrams.items() if k[:pos_qu]==selection[:pos_qu
我读过一些关于 python 嵌入式 C++ 的教程。我曾引用过 python 对象。 https://docs.python.org/3/c-api/function.html Python 脚本:
我正在使用嵌入式应用程序,在调试期间,调试器无法解析宏符号(我的理论:因为宏在预处理中丢失了)。我最终不得不先在源代码中找到宏,然后使用定义来监视变量。 我的问题是:有没有办法将宏定义合并到 elf
首先我要说的是我开发的是基于cortex m4的嵌入式设备应用。 我有引导加载程序和主应用程序通用的功能。现在我为引导加载程序和应用程序编译源文件 2 次。但是我的双库 dfu 空间不足,我想在 RO
作为嵌入式 C 编程的初学者,我很好奇每个(根据我的经验)程序执行是如何从 main() 函数开始的?这就像链接器识别 main() 并将那个“特殊” 函数的地址放入重置 vector 指向的地址。
在我的实时嵌入式处理器固件中,我需要十进制数字的格式化打印。标准 printf/sprintf 在工具链中不可用,所以我需要自己实现它。 我使用了除以十并取余的天真方法。但是我的目标处理器本身不支持除
我有编程经验,但在软件开发方面了解不多。我目前正在为我工作的公司编写一个软件,我开始挑战自己代码的可读性。 我想知道这是否是嵌入式 if 语句的“有效”替代方案,或者我是否可以使用更好的方法。 假
我有一个运行嵌入式 Linux 的嵌入式目标,我想计算以下时间: 1) 高速缓存读/写时序2) uncache 内存读/写时序 Linux 中是否有任何标准测试来计算上述时间? 我已经编写了自己的测试
大多数嵌入式设备都是为了在通常资源受限或低规格的设备上执行特定任务而构建的。 因此,大多数嵌入式开发人员需要去除不必要的库和模块,并为其特定设备和用例创建自定义分发。我们先来了解一下嵌入式 Linu
我正在嵌入式处理器上编写一个简单的裸机应用程序。作为此应用程序的一部分,它必须使用 malloc 在大约 256kB 的堆上分配一些内存。注意:最初这是在 main 中静态分配的,但在一定的大小限制下
我正在尝试为我 friend 的婚礼建立一个网站。我使用的是 Bootstrap 5,嵌入的视频没有填满屏幕大小。这是一个 live test page HTML: 您还需要代码吗?我想让视频的全宽
我有一个项目,我尝试为微 Controller 构建固件并尝试更好地控制所使用的优化标志。我想,而不是使用 -O flag 分别指定不同的优化标志。不幸的是,-O 似乎发生了一些优化魔法。我无法使用单
我正在使用双核设备,并且要求核心 A 创建一个数据结构,其中包含在核心 B 上运行的函数列表的参数,定期更新它并通知核心 B。参数和类型的数量可以改变在运行期间。 我的计划如下.. 创建一个 Para
我们有一个 Microsoft.Phone.Controls.WebBrowser内嵌控件 StackPanel , 在 PivotItem 内在 Windows Phone 8 上。以简化的形式,它
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 2 年前。 Improve this ques
我是一名优秀的程序员,十分优秀!