def help_push (self):
self.do_push("-h")
+ @verify_connected
def do_portattr (self, line):
'''Change/show port(s) attributes\n'''
self.stateless_client.set_port_attr_line(line)
# get stats
+ @__api_check(True)
def get_stats (self, ports = None, sync_now = True):
"""
Return dictionary containing statistics information gathered from the server.
self.src = self.port.get_src_addr()
if self.dst['ipv4'] is None:
- return self.port.err("Port has a non-IPv4 destination: '{0}'".format(dst['mac']))
+ return self.port.err("Port has a non-IPv4 destination: '{0}'".format(self.dst['mac']))
if self.src['ipv4'] is None:
return self.port.err('Port must have an IPv4 source address configured')
printf(" ERROR create file \n");
return(false);
}
+
/* prepare the write counter */
m_pkt_count = 0;
return init();
get_stateless_obj()->get_platform_api()->getPortAttrObj(port_id)->to_json(result["result"]["attr"]);
/* RX info */
- result["result"]["rx_info"] = port->rx_features_to_json();
+ try {
+ result["result"]["rx_info"] = port->rx_features_to_json();
+ } catch (const TrexException &ex) {
+ generate_execute_err(result, ex.what());
+ }
return (TREX_RPC_CMD_OK);
}
}
void CRxCoreStateless::handle_work_stage(bool do_try_rx_queue) {
- int i = 0;
- int j = 0;
+
+ /* set the next sync time to */
+ dsec_t sync_time_sec = now_sec() + (1.0 / 1000);
while (m_state == STATE_WORKING) {
-
+
if (do_try_rx_queue) {
try_rx_queues();
}
process_all_pending_pkts();
- /* TODO: with scheduler, this should be solved better */
- i++;
- if (i == 100000) { // approx 10msec
- i = 0;
- periodic_check_for_cp_messages(); // m_state might change in here
-
- j++;
- if (j == 100) { // approx 1 sec
- j = 0;
- port_manager_tick();
- }
+ dsec_t now = now_sec();
+
+ if ( (now - sync_time_sec) > 0 ) {
+ periodic_check_for_cp_messages();
+ port_manager_tick();
+ sync_time_sec = now + (1.0 / 1000);
}
rte_pause();
+
}
}