On Tue, Sep 22, 2015 at 04:50:42PM -0400, Waiman Long wrote:

> @@ -100,10 +242,13 @@ static struct qspinlock **pv_hash(struct qspinlock 
> *lock, struct pv_node *node)
>  {
>       unsigned long offset, hash = hash_ptr(lock, pv_lock_hash_bits);
>       struct pv_hash_entry *he;
> +     int hopcnt = 0;
>  
>       for_each_hash_entry(he, offset, hash) {
> +             hopcnt++;
>               if (!cmpxchg(&he->lock, NULL, lock)) {
>                       WRITE_ONCE(he->node, node);
> +                     pvstat_hop(hopcnt);
>                       return &he->lock;
>               }
>       }
> @@ -164,9 +309,10 @@ static void pv_init_node(struct mcs_spinlock *node)
>  static void pv_wait_node(struct mcs_spinlock *node)
>  {
>       struct pv_node *pn = (struct pv_node *)node;
> +     int waitcnt = 0;
>       int loop;
>  
> -     for (;;) {
> +     for (;; waitcnt++) {
>               for (loop = SPIN_THRESHOLD; loop; loop--) {
>                       if (READ_ONCE(node->locked))
>                               return;

> @@ -250,6 +401,7 @@ static void pv_wait_head(struct qspinlock *lock, struct 
> mcs_spinlock *node)
>       struct pv_node *pn = (struct pv_node *)node;
>       struct __qspinlock *l = (void *)lock;
>       struct qspinlock **lp = NULL;
> +     int waitcnt = 0;
>       int loop;
>  
>       /*
> @@ -259,7 +411,7 @@ static void pv_wait_head(struct qspinlock *lock, struct 
> mcs_spinlock *node)
>       if (READ_ONCE(pn->state) == vcpu_hashed)
>               lp = (struct qspinlock **)1;
>  
> -     for (;;) {
> +     for (;; waitcnt++) {
>               for (loop = SPIN_THRESHOLD; loop; loop--) {
>                       if (!READ_ONCE(l->locked))
>                               return;

These things are ugly; did you verify that they compile away for the
!stats case?
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to