- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我想测量上下文切换时间的开销。
这是我的想法:
有两个任务:
我创建了一个任务如下:
void calculate_ct(void *pvParameters)
{
int i = 0;
for(; i < 100; i++)
{
vTaskDelay(100 / portTICK_RATE_MS); // delay 100 ms
}
// get_time();
vTaskDelete(NULL);
}
当任务调用 vTaskDelay() 时,它会变成阻塞状态。这意味着发生 上下文切换
到空闲任务。
我可以在最后使用 get_time() 减去延迟时间(10 * 100ms)得到上下文切换时间的总开销,并将开销除以 10 得到上下文切换时间开销的平均值吗?
获取时间()如下:
unsigned int get_reload()
{
return *(uint32_t *) 0xE000E014;
}
unsigned int get_current()
{
return *(uint32_t *) 0xE000E018;
}
unsigned int get_time()
{
static unsigned int const *reload = (void *) 0xE000E014;
static unsigned int const *current = (void *) 0xE000E018;
static const unsigned int scale = 1000000 / configTICK_RATE_HZ;
/* microsecond */
return xTaskGetTickCount() * scale + (*reload - *current) * (1.0) / (*reload / scale);
}
最佳答案
首先,不是特定于 FreeRTOS 的信息:
大多数测量上下文切换时间的尝试都是测量执行一个函数的时间,而这个函数恰好有一个上下文切换。因此,您测量的时间将取决于您选择的功能,与上下文切换时间无关。在测量一个 RTOS 的时间时确实如此,在尝试比较 RTOS 时会更加复杂,因为所选择的函数将包括跨不同 RTOS 的非常不同的功能——这使得比较在很大程度上毫无用处,尽管人们没有意识到这一点,并采取它是一个“绝对”。毕竟,获得最快切换时间的方法是删除所有功能,或者打破调度策略,从而减少需要执行的逻辑。
如果您想测量上下文切换时间,那么只测量它,不要尝试测量函数执行时间,因为上下文切换时间只是您实际测量时间的一小部分。
然后是FreeRTOS的具体细节:
此处显示了有关上下文切换中所用周期数的信息:http://www.freertos.org/FAQMem.html#ContextSwitchTime .您需要按如下方式配置系统:
将 configUSE_PORT_OPTIMISED_TASK_SELECTION 设置为 1 - 这将使用一个或多个 asm 指令来选择要运行的下一个任务,而不是使用通用的 C 实现。
设置configCHECK_FOR_STACK_OVERFLOW到 0 - 这将删除堆栈溢出检查,这是在上下文切换中执行的最长的事情。
确保编译器优化设置为优化速度。
确保没有定义跟踪宏。跟踪宏将代码添加到内核中。
确保configGENERATE_RUN_TIME_STATS设置为 0 - 这将删除收集统计信息的代码。
FreeRTOS 包含允许您将代码插入上下文切换的跟踪宏。您可以使用这些宏来设置可以在示波器上测量的输出。这将允许您测量上下文切换,而不是中断进入时间,但您还将测量设置或清除输出所花费的时间 - 这将因架构而异。
您想测量上下文切换时间,还是执行包含上下文切换的函数的时间?
关于c - FreeRTOS : How to measure context switching time?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30975423/
我正在尝试加载外部 SVG 并将其附加到 Electron 项目中的现有 SVG。 d3.xml 方法对我不起作用,所以我正在查看 d3.symbols ,希望如果我提供路径数据(来自 fs.read
我正在编写一个 Web 应用程序,使用 Go 作为后端。我正在使用这个 GraphQL 库 (link)和 Echo Web 框架 (link) .问题在于 graphql-go 库在 Go 中使用了
有没有办法改造 gin.Context至 context.Context在围棋?构建 Go 微服务应该使用什么? 最佳答案 标准库的 context.Context type 是一个接口(interf
如果我能够像这样注册一个接收器: LocalBroadcastManager.getInstance(this).registerReceiver(mMessageReceiver, new Inte
如果我有 appengine.Context 而不是 ,我不知道如何调用 cloud.WithContext 和 google.DefaultClient >上下文。上下文。 有(旧的)“appeng
有什么区别- AccountManager accountManager = (AccountManager) context.getSystemService(Context.ACCOUNT_SER
我刚读了这篇文章:Build You Own Web Framework In Go为了在处理程序之间共享值,我选择了 context.Context我通过以下方式使用它在处理程序和中间件之间共享值:
在 Visual Studio Code 中,我对 3 个“上下文”菜单项感到非常困惑:Run Tests in Context和 Debug Tests in Context和 Run .NET C
我正在使用带有 和 @Autowired 的 Spring 2.5.6 版本。 虽然我在调度程序上下文中使用 SimpleUrlHandlerMapping ,但一切正常 - Autowiring 工
我使用的是 Context.registerReceiver()、Context.sendBroadcast(Intent) 和 Context.unregisterReceiver() 但是当我看到
问题在于以下错误, [错误] 在 scala.tools.nsc.typechecker.Typers$Typer.typedApply$1(Typers.scala:4580)[错误] 在 scal
最近我正在尝试使用 SoundPool 在我的应用程序中播放一些简单的音效 但不幸的是它在 AVD 中不起作用并且应用程序崩溃 “上下文”到底是什么意思? 完全不懂 提前致谢 最佳答案 任何上下文都允
我正在使用上下文建议器,我想知道我们是否可以设置用于建议的上下文范围,而不是使用所有上下文。 目前查询需要匹配所有上下文。我们能否在上下文中添加“或”运算和/或指定用于特定查询的上下文? 以here为
我被一个使用这种方法的函数卡住了。所以我知道如何使用 expressionValue(with:context:) 函数,但上下文如何参与对我来说仍然是不透明的。也许有人有简单的例子? try tra
我正在尝试在上下文管理器中更改我的 python 程序中的目录。使用 invoke.context.Context 似乎是正确的方法,从 Fabric 文档中获取并且使用常规 with os.chdi
我最近开始使用 Android Studio 处理我的 Android 项目。我注意到在 IDE 的右下角,有文本 Context: .好奇心打败了我,所以现在我正在网上搜索更多信息。我还没有找到任
假设我有这些功能: func A(ctx context.Context) { // A takes some time to process } func B(ctx context.Con
所以,我有一个 context.Context( https://golang.org/pkg/context/ ) 变量,有没有办法列出这个变量包含的所有键? 最佳答案 可以使用不安全反射列出 co
我正在尝试找出传播 context.Context 的正确方法用于在使用 Gin 时使用 OpenTelemetry 进行跟踪。 我目前有一个 gin调用函数并传递 *gin.Context 的处理程
我们可以使用 Remove["context`*"] 删除特定上下文中的所有符号。 .但是是否可以删除 "context`"自己从系统中删除,以便它不再在 Contexts[] 中列出? 最佳答案 据
我是一名优秀的程序员,十分优秀!