停止优化g
Stop goto optimization g
本文关键字:优化 更新时间:2023-10-16
在编写asm代码时,有一个技巧可以通过告诉cpu显式跳转到下一条指令来减慢代码的运行周期。我想用c++模板做一些类似的事情。下面是我的代码:
template <unsigned int c>
inline void adelay()
{
goto x;
x:
adelay<c-1>();
}
template <>
inline void adelay<0>()
{
}
虽然这个想法似乎是合理的,但优化器似乎通过删除jmp代码而成为阻碍。有什么想法可以实现吗?
这样做的原因是为了减慢微控制器的代码,使其以非常特定的频率输出光束脉冲。这是一个非常专业的用途,除了在低级硬件访问(如编写驱动程序或编程微控制器)中并不常见。即使这样,我也尽可能地避免这样的事情。不幸的是,这并非总是可以避免的。
这就是优化器应该做的——优化,包括删除非功能代码。要么在编译器选项中完全禁用优化,要么使用其他方法来减慢程序的速度,有很多api允许您在指定的时间内休眠。
你可以添加这个属性:
template <>
inline void __attribute__((optimize("O0"))) adelay<0>()
{
}
应该会阻止优化。虽然正如其他人提到的,可能有更好的方法,但如果这纯粹是为了学习,那就太好了。我通常使用它来快速验证汇编程序输出,或者当我不在命令行时。
谢谢大家的帮助。我没有使用jmp指令,而是使用nop指令:
template <unsigned int c>
inline void adelay()
{
asm("nop");
adelay<c-1>();
}
template <>
inline void adelay<0>()
{
}
在某一点上,我使用了引用一个易失性变量,它以稍微慢一点的粒度工作:
static volatile int _adelay = 0;
template <unsigned int c>
inline void adelay()
{
_adelay;
adelay<c-1>();
}
template <>
inline void adelay<0>()
{
}
当我的内存不足时,这可能很有用。
再次感谢!:)
Adrian相关文章:
- 空基优化子对象的地址
- 关闭||运算符优化
- 如何解决gcc编译器优化导致的centos双编译器设置中的分段错误
- 返回值优化:显式移动还是隐式
- 人脸跟踪arduino代码的优化
- 使用仅使用一次的变量调用的复制构造函数.这可能是通过调用move构造函数进行编译器优化的情况吗
- 纯函数,为什么没有优化
- 为什么大多数 pair 实现默认不使用压缩(空基优化)?
- 如何以优化的方式同时迭代两个间距不相等的数组
- 小字符串优化(调试与发布模式)
- 浮点定向舍入和优化
- Visual Studio 调试优化如何工作?
- 为什么开关的优化方式与 c/c++ 中的链接不同?
- 线性优化目标函数中的绝对值
- GCC 会优化内联访问器吗?
- gcc 如何优化此循环?
- 如何防止 CUDA-GDB 中的<优化输出>值
- 为什么我的程序在 O0 和 O2 的优化级别返回不同的结果
- 这个C++编译器优化(在自身的实例上调用对象自己的构造函数)的名称是什么,它是如何工作的?
- 使用 std::p air 进行返回值优化