]> git.karo-electronics.de Git - karo-tx-linux.git/blob - fs/btrfs/dir-item.c
Mountable btrfs, with readdir
[karo-tx-linux.git] / fs / btrfs / dir-item.c
1 #include <linux/module.h>
2 #include "ctree.h"
3 #include "disk-io.h"
4 #include "hash.h"
5 #include "transaction.h"
6
7 int btrfs_insert_dir_item(struct btrfs_trans_handle *trans, struct btrfs_root
8                           *root, char *name, int name_len, u64 dir, u64
9                           objectid, u8 type)
10 {
11         int ret = 0;
12         struct btrfs_path path;
13         struct btrfs_dir_item *dir_item;
14         char *name_ptr;
15         struct btrfs_key key;
16         u32 data_size;
17
18         key.objectid = dir;
19         key.flags = 0;
20         btrfs_set_key_type(&key, BTRFS_DIR_ITEM_KEY);
21         ret = btrfs_name_hash(name, name_len, &key.offset);
22         BUG_ON(ret);
23         btrfs_init_path(&path);
24         data_size = sizeof(*dir_item) + name_len;
25         ret = btrfs_insert_empty_item(trans, root, &path, &key, data_size);
26         if (ret)
27                 goto out;
28
29         dir_item = btrfs_item_ptr(btrfs_buffer_leaf(path.nodes[0]),
30                                   path.slots[0],
31                                   struct btrfs_dir_item);
32         btrfs_set_dir_objectid(dir_item, objectid);
33         btrfs_set_dir_type(dir_item, type);
34         btrfs_set_dir_flags(dir_item, 0);
35         btrfs_set_dir_name_len(dir_item, name_len);
36         name_ptr = (char *)(dir_item + 1);
37         memcpy(name_ptr, name, name_len);
38 out:
39         btrfs_release_path(root, &path);
40         return ret;
41 }
42
43 int btrfs_lookup_dir_item(struct btrfs_trans_handle *trans, struct btrfs_root
44                           *root, struct btrfs_path *path, u64 dir,
45                           const char *name, int name_len, int mod)
46 {
47         int ret;
48         struct btrfs_key key;
49         int ins_len = mod < 0 ? -1 : 0;
50         int cow = mod != 0;
51
52         key.objectid = dir;
53         key.flags = 0;
54         btrfs_set_key_type(&key, BTRFS_DIR_ITEM_KEY);
55         ret = btrfs_name_hash(name, name_len, &key.offset);
56         BUG_ON(ret);
57         ret = btrfs_search_slot(trans, root, &key, path, ins_len, cow);
58         return ret;
59 }
60
61 int btrfs_match_dir_item_name(struct btrfs_root *root,
62                               struct btrfs_path *path, char
63                               *name, int name_len)
64 {
65         struct btrfs_dir_item *dir_item;
66         char *name_ptr;
67
68         dir_item = btrfs_item_ptr(btrfs_buffer_leaf(path->nodes[0]),
69                                   path->slots[0],
70                                   struct btrfs_dir_item);
71         if (btrfs_dir_name_len(dir_item) != name_len)
72                 return 0;
73         name_ptr = (char *)(dir_item + 1);
74         if (memcmp(name_ptr, name, name_len))
75                 return 0;
76         return 1;
77 }