2007-03-21 23:12:56 +08:00
|
|
|
#include <linux/module.h>
|
2007-03-16 07:03:33 +08:00
|
|
|
#include "ctree.h"
|
|
|
|
#include "disk-io.h"
|
2007-03-17 04:20:31 +08:00
|
|
|
#include "transaction.h"
|
2007-03-16 07:03:33 +08:00
|
|
|
|
2007-03-17 04:20:31 +08:00
|
|
|
int btrfs_insert_inode(struct btrfs_trans_handle *trans, struct btrfs_root
|
|
|
|
*root, u64 objectid, struct btrfs_inode_item
|
|
|
|
*inode_item)
|
2007-03-16 07:03:33 +08:00
|
|
|
{
|
2007-04-02 23:20:42 +08:00
|
|
|
struct btrfs_path *path;
|
2007-03-16 07:03:33 +08:00
|
|
|
struct btrfs_key key;
|
|
|
|
int ret;
|
|
|
|
key.objectid = objectid;
|
|
|
|
key.flags = 0;
|
|
|
|
btrfs_set_key_type(&key, BTRFS_INODE_ITEM_KEY);
|
|
|
|
key.offset = 0;
|
|
|
|
|
2007-04-02 23:20:42 +08:00
|
|
|
path = btrfs_alloc_path();
|
|
|
|
BUG_ON(!path);
|
|
|
|
btrfs_init_path(path);
|
2007-03-17 04:20:31 +08:00
|
|
|
ret = btrfs_insert_item(trans, root, &key, inode_item,
|
|
|
|
sizeof(*inode_item));
|
2007-04-02 23:20:42 +08:00
|
|
|
btrfs_release_path(root, path);
|
|
|
|
btrfs_free_path(path);
|
2007-03-16 07:03:33 +08:00
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
2007-03-17 04:20:31 +08:00
|
|
|
int btrfs_lookup_inode(struct btrfs_trans_handle *trans, struct btrfs_root
|
|
|
|
*root, struct btrfs_path *path, u64 objectid, int mod)
|
2007-03-16 07:03:33 +08:00
|
|
|
{
|
|
|
|
struct btrfs_key key;
|
|
|
|
int ins_len = mod < 0 ? -1 : 0;
|
|
|
|
int cow = mod != 0;
|
|
|
|
|
|
|
|
key.objectid = objectid;
|
|
|
|
key.flags = 0;
|
|
|
|
btrfs_set_key_type(&key, BTRFS_INODE_ITEM_KEY);
|
|
|
|
key.offset = 0;
|
2007-03-17 04:20:31 +08:00
|
|
|
return btrfs_search_slot(trans, root, &key, path, ins_len, cow);
|
2007-03-16 07:03:33 +08:00
|
|
|
}
|