Linux Audio

Check our new training course

Loading...
v6.8
 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}
v6.9.4
 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 "orphan.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}