lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Date:	Thu, 5 Nov 2009 09:42:22 -0500
From:	Vivek Goyal <vgoyal@...hat.com>
To:	Divyesh Shah <dpshah@...gle.com>
Cc:	linux-kernel@...r.kernel.org, jens.axboe@...cle.com,
	nauman@...gle.com, lizf@...fujitsu.com, ryov@...inux.co.jp,
	fernando@....ntt.co.jp, s-uchida@...jp.nec.com, taka@...inux.co.jp,
	guijianfeng@...fujitsu.com, jmoyer@...hat.com,
	balbir@...ux.vnet.ibm.com, righi.andrea@...il.com,
	m-ikeda@...jp.nec.com, akpm@...ux-foundation.org, riel@...hat.com,
	kamezawa.hiroyu@...fujitsu.com
Subject: Re: [PATCH 11/20] blkio: Some CFQ debugging Aid

On Wed, Nov 04, 2009 at 07:10:00PM -0800, Divyesh Shah wrote:
> In the previous patchset when merged with the bio tracking patches we
> had a very convenient
>  biocg_id we could use for debugging. If the eventual plan is to merge
> the biotrack patches, do you think it makes sense to introduce the
> per-blkio cgroup id here when DEBUG_BLK_CGROUP=y and use that for all
> traces? The cgroup path name seems ugly to me.
> 

Hi Divyesh,

We still have biocg_id. Just that new name is "blkcg_id". So in evrey
blkio_group, we embed this id to know which cgroup this blkio_group
belongs to.

We had cgroup path in previous patches also. The only advantage of path
is that we don't have to call cgroup_path() again and again and we can
call it once when blkio_group instanciates and then store the path in
blio_group and use it.

Thanks
Vivek

