Commit 32312e27 authored by vember's avatar vember

Optimize the code, increase the bandwidth of more than 100M

parent ac565b19
set interface state GigabitEthernetb/0/0 up set interface state if_n3 up
set interface ip address GigabitEthernetb/0/0 192.168.10.10/24 set interface ip address if_n3 192.168.10.10/24
set interface state if_n6 up
set interface ip address if_n6 192.168.30.10/24
create gtpu tunnel src 192.168.10.10 dst 192.168.10.100 teid 1 encap-vrf-id 0 decap-next node ip4-lookup
ip route add 192.169.0.0/24 via gtpu_tunnel0
ip route add 0.0.0.0/0 via if_n6 192.168.30.11
set interface mac address if_n3 9c:69:b4:61:f0:c0
set interface state GigabitEthernetb/0/1 up
set interface ip address GigabitEthernetb/0/1 192.168.30.10/24
create gtpu tunnel src 192.168.10.10 dst 192.168.10.11 teid 1 encap-vrf-id 0 decap-next node ip4-lookup
ip route add 192.168.20.0/24 via gtpu_tunnel0
ip route add 0.0.0.0/0 via GigabitEthernetb/0/1
...@@ -158,8 +158,8 @@ upf_forward (vlib_main_t * vm, vlib_node_runtime_t * node, ...@@ -158,8 +158,8 @@ upf_forward (vlib_main_t * vm, vlib_node_runtime_t * node,
next = UPF_FORWARD_NEXT_DROP; next = UPF_FORWARD_NEXT_DROP;
//active = pfcp_get_rules (sess, PFCP_ACTIVE); //active = pfcp_get_rules (sess, PFCP_ACTIVE);
if (PREDICT_FALSE (!sess)) //if (PREDICT_FALSE (!sess))
goto trace; // goto trace;
if (PREDICT_TRUE (upf_buffer_opaque (b)->gtpu.pdr_idx != ~0)) if (PREDICT_TRUE (upf_buffer_opaque (b)->gtpu.pdr_idx != ~0))
{ {
...@@ -167,8 +167,8 @@ upf_forward (vlib_main_t * vm, vlib_node_runtime_t * node, ...@@ -167,8 +167,8 @@ upf_forward (vlib_main_t * vm, vlib_node_runtime_t * node,
//far = pfcp_get_far_by_id (active, pdr->far_id); // how find far by far_id ? //far = pfcp_get_far_by_id (active, pdr->far_id); // how find far by far_id ?
} }
if (PREDICT_FALSE (!pdr) /* || PREDICT_FALSE (!far)*/ ) //if (PREDICT_FALSE (!pdr) /* || PREDICT_FALSE (!far)*/ )
goto trace; // goto trace;
u8 is_find = 0; u8 is_find = 0;
......
...@@ -134,7 +134,11 @@ upf_gtpu_input (vlib_main_t * vm, ...@@ -134,7 +134,11 @@ upf_gtpu_input (vlib_main_t * vm,
if(0) if(0)
clib_warning("rule_index0:0x%x, rule_index0:0x%x, t0->flags:0x%x, t1->flags:0x%x", clib_warning("rule_index0:0x%x, rule_index0:0x%x, t0->flags:0x%x, t1->flags:0x%x",
rule_index0, rule_index1,t0->flags, t1->flags); rule_index0, rule_index1,t0->flags, t1->flags);
//static int count = 0;
//if((count++) % 100 == 0)
// clib_upf_debug(um->log_fd,"count:%d", count);
/* Prefetch next iteration. */ /* Prefetch next iteration. */
{ {
vlib_buffer_t *p2, *p3; vlib_buffer_t *p2, *p3;
...@@ -327,7 +331,8 @@ upf_gtpu_input (vlib_main_t * vm, ...@@ -327,7 +331,8 @@ upf_gtpu_input (vlib_main_t * vm,
if(gtpu0->next_ext_type == NR_RAN_CONTAINER || gtpu0->next_ext_type == PDU_SESSION_CONTAINER) if(gtpu0->next_ext_type == NR_RAN_CONTAINER || gtpu0->next_ext_type == PDU_SESSION_CONTAINER)
{ {
u8 *ext_header = (u8 *)(&gtpu0->next_ext_type + 1); u8 *ext_header = (u8 *)(&gtpu0->next_ext_type + 1);
while (cur_num < MAX_EXT_NUM && ((u8 *)ext_header < end)) static int count_a = 0;
while (cur_num < MAX_EXT_NUM && ((u8 *)ext_header < end) && (count_a == 0))
{ {
gtpu_hdr_len0 += (*ext_header) * 4; gtpu_hdr_len0 += (*ext_header) * 4;
gtpu_ext0[cur_num].len = (*ext_header); gtpu_ext0[cur_num].len = (*ext_header);
...@@ -343,7 +348,10 @@ upf_gtpu_input (vlib_main_t * vm, ...@@ -343,7 +348,10 @@ upf_gtpu_input (vlib_main_t * vm,
cur_num += 1; cur_num += 1;
tmp += 1 ; tmp += 1 ;
if(1 != *ext_header || NR_RAN_CONTAINER != *(ext_header + 3) || PDU_SESSION_CONTAINER != *(ext_header + 3)) if(1 != *ext_header || NR_RAN_CONTAINER != *(ext_header + 3) || PDU_SESSION_CONTAINER != *(ext_header + 3))
{
count_a++;
break; break;
}
} }
} }
} }
...@@ -405,6 +413,7 @@ upf_gtpu_input (vlib_main_t * vm, ...@@ -405,6 +413,7 @@ upf_gtpu_input (vlib_main_t * vm,
//add it in 20200708 //add it in 20200708
if(ip4_0) if(ip4_0)
{ {
static int count_b =0;
gtpu4_header_dl_t *gtpu_dl = bupt_lookup_dl_gtpu4_header_by_ueip(ip4_0->src_address.as_u32); gtpu4_header_dl_t *gtpu_dl = bupt_lookup_dl_gtpu4_header_by_ueip(ip4_0->src_address.as_u32);
if(gtpu_dl) if(gtpu_dl)
{ {
...@@ -415,9 +424,10 @@ upf_gtpu_input (vlib_main_t * vm, ...@@ -415,9 +424,10 @@ upf_gtpu_input (vlib_main_t * vm,
gtpu_dl->next_ext_type = gtpu0->next_ext_type; gtpu_dl->next_ext_type = gtpu0->next_ext_type;
gtpu_dl->cur_ext_num = cur_num; gtpu_dl->cur_ext_num = cur_num;
if(gtpu_dl->cur_ext_num > 0) if(gtpu_dl->cur_ext_num > 0 && (count_b == 0))
{ {
memcpy(gtpu_dl->ext_dl, gtpu_ext0, cur_num * sizeof(gtpu_ext_header_t)); memcpy(gtpu_dl->ext_dl, gtpu_ext0, cur_num * sizeof(gtpu_ext_header_t));
count_b++;
} }
} }
} }
...@@ -440,17 +450,7 @@ upf_gtpu_input (vlib_main_t * vm, ...@@ -440,17 +450,7 @@ upf_gtpu_input (vlib_main_t * vm,
if(UPF_GTPU_INPUT_NEXT_DROP == next0) if(UPF_GTPU_INPUT_NEXT_DROP == next0)
clib_upf_debug(um->log_fd, "gtpu_drop, packet 0"); clib_upf_debug(um->log_fd, "gtpu_drop, packet 0");
if(0x7302a8c0 == ip4_0->dst_address.as_u32 && 17 == ip4_0->protocol) //192.168.2.96
{
count++;
struct in_addr addr;
addr.s_addr = ip4_0->dst_address.as_u32;
long end_time = end_microsecond();
clib_upf_debug(um->log_fd,"UL ICMP count:%d,diff_time:%ld, dstip:%s, length:%d, packet 0", count, end_time - start_time, inet_ntoa(addr), clib_net_to_host_u16(ip4_0->length) - 20 - 8);
}
if (PREDICT_FALSE if (PREDICT_FALSE
((gtpu1->ver_flags & GTPU_VER_MASK) != GTPU_V1_VER)) ((gtpu1->ver_flags & GTPU_VER_MASK) != GTPU_V1_VER))
{ {
...@@ -578,7 +578,8 @@ upf_gtpu_input (vlib_main_t * vm, ...@@ -578,7 +578,8 @@ upf_gtpu_input (vlib_main_t * vm,
if (PREDICT_FALSE ((gtpu1->ver_flags & GTPU_E_BIT) != 0)) if (PREDICT_FALSE ((gtpu1->ver_flags & GTPU_E_BIT) != 0))
{ {
u8 *end = vlib_buffer_get_tail(b1); u8 *end = vlib_buffer_get_tail(b1);
if(gtpu1->next_ext_type == NR_RAN_CONTAINER || gtpu1->next_ext_type == PDU_SESSION_CONTAINER) static int count_c =0;
if((gtpu1->next_ext_type == NR_RAN_CONTAINER || gtpu1->next_ext_type == PDU_SESSION_CONTAINER) && (count_c == 0))
{ {
u8 *ext_header = (u8 *)(&gtpu1->next_ext_type + 1); u8 *ext_header = (u8 *)(&gtpu1->next_ext_type + 1);
while (cur_num < MAX_EXT_NUM && ((u8 *)ext_header < end)) while (cur_num < MAX_EXT_NUM && ((u8 *)ext_header < end))
...@@ -597,7 +598,11 @@ upf_gtpu_input (vlib_main_t * vm, ...@@ -597,7 +598,11 @@ upf_gtpu_input (vlib_main_t * vm,
cur_num += 1; cur_num += 1;
tmp += 1 ; tmp += 1 ;
if(1 != *ext_header || NR_RAN_CONTAINER != *(ext_header + 3) || PDU_SESSION_CONTAINER != *(ext_header + 3)) if(1 != *ext_header || NR_RAN_CONTAINER != *(ext_header + 3) || PDU_SESSION_CONTAINER != *(ext_header + 3))
{
count_c++;
break; break;
}
} }
} }
} }
...@@ -660,6 +665,7 @@ upf_gtpu_input (vlib_main_t * vm, ...@@ -660,6 +665,7 @@ upf_gtpu_input (vlib_main_t * vm,
//test //test
if(ip4_1) if(ip4_1)
{ {
static int count_d = 0;
gtpu4_header_dl_t *gtpu_dl = bupt_lookup_dl_gtpu4_header_by_ueip(ip4_1->src_address.as_u32); gtpu4_header_dl_t *gtpu_dl = bupt_lookup_dl_gtpu4_header_by_ueip(ip4_1->src_address.as_u32);
if(gtpu_dl) if(gtpu_dl)
{ {
...@@ -670,9 +676,10 @@ upf_gtpu_input (vlib_main_t * vm, ...@@ -670,9 +676,10 @@ upf_gtpu_input (vlib_main_t * vm,
gtpu_dl->next_ext_type = gtpu0->next_ext_type; gtpu_dl->next_ext_type = gtpu0->next_ext_type;
gtpu_dl->cur_ext_num = cur_num; gtpu_dl->cur_ext_num = cur_num;
if(gtpu_dl->cur_ext_num > 0) if(gtpu_dl->cur_ext_num > 0 && (count_d == 0))
{ {
memcpy(gtpu_dl->ext_dl, gtpu_ext1, cur_num * sizeof(gtpu_ext_header_t)); memcpy(gtpu_dl->ext_dl, gtpu_ext1, cur_num * sizeof(gtpu_ext_header_t));
count_d++;
} }
} }
} }
...@@ -698,16 +705,6 @@ upf_gtpu_input (vlib_main_t * vm, ...@@ -698,16 +705,6 @@ upf_gtpu_input (vlib_main_t * vm,
if(UPF_GTPU_INPUT_NEXT_DROP == next1) if(UPF_GTPU_INPUT_NEXT_DROP == next1)
clib_upf_debug(um->log_fd, "gtpu_drop, packet 1"); clib_upf_debug(um->log_fd, "gtpu_drop, packet 1");
if(0x7302a8c0 == ip4_1->dst_address.as_u32 && 17 == ip4_1->protocol) //192.168.2.96
{
count++;
struct in_addr addr;
addr.s_addr = ip4_1->dst_address.as_u32;
long end_time = end_microsecond();
clib_upf_debug(um->log_fd,"UL ICMP count:%d,diff_time:%ld, dstip:%s, length:%d, packet 1", count, end_time - start_time, inet_ntoa(addr), clib_net_to_host_u16(ip4_0->length) - 20 - 8);
}
vlib_validate_buffer_enqueue_x2 (vm, node, next_index, vlib_validate_buffer_enqueue_x2 (vm, node, next_index,
to_next, n_left_to_next, to_next, n_left_to_next,
bi0, bi1, next0, next1); bi0, bi1, next0, next1);
...@@ -894,7 +891,7 @@ upf_gtpu_input (vlib_main_t * vm, ...@@ -894,7 +891,7 @@ upf_gtpu_input (vlib_main_t * vm,
if (PREDICT_FALSE ((gtpu0->ver_flags & GTPU_E_BIT) != 0)) if (PREDICT_FALSE ((gtpu0->ver_flags & GTPU_E_BIT) != 0))
{ {
u8 *end = vlib_buffer_get_tail(b0); u8 *end = vlib_buffer_get_tail(b0);
if(gtpu0->next_ext_type == NR_RAN_CONTAINER || gtpu0->next_ext_type == PDU_SESSION_CONTAINER) if((gtpu0->next_ext_type == NR_RAN_CONTAINER) || (gtpu0->next_ext_type == PDU_SESSION_CONTAINER))
{ {
u8 *ext_header = (u8 *)(&gtpu0->next_ext_type + 1); u8 *ext_header = (u8 *)(&gtpu0->next_ext_type + 1);
while (cur_num < MAX_EXT_NUM && ((u8 *)ext_header < end)) while (cur_num < MAX_EXT_NUM && ((u8 *)ext_header < end))
...@@ -912,11 +909,11 @@ upf_gtpu_input (vlib_main_t * vm, ...@@ -912,11 +909,11 @@ upf_gtpu_input (vlib_main_t * vm,
ext_header = ext_header + gtpu_ext[cur_num].len * 4; ext_header = ext_header + gtpu_ext[cur_num].len * 4;
cur_num += 1; cur_num += 1;
tmp += 1 ; tmp += 1 ;
if(1 != *ext_header || NR_RAN_CONTAINER != *(ext_header + 3) || PDU_SESSION_CONTAINER != *(ext_header + 3)) if(1 != *ext_header || NR_RAN_CONTAINER != *(ext_header + 3) || PDU_SESSION_CONTAINER != *(ext_header + 3))
break; break;
} }
} }
} }
} }
else else
...@@ -947,6 +944,7 @@ upf_gtpu_input (vlib_main_t * vm, ...@@ -947,6 +944,7 @@ upf_gtpu_input (vlib_main_t * vm,
/* inner IP header */ /* inner IP header */
ip4_0 = vlib_buffer_get_current (b0) + hdr_len0; ip4_0 = vlib_buffer_get_current (b0) + hdr_len0;
// ueip_is_exist_in_teid(u32 ueip, upf_session_t); // ueip_is_exist_in_teid(u32 ueip, upf_session_t);
if ((ip4_0->ip_version_and_header_length & 0xF0) == 0x40) if ((ip4_0->ip_version_and_header_length & 0xF0) == 0x40)
...@@ -963,19 +961,18 @@ upf_gtpu_input (vlib_main_t * vm, ...@@ -963,19 +961,18 @@ upf_gtpu_input (vlib_main_t * vm,
if(ip4_0) if(ip4_0)
{ {
gtpu4_header_dl_t *gtpu_dl = bupt_lookup_dl_gtpu4_header_by_ueip(ip4_0->src_address.as_u32); gtpu4_header_dl_t *gtpu_dl = bupt_lookup_dl_gtpu4_header_by_ueip(ip4_0->src_address.as_u32);
if(gtpu_dl)
//Avoid copying data multiple times
if(gtpu_dl && (gtpu_dl->cur_ext_num == 0) && !cur_num)
{ {
gtpu_dl->ver_flags = gtpu0->ver_flags; gtpu_dl->ver_flags = gtpu0->ver_flags;
gtpu_dl->type = gtpu0->type; gtpu_dl->type = gtpu0->type;
gtpu_dl->sequence = clib_net_to_host_u16(gtpu0->sequence); gtpu_dl->sequence = clib_net_to_host_u16(gtpu0->sequence);
gtpu_dl->pdu_number = gtpu0->pdu_number; gtpu_dl->pdu_number = gtpu0->pdu_number;
gtpu_dl->next_ext_type = gtpu0->next_ext_type; gtpu_dl->next_ext_type = gtpu0->next_ext_type;
gtpu_dl->cur_ext_num = cur_num; gtpu_dl->cur_ext_num = cur_num;
if(gtpu_dl->cur_ext_num > 0) memcpy(gtpu_dl->ext_dl, gtpu_ext, cur_num * sizeof(gtpu_ext_header_t));
{
memcpy(gtpu_dl->ext_dl, gtpu_ext, cur_num * sizeof(gtpu_ext_header_t));
}
} }
} }
......
...@@ -161,8 +161,8 @@ upf_input (vlib_main_t * vm, vlib_node_runtime_t * node, ...@@ -161,8 +161,8 @@ upf_input (vlib_main_t * vm, vlib_node_runtime_t * node,
sidx = upf_buffer_opaque (b)->gtpu.session_index; sidx = upf_buffer_opaque (b)->gtpu.session_index;
sess = pool_elt_at_index (gtm->sessions, sidx); sess = pool_elt_at_index (gtm->sessions, sidx);
if (PREDICT_FALSE (!sess)) //if (PREDICT_FALSE (!sess))
goto trace; // goto trace;
if (PREDICT_TRUE (upf_buffer_opaque (b)->gtpu.pdr_idx != ~0)) if (PREDICT_TRUE (upf_buffer_opaque (b)->gtpu.pdr_idx != ~0))
{ {
...@@ -170,8 +170,8 @@ upf_input (vlib_main_t * vm, vlib_node_runtime_t * node, ...@@ -170,8 +170,8 @@ upf_input (vlib_main_t * vm, vlib_node_runtime_t * node,
//far = pfcp_get_far_by_id (active, pdr->far_id); // how find far by far_id ? //far = pfcp_get_far_by_id (active, pdr->far_id); // how find far by far_id ?
} }
if (PREDICT_FALSE (!pdr) /* || PREDICT_FALSE (!far)*/ ) //if (PREDICT_FALSE (!pdr) /* || PREDICT_FALSE (!far)*/ )
goto trace; // goto trace;
//inner ip //inner ip
if(pdr->pdi.ue_addr.ip4.as_u32 != ip4_0->src_address.as_u32) if(pdr->pdi.ue_addr.ip4.as_u32 != ip4_0->src_address.as_u32)
......
...@@ -2744,14 +2744,13 @@ ip4_rewrite_inline_with_gso (vlib_main_t * vm, ...@@ -2744,14 +2744,13 @@ ip4_rewrite_inline_with_gso (vlib_main_t * vm,
} }
//update len; //update len;
ip0->length = clib_host_to_net_u16(outter_ip_length + gtpu_gtpu_lack_len + ext_all_len); ip0->length = clib_host_to_net_u16(outter_ip_length + gtpu_gtpu_lack_len + ext_all_len);
udp0->length = clib_host_to_net_u16(outter_udp_length + gtpu_gtpu_lack_len + ext_all_len); udp0->length = clib_host_to_net_u16(outter_udp_length + gtpu_gtpu_lack_len + ext_all_len);
gtpu4_header->length = clib_host_to_net_u16(inner_ip_length + gtpu_gtpu_lack_len + ext_all_len); gtpu4_header->length = clib_host_to_net_u16(inner_ip_length + gtpu_gtpu_lack_len + ext_all_len);
clib_memcpy_fast(new_gtpu_header, gtpu4_header, sizeof(bupt_gtpu4_header_t)); clib_memcpy_fast(new_gtpu_header, gtpu4_header, sizeof(bupt_gtpu4_header_t));
clib_memcpy_fast(new_gtpu_header + sizeof(bupt_gtpu4_header_t), gtpu4_ext_body, ext_all_len); clib_memcpy_fast(new_gtpu_header + sizeof(bupt_gtpu4_header_t), gtpu4_ext_body, ext_all_len);
//84: ip + icmp ; //84: ip + icmp ;
u8 *old_ip4 = (u8 *)(gtpu0 + 1); u8 *old_ip4 = (u8 *)(gtpu0 + 1);
clib_memcpy_fast(new_gtpu_header + sizeof(bupt_gtpu4_header_t) + ext_all_len, old_ip4, inner_ip_length); clib_memcpy_fast(new_gtpu_header + sizeof(bupt_gtpu4_header_t) + ext_all_len, old_ip4, inner_ip_length);
......
...@@ -2,24 +2,38 @@ unix { ...@@ -2,24 +2,38 @@ unix {
nodaemon nodaemon
log /var/log/upf/vpp/vpp.log log /var/log/upf/vpp/vpp.log
full-coredump full-coredump
gid vpp
interactive interactive
gid vpp
cli-listen /run/vpp/cli.sock cli-listen /run/vpp/cli.sock
#exec test_wzy.sh exec ./config_system.sh
#cli-listen localhost:5002 logsize 100
#exec @/work/gtpu_ext/vpp_0618/config_system.sh@ cli-prompt bupt#
exec /work/modify_teid/Buptvppe/config_system.sh
#exec /work96/test_mul_thread/upf_v0.4/upf-vpp/src/Buptvppe/config_system_v1.sh
monitor_url http://192.168.2.216:8878/status/vpp
} }
api-trace { api-trace {
on on
#save-api-table /tmp/save_api_table
} }
api-segment { api-segment {
gid vpp gid vpp
# global-size 2G
# api-size 64M
# global-pvt-heap-size size 262144
#api-pvt-heap-size 1M
}
logging
{
default-log-level info
default-syslog-log-level info
}
statseg {
default
#size 1024M
per-node-counters on
} }
cpu { cpu {
...@@ -30,11 +44,11 @@ cpu { ...@@ -30,11 +44,11 @@ cpu {
## Set logical CPU core where main thread runs, if main core is not set ## Set logical CPU core where main thread runs, if main core is not set
## VPP will use core 1 if available ## VPP will use core 1 if available
main-core 13 main-core 6
## Set logical CPU core(s) where worker threads are running ## Set logical CPU core(s) where worker threads are running
corelist-workers 14,15 corelist-workers 7
#corelist-io 5,6 #corelist-io 3,4
## Automatic pinning of thread(s) to CPU core(s) ## Automatic pinning of thread(s) to CPU core(s)
...@@ -42,12 +56,12 @@ cpu { ...@@ -42,12 +56,12 @@ cpu {
## Skipped CPU core(s) are not used for pinning main thread and working thread(s). ## Skipped CPU core(s) are not used for pinning main thread and working thread(s).
## The main thread is automatically pinned to the first available CPU core and worker(s) ## The main thread is automatically pinned to the first available CPU core and worker(s)
## are pinned to next free CPU core(s) after core assigned to main thread ## are pinned to next free CPU core(s) after core assigned to main thread
#skip-cores 4 # skip-cores 4
## Specify a number of workers to be created ## Specify a number of workers to be created
## Workers are pinned to N consecutive CPU cores while skipping "skip-cores" CPU core(s) ## Workers are pinned to N consecutive CPU cores while skipping "skip-cores" CPU core(s)
## and main thread's CPU core ## and main thread's CPU core
#workers 4 #workers 1
## Set scheduling policy and priority of main and worker threads ## Set scheduling policy and priority of main and worker threads
...@@ -64,32 +78,37 @@ buffers { ...@@ -64,32 +78,37 @@ buffers {
## Increase number of buffers allocated, needed only in scenarios with ## Increase number of buffers allocated, needed only in scenarios with
## large number of interfaces and worker threads. Value is per numa node. ## large number of interfaces and worker threads. Value is per numa node.
## Default is 16384 (8192 if running unpriviledged) ## Default is 16384 (8192 if running unpriviledged)
buffers-per-numa 128000 #buffers-per-numa 128000
#buffers-per-numa 2560000 buffers-per-numa 2560000
## Size of buffer data area ## Size of buffer data area
## Default is 2048 #Default is 2048
#default data-size 2048 #data size 4096
default data-size 2048 #default data-size 2048
} }
#mactime {
# lookup-table-buckets 32
# lookup-table-memory 1G
#}
dpdk { dpdk {
## Change default settings for all interfaces ## Change default settings for all interfaces
dev default { dev default {
## Number of receive queues, enables RSS ## Number of receive queues, enables RSS
## Default is 1 ## Default is 1
num-rx-queues 1 num-rx-queues 1
## Number of transmit queues, Default is equal ## Number of transmit queues, Default is equal
## to number of worker threads or 1 if no workers treads ## to number of worker threads or 1 if no workers treads
num-tx-queues 1
## Number of descriptors in transmit and receive rings ## Number of descriptors in transmit and receive rings
## increasing or reducing number can impact performance ## increasing or reducing number can impact performance
## Default is 1024 for both rx and tx ## Default is 1024 for both rx and tx
num-rx-desc 1024 # num-rx-desc 512
num-tx-desc 1024 # num-tx-desc 512
## VLAN strip offload mode for interface ## VLAN strip offload mode for interface
## Default is off ## Default is off
...@@ -98,29 +117,25 @@ dpdk { ...@@ -98,29 +117,25 @@ dpdk {
## Whitelist specific interface by specifying PCI address ## Whitelist specific interface by specifying PCI address
#82576 1G #82576 1G
#dev 0000:09:00.0 { dev 0000:02:00.0
# vlan-strip-offload off {
# num-rx-queues 1 name if_n3
# num-tx-queues 1 num-rx-queues 2
#} num-tx-queues 2
# dev 0000:09:00.1 { # num-rx-desc 1024
# vlan-strip-offload off # num-tx-desc 1024
# num-rx-queues 1 }
# num-tx-queues 1
#} dev 0000:02:00.1
{
name if_n6
#dev 0000:02:00.0 { num-rx-queues 1
# num-rx-queues 1 # num-rx-desc 1024
# num-rx-queues 1 # num-tx-desc 1024
#} }
dev 0000:06:00.1
dev 0000:06:00.0
#dev 0000:02:00.0
#dev 0000:05:00.0
## Whitelist specific interface by specifying PCI address and in ## Whitelist specific interface by specifying PCI address and in
## addition specify custom parameters for this interface ## addition specify custom parameters for this interface
...@@ -130,29 +145,39 @@ dpdk { ...@@ -130,29 +145,39 @@ dpdk {
## Change UIO driver used by VPP, Options are: igb_uio, vfio-pci, ## Change UIO driver used by VPP, Options are: igb_uio, vfio-pci,
## uio_pci_generic or auto (default) ## uio_pci_generic or auto (default)
# uio-driver vfio-pci
uio-driver igb_uio uio-driver igb_uio
#uio-driver vfio-pci
## Disable multi-segment buffers, improves performance but ## Disable multi-segment buffers, improves performance but
## disables Jumbo MTU support ## disables Jumbo MTU support
#no-multi-seg no-multi-seg
## Change hugepages allocation per-socket, needed only if there is need for ## Change hugepages allocation per-socket, needed only if there is need for
## larger number of mbufs. Default is 256M on each detected CPU socket ## larger number of mbufs. Default is 256M on each detected CPU socket
#socket-mem 2048,2048 #socket-mem 2048
socket-mem 1024 socket-mem 2048,2048
## Disables UDP / TCP TX checksum offload. Typically needed for use ## Disables UDP / TCP TX checksum offload. Typically needed for use
## faster vector PMDs (together with no-multi-seg) ## faster vector PMDs (together with no-multi-seg)
#no-tx-checksum-offload no-tx-checksum-offload
} }
plugins { #memory {
path /work/modify_teid/Buptvppe/build-root/install-vpp_debug-native/vpp/lib/vpp_plugins/ # main-heap-size 4G
# main-heap-page-size 1G
#}
#default main:1G, work:1G
heapsize 2G
#plugin default { enable }
plugins {
path ./build-root/install-vpp_debug-native/vpp/lib/vpp_plugins
plugin default { enable }
plugin dpdk_plugin.so { enable } plugin dpdk_plugin.so { enable }
plugin gtpu_plugin.so { enable } plugin gtpu_plugin.so { enable }
plugin upf_plugin.so { enable } plugin upf_plugin.so { enable }
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment