summaryrefslogtreecommitdiffstats
path: root/src/rpc-server/commands/trex_rpc_cmd_stream.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/rpc-server/commands/trex_rpc_cmd_stream.cpp')
-rw-r--r--src/rpc-server/commands/trex_rpc_cmd_stream.cpp116
1 files changed, 115 insertions, 1 deletions
diff --git a/src/rpc-server/commands/trex_rpc_cmd_stream.cpp b/src/rpc-server/commands/trex_rpc_cmd_stream.cpp
index 88b50089..58226a6b 100644
--- a/src/rpc-server/commands/trex_rpc_cmd_stream.cpp
+++ b/src/rpc-server/commands/trex_rpc_cmd_stream.cpp
@@ -25,16 +25,130 @@ limitations under the License.
using namespace std;
/**
+ * Stateless stream mode
+ * abstract class
+ */
+class TrexStreamMode {
+public:
+ enum mode_e {
+ CONTINUOUS,
+ SINGLE_BURST,
+ MULTI_BURST
+ };
+
+ virtual mode_e get_runtime_type() = 0;
+ virtual ~TrexStreamMode() {}
+};
+
+/**
+ * stream mode continuous
+ *
+ * @author imarom (30-Aug-15)
+ */
+class TrexStreamModeContinuous : public TrexStreamMode {
+public:
+ mode_e get_runtime_type() {
+ return (CONTINUOUS);
+ }
+private:
+ uint32_t pps;
+};
+
+/**
+ * single burst mode
+ *
+ */
+class TrexStreamModeSingleBurst : public TrexStreamMode {
+public:
+ mode_e get_runtime_type() {
+ return (SINGLE_BURST);
+ }
+private:
+
+ uint32_t packets;
+ uint32_t pps;
+};
+
+class TrexStreamModeMultiBurst : public TrexStreamMode {
+public:
+
+ mode_e get_runtime_type() {
+ return (MULTI_BURST);
+ }
+
+private:
+
+ uint32_t pps;
+ double ibg_usec;
+ uint32_t number_of_bursts;
+ uint32_t pkts_per_burst;
+};
+
+
+/**
+ * Stateless Stream
+ *
+ */
+class TrexStatelessStream {
+ friend class TrexRpcCmdAddStream;
+
+public:
+
+private:
+ /* config */
+ uint32_t stream_id;
+ uint8_t port_id;
+ double isg_usec;
+ uint32_t next_stream_id;
+ uint32_t loop_count;
+
+ /* indicators */
+ bool enable;
+ bool start;
+
+ /* pkt */
+ uint8_t *pkt;
+ uint16_t pkt_len;
+
+ /* stream mode */
+ TrexStreamMode *mode;
+
+ /* VM */
+
+ /* RX check */
+ struct {
+ bool enable;
+ bool seq_enable;
+ bool latency;
+ uint32_t stream_id;
+
+ } rx_check;
+
+};
+/**
* add new stream
*
*/
trex_rpc_cmd_rc_e
TrexRpcCmdAddStream::_run(const Json::Value &params, Json::Value &result) {
+ TrexStatelessStream stream;
+
check_param_count(params, 1, result);
check_field_type(params, "stream", FIELD_TYPE_OBJ, result);
- Json::Value &stream = result["stream"];
+ Json::Value &section = result["stream"];
+
+ /* create a new steram and populate it */
+
+ check_field_type(section, "stream_id", FIELD_TYPE_INT, result);
+ stream.stream_id = section["stream_id"].asInt();
+
+ check_field_type(section, "port_id", FIELD_TYPE_INT, result);
+ stream.port_id = section["port_id"].asInt();
+
+ check_field_type(section, "Is", FIELD_TYPE_DOUBLE, result);
+ stream.isg_usec = section["Is"].asDouble();
return (TREX_RPC_CMD_OK);
}