diff options
| -rw-r--r-- | block/blk-core.c | 16 | ||||
| -rw-r--r-- | block/elevator.c | 8 | ||||
| -rw-r--r-- | drivers/md/dm.c | 5 | ||||
| -rw-r--r-- | fs/bio.c | 3 | ||||
| -rw-r--r-- | include/linux/blktrace_api.h | 13 | ||||
| -rw-r--r-- | include/trace/block.h | 76 | ||||
| -rw-r--r-- | include/trace/events/block.h | 483 | ||||
| -rw-r--r-- | kernel/trace/Makefile | 5 | ||||
| -rw-r--r-- | kernel/trace/blktrace.c | 78 | ||||
| -rw-r--r-- | mm/bounce.c | 5 | 
10 files changed, 588 insertions, 104 deletions
diff --git a/block/blk-core.c b/block/blk-core.c index 1306de9cce0..9475bf99b89 100644 --- a/block/blk-core.c +++ b/block/blk-core.c @@ -28,22 +28,14 @@  #include <linux/task_io_accounting_ops.h>  #include <linux/blktrace_api.h>  #include <linux/fault-inject.h> -#include <trace/block.h> + +#define CREATE_TRACE_POINTS +#include <trace/events/block.h>  #include "blk.h" -DEFINE_TRACE(block_plug); -DEFINE_TRACE(block_unplug_io); -DEFINE_TRACE(block_unplug_timer); -DEFINE_TRACE(block_getrq); -DEFINE_TRACE(block_sleeprq); -DEFINE_TRACE(block_rq_requeue); -DEFINE_TRACE(block_bio_backmerge); -DEFINE_TRACE(block_bio_frontmerge); -DEFINE_TRACE(block_bio_queue); -DEFINE_TRACE(block_rq_complete); -DEFINE_TRACE(block_remap);	/* Also used in drivers/md/dm.c */  EXPORT_TRACEPOINT_SYMBOL_GPL(block_remap); +EXPORT_TRACEPOINT_SYMBOL_GPL(block_bio_complete);  static int __make_request(struct request_queue *q, struct bio *bio); diff --git a/block/elevator.c b/block/elevator.c index 7073a907257..e220f0c543e 100644 --- a/block/elevator.c +++ b/block/elevator.c @@ -33,17 +33,16 @@  #include <linux/compiler.h>  #include <linux/delay.h>  #include <linux/blktrace_api.h> -#include <trace/block.h>  #include <linux/hash.h>  #include <linux/uaccess.h> +#include <trace/events/block.h> +  #include "blk.h"  static DEFINE_SPINLOCK(elv_list_lock);  static LIST_HEAD(elv_list); -DEFINE_TRACE(block_rq_abort); -  /*   * Merge hash stuff.   */ @@ -55,9 +54,6 @@ static const int elv_hash_shift = 6;  #define rq_hash_key(rq)		((rq)->sector + (rq)->nr_sectors)  #define ELV_ON_HASH(rq)		(!hlist_unhashed(&(rq)->hash)) -DEFINE_TRACE(block_rq_insert); -DEFINE_TRACE(block_rq_issue); -  /*   * Query io scheduler to see if the current process issuing bio may be   * merged with rq. diff --git a/drivers/md/dm.c b/drivers/md/dm.c index e2ee4a79ea2..3fd8b1e6548 100644 --- a/drivers/md/dm.c +++ b/drivers/md/dm.c @@ -20,7 +20,8 @@  #include <linux/idr.h>  #include <linux/hdreg.h>  #include <linux/blktrace_api.h> -#include <trace/block.h> + +#include <trace/events/block.h>  #define DM_MSG_PREFIX "core" @@ -53,8 +54,6 @@ struct dm_target_io {  	union map_info info;  }; -DEFINE_TRACE(block_bio_complete); -  /*   * For request-based dm.   * One of these is allocated per request. @@ -26,10 +26,9 @@  #include <linux/mempool.h>  #include <linux/workqueue.h>  #include <linux/blktrace_api.h> -#include <trace/block.h>  #include <scsi/sg.h>		/* for struct sg_iovec */ -DEFINE_TRACE(block_split); +#include <trace/events/block.h>  /*   * Test patch to inline a certain number of bi_io_vec's inside the bio diff --git a/include/linux/blktrace_api.h b/include/linux/blktrace_api.h index 82b4636030e..c7ec31dd04c 100644 --- a/include/linux/blktrace_api.h +++ b/include/linux/blktrace_api.h @@ -218,5 +218,18 @@ static inline int blk_trace_init_sysfs(struct device *dev)  #endif /* CONFIG_BLK_DEV_IO_TRACE */ +#ifdef CONFIG_EVENT_TRACING + +static inline int blk_cmd_buf_len(struct request *rq) +{ +	return blk_pc_request(rq) ? rq->cmd_len * 3 : 1; +} + +extern void blk_dump_cmd(char *buf, struct request *rq); +extern void blk_fill_rwbs(char *rwbs, u32 rw, int bytes); +extern void blk_fill_rwbs_rq(char *rwbs, struct request *rq); + +#endif /* CONFIG_EVENT_TRACING */ +  #endif /* __KERNEL__ */  #endif diff --git a/include/trace/block.h b/include/trace/block.h deleted file mode 100644 index 5b12efa096b..00000000000 --- a/include/trace/block.h +++ /dev/null @@ -1,76 +0,0 @@ -#ifndef _TRACE_BLOCK_H -#define _TRACE_BLOCK_H - -#include <linux/blkdev.h> -#include <linux/tracepoint.h> - -DECLARE_TRACE(block_rq_abort, -	TP_PROTO(struct request_queue *q, struct request *rq), -	      TP_ARGS(q, rq)); - -DECLARE_TRACE(block_rq_insert, -	TP_PROTO(struct request_queue *q, struct request *rq), -	      TP_ARGS(q, rq)); - -DECLARE_TRACE(block_rq_issue, -	TP_PROTO(struct request_queue *q, struct request *rq), -	      TP_ARGS(q, rq)); - -DECLARE_TRACE(block_rq_requeue, -	TP_PROTO(struct request_queue *q, struct request *rq), -	      TP_ARGS(q, rq)); - -DECLARE_TRACE(block_rq_complete, -	TP_PROTO(struct request_queue *q, struct request *rq), -	      TP_ARGS(q, rq)); - -DECLARE_TRACE(block_bio_bounce, -	TP_PROTO(struct request_queue *q, struct bio *bio), -	      TP_ARGS(q, bio)); - -DECLARE_TRACE(block_bio_complete, -	TP_PROTO(struct request_queue *q, struct bio *bio), -	      TP_ARGS(q, bio)); - -DECLARE_TRACE(block_bio_backmerge, -	TP_PROTO(struct request_queue *q, struct bio *bio), -	      TP_ARGS(q, bio)); - -DECLARE_TRACE(block_bio_frontmerge, -	TP_PROTO(struct request_queue *q, struct bio *bio), -	      TP_ARGS(q, bio)); - -DECLARE_TRACE(block_bio_queue, -	TP_PROTO(struct request_queue *q, struct bio *bio), -	      TP_ARGS(q, bio)); - -DECLARE_TRACE(block_getrq, -	TP_PROTO(struct request_queue *q, struct bio *bio, int rw), -	      TP_ARGS(q, bio, rw)); - -DECLARE_TRACE(block_sleeprq, -	TP_PROTO(struct request_queue *q, struct bio *bio, int rw), -	      TP_ARGS(q, bio, rw)); - -DECLARE_TRACE(block_plug, -	TP_PROTO(struct request_queue *q), -	      TP_ARGS(q)); - -DECLARE_TRACE(block_unplug_timer, -	TP_PROTO(struct request_queue *q), -	      TP_ARGS(q)); - -DECLARE_TRACE(block_unplug_io, -	TP_PROTO(struct request_queue *q), -	      TP_ARGS(q)); - -DECLARE_TRACE(block_split, -	TP_PROTO(struct request_queue *q, struct bio *bio, unsigned int pdu), -	      TP_ARGS(q, bio, pdu)); - -DECLARE_TRACE(block_remap, -	TP_PROTO(struct request_queue *q, struct bio *bio, dev_t dev, -		 sector_t from), -	      TP_ARGS(q, bio, dev, from)); - -#endif diff --git a/include/trace/events/block.h b/include/trace/events/block.h new file mode 100644 index 00000000000..a99d1e565bb --- /dev/null +++ b/include/trace/events/block.h @@ -0,0 +1,483 @@ +#if !defined(_TRACE_BLOCK_H) || defined(TRACE_HEADER_MULTI_READ) +#define _TRACE_BLOCK_H + +#include <linux/blktrace_api.h> +#include <linux/blkdev.h> +#include <linux/tracepoint.h> + +#undef TRACE_SYSTEM +#define TRACE_SYSTEM block + +TRACE_EVENT(block_rq_abort, + +	TP_PROTO(struct request_queue *q, struct request *rq), + +	TP_ARGS(q, rq), + +	TP_STRUCT__entry( +		__field(  dev_t,	dev			) +		__field(  sector_t,	sector			) +		__field(  unsigned int,	nr_sector		) +		__field(  int,		errors			) +		__array(  char,		rwbs,	6		) +		__dynamic_array( char,	cmd,	blk_cmd_buf_len(rq)	) +	), + +	TP_fast_assign( +		__entry->dev	   = rq->rq_disk ? disk_devt(rq->rq_disk) : 0; +		__entry->sector    = blk_pc_request(rq) ? 0 : rq->hard_sector; +		__entry->nr_sector = blk_pc_request(rq) ? +						0 : rq->hard_nr_sectors; +		__entry->errors    = rq->errors; + +		blk_fill_rwbs_rq(__entry->rwbs, rq); +		blk_dump_cmd(__get_str(cmd), rq); +	), + +	TP_printk("%d,%d %s (%s) %llu + %u [%d]", +		  MAJOR(__entry->dev), MINOR(__entry->dev), +		  __entry->rwbs, __get_str(cmd), +		  __entry->sector, __entry->nr_sector, __entry->errors) +); + +TRACE_EVENT(block_rq_insert, + +	TP_PROTO(struct request_queue *q, struct request *rq), + +	TP_ARGS(q, rq), + +	TP_STRUCT__entry( +		__field(  dev_t,	dev			) +		__field(  sector_t,	sector			) +		__field(  unsigned int,	nr_sector		) +		__field(  unsigned int,	bytes			) +		__array(  char,		rwbs,	6		) +		__array(  char,         comm,   TASK_COMM_LEN   ) +		__dynamic_array( char,	cmd,	blk_cmd_buf_len(rq)	) +	), + +	TP_fast_assign( +		__entry->dev	   = rq->rq_disk ? disk_devt(rq->rq_disk) : 0; +		__entry->sector    = blk_pc_request(rq) ? 0 : rq->hard_sector; +		__entry->nr_sector = blk_pc_request(rq) ? +						0 : rq->hard_nr_sectors; +		__entry->bytes     = blk_pc_request(rq) ? rq->data_len : 0; + +		blk_fill_rwbs_rq(__entry->rwbs, rq); +		blk_dump_cmd(__get_str(cmd), rq); +		memcpy(__entry->comm, current->comm, TASK_COMM_LEN); +	), + +	TP_printk("%d,%d %s %u (%s) %llu + %u [%s]", +		  MAJOR(__entry->dev), MINOR(__entry->dev), +		  __entry->rwbs, __entry->bytes, __get_str(cmd), +		  __entry->sector, __entry->nr_sector, __entry->comm) +); + +TRACE_EVENT(block_rq_issue, + +	TP_PROTO(struct request_queue *q, struct request *rq), + +	TP_ARGS(q, rq), + +	TP_STRUCT__entry( +		__field(  dev_t,	dev			) +		__field(  sector_t,	sector			) +		__field(  unsigned int,	nr_sector		) +		__field(  unsigned int,	bytes			) +		__array(  char,		rwbs,	6		) +		__array(  char,		comm,   TASK_COMM_LEN   ) +		__dynamic_array( char,	cmd,	blk_cmd_buf_len(rq)	) +	), + +	TP_fast_assign( +		__entry->dev	   = rq->rq_disk ? disk_devt(rq->rq_disk) : 0; +		__entry->sector    = blk_pc_request(rq) ? 0 : rq->hard_sector; +		__entry->nr_sector = blk_pc_request(rq) ? +						0 : rq->hard_nr_sectors; +		__entry->bytes     = blk_pc_request(rq) ? rq->data_len : 0; + +		blk_fill_rwbs_rq(__entry->rwbs, rq); +		blk_dump_cmd(__get_str(cmd), rq); +		memcpy(__entry->comm, current->comm, TASK_COMM_LEN); +	), + +	TP_printk("%d,%d %s %u (%s) %llu + %u [%s]", +		  MAJOR(__entry->dev), MINOR(__entry->dev), +		  __entry->rwbs, __entry->bytes, __get_str(cmd), +		  __entry->sector, __entry->nr_sector, __entry->comm) +); + +TRACE_EVENT(block_rq_requeue, + +	TP_PROTO(struct request_queue *q, struct request *rq), + +	TP_ARGS(q, rq), + +	TP_STRUCT__entry( +		__field(  dev_t,	dev			) +		__field(  sector_t,	sector			) +		__field(  unsigned int,	nr_sector		) +		__field(  int,		errors			) +		__array(  char,		rwbs,	6		) +		__dynamic_array( char,	cmd,	blk_cmd_buf_len(rq)	) +	), + +	TP_fast_assign( +		__entry->dev	   = rq->rq_disk ? disk_devt(rq->rq_disk) : 0; +		__entry->sector    = blk_pc_request(rq) ? 0 : rq->hard_sector; +		__entry->nr_sector = blk_pc_request(rq) ? +						0 : rq->hard_nr_sectors; +		__entry->errors	   = rq->errors; + +		blk_fill_rwbs_rq(__entry->rwbs, rq); +		blk_dump_cmd(__get_str(cmd), rq); +	), + +	TP_printk("%d,%d %s (%s) %llu + %u [%d]", +		  MAJOR(__entry->dev), MINOR(__entry->dev), +		  __entry->rwbs, __get_str(cmd), +		  __entry->sector, __entry->nr_sector, __entry->errors) +); + +TRACE_EVENT(block_rq_complete, + +	TP_PROTO(struct request_queue *q, struct request *rq), + +	TP_ARGS(q, rq), + +	TP_STRUCT__entry( +		__field(  dev_t,	dev			) +		__field(  sector_t,	sector			) +		__field(  unsigned int,	nr_sector		) +		__field(  int,		errors			) +		__array(  char,		rwbs,	6		) +		__dynamic_array( char,	cmd,	blk_cmd_buf_len(rq)	) +	), + +	TP_fast_assign( +		__entry->dev	   = rq->rq_disk ? disk_devt(rq->rq_disk) : 0; +		__entry->sector    = blk_pc_request(rq) ? 0 : rq->hard_sector; +		__entry->nr_sector = blk_pc_request(rq) ? +						0 : rq->hard_nr_sectors; +		__entry->errors    = rq->errors; + +		blk_fill_rwbs_rq(__entry->rwbs, rq); +		blk_dump_cmd(__get_str(cmd), rq); +	), + +	TP_printk("%d,%d %s (%s) %llu + %u [%d]", +		  MAJOR(__entry->dev), MINOR(__entry->dev), +		  __entry->rwbs, __get_str(cmd), +		  __entry->sector, __entry->nr_sector, __entry->errors) +); +TRACE_EVENT(block_bio_bounce, + +	TP_PROTO(struct request_queue *q, struct bio *bio), + +	TP_ARGS(q, bio), + +	TP_STRUCT__entry( +		__field( dev_t,		dev			) +		__field( sector_t,	sector			) +		__field( unsigned int,	nr_sector		) +		__array( char,		rwbs,	6		) +		__array( char,		comm,	TASK_COMM_LEN	) +	), + +	TP_fast_assign( +		__entry->dev		= bio->bi_bdev->bd_dev; +		__entry->sector		= bio->bi_sector; +		__entry->nr_sector	= bio->bi_size >> 9; +		blk_fill_rwbs(__entry->rwbs, bio->bi_rw, bio->bi_size); +		memcpy(__entry->comm, current->comm, TASK_COMM_LEN); +	), + +	TP_printk("%d,%d %s %llu + %u [%s]", +		  MAJOR(__entry->dev), MINOR(__entry->dev), __entry->rwbs, +		  __entry->sector, __entry->nr_sector, __entry->comm) +); + +TRACE_EVENT(block_bio_complete, + +	TP_PROTO(struct request_queue *q, struct bio *bio), + +	TP_ARGS(q, bio), + +	TP_STRUCT__entry( +		__field( dev_t,		dev		) +		__field( sector_t,	sector		) +		__field( unsigned,	nr_sector	) +		__field( int,		error		) +		__array( char,		rwbs,	6	) +	), + +	TP_fast_assign( +		__entry->dev		= bio->bi_bdev->bd_dev; +		__entry->sector		= bio->bi_sector; +		__entry->nr_sector	= bio->bi_size >> 9; +		blk_fill_rwbs(__entry->rwbs, bio->bi_rw, bio->bi_size); +	), + +	TP_printk("%d,%d %s %llu + %u [%d]", +		  MAJOR(__entry->dev), MINOR(__entry->dev), __entry->rwbs, +		  __entry->sector, __entry->nr_sector, __entry->error) +); + +TRACE_EVENT(block_bio_backmerge, + +	TP_PROTO(struct request_queue *q, struct bio *bio), + +	TP_ARGS(q, bio), + +	TP_STRUCT__entry( +		__field( dev_t,		dev			) +		__field( sector_t,	sector			) +		__field( unsigned int,	nr_sector		) +		__array( char,		rwbs,	6		) +		__array( char,		comm,	TASK_COMM_LEN	) +	), + +	TP_fast_assign( +		__entry->dev		= bio->bi_bdev->bd_dev; +		__entry->sector		= bio->bi_sector; +		__entry->nr_sector	= bio->bi_size >> 9; +		blk_fill_rwbs(__entry->rwbs, bio->bi_rw, bio->bi_size); +		memcpy(__entry->comm, current->comm, TASK_COMM_LEN); +	), + +	TP_printk("%d,%d %s %llu + %u [%s]", +		  MAJOR(__entry->dev), MINOR(__entry->dev), __entry->rwbs, +		  __entry->sector, __entry->nr_sector, __entry->comm) +); + +TRACE_EVENT(block_bio_frontmerge, + +	TP_PROTO(struct request_queue *q, struct bio *bio), + +	TP_ARGS(q, bio), + +	TP_STRUCT__entry( +		__field( dev_t,		dev			) +		__field( sector_t,	sector			) +		__field( unsigned,	nr_sector		) +		__array( char,		rwbs,	6		) +		__array( char,		comm,	TASK_COMM_LEN	) +	), + +	TP_fast_assign( +		__entry->dev		= bio->bi_bdev->bd_dev; +		__entry->sector		= bio->bi_sector; +		__entry->nr_sector	= bio->bi_size >> 9; +		blk_fill_rwbs(__entry->rwbs, bio->bi_rw, bio->bi_size); +		memcpy(__entry->comm, current->comm, TASK_COMM_LEN); +	), + +	TP_printk("%d,%d %s %llu + %u [%s]", +		  MAJOR(__entry->dev), MINOR(__entry->dev), __entry->rwbs, +		  __entry->sector, __entry->nr_sector, __entry->comm) +); + +TRACE_EVENT(block_bio_queue, + +	TP_PROTO(struct request_queue *q, struct bio *bio), + +	TP_ARGS(q, bio), + +	TP_STRUCT__entry( +		__field( dev_t,		dev			) +		__field( sector_t,	sector			) +		__field( unsigned int,	nr_sector		) +		__array( char,		rwbs,	6		) +		__array( char,		comm,	TASK_COMM_LEN	) +	), + +	TP_fast_assign( +		__entry->dev		= bio->bi_bdev->bd_dev; +		__entry->sector		= bio->bi_sector; +		__entry->nr_sector	= bio->bi_size >> 9; +		blk_fill_rwbs(__entry->rwbs, bio->bi_rw, bio->bi_size); +		memcpy(__entry->comm, current->comm, TASK_COMM_LEN); +	), + +	TP_printk("%d,%d %s %llu + %u [%s]", +		  MAJOR(__entry->dev), MINOR(__entry->dev), __entry->rwbs, +		  __entry->sector, __entry->nr_sector, __entry->comm) +); + +TRACE_EVENT(block_getrq, + +	TP_PROTO(struct request_queue *q, struct bio *bio, int rw), + +	TP_ARGS(q, bio, rw), + +	TP_STRUCT__entry( +		__field( dev_t,		dev			) +		__field( sector_t,	sector			) +		__field( unsigned int,	nr_sector		) +		__array( char,		rwbs,	6		) +		__array( char,		comm,	TASK_COMM_LEN	) +        ), + +	TP_fast_assign( +		__entry->dev		= bio ? bio->bi_bdev->bd_dev : 0; +		__entry->sector		= bio ? bio->bi_sector : 0; +		__entry->nr_sector	= bio ? bio->bi_size >> 9 : 0; +		blk_fill_rwbs(__entry->rwbs, +			      bio ? bio->bi_rw : 0, __entry->nr_sector); +		memcpy(__entry->comm, current->comm, TASK_COMM_LEN); +        ), + +	TP_printk("%d,%d %s %llu + %u [%s]", +		  MAJOR(__entry->dev), MINOR(__entry->dev), __entry->rwbs, +		  __entry->sector, __entry->nr_sector, __entry->comm) +); + +TRACE_EVENT(block_sleeprq, + +	TP_PROTO(struct request_queue *q, struct bio *bio, int rw), + +	TP_ARGS(q, bio, rw), + +	TP_STRUCT__entry( +		__field( dev_t,		dev			) +		__field( sector_t,	sector			) +		__field( unsigned int,	nr_sector		) +		__array( char,		rwbs,	6		) +		__array( char,		comm,	TASK_COMM_LEN	) +	), + +	TP_fast_assign( +		__entry->dev		= bio ? bio->bi_bdev->bd_dev : 0; +		__entry->sector		= bio ? bio->bi_sector : 0; +		__entry->nr_sector	= bio ? bio->bi_size >> 9 : 0; +		blk_fill_rwbs(__entry->rwbs, +			    bio ? bio->bi_rw : 0, __entry->nr_sector); +		memcpy(__entry->comm, current->comm, TASK_COMM_LEN); +	), + +	TP_printk("%d,%d %s %llu + %u [%s]", +		  MAJOR(__entry->dev), MINOR(__entry->dev), __entry->rwbs, +		  __entry->sector, __entry->nr_sector, __entry->comm) +); + +TRACE_EVENT(block_plug, + +	TP_PROTO(struct request_queue *q), + +	TP_ARGS(q), + +	TP_STRUCT__entry( +		__array( char,		comm,	TASK_COMM_LEN	) +	), + +	TP_fast_assign( +		memcpy(__entry->comm, current->comm, TASK_COMM_LEN); +	), + +	TP_printk("[%s]", __entry->comm) +); + +TRACE_EVENT(block_unplug_timer, + +	TP_PROTO(struct request_queue *q), + +	TP_ARGS(q), + +	TP_STRUCT__entry( +		__field( int,		nr_rq			) +		__array( char,		comm,	TASK_COMM_LEN	) +	), + +	TP_fast_assign( +		__entry->nr_rq	= q->rq.count[READ] + q->rq.count[WRITE]; +		memcpy(__entry->comm, current->comm, TASK_COMM_LEN); +	), + +	TP_printk("[%s] %d", __entry->comm, __entry->nr_rq) +); + +TRACE_EVENT(block_unplug_io, + +	TP_PROTO(struct request_queue *q), + +	TP_ARGS(q), + +	TP_STRUCT__entry( +		__field( int,		nr_rq			) +		__array( char,		comm,	TASK_COMM_LEN	) +	), + +	TP_fast_assign( +		__entry->nr_rq	= q->rq.count[READ] + q->rq.count[WRITE]; +		memcpy(__entry->comm, current->comm, TASK_COMM_LEN); +	), + +	TP_printk("[%s] %d", __entry->comm, __entry->nr_rq) +); + +TRACE_EVENT(block_split, + +	TP_PROTO(struct request_queue *q, struct bio *bio, +		 unsigned int new_sector), + +	TP_ARGS(q, bio, new_sector), + +	TP_STRUCT__entry( +		__field( dev_t,		dev				) +		__field( sector_t,	sector				) +		__field( sector_t,	new_sector			) +		__array( char,		rwbs,		6		) +		__array( char,		comm,		TASK_COMM_LEN	) +	), + +	TP_fast_assign( +		__entry->dev		= bio->bi_bdev->bd_dev; +		__entry->sector		= bio->bi_sector; +		__entry->new_sector	= new_sector; +		blk_fill_rwbs(__entry->rwbs, bio->bi_rw, bio->bi_size); +		memcpy(__entry->comm, current->comm, TASK_COMM_LEN); +	), + +	TP_printk("%d,%d %s %llu / %llu [%s]", +		  MAJOR(__entry->dev), MINOR(__entry->dev), __entry->rwbs, +		  __entry->sector, __entry->new_sector, __entry->comm) +); + +TRACE_EVENT(block_remap, + +	TP_PROTO(struct request_queue *q, struct bio *bio, dev_t dev, +		 sector_t from), + +	TP_ARGS(q, bio, dev, from), + +	TP_STRUCT__entry( +		__field( dev_t,		dev		) +		__field( sector_t,	sector		) +		__field( unsigned int,	nr_sector	) +		__field( dev_t,		old_dev		) +		__field( sector_t,	old_sector	) +		__array( char,		rwbs,	6	) +	), + +	TP_fast_assign( +		__entry->dev		= bio->bi_bdev->bd_dev; +		__entry->sector		= bio->bi_sector; +		__entry->nr_sector	= bio->bi_size >> 9; +		__entry->old_dev	= dev; +		__entry->old_sector	= from; +		blk_fill_rwbs(__entry->rwbs, bio->bi_rw, bio->bi_size); +	), + +	TP_printk("%d,%d %s %llu + %u <- (%d,%d) %llu", +		  MAJOR(__entry->dev), MINOR(__entry->dev), __entry->rwbs, +		  __entry->sector, __entry->nr_sector, +		  MAJOR(__entry->old_dev), MINOR(__entry->old_dev), +		  __entry->old_sector) +); + +#endif /* _TRACE_BLOCK_H */ + +/* This part must be outside protection */ +#include <trace/define_trace.h> + diff --git a/kernel/trace/Makefile b/kernel/trace/Makefile index 06b85850fab..844164dca90 100644 --- a/kernel/trace/Makefile +++ b/kernel/trace/Makefile @@ -45,7 +45,10 @@ obj-$(CONFIG_HW_BRANCH_TRACER) += trace_hw_branches.o  obj-$(CONFIG_POWER_TRACER) += trace_power.o  obj-$(CONFIG_KMEMTRACE) += kmemtrace.o  obj-$(CONFIG_WORKQUEUE_TRACER) += trace_workqueue.o -obj-$(CONFIG_BLK_DEV_IO_TRACE)	+= blktrace.o +obj-$(CONFIG_BLK_DEV_IO_TRACE) += blktrace.o +ifeq ($(CONFIG_BLOCK),y) +obj-$(CONFIG_EVENT_TRACING) += blktrace.o +endif  obj-$(CONFIG_EVENT_TRACING) += trace_events.o  obj-$(CONFIG_EVENT_TRACING) += trace_export.o  obj-$(CONFIG_FTRACE_SYSCALLS) += trace_syscalls.o diff --git a/kernel/trace/blktrace.c b/kernel/trace/blktrace.c index e3abf55bc8e..7bd6a9893c2 100644 --- a/kernel/trace/blktrace.c +++ b/kernel/trace/blktrace.c @@ -23,10 +23,14 @@  #include <linux/mutex.h>  #include <linux/debugfs.h>  #include <linux/time.h> -#include <trace/block.h>  #include <linux/uaccess.h> + +#include <trace/events/block.h> +  #include "trace_output.h" +#ifdef CONFIG_BLK_DEV_IO_TRACE +  static unsigned int blktrace_seq __read_mostly = 1;  static struct trace_array *blk_tr; @@ -1658,3 +1662,75 @@ int blk_trace_init_sysfs(struct device *dev)  	return sysfs_create_group(&dev->kobj, &blk_trace_attr_group);  } +#endif /* CONFIG_BLK_DEV_IO_TRACE */ + +#ifdef CONFIG_EVENT_TRACING + +void blk_dump_cmd(char *buf, struct request *rq) +{ +	int i, end; +	int len = rq->cmd_len; +	unsigned char *cmd = rq->cmd; + +	if (!blk_pc_request(rq)) { +		buf[0] = '\0'; +		return; +	} + +	for (end = len - 1; end >= 0; end--) +		if (cmd[end]) +			break; +	end++; + +	for (i = 0; i < len; i++) { +		buf += sprintf(buf, "%s%02x", i == 0 ? "" : " ", cmd[i]); +		if (i == end && end != len - 1) { +			sprintf(buf, " .."); +			break; +		} +	} +} + +void blk_fill_rwbs(char *rwbs, u32 rw, int bytes) +{ +	int i = 0; + +	if (rw & WRITE) +		rwbs[i++] = 'W'; +	else if (rw & 1 << BIO_RW_DISCARD) +		rwbs[i++] = 'D'; +	else if (bytes) +		rwbs[i++] = 'R'; +	else +		rwbs[i++] = 'N'; + +	if (rw & 1 << BIO_RW_AHEAD) +		rwbs[i++] = 'A'; +	if (rw & 1 << BIO_RW_BARRIER) +		rwbs[i++] = 'B'; +	if (rw & 1 << BIO_RW_SYNCIO) +		rwbs[i++] = 'S'; +	if (rw & 1 << BIO_RW_META) +		rwbs[i++] = 'M'; + +	rwbs[i] = '\0'; +} + +void blk_fill_rwbs_rq(char *rwbs, struct request *rq) +{ +	int rw = rq->cmd_flags & 0x03; +	int bytes; + +	if (blk_discard_rq(rq)) +		rw |= (1 << BIO_RW_DISCARD); + +	if (blk_pc_request(rq)) +		bytes = rq->data_len; +	else +		bytes = rq->hard_nr_sectors << 9; + +	blk_fill_rwbs(rwbs, rw, bytes); +} + +#endif /* CONFIG_EVENT_TRACING */ + diff --git a/mm/bounce.c b/mm/bounce.c index e590272fe7a..65f5e17e411 100644 --- a/mm/bounce.c +++ b/mm/bounce.c @@ -14,16 +14,15 @@  #include <linux/hash.h>  #include <linux/highmem.h>  #include <linux/blktrace_api.h> -#include <trace/block.h>  #include <asm/tlbflush.h> +#include <trace/events/block.h> +  #define POOL_SIZE	64  #define ISA_POOL_SIZE	16  static mempool_t *page_pool, *isa_page_pool; -DEFINE_TRACE(block_bio_bounce); -  #ifdef CONFIG_HIGHMEM  static __init int init_emergency_pool(void)  {  |