Lines Matching refs:rule
12 struct sja1105_rule *rule,
23 e->rule = rule;
95 struct sja1105_rule *rule;
102 list_for_each_entry(rule, &priv->flow_block.rules, list) {
103 if (rule->type != SJA1105_RULE_VL)
105 if (rule->vl.type != SJA1105_VL_TIME_TRIGGERED)
108 if (max_cycle_time < rule->vl.cycle_time) {
109 max_cycle_time = rule->vl.cycle_time;
110 its_base_time = rule->vl.base_time;
124 list_for_each_entry(rule, &priv->flow_block.rules, list) {
128 if (rule->type != SJA1105_RULE_VL)
130 if (rule->vl.type != SJA1105_VL_TIME_TRIGGERED)
137 rbt = future_base_time(rule->vl.base_time, rule->vl.cycle_time,
143 for (i = 0; i < rule->vl.num_entries; i++) {
144 u8 gate_state = rule->vl.entries[i].gate_state;
148 rc = sja1105_insert_gate_entry(gating_cfg, rule,
155 entry_time += rule->vl.cycle_time;
157 time += rule->vl.entries[i].interval;
181 * all specified in rule) | (specified in rule)
192 * | \ (per rule) / | |
194 * v ------------ index of rule contents of rule
307 struct sja1105_rule *rule;
313 list_for_each_entry(rule, &priv->flow_block.rules, list) {
314 if (rule->type != SJA1105_RULE_VL)
317 num_virtual_links += hweight_long(rule->port_mask);
319 if (rule->vl.type != SJA1105_VL_NONCRITICAL)
321 if (max_sharindx < rule->vl.sharindx)
322 max_sharindx = rule->vl.sharindx;
383 list_for_each_entry(rule, &priv->flow_block.rules, list) {
386 if (rule->type != SJA1105_RULE_VL)
389 for_each_set_bit(port, &rule->port_mask, SJA1105_NUM_PORTS) {
392 vl_lookup[k].macaddr = rule->key.vl.dmac;
393 if (rule->key.type == SJA1105_KEY_VLAN_AWARE_VL) {
394 vl_lookup[k].vlanid = rule->key.vl.vid;
395 vl_lookup[k].vlanprior = rule->key.vl.pcp;
406 if (rule->vl.type == SJA1105_VL_NONCRITICAL)
407 vl_lookup[k].destports = rule->vl.destports;
410 vl_lookup[k].flow_cookie = rule->cookie;
466 struct sja1105_rule *rule = sja1105_rule_find(priv, cookie);
468 if (rule->vl.type == SJA1105_VL_NONCRITICAL)
470 if (rule->vl.type == SJA1105_VL_TIME_TRIGGERED) {
471 int sharindx = rule->vl.sharindx;
475 vl_policing[i].maxlen = rule->vl.maxlen;
480 vl_fwd[sharindx].priority = rule->vl.ipv;
482 vl_fwd[sharindx].destports = rule->vl.destports;
496 struct sja1105_rule *rule = sja1105_rule_find(priv, cookie);
512 if (!rule) {
513 rule = kzalloc(sizeof(*rule), GFP_KERNEL);
514 if (!rule)
517 rule->cookie = cookie;
518 rule->type = SJA1105_RULE_VL;
519 rule->key = *key;
520 list_add(&rule->list, &priv->flow_block.rules);
523 rule->port_mask |= BIT(port);
525 rule->vl.destports |= destports;
527 rule->vl.destports = destports;
531 rule->port_mask &= ~BIT(port);
532 if (!rule->port_mask) {
533 list_del(&rule->list);
534 kfree(rule);
542 struct sja1105_rule *rule, struct netlink_ext_ack *extack)
546 rule->port_mask &= ~BIT(port);
547 if (!rule->port_mask) {
548 list_del(&rule->list);
549 kfree(rule);
573 struct sja1105_rule *rule = sja1105_rule_find(priv, cookie);
611 if (!rule) {
612 rule = kzalloc(sizeof(*rule), GFP_KERNEL);
613 if (!rule)
616 list_add(&rule->list, &priv->flow_block.rules);
617 rule->cookie = cookie;
618 rule->type = SJA1105_RULE_VL;
619 rule->key = *key;
620 rule->vl.type = SJA1105_VL_TIME_TRIGGERED;
621 rule->vl.sharindx = index;
622 rule->vl.base_time = base_time;
623 rule->vl.cycle_time = cycle_time;
624 rule->vl.num_entries = num_entries;
625 rule->vl.entries = kcalloc(num_entries,
628 if (!rule->vl.entries) {
674 rule->vl.entries[i] = entries[i];
685 rule->vl.maxlen = VLAN_ETH_FRAME_LEN + ETH_FCS_LEN;
686 rule->vl.ipv = ipv;
689 rule->port_mask |= BIT(port);
707 rule->port_mask &= ~BIT(port);
708 if (!rule->port_mask) {
709 list_del(&rule->list);
710 kfree(rule->vl.entries);
711 kfree(rule);
750 struct sja1105_rule *rule, struct flow_stats *stats,
761 if (rule->vl.type != SJA1105_VL_TIME_TRIGGERED)
764 vlid = sja1105_find_vlid(priv, port, &rule->key);
781 flow_stats_update(stats, 0, pkts - rule->vl.stats.pkts, 0,
782 jiffies - rule->vl.stats.lastused,
785 rule->vl.stats.pkts = pkts;
786 rule->vl.stats.lastused = jiffies;