Fixing OF flow and group provider run-time dependency.
Change-Id: I25fa3c72ab01500c39fc90198abc4c383a9512a2
Showing
8 changed files
with
46 additions
and
21 deletions
... | @@ -64,6 +64,8 @@ import org.onosproject.net.flow.criteria.UdpPortCriterion; | ... | @@ -64,6 +64,8 @@ import org.onosproject.net.flow.criteria.UdpPortCriterion; |
64 | import org.onosproject.net.flow.criteria.VlanIdCriterion; | 64 | import org.onosproject.net.flow.criteria.VlanIdCriterion; |
65 | import org.onosproject.net.flow.criteria.VlanPcpCriterion; | 65 | import org.onosproject.net.flow.criteria.VlanPcpCriterion; |
66 | import org.onosproject.openflow.controller.ExtensionSelectorInterpreter; | 66 | import org.onosproject.openflow.controller.ExtensionSelectorInterpreter; |
67 | +import org.onosproject.provider.of.flow.util.NoMappingFoundException; | ||
68 | +import org.onosproject.provider.of.flow.util.OpenFlowValueMapper; | ||
67 | import org.projectfloodlight.openflow.protocol.OFFactory; | 69 | import org.projectfloodlight.openflow.protocol.OFFactory; |
68 | import org.projectfloodlight.openflow.protocol.OFFlowMod; | 70 | import org.projectfloodlight.openflow.protocol.OFFlowMod; |
69 | import org.projectfloodlight.openflow.protocol.match.Match; | 71 | import org.projectfloodlight.openflow.protocol.match.Match; | ... | ... |
providers/openflow/flow/src/main/java/org/onosproject/provider/of/flow/impl/FlowModBuilderVer13.java
... | @@ -54,6 +54,8 @@ import org.onosproject.net.flow.instructions.L3ModificationInstruction.ModIPv6Fl | ... | @@ -54,6 +54,8 @@ import org.onosproject.net.flow.instructions.L3ModificationInstruction.ModIPv6Fl |
54 | import org.onosproject.net.flow.instructions.L4ModificationInstruction; | 54 | import org.onosproject.net.flow.instructions.L4ModificationInstruction; |
55 | import org.onosproject.net.flow.instructions.L4ModificationInstruction.ModTransportPortInstruction; | 55 | import org.onosproject.net.flow.instructions.L4ModificationInstruction.ModTransportPortInstruction; |
56 | import org.onosproject.openflow.controller.ExtensionTreatmentInterpreter; | 56 | import org.onosproject.openflow.controller.ExtensionTreatmentInterpreter; |
57 | +import org.onosproject.provider.of.flow.util.NoMappingFoundException; | ||
58 | +import org.onosproject.provider.of.flow.util.OpenFlowValueMapper; | ||
57 | import org.projectfloodlight.openflow.protocol.OFFactory; | 59 | import org.projectfloodlight.openflow.protocol.OFFactory; |
58 | import org.projectfloodlight.openflow.protocol.OFFlowAdd; | 60 | import org.projectfloodlight.openflow.protocol.OFFlowAdd; |
59 | import org.projectfloodlight.openflow.protocol.OFFlowDeleteStrict; | 61 | import org.projectfloodlight.openflow.protocol.OFFlowDeleteStrict; | ... | ... |
... | @@ -53,6 +53,7 @@ import org.onosproject.openflow.controller.OpenFlowSwitch; | ... | @@ -53,6 +53,7 @@ import org.onosproject.openflow.controller.OpenFlowSwitch; |
53 | import org.onosproject.openflow.controller.OpenFlowSwitchListener; | 53 | import org.onosproject.openflow.controller.OpenFlowSwitchListener; |
54 | import org.onosproject.openflow.controller.RoleState; | 54 | import org.onosproject.openflow.controller.RoleState; |
55 | import org.onosproject.openflow.controller.ThirdPartyMessage; | 55 | import org.onosproject.openflow.controller.ThirdPartyMessage; |
56 | +import org.onosproject.provider.of.flow.util.FlowEntryBuilder; | ||
56 | import org.osgi.service.component.ComponentContext; | 57 | import org.osgi.service.component.ComponentContext; |
57 | import org.projectfloodlight.openflow.protocol.OFBadRequestCode; | 58 | import org.projectfloodlight.openflow.protocol.OFBadRequestCode; |
58 | import org.projectfloodlight.openflow.protocol.OFBarrierRequest; | 59 | import org.projectfloodlight.openflow.protocol.OFBarrierRequest; | ... | ... |
1 | /* | 1 | /* |
2 | - * Copyright 2014-2015 Open Networking Laboratory | 2 | + * Copyright 2016 Open Networking Laboratory |
3 | * | 3 | * |
4 | * Licensed under the Apache License, Version 2.0 (the "License"); | 4 | * Licensed under the Apache License, Version 2.0 (the "License"); |
5 | * you may not use this file except in compliance with the License. | 5 | * you may not use this file except in compliance with the License. |
... | @@ -13,7 +13,7 @@ | ... | @@ -13,7 +13,7 @@ |
13 | * See the License for the specific language governing permissions and | 13 | * See the License for the specific language governing permissions and |
14 | * limitations under the License. | 14 | * limitations under the License. |
15 | */ | 15 | */ |
16 | -package org.onosproject.provider.of.flow.impl; | 16 | +package org.onosproject.provider.of.flow.util; |
17 | 17 | ||
18 | import com.google.common.collect.Lists; | 18 | import com.google.common.collect.Lists; |
19 | import org.onlab.packet.EthType; | 19 | import org.onlab.packet.EthType; |
... | @@ -101,10 +101,10 @@ import static org.onosproject.net.flow.criteria.Criteria.matchOduSignalId; | ... | @@ -101,10 +101,10 @@ import static org.onosproject.net.flow.criteria.Criteria.matchOduSignalId; |
101 | import static org.onosproject.net.flow.criteria.Criteria.matchOduSignalType; | 101 | import static org.onosproject.net.flow.criteria.Criteria.matchOduSignalType; |
102 | import static org.onosproject.net.flow.instructions.Instructions.modL0Lambda; | 102 | import static org.onosproject.net.flow.instructions.Instructions.modL0Lambda; |
103 | import static org.onosproject.net.flow.instructions.Instructions.modL1OduSignalId; | 103 | import static org.onosproject.net.flow.instructions.Instructions.modL1OduSignalId; |
104 | -import static org.onosproject.provider.of.flow.impl.OpenFlowValueMapper.lookupChannelSpacing; | 104 | +import static org.onosproject.provider.of.flow.util.OpenFlowValueMapper.lookupChannelSpacing; |
105 | -import static org.onosproject.provider.of.flow.impl.OpenFlowValueMapper.lookupGridType; | 105 | +import static org.onosproject.provider.of.flow.util.OpenFlowValueMapper.lookupGridType; |
106 | -import static org.onosproject.provider.of.flow.impl.OpenFlowValueMapper.lookupOchSignalType; | 106 | +import static org.onosproject.provider.of.flow.util.OpenFlowValueMapper.lookupOchSignalType; |
107 | -import static org.onosproject.provider.of.flow.impl.OpenFlowValueMapper.lookupOduSignalType; | 107 | +import static org.onosproject.provider.of.flow.util.OpenFlowValueMapper.lookupOduSignalType; |
108 | 108 | ||
109 | public class FlowEntryBuilder { | 109 | public class FlowEntryBuilder { |
110 | private static final Logger log = LoggerFactory.getLogger(FlowEntryBuilder.class); | 110 | private static final Logger log = LoggerFactory.getLogger(FlowEntryBuilder.class); | ... | ... |
1 | /* | 1 | /* |
2 | - * Copyright 2015 Open Networking Laboratory | 2 | + * Copyright 2016 Open Networking Laboratory |
3 | * | 3 | * |
4 | * Licensed under the Apache License, Version 2.0 (the "License"); | 4 | * Licensed under the Apache License, Version 2.0 (the "License"); |
5 | * you may not use this file except in compliance with the License. | 5 | * you may not use this file except in compliance with the License. |
... | @@ -13,7 +13,7 @@ | ... | @@ -13,7 +13,7 @@ |
13 | * See the License for the specific language governing permissions and | 13 | * See the License for the specific language governing permissions and |
14 | * limitations under the License. | 14 | * limitations under the License. |
15 | */ | 15 | */ |
16 | -package org.onosproject.provider.of.flow.impl; | 16 | +package org.onosproject.provider.of.flow.util; |
17 | 17 | ||
18 | /** | 18 | /** |
19 | * Thrown to indicate that no mapping for the input value is found. | 19 | * Thrown to indicate that no mapping for the input value is found. | ... | ... |
1 | /* | 1 | /* |
2 | - * Copyright 2015 Open Networking Laboratory | 2 | + * Copyright 2016 Open Networking Laboratory |
3 | * | 3 | * |
4 | * Licensed under the Apache License, Version 2.0 (the "License"); | 4 | * Licensed under the Apache License, Version 2.0 (the "License"); |
5 | * you may not use this file except in compliance with the License. | 5 | * you may not use this file except in compliance with the License. |
... | @@ -13,7 +13,7 @@ | ... | @@ -13,7 +13,7 @@ |
13 | * See the License for the specific language governing permissions and | 13 | * See the License for the specific language governing permissions and |
14 | * limitations under the License. | 14 | * limitations under the License. |
15 | */ | 15 | */ |
16 | -package org.onosproject.provider.of.flow.impl; | 16 | +package org.onosproject.provider.of.flow.util; |
17 | 17 | ||
18 | import com.google.common.collect.BiMap; | 18 | import com.google.common.collect.BiMap; |
19 | import com.google.common.collect.EnumHashBiMap; | 19 | import com.google.common.collect.EnumHashBiMap; |
... | @@ -25,7 +25,7 @@ import org.onosproject.net.OduSignalType; | ... | @@ -25,7 +25,7 @@ import org.onosproject.net.OduSignalType; |
25 | /** | 25 | /** |
26 | * Collection of helper methods to convert protocol agnostic models to values used in OpenFlow spec. | 26 | * Collection of helper methods to convert protocol agnostic models to values used in OpenFlow spec. |
27 | */ | 27 | */ |
28 | -final class OpenFlowValueMapper { | 28 | +public final class OpenFlowValueMapper { |
29 | 29 | ||
30 | // prohibit instantiation | 30 | // prohibit instantiation |
31 | private OpenFlowValueMapper() {} | 31 | private OpenFlowValueMapper() {} |
... | @@ -94,7 +94,7 @@ final class OpenFlowValueMapper { | ... | @@ -94,7 +94,7 @@ final class OpenFlowValueMapper { |
94 | * @return the byte value corresponding to the specified grid type | 94 | * @return the byte value corresponding to the specified grid type |
95 | * @throws NoMappingFoundException if the specified grid type is not found | 95 | * @throws NoMappingFoundException if the specified grid type is not found |
96 | */ | 96 | */ |
97 | - static byte lookupGridType(GridType type) { | 97 | + public static byte lookupGridType(GridType type) { |
98 | return lookup(GRID_TYPES, type, Byte.class); | 98 | return lookup(GRID_TYPES, type, Byte.class); |
99 | } | 99 | } |
100 | 100 | ||
... | @@ -106,7 +106,7 @@ final class OpenFlowValueMapper { | ... | @@ -106,7 +106,7 @@ final class OpenFlowValueMapper { |
106 | * @param type byte value as grid type defined the spec | 106 | * @param type byte value as grid type defined the spec |
107 | * @return the corresponding GridType instance | 107 | * @return the corresponding GridType instance |
108 | */ | 108 | */ |
109 | - static GridType lookupGridType(byte type) { | 109 | + public static GridType lookupGridType(byte type) { |
110 | return lookup(GRID_TYPES.inverse(), type, GridType.class); | 110 | return lookup(GRID_TYPES.inverse(), type, GridType.class); |
111 | } | 111 | } |
112 | 112 | ||
... | @@ -119,7 +119,7 @@ final class OpenFlowValueMapper { | ... | @@ -119,7 +119,7 @@ final class OpenFlowValueMapper { |
119 | * @return byte value corresponding to the specified channel spacing | 119 | * @return byte value corresponding to the specified channel spacing |
120 | * @throws NoMappingFoundException if the specified channel spacing is not found | 120 | * @throws NoMappingFoundException if the specified channel spacing is not found |
121 | */ | 121 | */ |
122 | - static byte lookupChannelSpacing(ChannelSpacing spacing) { | 122 | + public static byte lookupChannelSpacing(ChannelSpacing spacing) { |
123 | return lookup(CHANNEL_SPACING, spacing, Byte.class); | 123 | return lookup(CHANNEL_SPACING, spacing, Byte.class); |
124 | } | 124 | } |
125 | 125 | ||
... | @@ -132,7 +132,7 @@ final class OpenFlowValueMapper { | ... | @@ -132,7 +132,7 @@ final class OpenFlowValueMapper { |
132 | * @return the corresponding ChannelSpacing instance | 132 | * @return the corresponding ChannelSpacing instance |
133 | * @throws NoMappingFoundException if the specified channel spacing is not found | 133 | * @throws NoMappingFoundException if the specified channel spacing is not found |
134 | */ | 134 | */ |
135 | - static ChannelSpacing lookupChannelSpacing(byte spacing) { | 135 | + public static ChannelSpacing lookupChannelSpacing(byte spacing) { |
136 | return lookup(CHANNEL_SPACING.inverse(), spacing, ChannelSpacing.class); | 136 | return lookup(CHANNEL_SPACING.inverse(), spacing, ChannelSpacing.class); |
137 | } | 137 | } |
138 | 138 | ||
... | @@ -145,7 +145,7 @@ final class OpenFlowValueMapper { | ... | @@ -145,7 +145,7 @@ final class OpenFlowValueMapper { |
145 | * @return byte value corresponding to the specified OCh signal type | 145 | * @return byte value corresponding to the specified OCh signal type |
146 | * @throws NoMappingFoundException if the specified Och signal type is not found | 146 | * @throws NoMappingFoundException if the specified Och signal type is not found |
147 | */ | 147 | */ |
148 | - static byte lookupOchSignalType(OchSignalType signalType) { | 148 | + public static byte lookupOchSignalType(OchSignalType signalType) { |
149 | return lookup(OCH_SIGNAL_TYPES, signalType, Byte.class); | 149 | return lookup(OCH_SIGNAL_TYPES, signalType, Byte.class); |
150 | } | 150 | } |
151 | 151 | ||
... | @@ -158,7 +158,7 @@ final class OpenFlowValueMapper { | ... | @@ -158,7 +158,7 @@ final class OpenFlowValueMapper { |
158 | * @return the corresponding OchSignalType instance | 158 | * @return the corresponding OchSignalType instance |
159 | * @throws NoMappingFoundException if the specified Och signal type is not found | 159 | * @throws NoMappingFoundException if the specified Och signal type is not found |
160 | */ | 160 | */ |
161 | - static OchSignalType lookupOchSignalType(byte signalType) { | 161 | + public static OchSignalType lookupOchSignalType(byte signalType) { |
162 | return lookup(OCH_SIGNAL_TYPES.inverse(), signalType, OchSignalType.class); | 162 | return lookup(OCH_SIGNAL_TYPES.inverse(), signalType, OchSignalType.class); |
163 | } | 163 | } |
164 | 164 | ||
... | @@ -171,7 +171,7 @@ final class OpenFlowValueMapper { | ... | @@ -171,7 +171,7 @@ final class OpenFlowValueMapper { |
171 | * @return byte value corresponding to the specified ODU signal type | 171 | * @return byte value corresponding to the specified ODU signal type |
172 | * @throws NoMappingFoundException if the specified ODU signal type is not found | 172 | * @throws NoMappingFoundException if the specified ODU signal type is not found |
173 | */ | 173 | */ |
174 | - static byte lookupOduSignalType(OduSignalType signalType) { | 174 | + public static byte lookupOduSignalType(OduSignalType signalType) { |
175 | return lookup(ODU_SIGNAL_TYPES, signalType, Byte.class); | 175 | return lookup(ODU_SIGNAL_TYPES, signalType, Byte.class); |
176 | } | 176 | } |
177 | 177 | ||
... | @@ -184,7 +184,7 @@ final class OpenFlowValueMapper { | ... | @@ -184,7 +184,7 @@ final class OpenFlowValueMapper { |
184 | * @return the corresponding OchSignalType instance | 184 | * @return the corresponding OchSignalType instance |
185 | * @throws NoMappingFoundException if the specified ODU signal type is not found | 185 | * @throws NoMappingFoundException if the specified ODU signal type is not found |
186 | */ | 186 | */ |
187 | - static OduSignalType lookupOduSignalType(byte signalType) { | 187 | + public static OduSignalType lookupOduSignalType(byte signalType) { |
188 | return lookup(ODU_SIGNAL_TYPES.inverse(), signalType, OduSignalType.class); | 188 | return lookup(ODU_SIGNAL_TYPES.inverse(), signalType, OduSignalType.class); |
189 | } | 189 | } |
190 | } | 190 | } | ... | ... |
providers/openflow/flow/src/main/java/org/onosproject/provider/of/flow/util/package-info.java
0 → 100644
1 | +/* | ||
2 | + * Copyright 2016 Open Networking Laboratory | ||
3 | + * | ||
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 | ||
7 | + * | ||
8 | + * http://www.apache.org/licenses/LICENSE-2.0 | ||
9 | + * | ||
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. | ||
15 | + */ | ||
16 | + | ||
17 | +/** | ||
18 | + * Shared utilities for OF flow rule and group providers. | ||
19 | + */ | ||
20 | +package org.onosproject.provider.of.flow.util; | ||
... | \ No newline at end of file | ... | \ No newline at end of file |
... | @@ -31,7 +31,7 @@ import org.onosproject.net.group.DefaultGroupBucket; | ... | @@ -31,7 +31,7 @@ import org.onosproject.net.group.DefaultGroupBucket; |
31 | import org.onosproject.net.group.GroupBucket; | 31 | import org.onosproject.net.group.GroupBucket; |
32 | import org.onosproject.net.group.GroupBuckets; | 32 | import org.onosproject.net.group.GroupBuckets; |
33 | import org.onosproject.openflow.controller.Dpid; | 33 | import org.onosproject.openflow.controller.Dpid; |
34 | -import org.onosproject.provider.of.flow.impl.FlowEntryBuilder; | 34 | +import org.onosproject.provider.of.flow.util.FlowEntryBuilder; |
35 | import org.projectfloodlight.openflow.protocol.OFBucket; | 35 | import org.projectfloodlight.openflow.protocol.OFBucket; |
36 | import org.projectfloodlight.openflow.protocol.OFGroupType; | 36 | import org.projectfloodlight.openflow.protocol.OFGroupType; |
37 | import org.projectfloodlight.openflow.protocol.action.OFAction; | 37 | import org.projectfloodlight.openflow.protocol.action.OFAction; |
... | @@ -41,7 +41,7 @@ import java.util.List; | ... | @@ -41,7 +41,7 @@ import java.util.List; |
41 | 41 | ||
42 | import static org.slf4j.LoggerFactory.getLogger; | 42 | import static org.slf4j.LoggerFactory.getLogger; |
43 | 43 | ||
44 | -/* | 44 | +/** |
45 | * Builder for GroupBucketEntry. | 45 | * Builder for GroupBucketEntry. |
46 | */ | 46 | */ |
47 | public class GroupBucketEntryBuilder { | 47 | public class GroupBucketEntryBuilder { | ... | ... |
-
Please register or login to post a comment