diff options
Diffstat (limited to 'datapath-windows/ovsext/Flow.c')
-rw-r--r-- | datapath-windows/ovsext/Flow.c | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/datapath-windows/ovsext/Flow.c b/datapath-windows/ovsext/Flow.c index 9993e49ba..a82b51b0d 100644 --- a/datapath-windows/ovsext/Flow.c +++ b/datapath-windows/ovsext/Flow.c @@ -850,6 +850,14 @@ MapFlowKeyToNlKey(PNL_BUFFER nlBuf, goto done; } + if (flowKey->dpHash) { + if (!NlMsgPutTailU32(nlBuf, OVS_KEY_ATTR_DP_HASH, + flowKey->dpHash)) { + rc = STATUS_UNSUCCESSFUL; + goto done; + } + } + /* Ethernet header */ RtlCopyMemory(&(ethKey.eth_src), flowKey->l2.dlSrc, ETH_ADDR_LEN); RtlCopyMemory(&(ethKey.eth_dst), flowKey->l2.dlDst, ETH_ADDR_LEN); @@ -1377,6 +1385,11 @@ _MapKeyAttrToFlowPut(PNL_ATTR *keyAttrs, destKey->l2.keyLen += sizeof(destKey->recircId); } + if (keyAttrs[OVS_KEY_ATTR_DP_HASH]) { + destKey->dpHash = NlAttrGetU32(keyAttrs[OVS_KEY_ATTR_DP_HASH]); + destKey->l2.keyLen += sizeof(destKey->dpHash); + } + /* ===== L2 headers ===== */ destKey->l2.inPort = NlAttrGetU32(keyAttrs[OVS_KEY_ATTR_IN_PORT]); @@ -2269,6 +2282,7 @@ ReportFlowInfo(OvsFlow *flow, } info->key.recircId = flow->key.recircId; + info->key.dpHash = flow->key.dpHash; return status; } |