diff options
author | David S. Miller <davem@davemloft.net> | 2008-07-16 04:42:40 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2008-07-17 22:21:19 -0400 |
commit | 7698b4fcabcd790efc4f226bada1e7b5870653af (patch) | |
tree | 031ce7a911fc5bff995421a5615d9ab25416a479 /net/sched/sch_cbq.c | |
parent | e2627c8c2241bce45e368e150654d076b58a4595 (diff) |
pkt_sched: Add and use qdisc_root() and qdisc_root_lock().
When code wants to lock the qdisc tree state, the logic
operation it's doing is locking the top-level qdisc that
sits of the root of the netdev_queue.
Add qdisc_root_lock() to represent this and convert the
easiest cases.
In order for this to work out in all cases, we have to
hook up the noop_qdisc to a dummy netdev_queue.
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/sched/sch_cbq.c')
-rw-r--r-- | net/sched/sch_cbq.c | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/net/sched/sch_cbq.c b/net/sched/sch_cbq.c index 4efc836cbf38..37ae653db683 100644 --- a/net/sched/sch_cbq.c +++ b/net/sched/sch_cbq.c | |||
@@ -1744,12 +1744,13 @@ static void cbq_put(struct Qdisc *sch, unsigned long arg) | |||
1744 | 1744 | ||
1745 | if (--cl->refcnt == 0) { | 1745 | if (--cl->refcnt == 0) { |
1746 | #ifdef CONFIG_NET_CLS_ACT | 1746 | #ifdef CONFIG_NET_CLS_ACT |
1747 | spinlock_t *root_lock = qdisc_root_lock(sch); | ||
1747 | struct cbq_sched_data *q = qdisc_priv(sch); | 1748 | struct cbq_sched_data *q = qdisc_priv(sch); |
1748 | 1749 | ||
1749 | spin_lock_bh(&sch->dev_queue->lock); | 1750 | spin_lock_bh(root_lock); |
1750 | if (q->rx_class == cl) | 1751 | if (q->rx_class == cl) |
1751 | q->rx_class = NULL; | 1752 | q->rx_class = NULL; |
1752 | spin_unlock_bh(&sch->dev_queue->lock); | 1753 | spin_unlock_bh(root_lock); |
1753 | #endif | 1754 | #endif |
1754 | 1755 | ||
1755 | cbq_destroy_class(sch, cl); | 1756 | cbq_destroy_class(sch, cl); |
@@ -1828,7 +1829,7 @@ cbq_change_class(struct Qdisc *sch, u32 classid, u32 parentid, struct nlattr **t | |||
1828 | 1829 | ||
1829 | if (tca[TCA_RATE]) | 1830 | if (tca[TCA_RATE]) |
1830 | gen_replace_estimator(&cl->bstats, &cl->rate_est, | 1831 | gen_replace_estimator(&cl->bstats, &cl->rate_est, |
1831 | &sch->dev_queue->lock, | 1832 | qdisc_root_lock(sch), |
1832 | tca[TCA_RATE]); | 1833 | tca[TCA_RATE]); |
1833 | return 0; | 1834 | return 0; |
1834 | } | 1835 | } |
@@ -1919,7 +1920,7 @@ cbq_change_class(struct Qdisc *sch, u32 classid, u32 parentid, struct nlattr **t | |||
1919 | 1920 | ||
1920 | if (tca[TCA_RATE]) | 1921 | if (tca[TCA_RATE]) |
1921 | gen_new_estimator(&cl->bstats, &cl->rate_est, | 1922 | gen_new_estimator(&cl->bstats, &cl->rate_est, |
1922 | &sch->dev_queue->lock, tca[TCA_RATE]); | 1923 | qdisc_root_lock(sch), tca[TCA_RATE]); |
1923 | 1924 | ||
1924 | *arg = (unsigned long)cl; | 1925 | *arg = (unsigned long)cl; |
1925 | return 0; | 1926 | return 0; |