如何将4个uint32_t整数组合成一个完整的128位int并返回

时间:2016-02-20 17:50:18

标签: c integer bit 128-bit

作为结构的一部分(让我们称之为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;

如何做到这一点?

2 个答案:

答案 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位(大端架构)。