mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-04 10:40:15 +02:00 
			
		
		
		
	net/sched: sch_qfq: refactor parsing of netlink parameters
Two parameters can be transformed into netlink policies and validated while parsing the netlink message. Reviewed-by: Simon Horman <simon.horman@corigine.com> Acked-by: Jamal Hadi Salim <jhs@mojatatu.com> Signed-off-by: Pedro Tammela <pctammela@mojatatu.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
		
							parent
							
								
									c69a9b023f
								
							
						
					
					
						commit
						25369891fc
					
				
					 1 changed files with 11 additions and 14 deletions
				
			
		| 
						 | 
				
			
			@ -113,6 +113,7 @@
 | 
			
		|||
 | 
			
		||||
#define QFQ_MTU_SHIFT		16	/* to support TSO/GSO */
 | 
			
		||||
#define QFQ_MIN_LMAX		512	/* see qfq_slot_insert */
 | 
			
		||||
#define QFQ_MAX_LMAX		(1UL << QFQ_MTU_SHIFT)
 | 
			
		||||
 | 
			
		||||
#define QFQ_MAX_AGG_CLASSES	8 /* max num classes per aggregate allowed */
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -214,9 +215,14 @@ static struct qfq_class *qfq_find_class(struct Qdisc *sch, u32 classid)
 | 
			
		|||
	return container_of(clc, struct qfq_class, common);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static struct netlink_range_validation lmax_range = {
 | 
			
		||||
	.min = QFQ_MIN_LMAX,
 | 
			
		||||
	.max = QFQ_MAX_LMAX,
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
static const struct nla_policy qfq_policy[TCA_QFQ_MAX + 1] = {
 | 
			
		||||
	[TCA_QFQ_WEIGHT] = { .type = NLA_U32 },
 | 
			
		||||
	[TCA_QFQ_LMAX] = { .type = NLA_U32 },
 | 
			
		||||
	[TCA_QFQ_WEIGHT] = NLA_POLICY_RANGE(NLA_U32, 1, QFQ_MAX_WEIGHT),
 | 
			
		||||
	[TCA_QFQ_LMAX] = NLA_POLICY_FULL_RANGE(NLA_U32, &lmax_range),
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
| 
						 | 
				
			
			@ -408,17 +414,13 @@ static int qfq_change_class(struct Qdisc *sch, u32 classid, u32 parentid,
 | 
			
		|||
	}
 | 
			
		||||
 | 
			
		||||
	err = nla_parse_nested_deprecated(tb, TCA_QFQ_MAX, tca[TCA_OPTIONS],
 | 
			
		||||
					  qfq_policy, NULL);
 | 
			
		||||
					  qfq_policy, extack);
 | 
			
		||||
	if (err < 0)
 | 
			
		||||
		return err;
 | 
			
		||||
 | 
			
		||||
	if (tb[TCA_QFQ_WEIGHT]) {
 | 
			
		||||
	if (tb[TCA_QFQ_WEIGHT])
 | 
			
		||||
		weight = nla_get_u32(tb[TCA_QFQ_WEIGHT]);
 | 
			
		||||
		if (!weight || weight > (1UL << QFQ_MAX_WSHIFT)) {
 | 
			
		||||
			pr_notice("qfq: invalid weight %u\n", weight);
 | 
			
		||||
			return -EINVAL;
 | 
			
		||||
		}
 | 
			
		||||
	} else
 | 
			
		||||
	else
 | 
			
		||||
		weight = 1;
 | 
			
		||||
 | 
			
		||||
	if (tb[TCA_QFQ_LMAX])
 | 
			
		||||
| 
						 | 
				
			
			@ -426,11 +428,6 @@ static int qfq_change_class(struct Qdisc *sch, u32 classid, u32 parentid,
 | 
			
		|||
	else
 | 
			
		||||
		lmax = psched_mtu(qdisc_dev(sch));
 | 
			
		||||
 | 
			
		||||
	if (lmax < QFQ_MIN_LMAX || lmax > (1UL << QFQ_MTU_SHIFT)) {
 | 
			
		||||
		pr_notice("qfq: invalid max length %u\n", lmax);
 | 
			
		||||
		return -EINVAL;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	inv_w = ONE_FP / weight;
 | 
			
		||||
	weight = ONE_FP / inv_w;
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in a new issue