-
Notifications
You must be signed in to change notification settings - Fork 94
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[dpapp] Add flow in bmv2 pipeline #608
Conversation
Hi @jimmyzhai - is this also ready to merge? Thank you! |
Hi @jimmyzhai - looks like we have conflicts here too... |
bb8a85a
to
1e3fd57
Compare
65e401d
to
7a721be
Compare
1. Update flow table 2. Add dash headers towards DPAPP
2. refactor dash_ingress
7a721be
to
e939e3d
Compare
dash-pipeline/bmv2/dash_headers.p4
Outdated
const bit<16> PACKET_META_HDR_SIZE=dash_packet_meta_t.minSizeInBytes(); | ||
|
||
#define DASH_ETHTYPE 0x876d | ||
#define DPAPP_MAC 0x02fe23f0e413 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
will the MAC be changed on other people's machine?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's a temporary hardcode. Mark FIXME comment to fix it later.
dash-pipeline/bmv2/dash_metadata.p4
Outdated
@@ -261,7 +140,7 @@ struct ha_data_t { | |||
bit<16> dp_channel_src_port_max; | |||
|
|||
// HA packet/flow state | |||
dash_ha_flow_sync_state_t flow_sync_state; | |||
dash_flow_state_t flow_sync_state; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
since you renamed the struct, will be better to also rename the field
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Rename it to ha_flow_state
.
dash-pipeline/bmv2/dash_metadata.p4
Outdated
@@ -303,13 +182,18 @@ struct metadata_t { | |||
|
|||
// Flow data | |||
conntrack_data_t conntrack_data; | |||
flow_table_data_t flow_table; | |||
dash_flow_state_t flow_state; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
is this duplicated w/ the one in ha_data_t?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It is NO by now. Flow state machine and ha state machine are separated. We may refine it later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this design is weird, what's their difference? if they are not the same, can we split them into 2 types?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
if they are the same, then we should merge them into one.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Merged
dash-pipeline/bmv2/dash_parser.p4
Outdated
packet.extract(hd.u0_ethernet); | ||
transition select(hd.u0_ethernet.ether_type) { | ||
IPV4_ETHTYPE: parse_u0_ipv4; | ||
IPV6_ETHTYPE: parse_u0_ipv6; | ||
DASH_ETHTYPE: parse_dash; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
parse_dash -> parse_dash_hdr and etc.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fixed
dash-pipeline/bmv2/dash_parser.p4
Outdated
default: accept; | ||
} | ||
} | ||
|
||
state parse_dash { | ||
packet.extract(hd.packet_meta); | ||
if (hd.packet_meta.packet_subtype != dash_packet_subtype_t.NONE) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
will be better to check packet_subtype against the flow_xxx instead of NONE. it will be more robust and more readable.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fixed
dash-pipeline/bmv2/dash_pipeline.p4
Outdated
table acl_group { | ||
/* This table API should be implemented manually using underlay SAI */ | ||
@SaiTable[ignored = "true"] | ||
table appliance { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
need to sync to latest code. this is changed now.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
fixed
dash-pipeline/bmv2/dash_pipeline.p4
Outdated
@@ -17,65 +17,94 @@ | |||
#include "stages/metering_update.p4" | |||
#include "underlay.p4" | |||
|
|||
control dash_ingress( | |||
control dash_inbound_routing_stage( |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this seems to be doing similar things as this PR: #569. will need to resolve the conflicts...
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Merged PR #569.
as make p4c-dpdk-pna fails due to: terminate called after throwing an instance of 'Util::CompilerBug' what(): In file: /p4c/backends/dpdk/dpdkArch.cpp:467 Compiler Bug: header fields should be of type bit<> or varbit<>found this is_ipv6
overlay_rewrite_data_t -> meta_overlay_rewrite_data_t, as header in struct is not well supported for target dpdk-pna.
@@ -134,14 +46,6 @@ enum bit<8> dash_eni_mac_type_t { | |||
struct conntrack_data_t { | |||
bool allow_in; | |||
bool allow_out; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
the following fields are flow related and intentionally being aggregated into this structure, because conntrack_data_t is used to hold all data that is related to flow.
and many of them are moved out from this structure and some fields seem to be missing, such as reverse_flow_key (it somehow doesn't show up in my search).
it doesn't feel to be right to me. this structure should not be changed. I can understand moving some of the data types as header, but the metadata should be remained - as they are different from header conceptually.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
For flow, I intend to use a new flow metadata.
length = length + FLOW_DATA_HDR_SIZE; | ||
|
||
if (meta.routing_actions & dash_routing_actions_t.STATIC_ENCAP != 0) { | ||
#ifdef TARGET_DPDK_PNA |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
is it possible to remove these ifdef?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Not necessary
meta.conntrack_data.flow_table.max_flow_count = max_flow_count; | ||
meta.conntrack_data.flow_table.flow_enabled_key = dash_flow_enabled_key; | ||
meta.conntrack_data.flow_table.flow_ttl_in_milliseconds = flow_ttl_in_milliseconds; | ||
meta.flow_table.max_flow_count = max_flow_count; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
do you mind to keep these fields in the conntrack_data, which makes the code easy the understand and won't complicates the metadata top-level structure - it is already a mess. : (
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'll re-organize them in flow metadata with new PR
@@ -125,6 +119,12 @@ sai_apis: | |||
type: sai_uint16_t | |||
objects: null | |||
valid_only: null | |||
- !!python/object:utils.sai_spec.sai_struct_entry.SaiStructEntry |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
wow... the API changes in this file is not expected, many of them are order change. we need to get this fixed. this will break the existing flow API.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
fixed
a3b9cf2
to
0045672
Compare
0045672
to
73256bc
Compare
dash-pipeline/bmv2/dash_headers.p4
Outdated
ENCAP_U1 = (1 << 1), | ||
SET_SMAC = (1 << 2), | ||
SET_DMAC = (1 << 3), | ||
NAT = (1 << 4), |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
will be better to split into DNAT and SNAT, same to the NAT_PORT.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fixed
dash-pipeline/bmv2/dash_headers.p4
Outdated
NAT46 = (1 << 5), | ||
NAT64 = (1 << 6), | ||
NAT_PORT = (1 << 7), | ||
REVERSE_TUNNEL = (1 << 8) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
sync'ed offline. remove : D
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fixed
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
overall looks good to me! the change is already large enough. let's get this change in first, and leave other improvements to later changes.
@@ -24,6 +24,7 @@ def load_word_fixers() -> None: | |||
"pb": "protocol buffer", | |||
"proto": "protocol", | |||
"smac": "source MAC", | |||
"dest": "destination", |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why is the goal of dest?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is only for word spell check, "dest" is used as a short style of "destination" in code/document.
meta.u0_encap_data.vni); | ||
} | ||
else if (meta.u0_encap_data.dash_encapsulation == dash_encapsulation_t.NVGRE) { | ||
push_vxlan_tunnel_u0(hdr, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should we change this?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
fixed
meta.u0_encap_data.vni); | ||
} | ||
else if (meta.u0_encap_data.dash_encapsulation == dash_encapsulation_t.NVGRE) { | ||
push_vxlan_tunnel_u1(hdr, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should we change this?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
fixed
|
||
/* Reverse flow key is not used by now */ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should put near the Reverse flow key.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should be right here for a placeholder of reverse flow key.
|
||
apply { | ||
if (!hdr.flow_key.isValid()) { | ||
flow_table.apply(); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why this line is related to hdr.flow_key.isValid()?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If the packet is recirculated from dpapp to dash pipeline, the flow key has been filled in dash parser and become valid. Here not need to set flow key again.
Thanks Zhixiong for reviewing it! |
Following dpapp HLD - #606, this is the 2nd part implementation. It updates bmv2 pipeline to have stateful packet processing.