mirror of
https://github.com/torvalds/linux.git
synced 2026-03-08 04:04:43 +01:00
Merge patch series "Introduce tracepoint for hugetlbfs"
Hongbo Li <lihongbo22@huawei.com> says:
Add some basic tracepoints for debugging hugetlbfs: {alloc, free,
evict}_inode, setattr and fallocate.
* patches from https://lore.kernel.org/r/20240829064110.67884-1-lihongbo22@huawei.com:
hugetlbfs: use tracepoints in hugetlbfs functions.
hugetlbfs: support tracepoint
Link: https://lore.kernel.org/r/20240829064110.67884-1-lihongbo22@huawei.com
Signed-off-by: Christian Brauner <brauner@kernel.org>
This commit is contained in:
commit
2b2b1a20db
3 changed files with 172 additions and 2 deletions
|
|
@ -10517,6 +10517,7 @@ F: Documentation/mm/hugetlbfs_reserv.rst
|
|||
F: Documentation/mm/vmemmap_dedup.rst
|
||||
F: fs/hugetlbfs/
|
||||
F: include/linux/hugetlb.h
|
||||
F: include/trace/events/hugetlbfs.h
|
||||
F: mm/hugetlb.c
|
||||
F: mm/hugetlb_vmemmap.c
|
||||
F: mm/hugetlb_vmemmap.h
|
||||
|
|
|
|||
|
|
@ -39,6 +39,9 @@
|
|||
#include <linux/uaccess.h>
|
||||
#include <linux/sched/mm.h>
|
||||
|
||||
#define CREATE_TRACE_POINTS
|
||||
#include <trace/events/hugetlbfs.h>
|
||||
|
||||
static const struct address_space_operations hugetlbfs_aops;
|
||||
static const struct file_operations hugetlbfs_file_operations;
|
||||
static const struct inode_operations hugetlbfs_dir_inode_operations;
|
||||
|
|
@ -687,6 +690,7 @@ static void hugetlbfs_evict_inode(struct inode *inode)
|
|||
{
|
||||
struct resv_map *resv_map;
|
||||
|
||||
trace_hugetlbfs_evict_inode(inode);
|
||||
remove_inode_hugepages(inode, 0, LLONG_MAX);
|
||||
|
||||
/*
|
||||
|
|
@ -814,8 +818,10 @@ static long hugetlbfs_fallocate(struct file *file, int mode, loff_t offset,
|
|||
if (mode & ~(FALLOC_FL_KEEP_SIZE | FALLOC_FL_PUNCH_HOLE))
|
||||
return -EOPNOTSUPP;
|
||||
|
||||
if (mode & FALLOC_FL_PUNCH_HOLE)
|
||||
return hugetlbfs_punch_hole(inode, offset, len);
|
||||
if (mode & FALLOC_FL_PUNCH_HOLE) {
|
||||
error = hugetlbfs_punch_hole(inode, offset, len);
|
||||
goto out_nolock;
|
||||
}
|
||||
|
||||
/*
|
||||
* Default preallocate case.
|
||||
|
|
@ -919,6 +925,9 @@ static long hugetlbfs_fallocate(struct file *file, int mode, loff_t offset,
|
|||
inode_set_ctime_current(inode);
|
||||
out:
|
||||
inode_unlock(inode);
|
||||
|
||||
out_nolock:
|
||||
trace_hugetlbfs_fallocate(inode, mode, offset, len, error);
|
||||
return error;
|
||||
}
|
||||
|
||||
|
|
@ -935,6 +944,8 @@ static int hugetlbfs_setattr(struct mnt_idmap *idmap,
|
|||
if (error)
|
||||
return error;
|
||||
|
||||
trace_hugetlbfs_setattr(inode, dentry, attr);
|
||||
|
||||
if (ia_valid & ATTR_SIZE) {
|
||||
loff_t oldsize = inode->i_size;
|
||||
loff_t newsize = attr->ia_size;
|
||||
|
|
@ -1033,6 +1044,7 @@ static struct inode *hugetlbfs_get_inode(struct super_block *sb,
|
|||
break;
|
||||
}
|
||||
lockdep_annotate_inode_mutex_key(inode);
|
||||
trace_hugetlbfs_alloc_inode(inode, dir, mode);
|
||||
} else {
|
||||
if (resv_map)
|
||||
kref_put(&resv_map->refs, resv_map_release);
|
||||
|
|
@ -1272,6 +1284,7 @@ static struct inode *hugetlbfs_alloc_inode(struct super_block *sb)
|
|||
|
||||
static void hugetlbfs_free_inode(struct inode *inode)
|
||||
{
|
||||
trace_hugetlbfs_free_inode(inode);
|
||||
kmem_cache_free(hugetlbfs_inode_cachep, HUGETLBFS_I(inode));
|
||||
}
|
||||
|
||||
|
|
|
|||
156
include/trace/events/hugetlbfs.h
Normal file
156
include/trace/events/hugetlbfs.h
Normal file
|
|
@ -0,0 +1,156 @@
|
|||
/* SPDX-License-Identifier: GPL-2.0 */
|
||||
#undef TRACE_SYSTEM
|
||||
#define TRACE_SYSTEM hugetlbfs
|
||||
|
||||
#if !defined(_TRACE_HUGETLBFS_H) || defined(TRACE_HEADER_MULTI_READ)
|
||||
#define _TRACE_HUGETLBFS_H
|
||||
|
||||
#include <linux/tracepoint.h>
|
||||
|
||||
TRACE_EVENT(hugetlbfs_alloc_inode,
|
||||
|
||||
TP_PROTO(struct inode *inode, struct inode *dir, int mode),
|
||||
|
||||
TP_ARGS(inode, dir, mode),
|
||||
|
||||
TP_STRUCT__entry(
|
||||
__field(dev_t, dev)
|
||||
__field(ino_t, ino)
|
||||
__field(ino_t, dir)
|
||||
__field(__u16, mode)
|
||||
),
|
||||
|
||||
TP_fast_assign(
|
||||
__entry->dev = inode->i_sb->s_dev;
|
||||
__entry->ino = inode->i_ino;
|
||||
__entry->dir = dir->i_ino;
|
||||
__entry->mode = mode;
|
||||
),
|
||||
|
||||
TP_printk("dev %d,%d ino %lu dir %lu mode 0%o",
|
||||
MAJOR(__entry->dev), MINOR(__entry->dev),
|
||||
(unsigned long) __entry->ino,
|
||||
(unsigned long) __entry->dir, __entry->mode)
|
||||
);
|
||||
|
||||
DECLARE_EVENT_CLASS(hugetlbfs__inode,
|
||||
|
||||
TP_PROTO(struct inode *inode),
|
||||
|
||||
TP_ARGS(inode),
|
||||
|
||||
TP_STRUCT__entry(
|
||||
__field(dev_t, dev)
|
||||
__field(ino_t, ino)
|
||||
__field(__u16, mode)
|
||||
__field(loff_t, size)
|
||||
__field(unsigned int, nlink)
|
||||
__field(unsigned int, seals)
|
||||
__field(blkcnt_t, blocks)
|
||||
),
|
||||
|
||||
TP_fast_assign(
|
||||
__entry->dev = inode->i_sb->s_dev;
|
||||
__entry->ino = inode->i_ino;
|
||||
__entry->mode = inode->i_mode;
|
||||
__entry->size = inode->i_size;
|
||||
__entry->nlink = inode->i_nlink;
|
||||
__entry->seals = HUGETLBFS_I(inode)->seals;
|
||||
__entry->blocks = inode->i_blocks;
|
||||
),
|
||||
|
||||
TP_printk("dev %d,%d ino %lu mode 0%o size %lld nlink %u seals %u blocks %llu",
|
||||
MAJOR(__entry->dev), MINOR(__entry->dev), (unsigned long) __entry->ino,
|
||||
__entry->mode, __entry->size, __entry->nlink, __entry->seals,
|
||||
(unsigned long long)__entry->blocks)
|
||||
);
|
||||
|
||||
DEFINE_EVENT(hugetlbfs__inode, hugetlbfs_evict_inode,
|
||||
|
||||
TP_PROTO(struct inode *inode),
|
||||
|
||||
TP_ARGS(inode)
|
||||
);
|
||||
|
||||
DEFINE_EVENT(hugetlbfs__inode, hugetlbfs_free_inode,
|
||||
|
||||
TP_PROTO(struct inode *inode),
|
||||
|
||||
TP_ARGS(inode)
|
||||
);
|
||||
|
||||
TRACE_EVENT(hugetlbfs_setattr,
|
||||
|
||||
TP_PROTO(struct inode *inode, struct dentry *dentry,
|
||||
struct iattr *attr),
|
||||
|
||||
TP_ARGS(inode, dentry, attr),
|
||||
|
||||
TP_STRUCT__entry(
|
||||
__field(dev_t, dev)
|
||||
__field(ino_t, ino)
|
||||
__field(unsigned int, d_len)
|
||||
__string(d_name, dentry->d_name.name)
|
||||
__field(unsigned int, ia_valid)
|
||||
__field(unsigned int, ia_mode)
|
||||
__field(loff_t, old_size)
|
||||
__field(loff_t, ia_size)
|
||||
),
|
||||
|
||||
TP_fast_assign(
|
||||
__entry->dev = inode->i_sb->s_dev;
|
||||
__entry->ino = inode->i_ino;
|
||||
__entry->d_len = dentry->d_name.len;
|
||||
__assign_str(d_name);
|
||||
__entry->ia_valid = attr->ia_valid;
|
||||
__entry->ia_mode = attr->ia_mode;
|
||||
__entry->old_size = inode->i_size;
|
||||
__entry->ia_size = attr->ia_size;
|
||||
),
|
||||
|
||||
TP_printk("dev %d,%d ino %lu name %.*s valid %#x mode 0%o old_size %lld size %lld",
|
||||
MAJOR(__entry->dev), MINOR(__entry->dev), (unsigned long)__entry->ino,
|
||||
__entry->d_len, __get_str(d_name), __entry->ia_valid, __entry->ia_mode,
|
||||
__entry->old_size, __entry->ia_size)
|
||||
);
|
||||
|
||||
TRACE_EVENT(hugetlbfs_fallocate,
|
||||
|
||||
TP_PROTO(struct inode *inode, int mode,
|
||||
loff_t offset, loff_t len, int ret),
|
||||
|
||||
TP_ARGS(inode, mode, offset, len, ret),
|
||||
|
||||
TP_STRUCT__entry(
|
||||
__field(dev_t, dev)
|
||||
__field(ino_t, ino)
|
||||
__field(int, mode)
|
||||
__field(loff_t, offset)
|
||||
__field(loff_t, len)
|
||||
__field(loff_t, size)
|
||||
__field(int, ret)
|
||||
),
|
||||
|
||||
TP_fast_assign(
|
||||
__entry->dev = inode->i_sb->s_dev;
|
||||
__entry->ino = inode->i_ino;
|
||||
__entry->mode = mode;
|
||||
__entry->offset = offset;
|
||||
__entry->len = len;
|
||||
__entry->size = inode->i_size;
|
||||
__entry->ret = ret;
|
||||
),
|
||||
|
||||
TP_printk("dev %d,%d ino %lu mode 0%o offset %lld len %lld size %lld ret %d",
|
||||
MAJOR(__entry->dev), MINOR(__entry->dev),
|
||||
(unsigned long)__entry->ino, __entry->mode,
|
||||
(unsigned long long)__entry->offset,
|
||||
(unsigned long long)__entry->len,
|
||||
(unsigned long long)__entry->size,
|
||||
__entry->ret)
|
||||
);
|
||||
|
||||
#endif /* _TRACE_HUGETLBFS_H */
|
||||
|
||||
/* This part must be outside protection */
|
||||
#include <trace/define_trace.h>
|
||||
Loading…
Add table
Add a link
Reference in a new issue