作为结构的一部分(让我们称之为ASM)在头文件中声明了四个uint32_t整数。
uint32_t Result1;
uint32_t Result2;
uint32_t Result3;
uint32_t Result4;
我想这样访问:ASM->Result1, ASM->Result2
等并将它们组合成一个128位int,Result1是左边的0-31位,所以最后我得:
返回128bitint = Result1Result2Result3Result4;
如何做到这一点?
答案 0 :(得分:3)
我使用union:
#include <stdio.h>
#include <stdint.h>
#include <inttypes.h>
int main(void) {
union {
struct {
uint32_t v1;
uint32_t v2;
uint32_t v3;
uint32_t v4;
} __attribute__((packed));
unsigned __int128 i128;
} t128;
t128.v1 = 0x22221111;
t128.v2 = 0x44443333;
t128.v3 = 0x66665555;
t128.v4 = 0x88887777;
printf("0x%016"PRIx64"%016"PRIx64"\n", (uint64_t)(t128.i128 >> 64), (uint64_t)t128.i128);
return 0;
}
这给出了:
0x88887777666655554444333322221111
作为intel(little-endian)架构的结果。
答案 1 :(得分:1)
您需要支持128位整数。
在适当的平台上使用gcc
,您可以写下:
__uint128_t getval(const struct ASM *s) {
return ((__uint128_t)s->Result1 << 0) |
((__uint128_t)s->Result2 << 32) |
((__uint128_t)s->Result3 << 64) |
((__uint128_t)s->Result4 << 96);
}
请注意,不清楚 Result1是左边的位0-31 是什么意思。为了澄清您的规范,您必须确定Result1
是低位32位(英特尔架构,小端,我的代码)或高位32位(大端架构)。