/Linux-v6.1/samples/pktgen/ |
D | pktgen_sample04_many_flows.sh | 4 # Script example for many flows testing 6 # Number of simultaneous flows limited by variable $FLOWS 33 # Limiting the number of concurrent flows ($FLOWS) 36 [ -z "$FLOWS" ] && FLOWS="8000" 84 # Limit number of flows (max 65535) 85 pg_set $dev "flows $FLOWS"
|
/Linux-v6.1/tools/testing/selftests/tc-testing/tc-tests/qdiscs/ |
D | fq_codel.json | 18 …"matchPattern": "qdisc fq_codel 1: root refcnt [0-9]+ limit 10240p flows 1024 quantum.*target 5ms … 41 …"matchPattern": "qdisc fq_codel 1: root refcnt [0-9]+ limit 1000p flows 1024 quantum.*target 5ms i… 64 …"matchPattern": "qdisc fq_codel 1: root refcnt [0-9]+ limit 10240p flows 1024 quantum.*target 5ms … 87 …"matchPattern": "qdisc fq_codel 1: root refcnt [0-9]+ limit 10240p flows 1024 quantum.*target 2ms … 110 …"matchPattern": "qdisc fq_codel 1: root refcnt [0-9]+ limit 10240p flows 1024 quantum.*target 5ms … 133 …"matchPattern": "qdisc fq_codel 1: root refcnt [0-9]+ limit 10240p flows 1024 quantum 9000 target … 156 …"matchPattern": "qdisc fq_codel 1: root refcnt [0-9]+ limit 10240p flows 1024 quantum.*target 5ms … 179 …"matchPattern": "qdisc fq_codel 1: root refcnt [0-9]+ limit 10240p flows 1024 quantum.*target 5ms … 202 …"matchPattern": "qdisc fq_codel 1: root refcnt [0-9]+ limit 10240p flows 1024 quantum.*target 5ms … 222 …"cmdUnderTest": "$TC qdisc add dev $DUMMY handle 1: root fq_codel limit 1000 flows 256 drop_batch … [all …]
|
D | fq_pie.json | 4 "name": "Create FQ-PIE with invalid number of flows", 12 "cmdUnderTest": "$TC qdisc add dev $DUMMY handle 1: root fq_pie flows 65536", 15 "matchPattern": "qdisc fq_pie 1: root refcnt 2 limit 10240p flows 65536",
|
/Linux-v6.1/include/net/ |
D | fq_impl.h | 36 idx = flow - fq->flows; in __fq_adjust_removal() 152 flow = &fq->flows[idx]; in fq_flow_classify() 160 tin->flows++; in fq_flow_classify() 173 struct fq_flow *cur = &fq->flows[i]; in fq_find_fattest_flow() 357 fq->flows = kvcalloc(fq->flows_cnt, sizeof(fq->flows[0]), GFP_KERNEL); in fq_init() 358 if (!fq->flows) in fq_init() 363 kvfree(fq->flows); in fq_init() 364 fq->flows = NULL; in fq_init() 369 fq_flow_init(&fq->flows[i]); in fq_init() 380 fq_flow_reset(fq, &fq->flows[i], free_func); in fq_reset() [all …]
|
D | fq.h | 43 * pull interleaved packets out of the associated flows. 57 u32 flows; member 65 * @limit: max number of packets that can be queued across all flows 66 * @backlog: number of packets queued across all flows 69 struct fq_flow *flows; member
|
/Linux-v6.1/net/sched/ |
D | sch_fq_codel.c | 29 * Packets are classified (internal classifier or external) on flows. 30 * This is a Stochastic model (as we use a hash, several flows 33 * Flows are linked onto two (Round Robin) lists, 34 * so that new flows have priority on old ones. 53 struct fq_codel_flow *flows; /* Flows table [flows_cnt] */ member 55 u32 flows_cnt; /* number of flows */ 66 struct list_head new_flows; /* list of new flows */ 67 struct list_head old_flows; /* list of old flows */ 148 * This might sound expensive, but with 1024 flows, we scan in fq_codel_drop() 164 flow = &q->flows[idx]; in fq_codel_drop() [all …]
|
D | sch_fq_pie.c | 21 * - Packets are classified on flows. 22 * - This is a Stochastic model (as we use a hash, several flows might 25 * - Flows are linked onto two (Round Robin) lists, 26 * so that new flows have priority on old ones. 57 struct fq_pie_flow *flows; member 149 sel_flow = &q->flows[idx]; in fq_pie_qdisc_enqueue() 298 if (q->flows) { in fq_pie_change() 300 "Number of flows cannot be changed"); in fq_pie_change() 306 "Number of flows must range in [1..65536]"); in fq_pie_change() 380 pie_calculate_probability(&q->p_params, &q->flows[idx].vars, in fq_pie_timer() [all …]
|
D | sch_sfq.c | 53 When hash collisions occur, several flows are considered as one. 69 - max 65408 flows, 76 #define SFQ_MAX_FLOWS (0x10000 - SFQ_MAX_DEPTH - 1) /* max number of flows */ 127 struct sfq_slot *slots; /* Flows table ('maxflows' entries) */ 135 * dep[0] : list of unused flows 136 * dep[1] : list of flows with 1 packet 137 * dep[X] : list of flows with X packets 140 unsigned int maxflows; /* number of flows in flows array */ 455 * but we could endup servicing new flows only, and freeze old ones. in sfq_enqueue() 458 /* We could use a bigger initial quantum for new flows */ in sfq_enqueue() [all …]
|
D | sch_fq.c | 12 * Flows are dynamically allocated and stored in a hash table of RB trees 13 * They are also part of one Round Robin 'queues' (new or old flows) 27 * dequeue() : serves flows in Round Robin 101 struct rb_root delayed; /* for rate limited flows */ 120 u32 flows; member 207 /* limit number of collected flows per round */ 254 q->flows -= fcnt; in fq_gc() 304 if (q->flows >= (2U << q->fq_trees_log) && in fq_classify() 305 q->inactive_flows > q->flows/2) in fq_classify() 359 q->flows++; in fq_classify() [all …]
|
D | sch_atm.c | 66 struct list_head flows; /* NB: "link" is also on this member 78 list_for_each_entry(flow, &p->flows, list) { in lookup_flow() 356 list_for_each_entry(flow, &p->flows, list) { in atm_tc_walk() 390 list_for_each_entry(flow, &p->flows, list) { in atm_tc_enqueue() 474 list_for_each_entry(flow, &p->flows, list) { in sch_atm_dequeue() 545 INIT_LIST_HEAD(&p->flows); in atm_tc_init() 548 list_add(&p->link.list, &p->flows); in atm_tc_init() 574 list_for_each_entry(flow, &p->flows, list) in atm_tc_reset() 584 list_for_each_entry(flow, &p->flows, list) { in atm_tc_destroy() 589 list_for_each_entry_safe(flow, tmp, &p->flows, list) { in atm_tc_destroy()
|
/Linux-v6.1/drivers/crypto/allwinner/sun8i-ss/ |
D | sun8i-ss-core.c | 74 ss->flows[flow].stat_req++; in sun8i_ss_run_task() 130 reinit_completion(&ss->flows[flow].complete); in sun8i_ss_run_task() 131 ss->flows[flow].status = 0; in sun8i_ss_run_task() 136 wait_for_completion_interruptible_timeout(&ss->flows[flow].complete, in sun8i_ss_run_task() 138 if (ss->flows[flow].status == 0) { in sun8i_ss_run_task() 157 ss->flows[flow].status = 1; in ss_irq_handler() 158 complete(&ss->flows[flow].complete); in ss_irq_handler() 453 seq_printf(seq, "Channel %d: nreq %lu\n", i, ss->flows[i].stat_req); in sun8i_ss_debugfs_show() 509 crypto_engine_exit(ss->flows[i].engine); in sun8i_ss_free_flows() 521 ss->flows = devm_kcalloc(ss->dev, MAXFLOW, sizeof(struct sun8i_ss_flow), in allocate_flows() [all …]
|
D | sun8i-ss-prng.c | 127 reinit_completion(&ss->flows[flow].complete); in sun8i_ss_prng_generate() 128 ss->flows[flow].status = 0; in sun8i_ss_prng_generate() 134 wait_for_completion_interruptible_timeout(&ss->flows[flow].complete, in sun8i_ss_prng_generate() 136 if (ss->flows[flow].status == 0) { in sun8i_ss_prng_generate()
|
/Linux-v6.1/drivers/net/wireless/intel/iwlwifi/ |
D | iwl-drv.h | 29 * DOC: Driver system flows - drv component 31 * This component implements the system flows such as bus enumeration, bus 32 * removal. Bus dependent parts of system flows (such as iwl_pci_probe) are in 37 * the wifi flows: it will allow to have several fw API implementation. These 62 * specific system flows implementations. For example, the bus specific probe 73 * Stop the driver. This should be called by bus specific system flows
|
/Linux-v6.1/samples/bpf/ |
D | do_hbm_test.sh | 18 echo " [-f=<#flows>|--flows=<#flows>] [-h] [-i=<id>|--id=<id >]" 34 echo " -f or --flows number of concurrent flows (default=1)" 38 echo " -l do not limit flows using loopback" 78 flows=1 150 -f=*|--flows=*) 151 flows="${i#*=}" 278 while [ $flow_cnt -le $flows ] ; do 320 while [ $flow_cnt -le $flows ] ; do 346 iperf3 -c $host -p $port -i 0 -P $flows -f m -t $dur > iperf.$id 366 while [ $flow_cnt -le $flows ] ; do [all …]
|
/Linux-v6.1/Documentation/networking/ |
D | scaling.rst | 31 of logical flows. Packets for each flow are steered to a separate receive 188 to the same CPU is CPU load imbalance if flows vary in packet rate. 194 Flow Limit is an optional RPS feature that prioritizes small flows 195 during CPU contention by dropping packets from large flows slightly 196 ahead of those from small flows. It is active only when an RPS or RFS 202 new packet is dropped. Packets from other flows are still only 206 even large flows maintain connectivity. 224 identification of large flows and fewer false positives. The default 261 flows to the CPUs where those flows are being processed. The flow hash 266 same CPU. Indeed, with many flows and few CPUs, it is very likely that [all …]
|
D | nf_flowtable.rst | 33 specifies what flows are placed into the flowtable. Hence, packets follow the 34 classic IP forwarding path unless the user explicitly instruct flows to use this 111 You can identify offloaded flows through the [OFFLOAD] tag when listing your 130 instead the real device is sufficient for the flowtable to track your flows. 198 There is a workqueue that adds the flows to the hardware. Note that a few 202 You can identify hardware offloaded flows through the [HW_OFFLOAD] tag when
|
D | openvswitch.rst | 16 table" that userspace populates with "flows" that map from keys based 104 A wildcarded flow can represent a group of exact match flows. Each '1' bit 108 by reduce the number of new flows need to be processed by the user space program. 120 two possible approaches: reactively install flows as they miss the kernel 130 The behavior when using overlapping wildcarded flows is undefined. It is the 133 performs best-effort detection of overlapping wildcarded flows and may reject 146 future operations. The kernel is not required to index flows by the original
|
/Linux-v6.1/drivers/net/ethernet/marvell/mvpp2/ |
D | mvpp2_cls.c | 26 /* TCP over IPv4 flows, Not fragmented, no vlan tag */ 45 /* TCP over IPv4 flows, Not fragmented, with vlan tag */ 61 /* TCP over IPv4 flows, fragmented, no vlan tag */ 80 /* TCP over IPv4 flows, fragmented, with vlan tag */ 96 /* UDP over IPv4 flows, Not fragmented, no vlan tag */ 115 /* UDP over IPv4 flows, Not fragmented, with vlan tag */ 131 /* UDP over IPv4 flows, fragmented, no vlan tag */ 150 /* UDP over IPv4 flows, fragmented, with vlan tag */ 166 /* TCP over IPv6 flows, not fragmented, no vlan tag */ 179 /* TCP over IPv6 flows, not fragmented, with vlan tag */ [all …]
|
/Linux-v6.1/drivers/net/ethernet/netronome/nfp/flower/ |
D | conntrack.h | 50 * @tc_merge_tb: The table of merged tc flows 56 * @nft_merge_tb: The table of merged tc+nft flows 118 * @children: List of tc_merge flows this flow forms part of 139 * struct nfp_fl_ct_tc_merge - Merge of two flows from tc 161 * struct nfp_fl_nft_tc_merge - Merge of tc_merge flows with nft flow 257 * nfp_fl_ct_stats() - Handle flower stats callbacks for ct flows
|
/Linux-v6.1/drivers/net/ethernet/mellanox/mlx5/core/en/ |
D | tc_priv.h | 83 /* flows sharing the same reformat object - currently mpls decap */ 87 /* flows sharing same route entry */ 101 struct list_head hairpin; /* flows sharing the same hairpin */ 102 struct list_head peer; /* flows with peer flow */ 103 struct list_head unready; /* flows not ready to be offloaded (e.g
|
/Linux-v6.1/drivers/dma/ti/ |
D | k3-udma-glue.c | 83 struct k3_udma_glue_rx_flow *flows; member 616 * req.rxcq_qnum = k3_ringacc_get_ring_id(rx_chn->flows[0].ringrx); in k3_udma_glue_cfg_rx_chn() 641 struct k3_udma_glue_rx_flow *flow = &rx_chn->flows[flow_num]; in k3_udma_glue_release_rx_flow() 661 struct k3_udma_glue_rx_flow *flow = &rx_chn->flows[flow_idx]; in k3_udma_glue_cfg_rx_flow() 958 rx_chn->flows = devm_kcalloc(dev, rx_chn->flow_num, in k3_udma_glue_request_rx_chn_priv() 959 sizeof(*rx_chn->flows), GFP_KERNEL); in k3_udma_glue_request_rx_chn_priv() 960 if (!rx_chn->flows) { in k3_udma_glue_request_rx_chn_priv() 970 rx_chn->flows[i].udma_rflow_id = rx_chn->flow_id_base + i; in k3_udma_glue_request_rx_chn_priv() 1014 * Linux can only request and manipulate by dedicated RX flows in k3_udma_glue_request_remote_rx_chn() 1039 rx_chn->flows = devm_kcalloc(dev, rx_chn->flow_num, in k3_udma_glue_request_remote_rx_chn() [all …]
|
/Linux-v6.1/include/uapi/linux/ |
D | pkt_sched.h | 62 classes (or flows) have major equal to parent qdisc major, and 218 unsigned flows; /* Maximal number of flows */ member 767 __u32 penalty_rate; /* inelastic flows are rate limited to 'rate' pps */ 866 __u32 new_flows_len; /* count of flows in new list */ 867 __u32 old_flows_len; /* count of flows in old list */ 941 __u32 flows; member 1031 __u32 new_flow_count; /* count of new flows created by packets */ 1032 __u32 new_flows_len; /* count of flows in new list */ 1033 __u32 old_flows_len; /* count of flows in old list */
|
/Linux-v6.1/drivers/media/platform/amphion/ |
D | vpu_dbg.c | 186 for (i = 0; i < ARRAY_SIZE(inst->flows); i++) { in vpu_dbg_instance() 187 u32 idx = (inst->flow_idx + i) % (ARRAY_SIZE(inst->flows)); in vpu_dbg_instance() 189 if (!inst->flows[idx]) in vpu_dbg_instance() 192 inst->flows[idx] >= VPU_MSG_ID_NOOP ? "M" : "C", in vpu_dbg_instance() 193 inst->flows[idx]); in vpu_dbg_instance() 485 inst->flows[inst->flow_idx] = flow; in vpu_inst_record_flow() 486 inst->flow_idx = (inst->flow_idx + 1) % (ARRAY_SIZE(inst->flows)); in vpu_inst_record_flow()
|
/Linux-v6.1/tools/perf/pmu-events/arch/arm64/fujitsu/a64fx/ |
D | pipeline.json | 141 … the number of times where 2 elements of the gather instructions became 2 flows because 2 elements… 144 … the number of times where 2 elements of the gather instructions became 2 flows because 2 elements… 159 "PublicDescription": "This event counts the number of flows of the scatter instructions.", 162 "BriefDescription": "This event counts the number of flows of the scatter instructions."
|
/Linux-v6.1/drivers/infiniband/hw/hfi1/ |
D | tid_rdma.c | 47 /* Reserved generation value to set to unused flows for kernel contexts */ 757 u32 generation = rcd->flows[flow_idx].generation; in kern_setup_hw_flow() 775 rcd->flows[flow_idx].generation = in kern_clear_hw_flow() 776 kern_flow_generation_next(rcd->flows[flow_idx].generation); in kern_clear_hw_flow() 804 rcd->flows[fs->index].generation = fs->generation; in hfi1_kern_setup_hw_flow() 853 rcd->flows[i].generation = mask_generation(get_random_u32()); in hfi1_kern_init_ctxt_generations() 1436 * (6) Reserves and programs HW flows. 1443 * invocation of function call. With flow = &req->flows[req->flow_idx], 1465 struct tid_rdma_flow *flow = &req->flows[req->setup_head]; in hfi1_kern_exp_rcv_setup() 1556 struct tid_rdma_flow *flow = &req->flows[req->clear_tail]; in hfi1_kern_exp_rcv_clear() [all …]
|