[lttng-dev] [PATCH lttng-modules v2] Fix: writeback probe on RHEL >= 3.10.0-327.10.1
Mathieu Desnoyers
mathieu.desnoyers at efficios.com
Thu Apr 21 21:42:47 UTC 2016
Merged into master, 2.7 and 2.8, thanks!
Mathieu
----- On Apr 21, 2016, at 4:11 PM, Michael Jeanson mjeanson at efficios.com wrote:
> Signed-off-by: Michael Jeanson <mjeanson at efficios.com>
> ---
> instrumentation/events/lttng-module/writeback.h | 37 ++++++++++++++++++-------
> 1 file changed, 27 insertions(+), 10 deletions(-)
>
> diff --git a/instrumentation/events/lttng-module/writeback.h
> b/instrumentation/events/lttng-module/writeback.h
> index a215f55..6006c29 100644
> --- a/instrumentation/events/lttng-module/writeback.h
> +++ b/instrumentation/events/lttng-module/writeback.h
> @@ -13,17 +13,34 @@
> #ifndef _TRACE_WRITEBACK_DEF_
> #define _TRACE_WRITEBACK_DEF_
>
> -#if (LINUX_VERSION_CODE < KERNEL_VERSION(4,0,0) && \
> - LTTNG_RHEL_VERSION_CODE < LTTNG_RHEL_KERNEL_VERSION(3,10,0,327,10,1))
> -static inline struct backing_dev_info *inode_to_bdi(struct inode *inode)
> +/*
> + * Vanilla kernels before 4.0 do not implement inode_to_bdi
> + * RHEL kernels before 3.10.0-327.10.1 do not implement inode_to_bdi
> + * RHEL kernel 3.10.0-327.10.1 has inode_to_bdi
> + * RHEL kernel 3.10.0-327.13.1 includes a partial merge of upstream
> + * commit a212b105b07d75b48b1a166378282e8a77fbf53d which inlines
> + * inode_to_bdi but not sb_is_blkdev_sb making it unusable by modules.
> + */
> +#if (LINUX_VERSION_CODE < KERNEL_VERSION(4,0,0))
> +static inline struct backing_dev_info *lttng_inode_to_bdi(struct inode *inode)
> {
> - struct super_block *sb = inode->i_sb;
> + struct super_block *sb;
> +
> + if (!inode)
> + return &noop_backing_dev_info;
> +
> + sb = inode->i_sb;
>
> if (strcmp(sb->s_type->name, "bdev") == 0)
> return inode->i_mapping->backing_dev_info;
>
> return sb->s_bdi;
> }
> +#else
> +static inline struct backing_dev_info *lttng_inode_to_bdi(struct inode *inode)
> +{
> + return inode_to_bdi(inode);
> +}
> #endif /* #if (LINUX_VERSION_CODE < KERNEL_VERSION(4,0,0)) */
>
> #endif
> @@ -65,7 +82,7 @@ LTTNG_TRACEPOINT_EVENT(writeback_dirty_page,
> TP_ARGS(page, mapping),
> TP_FIELDS(
> ctf_array_text(char, name,
> - mapping ? dev_name(inode_to_bdi(mapping->host)->dev) : "(unknown)", 32)
> + mapping ? dev_name(lttng_inode_to_bdi(mapping->host)->dev) : "(unknown)",
> 32)
> ctf_integer(unsigned long, ino, mapping ? mapping->host->i_ino : 0)
> ctf_integer(pgoff_t, index, page->index)
> )
> @@ -77,8 +94,8 @@ LTTNG_TRACEPOINT_EVENT_CLASS(writeback_dirty_inode_template,
> TP_FIELDS(
> /* may be called for files on pseudo FSes w/ unregistered bdi */
> ctf_array_text(char, name,
> - inode_to_bdi(inode)->dev ?
> - dev_name(inode_to_bdi(inode)->dev) : "(unknown)", 32)
> + lttng_inode_to_bdi(inode)->dev ?
> + dev_name(lttng_inode_to_bdi(inode)->dev) : "(unknown)", 32)
> ctf_integer(unsigned long, ino, inode->i_ino)
> ctf_integer(unsigned long, state, inode->i_state)
> ctf_integer(unsigned long, flags, flags)
> @@ -97,7 +114,7 @@ LTTNG_TRACEPOINT_EVENT_CLASS(writeback_write_inode_template,
> TP_ARGS(inode, wbc),
> TP_FIELDS(
> ctf_array_text(char, name,
> - dev_name(inode_to_bdi(inode)->dev), 32)
> + dev_name(lttng_inode_to_bdi(inode)->dev), 32)
> ctf_integer(unsigned long, ino, inode->i_ino)
> ctf_integer(int, sync_mode, wbc->sync_mode)
> )
> @@ -609,7 +626,7 @@ LTTNG_TRACEPOINT_EVENT(writeback_sb_inodes_requeue,
>
> TP_FIELDS(
> ctf_array_text(char, name,
> - dev_name(inode_to_bdi(inode)->dev), 32)
> + dev_name(lttng_inode_to_bdi(inode)->dev), 32)
> ctf_integer(unsigned long, ino, inode->i_ino)
> ctf_integer(unsigned long, state, inode->i_state)
> ctf_integer(unsigned long, dirtied_when, inode->dirtied_when)
> @@ -657,7 +674,7 @@
> LTTNG_TRACEPOINT_EVENT_CLASS(writeback_single_inode_template,
>
> TP_FIELDS(
> ctf_array_text(char, name,
> - dev_name(inode_to_bdi(inode)->dev), 32)
> + dev_name(lttng_inode_to_bdi(inode)->dev), 32)
> ctf_integer(unsigned long, ino, inode->i_ino)
> ctf_integer(unsigned long, state, inode->i_state)
> ctf_integer(unsigned long, dirtied_when, inode->dirtied_when)
> --
> 2.7.4
--
Mathieu Desnoyers
EfficiOS Inc.
http://www.efficios.com
More information about the lttng-dev
mailing list