linux-btrfs.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* btrfs_extref_hash 64-bit vs. btrfs_crc32c 32-bit
@ 2017-09-23 10:35 Hans van Kranenburg
  2017-09-24 17:31 ` Hans van Kranenburg
  0 siblings, 1 reply; 2+ messages in thread
From: Hans van Kranenburg @ 2017-09-23 10:35 UTC (permalink / raw)
  To: linux-btrfs

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.

-- 
Hans van Kranenburg

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2017-09-24 17:31 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2017-09-23 10:35 btrfs_extref_hash 64-bit vs. btrfs_crc32c 32-bit Hans van Kranenburg
2017-09-24 17:31 ` Hans van Kranenburg

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).