Loading...
1// SPDX-License-Identifier: GPL-2.0
2/*
3 * Copyright (C) 2008 Red Hat. All rights reserved.
4 */
5
6#include "ctree.h"
7#include "disk-io.h"
8#include "orphan.h"
9
10int btrfs_insert_orphan_item(struct btrfs_trans_handle *trans,
11 struct btrfs_root *root, u64 offset)
12{
13 struct btrfs_path *path;
14 struct btrfs_key key;
15 int ret = 0;
16
17 key.objectid = BTRFS_ORPHAN_OBJECTID;
18 key.type = BTRFS_ORPHAN_ITEM_KEY;
19 key.offset = offset;
20
21 path = btrfs_alloc_path();
22 if (!path)
23 return -ENOMEM;
24
25 ret = btrfs_insert_empty_item(trans, root, path, &key, 0);
26
27 btrfs_free_path(path);
28 return ret;
29}
30
31int btrfs_del_orphan_item(struct btrfs_trans_handle *trans,
32 struct btrfs_root *root, u64 offset)
33{
34 struct btrfs_path *path;
35 struct btrfs_key key;
36 int ret = 0;
37
38 key.objectid = BTRFS_ORPHAN_OBJECTID;
39 key.type = BTRFS_ORPHAN_ITEM_KEY;
40 key.offset = offset;
41
42 path = btrfs_alloc_path();
43 if (!path)
44 return -ENOMEM;
45
46 ret = btrfs_search_slot(trans, root, &key, path, -1, 1);
47 if (ret < 0)
48 goto out;
49 if (ret) { /* JDM: Really? */
50 ret = -ENOENT;
51 goto out;
52 }
53
54 ret = btrfs_del_item(trans, root, path);
55
56out:
57 btrfs_free_path(path);
58 return ret;
59}
1// SPDX-License-Identifier: GPL-2.0
2/*
3 * Copyright (C) 2008 Red Hat. All rights reserved.
4 */
5
6#include "ctree.h"
7#include "disk-io.h"
8
9int btrfs_insert_orphan_item(struct btrfs_trans_handle *trans,
10 struct btrfs_root *root, u64 offset)
11{
12 struct btrfs_path *path;
13 struct btrfs_key key;
14 int ret = 0;
15
16 key.objectid = BTRFS_ORPHAN_OBJECTID;
17 key.type = BTRFS_ORPHAN_ITEM_KEY;
18 key.offset = offset;
19
20 path = btrfs_alloc_path();
21 if (!path)
22 return -ENOMEM;
23
24 ret = btrfs_insert_empty_item(trans, root, path, &key, 0);
25
26 btrfs_free_path(path);
27 return ret;
28}
29
30int btrfs_del_orphan_item(struct btrfs_trans_handle *trans,
31 struct btrfs_root *root, u64 offset)
32{
33 struct btrfs_path *path;
34 struct btrfs_key key;
35 int ret = 0;
36
37 key.objectid = BTRFS_ORPHAN_OBJECTID;
38 key.type = BTRFS_ORPHAN_ITEM_KEY;
39 key.offset = offset;
40
41 path = btrfs_alloc_path();
42 if (!path)
43 return -ENOMEM;
44
45 ret = btrfs_search_slot(trans, root, &key, path, -1, 1);
46 if (ret < 0)
47 goto out;
48 if (ret) { /* JDM: Really? */
49 ret = -ENOENT;
50 goto out;
51 }
52
53 ret = btrfs_del_item(trans, root, path);
54
55out:
56 btrfs_free_path(path);
57 return ret;
58}