On 09/23/2017 12:35 PM, Hans van Kranenburg wrote:
> Hi,
> 
> When looking around in the kernel code, I ran into this (hash.h):
> 
> u32 btrfs_crc32c(u32 crc, const void *address, unsigned int length);
> 
> [...]
> 
> static inline u64 btrfs_extref_hash(u64 parent_objectid, const char *name,
> int len)
> {
> return (u64) btrfs_crc32c(parent_objectid, name, len);
> }
> 
> [...]
> 
> What is the "official" behaviour of just stuffing a 64-bit
> (parent_objectid) value into a 32-bit function argument (crc)? Does it
> get truncated? Does this compile without a warning?
> 
> I would expect that the caller should do the housekeeping of deciding
> how to transform the 64 bit parent_objectid into some 32 bit value.

In the meantime I can of course answer this myself...

#include <stdlib.h>
#include <stdio.h>

typedef unsigned int __u32;
typedef unsigned long __u64;

void i_eat_32_for_breakfast(__u32 food) {
        printf("%u\n", food);
}

int main(void) {
        __u64 eat_this = 4294968320;
        i_eat_32_for_breakfast(eat_this);
        return 0;
}

-$ ./breakfast
1024

-- 
Hans van Kranenburg
--
To unsubscribe from this list: send the line "unsubscribe linux-btrfs" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to