Bug 2756 - Match model update
[openflowjava.git] / openflow-protocol-impl / src / main / java / org / opendaylight / openflowjava / protocol / impl / serialization / match / OxmArpShaSerializer.java
index d4e8c3c04df83e7720bff6b0493ac52a9c817fb4..13903be36f96191cb0f3a35e2cef107b63dc84a1 100644 (file)
@@ -7,8 +7,12 @@
  */
 package org.opendaylight.openflowjava.protocol.impl.serialization.match;
 
+import io.netty.buffer.ByteBuf;
+
 import org.opendaylight.openflowjava.protocol.api.util.EncodeConstants;
 import org.opendaylight.openflowjava.protocol.api.util.OxmMatchConstants;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev150225.match.entries.grouping.MatchEntry;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.oxm.rev150225.match.entry.value.grouping.match.entry.value.ArpShaCase;
 
 /**
  * @author michal.polkorab
@@ -16,6 +20,16 @@ import org.opendaylight.openflowjava.protocol.api.util.OxmMatchConstants;
  */
 public class OxmArpShaSerializer extends AbstractOxmMacAddressSerializer {
 
+    @Override
+    public void serialize(MatchEntry entry, ByteBuf outBuffer) {
+        super.serialize(entry, outBuffer);
+        ArpShaCase entryValue = (ArpShaCase) entry.getMatchEntryValue();
+        writeMacAddress(entryValue.getArpSha().getMacAddress(), outBuffer);
+        if (entry.isHasMask()) {
+            writeMask(entryValue.getArpSha().getMask(), outBuffer, EncodeConstants.MAC_ADDRESS_LENGTH);
+        }
+    }
+
     @Override
     protected int getOxmClassCode() {
         return OxmMatchConstants.OPENFLOW_BASIC_CLASS;