X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=openflowplugin-impl%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fopenflowplugin%2Fimpl%2Fprotocol%2Fserialization%2Fmessages%2FGroupMessageSerializer.java;h=d05129b9992e5f1e1ebff9652d74c48e99c0ea69;hb=7efd88b5573838da910ffbbab67f8e606b8d5709;hp=768b5c48a87bd1d44ef0e9ea66cd0e1823df814f;hpb=163b3dd5740b83123674df4a65f0de40860bb3e6;p=openflowplugin.git diff --git a/openflowplugin-impl/src/main/java/org/opendaylight/openflowplugin/impl/protocol/serialization/messages/GroupMessageSerializer.java b/openflowplugin-impl/src/main/java/org/opendaylight/openflowplugin/impl/protocol/serialization/messages/GroupMessageSerializer.java index 768b5c48a8..d05129b999 100644 --- a/openflowplugin-impl/src/main/java/org/opendaylight/openflowplugin/impl/protocol/serialization/messages/GroupMessageSerializer.java +++ b/openflowplugin-impl/src/main/java/org/opendaylight/openflowplugin/impl/protocol/serialization/messages/GroupMessageSerializer.java @@ -17,6 +17,7 @@ import org.opendaylight.openflowjava.protocol.api.extensibility.SerializerRegist import org.opendaylight.openflowjava.protocol.api.util.EncodeConstants; import org.opendaylight.openflowplugin.api.OFConstants; import org.opendaylight.openflowplugin.impl.protocol.serialization.util.ActionUtil; +import org.opendaylight.openflowplugin.openflow.md.core.sal.convertor.common.OrderComparator; import org.opendaylight.yang.gen.v1.urn.opendaylight.group.types.rev131018.GroupMessage; import org.opendaylight.yang.gen.v1.urn.opendaylight.group.types.rev131018.group.buckets.Bucket; import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev130731.GroupModCommand; @@ -25,22 +26,40 @@ import org.opendaylight.yang.gen.v1.urn.opendaylight.openflow.common.types.rev13 * Translates GroupMod messages. * OF protocol versions: 1.3. */ -public class GroupMessageSerializer extends AbstractMessageSerializer implements SerializerRegistryInjector { +public class GroupMessageSerializer extends AbstractMessageSerializer implements + SerializerRegistryInjector { private static final byte PADDING_IN_GROUP_MOD_MESSAGE = 1; private static final byte PADDING_IN_BUCKET = 4; + private static final int OFPGC_ADD_OR_MOD = 32768; + private final boolean isGroupAddModEnabled; private static final Comparator COMPARATOR = (bucket1, bucket2) -> { - if (bucket1.getBucketId() == null || bucket2.getBucketId() == null) return 0; + if (bucket1.getBucketId() == null || bucket2.getBucketId() == null) { + return 0; + } return bucket1.getBucketId().getValue().compareTo(bucket2.getBucketId().getValue()); }; private SerializerRegistry registry; + public GroupMessageSerializer(boolean isGroupAddModEnabled) { + this.isGroupAddModEnabled = isGroupAddModEnabled; + } + @Override public void serialize(GroupMessage message, ByteBuf outBuffer) { - int index = outBuffer.writerIndex(); + final int index = outBuffer.writerIndex(); super.serialize(message, outBuffer); - outBuffer.writeShort(message.getCommand().getIntValue()); + if (isGroupAddModEnabled) { + if (message.getCommand().equals(GroupModCommand.OFPGCADD) + || message.getCommand().equals(GroupModCommand.OFPGCMODIFY)) { + outBuffer.writeShort(OFPGC_ADD_OR_MOD); + } else { + outBuffer.writeShort(message.getCommand().getIntValue()); + } + } else { + outBuffer.writeShort(message.getCommand().getIntValue()); + } outBuffer.writeByte(message.getGroupType().getIntValue()); outBuffer.writeZero(PADDING_IN_GROUP_MOD_MESSAGE); outBuffer.writeInt(message.getGroupId().getValue().intValue()); @@ -51,23 +70,26 @@ public class GroupMessageSerializer extends AbstractMessageSerializer b.stream() .sorted(COMPARATOR) .forEach(bucket -> { - int bucketIndex = outBuffer.writerIndex(); + final int bucketIndex = outBuffer.writerIndex(); outBuffer.writeShort(EncodeConstants.EMPTY_LENGTH); outBuffer.writeShort(MoreObjects.firstNonNull(bucket.getWeight(), 0)); - outBuffer.writeInt(MoreObjects.firstNonNull(bucket.getWatchPort(), OFConstants.OFPG_ANY).intValue()); - outBuffer.writeInt(MoreObjects.firstNonNull(bucket.getWatchGroup(), OFConstants.OFPG_ANY).intValue()); + outBuffer.writeInt(MoreObjects.firstNonNull(bucket.getWatchPort(), OFConstants.OFPG_ANY) + .intValue()); + outBuffer.writeInt(MoreObjects.firstNonNull(bucket.getWatchGroup(), OFConstants.OFPG_ANY) + .intValue()); outBuffer.writeZero(PADDING_IN_BUCKET); - Optional.ofNullable(bucket.getAction()).ifPresent(as -> as.forEach(a -> - ActionUtil.writeAction( - a.getAction(), - OFConstants.OFP_VERSION_1_3, - registry, - outBuffer))); + Optional.ofNullable(bucket.getAction()).ifPresent(as -> as + .stream() + .sorted(OrderComparator.build()) + .forEach(a -> ActionUtil.writeAction( + a.getAction(), + OFConstants.OFP_VERSION_1_3, + registry, + outBuffer))); outBuffer.setShort(bucketIndex, outBuffer.writerIndex() - bucketIndex); })); - outBuffer.setShort(index + 2, outBuffer.writerIndex() - index); }