blob: c3a2ec554361f5d33b4b5a1a6eda29dca5b82aad [file] [log] [blame]
Chris Mason6cbd5572007-06-12 09:07:21 -04001/*
2 * Copyright (C) 2007 Oracle. All rights reserved.
3 *
4 * This program is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU General Public
6 * License v2 as published by the Free Software Foundation.
7 *
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11 * General Public License for more details.
12 *
13 * You should have received a copy of the GNU General Public
14 * License along with this program; if not, write to the
15 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
16 * Boston, MA 021110-1307, USA.
17 */
18
Chris Mason24af03e2007-03-15 12:57:43 -040019#ifndef __HASH__
20#define __HASH__
David Woodhouse615f9962008-08-19 19:21:57 +010021
Filipe David Borba Manana14a958e2014-01-12 02:22:46 +000022int __init btrfs_hash_init(void);
23
24void btrfs_hash_exit(void);
Jeff Mahoney5f9e1052015-09-16 15:34:53 +020025const char* btrfs_crc32c_impl(void);
Filipe David Borba Manana14a958e2014-01-12 02:22:46 +000026
27u32 btrfs_crc32c(u32 crc, const void *address, unsigned int length);
28
David Woodhouse615f9962008-08-19 19:21:57 +010029static inline u64 btrfs_name_hash(const char *name, int len)
30{
Filipe David Borba Manana14a958e2014-01-12 02:22:46 +000031 return btrfs_crc32c((u32)~1, name, len);
David Woodhouse615f9962008-08-19 19:21:57 +010032}
Mark Fashehf1863732012-08-08 11:32:27 -070033
34/*
35 * Figure the key offset of an extended inode ref
36 */
37static inline u64 btrfs_extref_hash(u64 parent_objectid, const char *name,
38 int len)
39{
Filipe David Borba Manana14a958e2014-01-12 02:22:46 +000040 return (u64) btrfs_crc32c(parent_objectid, name, len);
Mark Fashehf1863732012-08-08 11:32:27 -070041}
42
Chris Mason24af03e2007-03-15 12:57:43 -040043#endif