Commit ad1ac501 authored by Josef Bacik's avatar Josef Bacik Committed by David Sterba

btrfs: move btrfs_map_token to accessors

This is specific to the item-accessor code, move it out of ctree.h into
accessor.h/.c and then update the users to include the new header file.
This un-inlines btrfs_init_map_token, however this is only called once
per function so it's not critical to be inlined.  This also saves 904
bytes of code on a release build.
Reviewed-by: default avatarJohannes Thumshirn <johannes.thumshirn@wdc.com>
Reviewed-by: default avatarAnand Jain <anand.jain@oracle.com>
Signed-off-by: default avatarJosef Bacik <josef@toxicpanda.com>
Reviewed-by: default avatarDavid Sterba <dsterba@suse.com>
Signed-off-by: default avatarDavid Sterba <dsterba@suse.com>
parent 818fe33a
...@@ -6,6 +6,7 @@ ...@@ -6,6 +6,7 @@
#include <asm/unaligned.h> #include <asm/unaligned.h>
#include "messages.h" #include "messages.h"
#include "ctree.h" #include "ctree.h"
#include "accessors.h"
static bool check_setget_bounds(const struct extent_buffer *eb, static bool check_setget_bounds(const struct extent_buffer *eb,
const void *ptr, unsigned off, int size) const void *ptr, unsigned off, int size)
...@@ -23,6 +24,13 @@ static bool check_setget_bounds(const struct extent_buffer *eb, ...@@ -23,6 +24,13 @@ static bool check_setget_bounds(const struct extent_buffer *eb,
return true; return true;
} }
void btrfs_init_map_token(struct btrfs_map_token *token, struct extent_buffer *eb)
{
token->eb = eb;
token->kaddr = page_address(eb->pages[0]);
token->offset = 0;
}
/* /*
* Macro templates that define helpers to read/write extent buffer data of a * Macro templates that define helpers to read/write extent buffer data of a
* given size, that are also used via ctree.h for access to item members by * given size, that are also used via ctree.h for access to item members by
......
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef BTRFS_ACCESSORS_H
#define BTRFS_ACCESSORS_H
struct btrfs_map_token {
struct extent_buffer *eb;
char *kaddr;
unsigned long offset;
};
void btrfs_init_map_token(struct btrfs_map_token *token, struct extent_buffer *eb);
#endif
...@@ -19,6 +19,7 @@ ...@@ -19,6 +19,7 @@
#include "tree-mod-log.h" #include "tree-mod-log.h"
#include "tree-checker.h" #include "tree-checker.h"
#include "fs.h" #include "fs.h"
#include "accessors.h"
static struct kmem_cache *btrfs_path_cachep; static struct kmem_cache *btrfs_path_cachep;
......
...@@ -52,6 +52,8 @@ struct btrfs_balance_control; ...@@ -52,6 +52,8 @@ struct btrfs_balance_control;
struct btrfs_delayed_root; struct btrfs_delayed_root;
struct reloc_control; struct reloc_control;
struct btrfs_map_token;
#define BTRFS_OLDEST_GENERATION 0ULL #define BTRFS_OLDEST_GENERATION 0ULL
#define BTRFS_EMPTY_DIR_SIZE 0 #define BTRFS_EMPTY_DIR_SIZE 0
...@@ -1199,23 +1201,9 @@ static inline u32 BTRFS_MAX_XATTR_SIZE(const struct btrfs_fs_info *info) ...@@ -1199,23 +1201,9 @@ static inline u32 BTRFS_MAX_XATTR_SIZE(const struct btrfs_fs_info *info)
return BTRFS_MAX_ITEM_SIZE(info) - sizeof(struct btrfs_dir_item); return BTRFS_MAX_ITEM_SIZE(info) - sizeof(struct btrfs_dir_item);
} }
struct btrfs_map_token {
struct extent_buffer *eb;
char *kaddr;
unsigned long offset;
};
#define BTRFS_BYTES_TO_BLKS(fs_info, bytes) \ #define BTRFS_BYTES_TO_BLKS(fs_info, bytes) \
((bytes) >> (fs_info)->sectorsize_bits) ((bytes) >> (fs_info)->sectorsize_bits)
static inline void btrfs_init_map_token(struct btrfs_map_token *token,
struct extent_buffer *eb)
{
token->eb = eb;
token->kaddr = page_address(eb->pages[0]);
token->offset = 0;
}
/* some macros to generate set/get functions for the struct fields. This /* some macros to generate set/get functions for the struct fields. This
* assumes there is a lefoo_to_cpu for every type, so lets make a simple * assumes there is a lefoo_to_cpu for every type, so lets make a simple
* one for u8: * one for u8:
......
...@@ -56,6 +56,7 @@ ...@@ -56,6 +56,7 @@
#include "subpage.h" #include "subpage.h"
#include "inode-item.h" #include "inode-item.h"
#include "fs.h" #include "fs.h"
#include "accessors.h"
struct btrfs_iget_args { struct btrfs_iget_args {
u64 ino; u64 ino;
......
...@@ -22,6 +22,7 @@ ...@@ -22,6 +22,7 @@
#include "zoned.h" #include "zoned.h"
#include "inode-item.h" #include "inode-item.h"
#include "fs.h" #include "fs.h"
#include "accessors.h"
#define MAX_CONFLICT_INODES 10 #define MAX_CONFLICT_INODES 10
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment