HIGUCHI Yuta | 356086e | 2013-06-12 15:21:19 -0700 | [diff] [blame] | 1 | package net.onrc.onos.ofcontroller.util; |
Pavlin Radoslavov | 5363c2a | 2013-02-18 09:55:42 -0800 | [diff] [blame] | 2 | |
| 3 | import java.util.ArrayList; |
| 4 | |
Pavlin Radoslavov | ad008e0 | 2013-02-21 18:42:42 -0800 | [diff] [blame] | 5 | import org.codehaus.jackson.annotate.JsonProperty; |
Pavlin Radoslavov | 5363c2a | 2013-02-18 09:55:42 -0800 | [diff] [blame] | 6 | |
| 7 | /** |
Pavlin Radoslavov | d5b21db | 2013-07-29 17:09:53 -0700 | [diff] [blame] | 8 | * The data forwarding path state from a source to a destination. |
Pavlin Radoslavov | 5363c2a | 2013-02-18 09:55:42 -0800 | [diff] [blame] | 9 | */ |
| 10 | public class DataPath { |
| 11 | private SwitchPort srcPort; // The source port |
| 12 | private SwitchPort dstPort; // The destination port |
| 13 | private ArrayList<FlowEntry> flowEntries; // The Flow Entries |
| 14 | |
| 15 | /** |
| 16 | * Default constructor. |
| 17 | */ |
| 18 | public DataPath() { |
Pavlin Radoslavov | b6f5354 | 2013-03-01 16:02:14 -0800 | [diff] [blame] | 19 | srcPort = new SwitchPort(); |
| 20 | dstPort = new SwitchPort(); |
Pavlin Radoslavov | f83aa44 | 2013-02-26 14:09:01 -0800 | [diff] [blame] | 21 | flowEntries = new ArrayList<FlowEntry>(); |
Pavlin Radoslavov | 5363c2a | 2013-02-18 09:55:42 -0800 | [diff] [blame] | 22 | } |
| 23 | |
| 24 | /** |
| 25 | * Get the data path source port. |
| 26 | * |
| 27 | * @return the data path source port. |
| 28 | */ |
Pavlin Radoslavov | 2013cbb | 2013-02-26 10:15:18 -0800 | [diff] [blame] | 29 | @JsonProperty("srcPort") |
Pavlin Radoslavov | 5363c2a | 2013-02-18 09:55:42 -0800 | [diff] [blame] | 30 | public SwitchPort srcPort() { return srcPort; } |
| 31 | |
| 32 | /** |
| 33 | * Set the data path source port. |
| 34 | * |
| 35 | * @param srcPort the data path source port to set. |
| 36 | */ |
Pavlin Radoslavov | 2013cbb | 2013-02-26 10:15:18 -0800 | [diff] [blame] | 37 | @JsonProperty("srcPort") |
Pavlin Radoslavov | 5363c2a | 2013-02-18 09:55:42 -0800 | [diff] [blame] | 38 | public void setSrcPort(SwitchPort srcPort) { |
| 39 | this.srcPort = srcPort; |
| 40 | } |
| 41 | |
| 42 | /** |
| 43 | * Get the data path destination port. |
| 44 | * |
| 45 | * @return the data path destination port. |
| 46 | */ |
Pavlin Radoslavov | 2013cbb | 2013-02-26 10:15:18 -0800 | [diff] [blame] | 47 | @JsonProperty("dstPort") |
Pavlin Radoslavov | 5363c2a | 2013-02-18 09:55:42 -0800 | [diff] [blame] | 48 | public SwitchPort dstPort() { return dstPort; } |
| 49 | |
| 50 | /** |
| 51 | * Set the data path destination port. |
| 52 | * |
| 53 | * @param dstPort the data path destination port to set. |
| 54 | */ |
Pavlin Radoslavov | 2013cbb | 2013-02-26 10:15:18 -0800 | [diff] [blame] | 55 | @JsonProperty("dstPort") |
Pavlin Radoslavov | 5363c2a | 2013-02-18 09:55:42 -0800 | [diff] [blame] | 56 | public void setDstPort(SwitchPort dstPort) { |
| 57 | this.dstPort = dstPort; |
| 58 | } |
| 59 | |
| 60 | /** |
| 61 | * Get the data path flow entries. |
| 62 | * |
| 63 | * @return the data path flow entries. |
| 64 | */ |
Pavlin Radoslavov | 2013cbb | 2013-02-26 10:15:18 -0800 | [diff] [blame] | 65 | @JsonProperty("flowEntries") |
Pavlin Radoslavov | 5363c2a | 2013-02-18 09:55:42 -0800 | [diff] [blame] | 66 | public ArrayList<FlowEntry> flowEntries() { return flowEntries; } |
| 67 | |
| 68 | /** |
| 69 | * Set the data path flow entries. |
| 70 | * |
| 71 | * @param flowEntries the data path flow entries to set. |
| 72 | */ |
Pavlin Radoslavov | 2013cbb | 2013-02-26 10:15:18 -0800 | [diff] [blame] | 73 | @JsonProperty("flowEntries") |
Pavlin Radoslavov | 5363c2a | 2013-02-18 09:55:42 -0800 | [diff] [blame] | 74 | public void setFlowEntries(ArrayList<FlowEntry> flowEntries) { |
| 75 | this.flowEntries = flowEntries; |
| 76 | } |
| 77 | |
| 78 | /** |
Pavlin Radoslavov | 204b286 | 2013-07-12 14:15:36 -0700 | [diff] [blame] | 79 | * Apply Flow Path Flags to the pre-computed Data Path. |
| 80 | * |
| 81 | * @param flowPathFlags the Flow Path Flags to apply. |
| 82 | */ |
| 83 | public void applyFlowPathFlags(FlowPathFlags flowPathFlags) { |
| 84 | if (flowPathFlags == null) |
| 85 | return; // Nothing to do |
| 86 | |
| 87 | // Discard the first Flow Entry |
| 88 | if (flowPathFlags.isDiscardFirstHopEntry()) { |
| 89 | if (flowEntries.size() > 0) |
| 90 | flowEntries.remove(0); |
| 91 | } |
| 92 | |
| 93 | // Keep only the first Flow Entry |
| 94 | if (flowPathFlags.isKeepOnlyFirstHopEntry()) { |
| 95 | if (flowEntries.size() > 1) { |
| 96 | FlowEntry flowEntry = flowEntries.get(0); |
| 97 | flowEntries.clear(); |
| 98 | flowEntries.add(flowEntry); |
| 99 | } |
| 100 | } |
| 101 | } |
| 102 | |
| 103 | /** |
Pavlin Radoslavov | dbaaf2e | 2013-03-29 04:25:55 -0700 | [diff] [blame] | 104 | * Get a string with the summary of the shortest-path data path |
| 105 | * computation. |
| 106 | * |
| 107 | * NOTE: This method assumes the DataPath was created by |
| 108 | * using FlowManager::getShortestPath() so the inPort and outPort |
| 109 | * of the Flow Entries are set. |
| 110 | * NOTE: This method is a temporary solution and will be removed |
| 111 | * in the future. |
| 112 | * |
| 113 | * @return a string with the summary of the shortest-path |
| 114 | * data path computation if valid, otherwise the string "X". |
| 115 | * If the shortest-path was valid, The string has the following form: |
| 116 | * inPort/dpid/outPort;inPort/dpid/outPort;... |
| 117 | */ |
| 118 | public String dataPathSummary() { |
| 119 | String resultStr = new String(); |
| 120 | if (this.flowEntries != null) { |
| 121 | for (FlowEntry flowEntry : this.flowEntries) { |
| 122 | // The data path summary string |
| 123 | resultStr = resultStr + |
| 124 | flowEntry.inPort().toString() + "/" |
| 125 | + flowEntry.dpid().toString() + "/" + |
| 126 | flowEntry.outPort().toString() + ";"; |
| 127 | } |
| 128 | } |
| 129 | if (resultStr.isEmpty()) |
| 130 | resultStr = "X"; // Invalid shortest-path |
| 131 | return resultStr; |
| 132 | } |
| 133 | |
| 134 | /** |
Pavlin Radoslavov | 5363c2a | 2013-02-18 09:55:42 -0800 | [diff] [blame] | 135 | * Convert the data path to a string. |
| 136 | * |
Pavlin Radoslavov | ad008e0 | 2013-02-21 18:42:42 -0800 | [diff] [blame] | 137 | * The string has the following form: |
Pavlin Radoslavov | a10a9a8 | 2013-02-22 11:47:54 -0800 | [diff] [blame] | 138 | * [src=01:01:01:01:01:01:01:01/1111 flowEntry=<entry1> flowEntry=<entry2> flowEntry=<entry3> dst=02:02:02:02:02:02:02:02/2222] |
Pavlin Radoslavov | ad008e0 | 2013-02-21 18:42:42 -0800 | [diff] [blame] | 139 | * |
Pavlin Radoslavov | 5363c2a | 2013-02-18 09:55:42 -0800 | [diff] [blame] | 140 | * @return the data path as a string. |
| 141 | */ |
| 142 | @Override |
| 143 | public String toString() { |
Pavlin Radoslavov | a10a9a8 | 2013-02-22 11:47:54 -0800 | [diff] [blame] | 144 | String ret = "[src=" + this.srcPort.toString(); |
Pavlin Radoslavov | ad008e0 | 2013-02-21 18:42:42 -0800 | [diff] [blame] | 145 | |
| 146 | for (FlowEntry fe : flowEntries) { |
Pavlin Radoslavov | a10a9a8 | 2013-02-22 11:47:54 -0800 | [diff] [blame] | 147 | ret += " flowEntry=" + fe.toString(); |
Pavlin Radoslavov | ad008e0 | 2013-02-21 18:42:42 -0800 | [diff] [blame] | 148 | } |
Pavlin Radoslavov | a10a9a8 | 2013-02-22 11:47:54 -0800 | [diff] [blame] | 149 | ret += " dst=" + this.dstPort.toString() + "]"; |
Pavlin Radoslavov | ad008e0 | 2013-02-21 18:42:42 -0800 | [diff] [blame] | 150 | |
Pavlin Radoslavov | 5363c2a | 2013-02-18 09:55:42 -0800 | [diff] [blame] | 151 | return ret; |
| 152 | } |
| 153 | } |