Lines Matching full:slot
51 * Append generic "corrupt leaf/node root=%llu block=%llu slot=%d: " to @fmt.
56 static void generic_err(const struct extent_buffer *eb, int slot, in generic_err() argument
69 "corrupt %s: root=%llu block=%llu slot=%d, %pV", in generic_err()
71 btrfs_header_owner(eb), btrfs_header_bytenr(eb), slot, &vaf); in generic_err()
81 static void file_extent_err(const struct extent_buffer *eb, int slot, in file_extent_err() argument
89 btrfs_item_key_to_cpu(eb, &key, slot); in file_extent_err()
96 "corrupt %s: root=%llu block=%llu slot=%d ino=%llu file_offset=%llu, %pV", in file_extent_err()
98 btrfs_header_owner(eb), btrfs_header_bytenr(eb), slot, in file_extent_err()
107 #define CHECK_FE_ALIGNED(leaf, slot, fi, name, alignment) \ argument
111 file_extent_err((leaf), (slot), \
141 static void dir_item_err(const struct extent_buffer *eb, int slot, in dir_item_err() argument
149 btrfs_item_key_to_cpu(eb, &key, slot); in dir_item_err()
156 "corrupt %s: root=%llu block=%llu slot=%d ino=%llu, %pV", in dir_item_err()
158 btrfs_header_owner(eb), btrfs_header_bytenr(eb), slot, in dir_item_err()
173 struct btrfs_key *key, int slot, in check_prev_ino() argument
177 if (slot == 0) in check_prev_ino()
198 dir_item_err(leaf, slot, in check_prev_ino()
204 struct btrfs_key *key, int slot, in check_extent_data_item() argument
210 u32 item_size = btrfs_item_size(leaf, slot); in check_extent_data_item()
214 file_extent_err(leaf, slot, in check_extent_data_item()
226 if (unlikely(!check_prev_ino(leaf, key, slot, prev_key))) in check_extent_data_item()
229 fi = btrfs_item_ptr(leaf, slot, struct btrfs_file_extent_item); in check_extent_data_item()
236 file_extent_err(leaf, slot, in check_extent_data_item()
244 file_extent_err(leaf, slot, in check_extent_data_item()
257 file_extent_err(leaf, slot, in check_extent_data_item()
264 file_extent_err(leaf, slot, in check_extent_data_item()
272 file_extent_err(leaf, slot, in check_extent_data_item()
286 file_extent_err(leaf, slot, in check_extent_data_item()
297 file_extent_err(leaf, slot, in check_extent_data_item()
302 if (unlikely(CHECK_FE_ALIGNED(leaf, slot, fi, ram_bytes, sectorsize) || in check_extent_data_item()
303 CHECK_FE_ALIGNED(leaf, slot, fi, disk_bytenr, sectorsize) || in check_extent_data_item()
304 CHECK_FE_ALIGNED(leaf, slot, fi, disk_num_bytes, sectorsize) || in check_extent_data_item()
305 CHECK_FE_ALIGNED(leaf, slot, fi, offset, sectorsize) || in check_extent_data_item()
306 CHECK_FE_ALIGNED(leaf, slot, fi, num_bytes, sectorsize))) in check_extent_data_item()
312 file_extent_err(leaf, slot, in check_extent_data_item()
323 if (slot > 0 && in check_extent_data_item()
329 prev_fi = btrfs_item_ptr(leaf, slot - 1, in check_extent_data_item()
333 file_extent_err(leaf, slot - 1, in check_extent_data_item()
344 int slot, struct btrfs_key *prev_key) in check_csum_item() argument
351 generic_err(leaf, slot, in check_csum_item()
357 generic_err(leaf, slot, in check_csum_item()
362 if (unlikely(!IS_ALIGNED(btrfs_item_size(leaf, slot), csumsize))) { in check_csum_item()
363 generic_err(leaf, slot, in check_csum_item()
365 btrfs_item_size(leaf, slot), csumsize); in check_csum_item()
368 if (slot > 0 && prev_key->type == BTRFS_EXTENT_CSUM_KEY) { in check_csum_item()
372 prev_item_size = btrfs_item_size(leaf, slot - 1); in check_csum_item()
376 generic_err(leaf, slot - 1, in check_csum_item()
386 #define inode_item_err(eb, slot, fmt, ...) \ argument
387 dir_item_err(eb, slot, fmt, __VA_ARGS__)
390 int slot) in check_inode_key() argument
395 btrfs_item_key_to_cpu(leaf, &item_key, slot); in check_inode_key()
411 generic_err(leaf, slot, in check_inode_key()
418 dir_item_err(leaf, slot, in check_inode_key()
429 inode_item_err(leaf, slot, in check_inode_key()
433 dir_item_err(leaf, slot, in check_inode_key()
442 int slot) in check_root_key() argument
447 btrfs_item_key_to_cpu(leaf, &item_key, slot); in check_root_key()
458 generic_err(leaf, slot, in check_root_key()
467 generic_err(leaf, slot, "invalid root id 0"); in check_root_key()
469 dir_item_err(leaf, slot, in check_root_key()
476 dir_item_err(leaf, slot, in check_root_key()
493 generic_err(leaf, slot, "invalid root id 0 for reloc tree"); in check_root_key()
501 int slot) in check_dir_item() argument
505 u32 item_size = btrfs_item_size(leaf, slot); in check_dir_item()
508 if (unlikely(!check_prev_ino(leaf, key, slot, prev_key))) in check_dir_item()
511 di = btrfs_item_ptr(leaf, slot, struct btrfs_dir_item); in check_dir_item()
524 dir_item_err(leaf, slot, in check_dir_item()
533 ret = check_root_key(leaf, &location_key, slot); in check_dir_item()
538 ret = check_inode_key(leaf, &location_key, slot); in check_dir_item()
542 dir_item_err(leaf, slot, in check_dir_item()
553 dir_item_err(leaf, slot, in check_dir_item()
561 dir_item_err(leaf, slot, in check_dir_item()
568 dir_item_err(leaf, slot, in check_dir_item()
581 dir_item_err(leaf, slot, in check_dir_item()
587 dir_item_err(leaf, slot, in check_dir_item()
595 dir_item_err(leaf, slot, in check_dir_item()
605 dir_item_err(leaf, slot, in check_dir_item()
623 dir_item_err(leaf, slot, in check_dir_item()
637 static void block_group_err(const struct extent_buffer *eb, int slot, in block_group_err() argument
645 btrfs_item_key_to_cpu(eb, &key, slot); in block_group_err()
652 "corrupt %s: root=%llu block=%llu slot=%d bg_start=%llu bg_len=%llu, %pV", in block_group_err()
654 btrfs_header_owner(eb), btrfs_header_bytenr(eb), slot, in block_group_err()
660 struct btrfs_key *key, int slot) in check_block_group_item() argument
664 u32 item_size = btrfs_item_size(leaf, slot); in check_block_group_item()
674 block_group_err(leaf, slot, in check_block_group_item()
680 block_group_err(leaf, slot, in check_block_group_item()
686 read_extent_buffer(leaf, &bgi, btrfs_item_ptr_offset(leaf, slot), in check_block_group_item()
698 block_group_err(leaf, slot, in check_block_group_item()
705 block_group_err(leaf, slot, in check_block_group_item()
713 block_group_err(leaf, slot, in check_block_group_item()
721 block_group_err(leaf, slot, in check_block_group_item()
734 block_group_err(leaf, slot, in check_block_group_item()
756 int slot = -1; in chunk_err() local
763 * Get the slot number by iterating through all slots, this in chunk_err()
769 slot = i; in chunk_err()
784 "corrupt leaf: root=%llu block=%llu slot=%d chunk_start=%llu, %pV", in chunk_err()
785 BTRFS_CHUNK_TREE_OBJECTID, leaf->start, slot, in chunk_err()
962 struct btrfs_key *key, int slot) in check_leaf_chunk_item() argument
966 if (unlikely(btrfs_item_size(leaf, slot) < sizeof(struct btrfs_chunk))) { in check_leaf_chunk_item()
969 btrfs_item_size(leaf, slot), in check_leaf_chunk_item()
981 btrfs_item_size(leaf, slot))) { in check_leaf_chunk_item()
984 btrfs_item_size(leaf, slot), in check_leaf_chunk_item()
994 static void dev_item_err(const struct extent_buffer *eb, int slot, in dev_item_err() argument
1001 btrfs_item_key_to_cpu(eb, &key, slot); in dev_item_err()
1008 "corrupt %s: root=%llu block=%llu slot=%d devid=%llu %pV", in dev_item_err()
1010 btrfs_header_owner(eb), btrfs_header_bytenr(eb), slot, in dev_item_err()
1016 struct btrfs_key *key, int slot) in check_dev_item() argument
1019 const u32 item_size = btrfs_item_size(leaf, slot); in check_dev_item()
1022 dev_item_err(leaf, slot, in check_dev_item()
1029 dev_item_err(leaf, slot, "invalid item size: has %u expect %zu", in check_dev_item()
1034 ditem = btrfs_item_ptr(leaf, slot, struct btrfs_dev_item); in check_dev_item()
1036 dev_item_err(leaf, slot, in check_dev_item()
1049 dev_item_err(leaf, slot, in check_dev_item()
1063 struct btrfs_key *key, int slot) in check_inode_item() argument
1069 const u32 item_size = btrfs_item_size(leaf, slot); in check_inode_item()
1075 ret = check_inode_key(leaf, key, slot); in check_inode_item()
1080 generic_err(leaf, slot, "invalid item size: has %u expect %zu", in check_inode_item()
1085 iitem = btrfs_item_ptr(leaf, slot, struct btrfs_inode_item); in check_inode_item()
1089 inode_item_err(leaf, slot, in check_inode_item()
1097 inode_item_err(leaf, slot, in check_inode_item()
1110 inode_item_err(leaf, slot, in check_inode_item()
1123 inode_item_err(leaf, slot, in check_inode_item()
1130 inode_item_err(leaf, slot, in check_inode_item()
1137 inode_item_err(leaf, slot, in check_inode_item()
1143 inode_item_err(leaf, slot, in check_inode_item()
1152 int slot) in check_root_item() argument
1160 ret = check_root_key(leaf, key, slot); in check_root_item()
1164 if (unlikely(btrfs_item_size(leaf, slot) != sizeof(ri) && in check_root_item()
1165 btrfs_item_size(leaf, slot) != in check_root_item()
1167 generic_err(leaf, slot, in check_root_item()
1169 btrfs_item_size(leaf, slot), sizeof(ri), in check_root_item()
1179 read_extent_buffer(leaf, &ri, btrfs_item_ptr_offset(leaf, slot), in check_root_item()
1180 btrfs_item_size(leaf, slot)); in check_root_item()
1185 generic_err(leaf, slot, in check_root_item()
1193 generic_err(leaf, slot, in check_root_item()
1201 generic_err(leaf, slot, in check_root_item()
1210 generic_err(leaf, slot, in check_root_item()
1216 generic_err(leaf, slot, in check_root_item()
1222 generic_err(leaf, slot, in check_root_item()
1230 generic_err(leaf, slot, in check_root_item()
1240 static void extent_err(const struct extent_buffer *eb, int slot, in extent_err() argument
1249 btrfs_item_key_to_cpu(eb, &key, slot); in extent_err()
1263 "corrupt %s: block=%llu slot=%d extent bytenr=%llu len=%llu %pV", in extent_err()
1265 eb->start, slot, bytenr, len, &vaf); in extent_err()
1283 struct btrfs_key *key, int slot, in check_extent_item() argument
1291 const u32 item_size = btrfs_item_size(leaf, slot); in check_extent_item()
1301 generic_err(leaf, slot, in check_extent_item()
1307 generic_err(leaf, slot, in check_extent_item()
1316 extent_err(leaf, slot, in check_extent_item()
1354 extent_err(leaf, slot, in check_extent_item()
1360 end = item_size + btrfs_item_ptr_offset(leaf, slot); in check_extent_item()
1363 ei = btrfs_item_ptr(leaf, slot, struct btrfs_extent_item); in check_extent_item()
1369 extent_err(leaf, slot, in check_extent_item()
1377 extent_err(leaf, slot, in check_extent_item()
1387 extent_err(leaf, slot, in check_extent_item()
1394 extent_err(leaf, slot, in check_extent_item()
1400 extent_err(leaf, slot, in check_extent_item()
1406 extent_err(leaf, slot, in check_extent_item()
1419 extent_err(leaf, slot, in check_extent_item()
1441 extent_err(leaf, slot, in check_extent_item()
1451 extent_err(leaf, slot, in check_extent_item()
1466 extent_err(leaf, slot, in check_extent_item()
1487 extent_err(leaf, slot, in check_extent_item()
1494 extent_err(leaf, slot, in check_extent_item()
1501 extent_err(leaf, slot, in check_extent_item()
1507 extent_err(leaf, slot, in check_extent_item()
1518 extent_err(leaf, slot, in check_extent_item()
1524 extent_err(leaf, slot, in check_extent_item()
1531 extent_err(leaf, slot, "unknown inline ref type: %u", in check_extent_item()
1536 extent_err(leaf, slot, in check_extent_item()
1545 extent_err(leaf, slot, in check_extent_item()
1557 extent_err(leaf, slot, in check_extent_item()
1564 extent_err(leaf, slot, in check_extent_item()
1580 extent_err(leaf, slot, in check_extent_item()
1593 struct btrfs_key *key, int slot) in check_simple_keyed_refs() argument
1600 sref = btrfs_item_ptr(leaf, slot, struct btrfs_shared_data_ref); in check_simple_keyed_refs()
1602 extent_err(leaf, slot, in check_simple_keyed_refs()
1610 if (unlikely(btrfs_item_size(leaf, slot) != expect_item_size)) { in check_simple_keyed_refs()
1611 generic_err(leaf, slot, in check_simple_keyed_refs()
1613 btrfs_item_size(leaf, slot), in check_simple_keyed_refs()
1618 generic_err(leaf, slot, in check_simple_keyed_refs()
1625 extent_err(leaf, slot, in check_simple_keyed_refs()
1634 struct btrfs_key *key, int slot) in check_extent_data_ref() argument
1637 unsigned long ptr = btrfs_item_ptr_offset(leaf, slot); in check_extent_data_ref()
1638 const unsigned long end = ptr + btrfs_item_size(leaf, slot); in check_extent_data_ref()
1640 if (unlikely(btrfs_item_size(leaf, slot) % sizeof(*dref) != 0)) { in check_extent_data_ref()
1641 generic_err(leaf, slot, in check_extent_data_ref()
1643 btrfs_item_size(leaf, slot), in check_extent_data_ref()
1648 generic_err(leaf, slot, in check_extent_data_ref()
1667 extent_err(leaf, slot, in check_extent_data_ref()
1674 extent_err(leaf, slot, in check_extent_data_ref()
1680 extent_err(leaf, slot, in check_extent_data_ref()
1686 extent_err(leaf, slot, in check_extent_data_ref()
1694 #define inode_ref_err(eb, slot, fmt, args...) \ argument
1695 inode_item_err(eb, slot, fmt, ##args)
1698 int slot) in check_inode_ref() argument
1704 if (unlikely(!check_prev_ino(leaf, key, slot, prev_key))) in check_inode_ref()
1707 if (unlikely(btrfs_item_size(leaf, slot) <= sizeof(*iref))) { in check_inode_ref()
1708 inode_ref_err(leaf, slot, in check_inode_ref()
1710 btrfs_item_size(leaf, slot), in check_inode_ref()
1715 ptr = btrfs_item_ptr_offset(leaf, slot); in check_inode_ref()
1716 end = ptr + btrfs_item_size(leaf, slot); in check_inode_ref()
1721 inode_ref_err(leaf, slot, in check_inode_ref()
1730 inode_ref_err(leaf, slot, in check_inode_ref()
1748 int slot, in check_dev_extent_item() argument
1754 de = btrfs_item_ptr(leaf, slot, struct btrfs_dev_extent); in check_dev_extent_item()
1758 generic_err(leaf, slot, in check_dev_extent_item()
1766 generic_err(leaf, slot, in check_dev_extent_item()
1774 generic_err(leaf, slot, in check_dev_extent_item()
1781 generic_err(leaf, slot, in check_dev_extent_item()
1789 generic_err(leaf, slot, in check_dev_extent_item()
1795 if (slot && prev_key->objectid == key->objectid && in check_dev_extent_item()
1800 prev_de = btrfs_item_ptr(leaf, slot - 1, struct btrfs_dev_extent); in check_dev_extent_item()
1803 generic_err(leaf, slot, in check_dev_extent_item()
1817 int slot, in check_leaf_item() argument
1825 ret = check_extent_data_item(leaf, key, slot, prev_key); in check_leaf_item()
1828 ret = check_csum_item(leaf, key, slot, prev_key); in check_leaf_item()
1833 ret = check_dir_item(leaf, key, prev_key, slot); in check_leaf_item()
1836 ret = check_inode_ref(leaf, key, prev_key, slot); in check_leaf_item()
1839 ret = check_block_group_item(leaf, key, slot); in check_leaf_item()
1842 chunk = btrfs_item_ptr(leaf, slot, struct btrfs_chunk); in check_leaf_item()
1843 ret = check_leaf_chunk_item(leaf, chunk, key, slot); in check_leaf_item()
1846 ret = check_dev_item(leaf, key, slot); in check_leaf_item()
1849 ret = check_dev_extent_item(leaf, key, slot, prev_key); in check_leaf_item()
1852 ret = check_inode_item(leaf, key, slot); in check_leaf_item()
1855 ret = check_root_item(leaf, key, slot); in check_leaf_item()
1859 ret = check_extent_item(leaf, key, slot, prev_key); in check_leaf_item()
1864 ret = check_simple_keyed_refs(leaf, key, slot); in check_leaf_item()
1867 ret = check_extent_data_ref(leaf, key, slot); in check_leaf_item()
1883 int slot; in __btrfs_check_leaf() local
1950 for (slot = 0; slot < nritems; slot++) { in __btrfs_check_leaf()
1954 btrfs_item_key_to_cpu(leaf, &key, slot); in __btrfs_check_leaf()
1958 generic_err(leaf, slot, in __btrfs_check_leaf()
1966 item_data_end = (u64)btrfs_item_offset(leaf, slot) + in __btrfs_check_leaf()
1967 btrfs_item_size(leaf, slot); in __btrfs_check_leaf()
1973 if (slot == 0) in __btrfs_check_leaf()
1977 slot - 1); in __btrfs_check_leaf()
1979 generic_err(leaf, slot, in __btrfs_check_leaf()
1991 generic_err(leaf, slot, in __btrfs_check_leaf()
1992 "slot end outside of leaf, have %llu expect range [0, %u]", in __btrfs_check_leaf()
1998 if (unlikely(btrfs_item_ptr_offset(leaf, slot) < in __btrfs_check_leaf()
1999 btrfs_item_nr_offset(leaf, slot) + sizeof(struct btrfs_item))) { in __btrfs_check_leaf()
2000 generic_err(leaf, slot, in __btrfs_check_leaf()
2001 "slot overlaps with its data, item end %lu data start %lu", in __btrfs_check_leaf()
2002 btrfs_item_nr_offset(leaf, slot) + in __btrfs_check_leaf()
2004 btrfs_item_ptr_offset(leaf, slot)); in __btrfs_check_leaf()
2019 ret = check_leaf_item(leaf, &key, slot, &prev_key); in __btrfs_check_leaf()
2048 int slot; in __btrfs_check_node() local
2067 for (slot = 0; slot < nr - 1; slot++) { in __btrfs_check_node()
2068 bytenr = btrfs_node_blockptr(node, slot); in __btrfs_check_node()
2069 btrfs_node_key_to_cpu(node, &key, slot); in __btrfs_check_node()
2070 btrfs_node_key_to_cpu(node, &next_key, slot + 1); in __btrfs_check_node()
2073 generic_err(node, slot, in __btrfs_check_node()
2078 generic_err(node, slot, in __btrfs_check_node()
2085 generic_err(node, slot, in __btrfs_check_node()