blob: 8d8c26a6c1a0987b618c3a8215e541403d6b05a5 [file] [log] [blame]
Chris Mason2e635a22007-03-21 11:12:56 -04001#include <linux/module.h>
Chris Mason1e1d2702007-03-15 19:03:33 -04002#include "ctree.h"
3#include "disk-io.h"
Chris Masone089f052007-03-16 16:20:31 -04004#include "transaction.h"
Chris Mason1e1d2702007-03-15 19:03:33 -04005
Chris Masone089f052007-03-16 16:20:31 -04006int btrfs_insert_inode(struct btrfs_trans_handle *trans, struct btrfs_root
7 *root, u64 objectid, struct btrfs_inode_item
8 *inode_item)
Chris Mason1e1d2702007-03-15 19:03:33 -04009{
10 struct btrfs_path path;
11 struct btrfs_key key;
12 int ret;
13 key.objectid = objectid;
14 key.flags = 0;
15 btrfs_set_key_type(&key, BTRFS_INODE_ITEM_KEY);
16 key.offset = 0;
17
18 btrfs_init_path(&path);
Chris Masone089f052007-03-16 16:20:31 -040019 ret = btrfs_insert_item(trans, root, &key, inode_item,
20 sizeof(*inode_item));
Chris Mason1e1d2702007-03-15 19:03:33 -040021 btrfs_release_path(root, &path);
22 return ret;
23}
24
Chris Masone089f052007-03-16 16:20:31 -040025int btrfs_lookup_inode(struct btrfs_trans_handle *trans, struct btrfs_root
26 *root, struct btrfs_path *path, u64 objectid, int mod)
Chris Mason1e1d2702007-03-15 19:03:33 -040027{
28 struct btrfs_key key;
29 int ins_len = mod < 0 ? -1 : 0;
30 int cow = mod != 0;
31
32 key.objectid = objectid;
33 key.flags = 0;
34 btrfs_set_key_type(&key, BTRFS_INODE_ITEM_KEY);
35 key.offset = 0;
Chris Masone089f052007-03-16 16:20:31 -040036 return btrfs_search_slot(trans, root, &key, path, ins_len, cow);
Chris Mason1e1d2702007-03-15 19:03:33 -040037}