*/
 static inline void htb_next_rb_node(struct rb_node **n)
 {
-       *n = rb_next(*n);
+       if (*n)
+               *n = rb_next(*n);
 }
 
 /**
  */
 static inline void htb_deactivate(struct htb_sched *q, struct htb_class *cl)
 {
-       WARN_ON(!cl->prio_activity);
-
+       if (!cl->prio_activity)
+               return;
        htb_deactivate_prios(q, cl);
        cl->prio_activity = 0;
 }
 {
        struct htb_class *cl = (struct htb_class *)arg;
 
-       if (!cl->prio_activity)
-               return;
        htb_deactivate(qdisc_priv(sch), cl);
 }
 
        if (cl->parent)
                cl->parent->children--;
 
-       if (cl->prio_activity)
-               htb_deactivate(q, cl);
+       htb_deactivate(q, cl);
 
        if (cl->cmode != HTB_CAN_SEND)
                htb_safe_rb_erase(&cl->pq_node,
                        /* turn parent into inner node */
                        qdisc_purge_queue(parent->leaf.q);
                        parent_qdisc = parent->leaf.q;
-                       if (parent->prio_activity)
-                               htb_deactivate(q, parent);
+                       htb_deactivate(q, parent);
 
                        /* remove from evt list because of level change */
                        if (parent->cmode != HTB_CAN_SEND) {