2  * Copyright 2014-2015 Open Networking Laboratory
 
   4  * Licensed under the Apache License, Version 2.0 (the "License");
 
   5  * you may not use this file except in compliance with the License.
 
   6  * You may obtain a copy of the License at
 
   8  *     http://www.apache.org/licenses/LICENSE-2.0
 
  10  * Unless required by applicable law or agreed to in writing, software
 
  11  * distributed under the License is distributed on an "AS IS" BASIS,
 
  12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 
  13  * See the License for the specific language governing permissions and
 
  14  * limitations under the License.
 
  16 package org.onosproject.provider.of.flow.impl;
 
  18 import static org.onosproject.net.flow.criteria.Criteria.matchLambda;
 
  19 import static org.onosproject.net.flow.criteria.Criteria.matchOchSignalType;
 
  20 import static org.onosproject.provider.of.flow.impl.OpenFlowValueMapper.lookupChannelSpacing;
 
  21 import static org.onosproject.provider.of.flow.impl.OpenFlowValueMapper.lookupGridType;
 
  22 import static org.onosproject.provider.of.flow.impl.OpenFlowValueMapper.lookupOchSignalType;
 
  23 import static org.slf4j.LoggerFactory.getLogger;
 
  25 import java.util.List;
 
  27 import org.onlab.packet.Ip4Address;
 
  28 import org.onlab.packet.Ip4Prefix;
 
  29 import org.onlab.packet.Ip6Address;
 
  30 import org.onlab.packet.Ip6Prefix;
 
  31 import org.onlab.packet.MacAddress;
 
  32 import org.onlab.packet.MplsLabel;
 
  33 import org.onlab.packet.TpPort;
 
  34 import org.onlab.packet.VlanId;
 
  35 import org.onosproject.core.DefaultGroupId;
 
  36 import org.onosproject.net.DeviceId;
 
  37 import org.onosproject.net.Lambda;
 
  38 import org.onosproject.net.PortNumber;
 
  39 import org.onosproject.net.flow.DefaultFlowEntry;
 
  40 import org.onosproject.net.flow.DefaultFlowRule;
 
  41 import org.onosproject.net.flow.DefaultTrafficSelector;
 
  42 import org.onosproject.net.flow.DefaultTrafficTreatment;
 
  43 import org.onosproject.net.flow.FlowEntry;
 
  44 import org.onosproject.net.flow.FlowEntry.FlowEntryState;
 
  45 import org.onosproject.net.flow.FlowRule;
 
  46 import org.onosproject.net.flow.TrafficSelector;
 
  47 import org.onosproject.net.flow.TrafficTreatment;
 
  48 import org.onosproject.net.flow.instructions.Instructions;
 
  49 import org.onosproject.openflow.controller.Dpid;
 
  50 import org.projectfloodlight.openflow.protocol.OFFlowMod;
 
  51 import org.projectfloodlight.openflow.protocol.OFFlowRemoved;
 
  52 import org.projectfloodlight.openflow.protocol.OFFlowStatsEntry;
 
  53 import org.projectfloodlight.openflow.protocol.action.OFAction;
 
  54 import org.projectfloodlight.openflow.protocol.action.OFActionCircuit;
 
  55 import org.projectfloodlight.openflow.protocol.action.OFActionExperimenter;
 
  56 import org.projectfloodlight.openflow.protocol.action.OFActionGroup;
 
  57 import org.projectfloodlight.openflow.protocol.action.OFActionOutput;
 
  58 import org.projectfloodlight.openflow.protocol.action.OFActionPopMpls;
 
  59 import org.projectfloodlight.openflow.protocol.action.OFActionSetDlDst;
 
  60 import org.projectfloodlight.openflow.protocol.action.OFActionSetDlSrc;
 
  61 import org.projectfloodlight.openflow.protocol.action.OFActionSetField;
 
  62 import org.projectfloodlight.openflow.protocol.action.OFActionSetNwDst;
 
  63 import org.projectfloodlight.openflow.protocol.action.OFActionSetNwSrc;
 
  64 import org.projectfloodlight.openflow.protocol.action.OFActionSetVlanPcp;
 
  65 import org.projectfloodlight.openflow.protocol.action.OFActionSetVlanVid;
 
  66 import org.projectfloodlight.openflow.protocol.instruction.OFInstruction;
 
  67 import org.projectfloodlight.openflow.protocol.instruction.OFInstructionApplyActions;
 
  68 import org.projectfloodlight.openflow.protocol.instruction.OFInstructionGotoTable;
 
  69 import org.projectfloodlight.openflow.protocol.instruction.OFInstructionWriteActions;
 
  70 import org.projectfloodlight.openflow.protocol.instruction.OFInstructionWriteMetadata;
 
  71 import org.projectfloodlight.openflow.protocol.match.Match;
 
  72 import org.projectfloodlight.openflow.protocol.match.MatchField;
 
  73 import org.projectfloodlight.openflow.protocol.oxm.OFOxm;
 
  74 import org.projectfloodlight.openflow.protocol.oxm.OFOxmOchSigidBasic;
 
  75 import org.projectfloodlight.openflow.protocol.ver13.OFFactoryVer13;
 
  76 import org.projectfloodlight.openflow.types.CircuitSignalID;
 
  77 import org.projectfloodlight.openflow.types.EthType;
 
  78 import org.projectfloodlight.openflow.types.IPv4Address;
 
  79 import org.projectfloodlight.openflow.types.IPv6Address;
 
  80 import org.projectfloodlight.openflow.types.Masked;
 
  81 import org.projectfloodlight.openflow.types.OFVlanVidMatch;
 
  82 import org.projectfloodlight.openflow.types.TransportPort;
 
  83 import org.projectfloodlight.openflow.types.U32;
 
  84 import org.projectfloodlight.openflow.types.U64;
 
  85 import org.projectfloodlight.openflow.types.U8;
 
  86 import org.projectfloodlight.openflow.types.VlanPcp;
 
  87 import org.slf4j.Logger;
 
  89 import com.google.common.collect.Lists;
 
  91 public class FlowEntryBuilder {
 
  92     private final Logger log = getLogger(getClass());
 
  94     private final OFFlowStatsEntry stat;
 
  95     private final OFFlowRemoved removed;
 
  96     private final OFFlowMod flowMod;
 
  98     private final Match match;
 
 100     // All actions are contained in an OFInstruction. For OF1.0
 
 101     // the instruction type is apply instruction (immediate set in ONOS speak)
 
 102     private final List<OFInstruction> instructions;
 
 104     private final Dpid dpid;
 
 106     public enum FlowType { STAT, REMOVED, MOD }
 
 108     private final FlowType type;
 
 110     public FlowEntryBuilder(Dpid dpid, OFFlowStatsEntry entry) {
 
 112         this.match = entry.getMatch();
 
 113         this.instructions = getInstructions(entry);
 
 117         this.type = FlowType.STAT;
 
 120     public FlowEntryBuilder(Dpid dpid, OFFlowRemoved removed) {
 
 121         this.match = removed.getMatch();
 
 122         this.removed = removed;
 
 125         this.instructions = null;
 
 128         this.type = FlowType.REMOVED;
 
 132     public FlowEntryBuilder(Dpid dpid, OFFlowMod fm) {
 
 133         this.match = fm.getMatch();
 
 135         this.instructions = getInstructions(fm);
 
 136         this.type = FlowType.MOD;
 
 142     public FlowEntry build(FlowEntryState... state) {
 
 146                 rule = DefaultFlowRule.builder()
 
 147                         .forDevice(DeviceId.deviceId(Dpid.uri(dpid)))
 
 148                         .withSelector(buildSelector())
 
 149                         .withTreatment(buildTreatment())
 
 150                         .withPriority(stat.getPriority())
 
 151                         .makeTemporary(stat.getIdleTimeout())
 
 152                         .withCookie(stat.getCookie().getValue())
 
 153                         .forTable(stat.getTableId().getValue())
 
 156                 return new DefaultFlowEntry(rule, FlowEntryState.ADDED,
 
 157                                       stat.getDurationSec(), stat.getPacketCount().getValue(),
 
 158                                       stat.getByteCount().getValue());
 
 160                 rule = DefaultFlowRule.builder()
 
 161                         .forDevice(DeviceId.deviceId(Dpid.uri(dpid)))
 
 162                         .withSelector(buildSelector())
 
 163                         .withPriority(removed.getPriority())
 
 164                         .makeTemporary(removed.getIdleTimeout())
 
 165                         .withCookie(removed.getCookie().getValue())
 
 166                         .forTable(removed.getTableId().getValue())
 
 169                 return new DefaultFlowEntry(rule, FlowEntryState.REMOVED, removed.getDurationSec(),
 
 170                                       removed.getPacketCount().getValue(), removed.getByteCount().getValue());
 
 172                 FlowEntryState flowState = state.length > 0 ? state[0] : FlowEntryState.FAILED;
 
 173                 rule = DefaultFlowRule.builder()
 
 174                         .forDevice(DeviceId.deviceId(Dpid.uri(dpid)))
 
 175                         .withSelector(buildSelector())
 
 176                         .withTreatment(buildTreatment())
 
 177                         .withPriority(flowMod.getPriority())
 
 178                         .makeTemporary(flowMod.getIdleTimeout())
 
 179                         .withCookie(flowMod.getCookie().getValue())
 
 180                         .forTable(flowMod.getTableId().getValue())
 
 183                 return new DefaultFlowEntry(rule, flowState, 0, 0, 0);
 
 185                 log.error("Unknown flow type : {}", this.type);
 
 191     private List<OFInstruction> getInstructions(OFFlowMod entry) {
 
 192         switch (entry.getVersion()) {
 
 194                 return Lists.newArrayList(OFFactoryVer13.INSTANCE.instructions()
 
 196                                                           entry.getActions()));
 
 200                 return entry.getInstructions();
 
 202                 log.warn("Unknown OF version {}", entry.getVersion());
 
 204         return Lists.newLinkedList();
 
 207     private List<OFInstruction> getInstructions(OFFlowStatsEntry entry) {
 
 208         switch (entry.getVersion()) {
 
 210                 return Lists.newArrayList(
 
 211                         OFFactoryVer13.INSTANCE.instructions().applyActions(entry.getActions()));
 
 215                 return entry.getInstructions();
 
 217                 log.warn("Unknown OF version {}", entry.getVersion());
 
 219         return Lists.newLinkedList();
 
 222     private TrafficTreatment buildTreatment() {
 
 223         TrafficTreatment.Builder builder = DefaultTrafficTreatment.builder();
 
 224         for (OFInstruction in : instructions) {
 
 225             switch (in.getType()) {
 
 227                     builder.transition(((int) ((OFInstructionGotoTable) in)
 
 228                             .getTableId().getValue()));
 
 231                     OFInstructionWriteMetadata m = (OFInstructionWriteMetadata) in;
 
 232                     builder.writeMetadata(m.getMetadata().getValue(),
 
 233                                           m.getMetadataMask().getValue());
 
 237                     buildActions(((OFInstructionWriteActions) in).getActions(),
 
 242                     buildActions(((OFInstructionApplyActions) in).getActions(),
 
 246                     builder.wipeDeferred();
 
 253                     log.warn("Unknown instructions type {}", in.getType());
 
 257         return builder.build();
 
 260     private TrafficTreatment.Builder buildActions(List<OFAction> actions,
 
 261                                                   TrafficTreatment.Builder builder) {
 
 262         for (OFAction act : actions) {
 
 263             switch (act.getType()) {
 
 265                     OFActionOutput out = (OFActionOutput) act;
 
 267                             PortNumber.portNumber(out.getPort().getPortNumber()));
 
 270                     OFActionSetVlanVid vlan = (OFActionSetVlanVid) act;
 
 271                     builder.setVlanId(VlanId.vlanId(vlan.getVlanVid().getVlan()));
 
 274                     OFActionSetVlanPcp pcp = (OFActionSetVlanPcp) act;
 
 275                     builder.setVlanPcp(pcp.getVlanPcp().getValue());
 
 278                     OFActionSetDlDst dldst = (OFActionSetDlDst) act;
 
 280                             MacAddress.valueOf(dldst.getDlAddr().getLong()));
 
 283                     OFActionSetDlSrc dlsrc = (OFActionSetDlSrc) act;
 
 285                             MacAddress.valueOf(dlsrc.getDlAddr().getLong()));
 
 289                     OFActionSetNwDst nwdst = (OFActionSetNwDst) act;
 
 290                     IPv4Address di = nwdst.getNwAddr();
 
 291                     builder.setIpDst(Ip4Address.valueOf(di.getInt()));
 
 294                     OFActionSetNwSrc nwsrc = (OFActionSetNwSrc) act;
 
 295                     IPv4Address si = nwsrc.getNwAddr();
 
 296                     builder.setIpSrc(Ip4Address.valueOf(si.getInt()));
 
 299                     OFActionExperimenter exp = (OFActionExperimenter) act;
 
 300                     if (exp.getExperimenter() == 0x80005A06 ||
 
 301                             exp.getExperimenter() == 0x748771) {
 
 302                         OFActionCircuit ct = (OFActionCircuit) exp;
 
 303                         short lambda = ((OFOxmOchSigidBasic) ct.getField()).getValue().getChannelNumber();
 
 304                         builder.add(Instructions.modL0Lambda(Lambda.indexedLambda(lambda)));
 
 306                         log.warn("Unsupported OFActionExperimenter {}", exp.getExperimenter());
 
 310                     OFActionSetField setField = (OFActionSetField) act;
 
 311                     handleSetField(builder, setField.getField());
 
 314                     OFActionPopMpls popMpls = (OFActionPopMpls) act;
 
 315                     builder.popMpls((short) popMpls.getEthertype().getValue());
 
 324                     builder.copyTtlOut();
 
 327                     builder.decMplsTtl();
 
 333                     OFActionGroup group = (OFActionGroup) act;
 
 334                     builder.group(new DefaultGroupId(group.getGroup().getGroupNumber()));
 
 357                     log.warn("Action type {} not yet implemented.", act.getType());
 
 364     private void handleSetField(TrafficTreatment.Builder builder, OFOxm<?> oxm) {
 
 365         switch (oxm.getMatchField().id) {
 
 367             @SuppressWarnings("unchecked")
 
 368             OFOxm<VlanPcp> vlanpcp = (OFOxm<VlanPcp>) oxm;
 
 369             builder.setVlanPcp(vlanpcp.getValue().getValue());
 
 372             @SuppressWarnings("unchecked")
 
 373             OFOxm<OFVlanVidMatch> vlanvid = (OFOxm<OFVlanVidMatch>) oxm;
 
 374             builder.setVlanId(VlanId.vlanId(vlanvid.getValue().getVlan()));
 
 377             @SuppressWarnings("unchecked")
 
 378             OFOxm<org.projectfloodlight.openflow.types.MacAddress> ethdst =
 
 379                     (OFOxm<org.projectfloodlight.openflow.types.MacAddress>) oxm;
 
 380             builder.setEthDst(MacAddress.valueOf(ethdst.getValue().getLong()));
 
 383             @SuppressWarnings("unchecked")
 
 384             OFOxm<org.projectfloodlight.openflow.types.MacAddress> ethsrc =
 
 385                     (OFOxm<org.projectfloodlight.openflow.types.MacAddress>) oxm;
 
 386             builder.setEthSrc(MacAddress.valueOf(ethsrc.getValue().getLong()));
 
 389             @SuppressWarnings("unchecked")
 
 390             OFOxm<IPv4Address> ip4dst = (OFOxm<IPv4Address>) oxm;
 
 391             builder.setIpDst(Ip4Address.valueOf(ip4dst.getValue().getInt()));
 
 394             @SuppressWarnings("unchecked")
 
 395             OFOxm<IPv4Address> ip4src = (OFOxm<IPv4Address>) oxm;
 
 396             builder.setIpSrc(Ip4Address.valueOf(ip4src.getValue().getInt()));
 
 399             @SuppressWarnings("unchecked")
 
 400             OFOxm<U32> labelId = (OFOxm<U32>) oxm;
 
 401             builder.setMpls(MplsLabel.mplsLabel((int) labelId.getValue().getValue()));
 
 404             @SuppressWarnings("unchecked")
 
 405             OFOxm<U8> mplsBos = (OFOxm<U8>) oxm;
 
 406             builder.setMplsBos(mplsBos.getValue() == U8.ZERO ? false : true);
 
 409             @SuppressWarnings("unchecked")
 
 410             OFOxm<U64> tunnelId = (OFOxm<U64>) oxm;
 
 411             builder.setTunnelId(tunnelId.getValue().getValue());
 
 414             @SuppressWarnings("unchecked")
 
 415             OFOxm<TransportPort> tcpdst = (OFOxm<TransportPort>) oxm;
 
 416             builder.setTcpDst(TpPort.tpPort(tcpdst.getValue().getPort()));
 
 419             @SuppressWarnings("unchecked")
 
 420             OFOxm<TransportPort> tcpsrc = (OFOxm<TransportPort>) oxm;
 
 421             builder.setTcpSrc(TpPort.tpPort(tcpsrc.getValue().getPort()));
 
 424             @SuppressWarnings("unchecked")
 
 425             OFOxm<TransportPort> udpdst = (OFOxm<TransportPort>) oxm;
 
 426             builder.setUdpDst(TpPort.tpPort(udpdst.getValue().getPort()));
 
 429             @SuppressWarnings("unchecked")
 
 430             OFOxm<TransportPort> udpsrc = (OFOxm<TransportPort>) oxm;
 
 431             builder.setUdpSrc(TpPort.tpPort(udpsrc.getValue().getPort()));
 
 438         case BSN_EGR_PORT_GROUP_ID:
 
 439         case BSN_GLOBAL_VRF_ALLOWED:
 
 440         case BSN_IN_PORTS_128:
 
 441         case BSN_L3_DST_CLASS_ID:
 
 442         case BSN_L3_INTERFACE_CLASS_ID:
 
 443         case BSN_L3_SRC_CLASS_ID:
 
 454         case BSN_VLAN_XLATE_PORT_GROUP_ID:
 
 475         case OCH_SIGID_BASIC:
 
 477         case OCH_SIGTYPE_BASIC:
 
 481             log.warn("Set field type {} not yet implemented.", oxm.getMatchField().id);
 
 486     // CHECKSTYLE IGNORE MethodLength FOR NEXT 1 LINES
 
 487     private TrafficSelector buildSelector() {
 
 490         Ip6Address ip6Address;
 
 493         TrafficSelector.Builder builder = DefaultTrafficSelector.builder();
 
 494         for (MatchField<?> field : match.getMatchFields()) {
 
 497                 builder.matchInPort(PortNumber
 
 498                         .portNumber(match.get(MatchField.IN_PORT).getPortNumber()));
 
 501                 builder.matchInPhyPort(PortNumber
 
 502                         .portNumber(match.get(MatchField.IN_PHY_PORT).getPortNumber()));
 
 506                     match.get(MatchField.METADATA).getValue().getValue();
 
 507                 builder.matchMetadata(metadata);
 
 510                 mac = MacAddress.valueOf(match.get(MatchField.ETH_DST).getLong());
 
 511                 builder.matchEthDst(mac);
 
 514                 mac = MacAddress.valueOf(match.get(MatchField.ETH_SRC).getLong());
 
 515                 builder.matchEthSrc(mac);
 
 518                 int ethType = match.get(MatchField.ETH_TYPE).getValue();
 
 519                 if (ethType == EthType.VLAN_FRAME.getValue()) {
 
 520                     builder.matchVlanId(VlanId.ANY);
 
 522                     builder.matchEthType((short) ethType);
 
 526                 VlanId vlanId = null;
 
 527                 if (match.isPartiallyMasked(MatchField.VLAN_VID)) {
 
 528                     Masked<OFVlanVidMatch> masked = match.getMasked(MatchField.VLAN_VID);
 
 529                     if (masked.getValue().equals(OFVlanVidMatch.PRESENT)
 
 530                             && masked.getMask().equals(OFVlanVidMatch.PRESENT)) {
 
 534                     if (!match.get(MatchField.VLAN_VID).isPresentBitSet()) {
 
 535                         vlanId = VlanId.NONE;
 
 537                         vlanId = VlanId.vlanId(match.get(MatchField.VLAN_VID).getVlan());
 
 540                 if (vlanId != null) {
 
 541                     builder.matchVlanId(vlanId);
 
 545                 byte vlanPcp = match.get(MatchField.VLAN_PCP).getValue();
 
 546                 builder.matchVlanPcp(vlanPcp);
 
 549                 byte ipDscp = match.get(MatchField.IP_DSCP).getDscpValue();
 
 550                 builder.matchIPDscp(ipDscp);
 
 553                 byte ipEcn = match.get(MatchField.IP_ECN).getEcnValue();
 
 554                 builder.matchIPEcn(ipEcn);
 
 557                 short proto = match.get(MatchField.IP_PROTO).getIpProtocolNumber();
 
 558                 builder.matchIPProtocol((byte) proto);
 
 561                 if (match.isPartiallyMasked(MatchField.IPV4_SRC)) {
 
 562                     Masked<IPv4Address> maskedIp = match.getMasked(MatchField.IPV4_SRC);
 
 563                     ip4Prefix = Ip4Prefix.valueOf(
 
 564                             maskedIp.getValue().getInt(),
 
 565                             maskedIp.getMask().asCidrMaskLength());
 
 567                     ip4Prefix = Ip4Prefix.valueOf(
 
 568                             match.get(MatchField.IPV4_SRC).getInt(),
 
 569                             Ip4Prefix.MAX_MASK_LENGTH);
 
 571                 builder.matchIPSrc(ip4Prefix);
 
 574                 if (match.isPartiallyMasked(MatchField.IPV4_DST)) {
 
 575                     Masked<IPv4Address> maskedIp = match.getMasked(MatchField.IPV4_DST);
 
 576                     ip4Prefix = Ip4Prefix.valueOf(
 
 577                             maskedIp.getValue().getInt(),
 
 578                             maskedIp.getMask().asCidrMaskLength());
 
 580                     ip4Prefix = Ip4Prefix.valueOf(
 
 581                             match.get(MatchField.IPV4_DST).getInt(),
 
 582                             Ip4Prefix.MAX_MASK_LENGTH);
 
 584                 builder.matchIPDst(ip4Prefix);
 
 587                 builder.matchTcpSrc(TpPort.tpPort(match.get(MatchField.TCP_SRC).getPort()));
 
 590                 builder.matchTcpDst(TpPort.tpPort(match.get(MatchField.TCP_DST).getPort()));
 
 593                 builder.matchUdpSrc(TpPort.tpPort(match.get(MatchField.UDP_SRC).getPort()));
 
 596                 builder.matchUdpDst(TpPort.tpPort(match.get(MatchField.UDP_DST).getPort()));
 
 599                 builder.matchMplsLabel(MplsLabel.mplsLabel((int) match.get(MatchField.MPLS_LABEL)
 
 603                 builder.matchMplsBos(match.get(MatchField.MPLS_BOS).getValue());
 
 606                 builder.matchSctpSrc(TpPort.tpPort(match.get(MatchField.SCTP_SRC).getPort()));
 
 609                 builder.matchSctpDst(TpPort.tpPort(match.get(MatchField.SCTP_DST).getPort()));
 
 612                 byte icmpType = (byte) match.get(MatchField.ICMPV4_TYPE).getType();
 
 613                 builder.matchIcmpType(icmpType);
 
 616                 byte icmpCode = (byte) match.get(MatchField.ICMPV4_CODE).getCode();
 
 617                 builder.matchIcmpCode(icmpCode);
 
 620                 if (match.isPartiallyMasked(MatchField.IPV6_SRC)) {
 
 621                     Masked<IPv6Address> maskedIp = match.getMasked(MatchField.IPV6_SRC);
 
 622                     ip6Prefix = Ip6Prefix.valueOf(
 
 623                             maskedIp.getValue().getBytes(),
 
 624                             maskedIp.getMask().asCidrMaskLength());
 
 626                     ip6Prefix = Ip6Prefix.valueOf(
 
 627                             match.get(MatchField.IPV6_SRC).getBytes(),
 
 628                             Ip6Prefix.MAX_MASK_LENGTH);
 
 630                 builder.matchIPv6Src(ip6Prefix);
 
 633                 if (match.isPartiallyMasked(MatchField.IPV6_DST)) {
 
 634                     Masked<IPv6Address> maskedIp = match.getMasked(MatchField.IPV6_DST);
 
 635                     ip6Prefix = Ip6Prefix.valueOf(
 
 636                             maskedIp.getValue().getBytes(),
 
 637                             maskedIp.getMask().asCidrMaskLength());
 
 639                     ip6Prefix = Ip6Prefix.valueOf(
 
 640                             match.get(MatchField.IPV6_DST).getBytes(),
 
 641                             Ip6Prefix.MAX_MASK_LENGTH);
 
 643                 builder.matchIPv6Dst(ip6Prefix);
 
 647                     match.get(MatchField.IPV6_FLABEL).getIPv6FlowLabelValue();
 
 648                 builder.matchIPv6FlowLabel(flowLabel);
 
 651                 byte icmpv6type = (byte) match.get(MatchField.ICMPV6_TYPE).getValue();
 
 652                 builder.matchIcmpv6Type(icmpv6type);
 
 655                 byte icmpv6code = (byte) match.get(MatchField.ICMPV6_CODE).getValue();
 
 656                 builder.matchIcmpv6Code(icmpv6code);
 
 660                     Ip6Address.valueOf(match.get(MatchField.IPV6_ND_TARGET).getBytes());
 
 661                 builder.matchIPv6NDTargetAddress(ip6Address);
 
 664                 mac = MacAddress.valueOf(match.get(MatchField.IPV6_ND_SLL).getLong());
 
 665                 builder.matchIPv6NDSourceLinkLayerAddress(mac);
 
 668                 mac = MacAddress.valueOf(match.get(MatchField.IPV6_ND_TLL).getLong());
 
 669                 builder.matchIPv6NDTargetLinkLayerAddress(mac);
 
 672                 builder.matchIPv6ExthdrFlags((short) match.get(MatchField.IPV6_EXTHDR)
 
 676                 CircuitSignalID sigId = match.get(MatchField.OCH_SIGID);
 
 677                 builder.add(matchLambda(Lambda.ochSignal(
 
 678                                 lookupGridType(sigId.getGridType()), lookupChannelSpacing(sigId.getChannelSpacing()),
 
 679                                 sigId.getChannelNumber(), sigId.getSpectralWidth())
 
 683                 U8 sigType = match.get(MatchField.OCH_SIGTYPE);
 
 684                 builder.add(matchOchSignalType(lookupOchSignalType((byte) sigType.getValue())));
 
 687                 long tunnelId = match.get(MatchField.TUNNEL_ID).getValue();
 
 688                 builder.matchTunnelId(tunnelId);
 
 697                 log.warn("Match type {} not yet implemented.", field.id);
 
 700         return builder.build();