1 /* SPDX-License-Identifier: GPL-2.0 */
2 /*
3 * Copyright (C) 2012 Fusion-io All rights reserved.
4 * Copyright (C) 2012 Intel Corp. All rights reserved.
5 */
6
7 #ifndef BTRFS_RAID56_H
8 #define BTRFS_RAID56_H
9
nr_parity_stripes(const struct map_lookup * map)10 static inline int nr_parity_stripes(const struct map_lookup *map)
11 {
12 if (map->type & BTRFS_BLOCK_GROUP_RAID5)
13 return 1;
14 else if (map->type & BTRFS_BLOCK_GROUP_RAID6)
15 return 2;
16 else
17 return 0;
18 }
19
nr_data_stripes(const struct map_lookup * map)20 static inline int nr_data_stripes(const struct map_lookup *map)
21 {
22 return map->num_stripes - nr_parity_stripes(map);
23 }
24 #define RAID5_P_STRIPE ((u64)-2)
25 #define RAID6_Q_STRIPE ((u64)-1)
26
27 #define is_parity_stripe(x) (((x) == RAID5_P_STRIPE) || \
28 ((x) == RAID6_Q_STRIPE))
29
30 struct btrfs_raid_bio;
31 struct btrfs_device;
32
33 int raid56_parity_recover(struct bio *bio, struct btrfs_io_context *bioc,
34 u32 stripe_len, int mirror_num, int generic_io);
35 int raid56_parity_write(struct bio *bio, struct btrfs_io_context *bioc, u32 stripe_len);
36
37 void raid56_add_scrub_pages(struct btrfs_raid_bio *rbio, struct page *page,
38 unsigned int pgoff, u64 logical);
39
40 struct btrfs_raid_bio *raid56_parity_alloc_scrub_rbio(struct bio *bio,
41 struct btrfs_io_context *bioc, u32 stripe_len,
42 struct btrfs_device *scrub_dev,
43 unsigned long *dbitmap, int stripe_nsectors);
44 void raid56_parity_submit_scrub_rbio(struct btrfs_raid_bio *rbio);
45
46 struct btrfs_raid_bio *
47 raid56_alloc_missing_rbio(struct bio *bio, struct btrfs_io_context *bioc,
48 u64 length);
49 void raid56_submit_missing_rbio(struct btrfs_raid_bio *rbio);
50
51 int btrfs_alloc_stripe_hash_table(struct btrfs_fs_info *info);
52 void btrfs_free_stripe_hash_table(struct btrfs_fs_info *info);
53
54 #endif
55