- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在使用 arm-none-eabi-gcc
7.4 为基于 ARM Cortex-M4 的微 Controller (特别是 EFM32WG940,但这应该与问题无关)编译“裸机”程序。
据我所知,sizeof(int)
和 sizeof(long int)
与他们未签名的同行一起是 4
.你实际上必须输入 long long int
得到一个 64 位整数(或 int64_t
),所以 long int
似乎完全是多余的。
在这种环境下,为什么__UINT32_TYPE__
predefined macro定义为 long unsigned int
?
有没有办法改uint32_t
成为 unsigned int
反而?
通常这不会打扰我,但它会导致 printf
因为-Wformat
让我难受.考虑类似:printf("hello %u\n", i);
(假设 i
是 uint32_t
)
这给了我一个警告,因为 %u
预计 unsigned
但是 uint32_t
是 unsigned long
.显然我可以把它改成 %lu
但是同样的代码在 x86 上编译时会给我一个警告。
编辑:
是的,一种静音方式 -Wformat
是使用 format macros来自 inttypes.h
像这样:printf("hello %" PRIu32, i);
这虽然实际上并没有回答我的问题,但如果代码不是那么难看的话就可以了,并且一些静态分析器没有问题。
我不想破解我所有的 printf 调用,而是想了解为什么 uint32_t
需要unsigned long int
而不是 unsigned int
在这个平台上,以及如何改变它。
最佳答案
As far as I see,
sizeof(int)
andsizeof(long int)
alongside with their unsigned counterparts are both 4. You actually have to typelong long int
to get a 64-bit integer (orint64_t
), solong int
seems to be entirely superfluous.
int
s 只有 15 个值位,而
long int
必须至少有 31 个,并且
long long int
必须至少为 63。有符号整数类型也有一个符号位,而无符号整数类型也有一个额外的值位。 (其中任何一个也可能有填充位,尽管这种情况并不常见。)所以不,
long int
不是多余的,至少在语义上不是多余的。
In this environment, why is the
__UINT32_TYPE__
predefined macro defined tolong unsigned int
?
__UINT32_TYPE__
是 glibc 实现细节。因此,对该问题的唯一合理答案是“因为
unsigned long int
是为
uint32_t
选择的类型。”但我带你实际上是问为什么首先选择这种类型。我无法在这里明确说明 GCC/glibc 开发人员做出决定的原因,但我认为我会在他们的位置做出相同的选择,他们试图支持各种架构。
long int
和
unsigned long int
保证分别至少有 31 和 32 个值位(而
int
和
unsigned int
不是),长版本是 [
u
的自然选择]
int32_t
在它们实际上满足其要求的那些平台上(总共正好 32 位,没有填充位,并且有符号版本实现为二进制补码)。对于某些受支持的体系结构,长版本是唯一正确的选择,并且它们是其余大多数体系结构可接受的选择之一。通过选择长版本,glibc 只需要对 64 位平台的一个子集进行异常(exception)处理,也许还有一些具有奇怪整数类型的平台。
int
没有任何要求,也没有理由为任何期望提供理由。和
unsigned int
将是为
int32_t
选择的类型和
uint32_t
当它们满足要求时,除非它们是满足要求的唯一可用类型。
Is there a way to change
uint32_t
to beunsigned int
instead?
uint32_t
的定义。由实现提供。您可以尝试修改 C 实现以进行更改,或者您可以选择完全不同的实现,但是任何重新定义已定义类型的尝试都会产生未定义的行为(并且可能但不一定会被编译器拒绝)。
unsigned int
)或者,对于
printf
但不是
scanf
, 将参数强制转换为与格式匹配的类型。
Obviously I can change it to
%lu
but then the same code will give me a warning when compiled on x86.
unsigned long
对于 32 位 x86,在 glibc 上也是 32 位宽。我不确定它是否是为
int32_t
选择的类型那里,但它是可行的选择之一。即使对于某些 64 位平台(例如 Win64)也是如此。对于两种替代方案都可行的任何给定平台,您可能会发现一些实现选择一种,而另一些实现选择另一种。
关于c - 为什么在 arm-none-eabi GCC 上将 `uint32_t` 类型定义为 `unsigned long`,以及如何更改它?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55782246/
将 ARM 处理器模式与 x86 操作模式(ring0 到 ring 3)进行比较,用户模式看起来就像 ring3,用户空间程序在其中运行。 但是,我无法将 ring0 与系统模式或主管模式联系起来。
为什么我们在 ARM 架构中有暂存寄存器?处理器如何使用它,我的意思是这个寄存器的用途是什么? 最佳答案 来自 Procedure Call Standard for the Arm Architec
我了解弱内存模型和强内存模型的基本区别。但是没有确切的弱定义,它取决于体系结构(这里是 ARM)。 我已经阅读了有关 ARM 信息中心的文档,但仍有很多内容不清楚。有人可以列出 - ARM 保证哪些内
我想在 arm 9 上分析我的代码,是否有任何分析器可以给我函数调用时间和每个函数占用的总周期?我更喜欢任何免费的分析器。我喜欢在 Linux 中使用 kcachegrind。 最佳答案 我不知道有什
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 7 年前。 Improve this qu
众所周知,对于X86架构:按下电源按钮后,机器开始执行0xFFFFFFF0处的代码,然后开始执行BIOS中的代码以进行硬件初始化。 BIOS 执行后,它使用引导加载程序将操作系统镜像加载到内存中。最后
我有 rootfs 和 klibc 文件系统。我正在创建 make 规则,而一些开发人员的编译器较旧,但没有联网。note1 我正在尝试验证所有文件都是使用 arm 仅当检测到某个版本的编译器时。我已
在部署实际应用程序之前,我们使用 ARM 模板部署 Azure 资源,作为构建过程的一部分。 到目前为止,我们所有的应用程序资源都自包含在资源组中。例如需要 SQL Server 和存储帐户的 Web
为什么 ARM Controller 在发生异常时要从 THUMB 状态返回到 ARM 状态? 最佳答案 一种解释可能是 ARM 模式是 CPU 的“ native ”操作模式,与有限的 Thumb
我正在尝试反转 128 位向量 (uint16x8) 的顺序。 例如,如果我有 a b c d e f g h 我想获得 h g f e d c b a 有没有一种简单的方法可以使用 NEON 内在函
有很多关于内存屏障的信息。大多数信息是指多核或多处理器架构。 Stackoverflow 上的某个地方还指出,单核处理器不需要内存屏障。 到目前为止,我找不到任何明确的解释,为什么单核 CPU 上不需
我想在 ARM Cortex A8 处理器上移植一小段代码。 L1 缓存和 L2 缓存都非常有限。我的程序中有 3 个数组。其中两个是顺序访问的(大小> 数组 A:6MB 和数组 B:3MB),第三个
我无法弄清楚这个 ARM 指令是做什么的: strd.w r0, r1, [r2] 我知道这是一个存储指令,它在 *r2 中存储了一些东西。但我不完全确定是什么。为什么有两个源寄存器
我很好奇为什么有些 ARM 指令(如 MUL 和 ADD)不使用桶形移位器。我想知道极限背后的理性。谢谢! 最佳答案 并不是没有使用桶形移位器;这是您无法指定它在非常具体的指令(数据处理和加载/存储)
我需要计算与 SSE 相同的操作: __m128i result1=_mm_avg_epu8 (upper, lower); 使用 NEON,我执行以下操作: uint8x16_t result1=v
我正在尝试使用 PLD 指令。我面临的问题如下: int32_t addr[10]; asm ("PLD [addr,#5]"); 我收到以下错误: Error: ARM register expec
根据 ARM 手册,应该可以访问特定 CPU 模式的存储寄存器,例如“r13_svc”。当我尝试执行此操作时,gcc 对我大喊大叫,并显示以下错误: 立即表达式需要 # 前缀 -- `mov r2,s
我正在使用 mbxxx 目标开发 Contiki 2.7。在构建我的代码时,链接器提示 .ARM.exidx 和 .data 部分的重叠 .在修改了链接器脚本 contiki-2.7/cpu/stm3
如何确定给定 ARM 处理器上是否存在 NEON 引擎?可以为此目的查询任何状态/标志寄存器吗? 最佳答案 我相信unixsmurf's answer如果使用具有特权内核的操作系统,这将与您获得的一样
如何在设备上分析我的 ARM 代码。 这是涉及 USB 和 SDH 处理的裸机代码,我看到了这个 Code Profiler for ARM但似乎很 slim ,我很熟悉DS5但如果您使用基于 lin
我是一名优秀的程序员,十分优秀!