> -Divyesh
> 
> On Tue, Nov 3, 2009 at 3:43 PM, Vivek Goyal <vgoyal@...hat.com> wrote:
> > o Some CFQ debugging Aid.
> >
> > Signed-off-by: Vivek Goyal <vgoyal@...hat.com>
> > ---
> >  block/Kconfig         |    9 +++++++++
> >  block/Kconfig.iosched |    9 +++++++++
> >  block/blk-cgroup.c    |    4 ++++
> >  block/blk-cgroup.h    |   13 +++++++++++++
> >  block/cfq-iosched.c   |   33 +++++++++++++++++++++++++++++++++
> >  5 files changed, 68 insertions(+), 0 deletions(-)
> >
> > diff --git a/block/Kconfig b/block/Kconfig
> > index 6ba1a8e..e20fbde 100644
> > --- a/block/Kconfig
> > +++ b/block/Kconfig
> > @@ -90,6 +90,15 @@ config BLK_CGROUP
> >        control disk bandwidth allocation (proportional time slice allocation)
> >        to such task groups.
> >
> > +config DEBUG_BLK_CGROUP
> > +       bool
> > +       depends on BLK_CGROUP
> > +       default n
> > +       ---help---
> > +       Enable some debugging help. Currently it stores the cgroup path
> > +       in the blk group which can be used by cfq for tracing various
> > +       group related activity.
> > +
> >  endif # BLOCK
> >
> >  config BLOCK_COMPAT
> > diff --git a/block/Kconfig.iosched b/block/Kconfig.iosched
> > index a521c69..9c5f0b5 100644
> > --- a/block/Kconfig.iosched
> > +++ b/block/Kconfig.iosched
> > @@ -48,6 +48,15 @@ config CFQ_GROUP_IOSCHED
> >        ---help---
> >          Enable group IO scheduling in CFQ.
> >
> > +config DEBUG_CFQ_IOSCHED
> > +       bool "Debug CFQ Scheduling"
> > +       depends on CFQ_GROUP_IOSCHED
> > +       select DEBUG_BLK_CGROUP
> > +       default n
> > +       ---help---
> > +         Enable CFQ IO scheduling debugging in CFQ. Currently it makes
> > +         blktrace output more verbose.
> > +
> >  choice
> >        prompt "Default I/O scheduler"
> >        default DEFAULT_CFQ
> > diff --git a/block/blk-cgroup.c b/block/blk-cgroup.c
> > index a62b8a3..4c68682 100644
> > --- a/block/blk-cgroup.c
> > +++ b/block/blk-cgroup.c
> > @@ -39,6 +39,10 @@ void blkiocg_add_blkio_group(struct blkio_cgroup *blkcg,
> >        blkg->blkcg_id = css_id(&blkcg->css);
> >        hlist_add_head_rcu(&blkg->blkcg_node, &blkcg->blkg_list);
> >        spin_unlock_irqrestore(&blkcg->lock, flags);
> > +#ifdef CONFIG_DEBUG_BLK_CGROUP
> > +       /* Need to take css reference ? */
> > +       cgroup_path(blkcg->css.cgroup, blkg->path, sizeof(blkg->path));
> > +#endif
> >  }
> >
> >  static void __blkiocg_del_blkio_group(struct blkio_group *blkg)
> > diff --git a/block/blk-cgroup.h b/block/blk-cgroup.h
> > index 2bf736b..cb72c35 100644
> > --- a/block/blk-cgroup.h
> > +++ b/block/blk-cgroup.h
> > @@ -26,12 +26,25 @@ struct blkio_group {
> >        void *key;
> >        struct hlist_node blkcg_node;
> >        unsigned short blkcg_id;
> > +#ifdef CONFIG_DEBUG_BLK_CGROUP
> > +       /* Store cgroup path */
> > +       char path[128];
> > +#endif
> >  };
> >
> >  #define BLKIO_WEIGHT_MIN       100
> >  #define BLKIO_WEIGHT_MAX       1000
> >  #define BLKIO_WEIGHT_DEFAULT   500
> >
> > +#ifdef CONFIG_DEBUG_BLK_CGROUP
> > +static inline char *blkg_path(struct blkio_group *blkg)
> > +{
> > +       return blkg->path;
> > +}
> > +#else
> > +static inline char *blkg_path(struct blkio_group *blkg) { return NULL; }
> > +#endif
> > +
> >  extern struct blkio_cgroup blkio_root_cgroup;
> >  struct blkio_cgroup *cgroup_to_blkio_cgroup(struct cgroup *cgroup);
> >  void blkiocg_add_blkio_group(struct blkio_cgroup *blkcg,
> > diff --git a/block/cfq-iosched.c b/block/cfq-iosched.c
> > index b9a052b..2fde3c4 100644
> > --- a/block/cfq-iosched.c
> > +++ b/block/cfq-iosched.c
> > @@ -258,8 +258,29 @@ CFQ_CFQQ_FNS(sync);
> >  CFQ_CFQQ_FNS(coop);
> >  #undef CFQ_CFQQ_FNS
> >
> > +#ifdef CONFIG_DEBUG_CFQ_IOSCHED
> > +#define cfq_log_cfqq(cfqd, cfqq, fmt, args...) \
> > +       blk_add_trace_msg((cfqd)->queue, "cfq%d%c %s " fmt, (cfqq)->pid, \
> > +                       cfq_cfqq_sync((cfqq)) ? 'S' : 'A', \
> > +                       blkg_path(&cfqq_to_cfqg((cfqq))->blkg), ##args);
> > +
> > +#define cfq_log_cfqe(cfqd, cfqe, fmt, args...)                 \
> > +       if (cfqq_of(cfqe)) {                                            \
> > +               struct cfq_queue *cfqq = cfqq_of(cfqe);                 \
> > +               blk_add_trace_msg((cfqd)->queue, "cfq%d%c %s " fmt,     \
> > +                       (cfqq)->pid, cfq_cfqq_sync((cfqq)) ? 'S' : 'A', \
> > +                       blkg_path(&cfqq_to_cfqg((cfqq))->blkg), ##args);\
> > +       } else {                                                        \
> > +               struct cfq_group *cfqg = cfqg_of(cfqe);                 \
> > +               blk_add_trace_msg((cfqd)->queue, "%s " fmt,             \
> > +                               blkg_path(&(cfqg)->blkg), ##args);      \
> > +       }
> > +#else
> >  #define cfq_log_cfqq(cfqd, cfqq, fmt, args...) \
> >        blk_add_trace_msg((cfqd)->queue, "cfq%d " fmt, (cfqq)->pid, ##args)
> > +#define cfq_log_cfqe(cfqd, cfqe, fmt, args...)
> > +#endif
> > +
> >  #define cfq_log(cfqd, fmt, args...)    \
> >        blk_add_trace_msg((cfqd)->queue, "cfq " fmt, ##args)
> >
> > @@ -400,6 +421,8 @@ cfq_init_cfqe_parent(struct cfq_entity *cfqe, struct cfq_entity *p_cfqe)
> >  #define for_each_entity(entity)        \
> >        for (; entity && entity->parent; entity = entity->parent)
> >
> > +#define cfqe_is_cfqq(cfqe)     (!(cfqe)->my_sd)
> > +
> >  static inline struct cfq_group *cfqg_of_blkg(struct blkio_group *blkg)
> >  {
> >        if (blkg)
> > @@ -588,6 +611,8 @@ void cfq_delink_blkio_group(void *key, struct blkio_group *blkg)
> >  #define for_each_entity(entity)        \
> >        for (; entity != NULL; entity = NULL)
> >
> > +#define cfqe_is_cfqq(cfqe)     1
> > +
> >  static void cfq_release_cfq_groups(struct cfq_data *cfqd) {}
> >  static inline void cfq_get_cfqg_ref(struct cfq_group *cfqg) {}
> >  static inline void cfq_put_cfqg(struct cfq_group *cfqg) {}
> > @@ -885,6 +910,10 @@ static void dequeue_cfqq(struct cfq_queue *cfqq)
> >                struct cfq_sched_data *sd = cfq_entity_sched_data(cfqe);
> >
> >                dequeue_cfqe(cfqe);
> > +               if (!cfqe_is_cfqq(cfqe)) {
> > +                       cfq_log_cfqe(cfqq->cfqd, cfqe, "del_from_rr group");
> > +               }
> > +
> >                /* Do not dequeue parent if it has other entities under it */
> >                if (sd->nr_active)
> >                        break;
> > @@ -970,6 +999,8 @@ static void requeue_cfqq(struct cfq_queue *cfqq, int add_front)
> >
> >  static void cfqe_served(struct cfq_entity *cfqe, unsigned long served)
> >  {
> > +       struct cfq_data *cfqd = cfqq_of(cfqe)->cfqd;
> > +
> >        for_each_entity(cfqe) {
> >                /*
> >                 * Can't update entity disk time while it is on sorted rb-tree
> > @@ -979,6 +1010,8 @@ static void cfqe_served(struct cfq_entity *cfqe, unsigned long served)
> >                cfqe->vdisktime += cfq_delta_fair(served, cfqe);
> >                update_min_vdisktime(cfqe->st);
> >                __enqueue_cfqe(cfqe->st, cfqe, 0);
> > +               cfq_log_cfqe(cfqd, cfqe, "served: vt=%llx min_vt=%llx",
> > +                               cfqe->vdisktime, cfqe->st->min_vdisktime);
> >
> >                /* If entity prio class has changed, take that into account */
> >                if (unlikely(cfqe->ioprio_class_changed)) {
> > --
> > 1.6.2.5
> >
> >
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