#include <itpp/protocol/tcp.h>
Public Member Functions | |
TCP_Sender (int label) | |
ADD DOCUMENTATION HERE. | |
virtual | ~TCP_Sender () |
ADD DOCUMENTATION HERE. | |
virtual void | setup () |
ADD DOCUMENTATION HERE. | |
virtual void | release (std::string trace_filename="") |
ADD DOCUMENTATION HERE. | |
virtual void | print_item (std::ostream &, const std::string &) |
Print support. | |
virtual void | set_debug (const bool enable_debug=true) |
ADD DOCUMENTATION HERE. | |
virtual void | set_debug (bool enable_debug, bool enable_signal_debug) |
ADD DOCUMENTATION HERE. | |
virtual void | set_trace (const bool enable_trace=true) |
ADD DOCUMENTATION HERE. | |
virtual void | save_trace (std::string filename) |
ADD DOCUMENTATION HERE. | |
Public Attributes | |
Signal< itpp::Packet * > | tcp_send |
ADD DOCUMENTATION HERE. | |
Slot< TCP_Sender, itpp::Packet * > | tcp_receive_ack |
ADD DOCUMENTATION HERE. | |
Slot< TCP_Sender, itpp::Packet * > | tcp_socket_write |
ADD DOCUMENTATION HERE. | |
Slot< TCP_Sender, std::string > | tcp_release |
ADD DOCUMENTATION HERE. | |
TTCPSender is an entity that models TCP flow and congestion control at the sender side. It is one of the key components of the TCP module.
TTCPSender communicates with its environment via three ports:
The sender is activated when the user entity (e.g. a generator) offers a message, whose length indicates the amount of data to be transferred, or when an ACK is received from the network. In both cases data is only sent if there is any unsent data available, the sending window (determined by the congestion window and by the receiver advertised window) is large enough and the silly window syndrome avoidance algorithm is passed. Data that has been sent remains in the sender buffer, which is modelled in a virtual manner, until it is acknowledged. If data has been ACKed it is erased in the sender buffer and the TCP sender tries to get new data and send it.
TTCPSender can be used with different versions of congestion control: Tahoe, Reno, and New Reno. Moreover, various options (e.g. usage of Nagle/Karn/Go-Back-N algorithms) and parameters (e.g. mss, max cwnd, initial values, timer granularity) can be defined in the input file.
The class provides a simplified connection control via methods Setup and Release. Those methods are only used to reset internal state variables. No control messages are sent over the network, i.e. the sender assumes that the corresponding methods at the receiver side are called as well.
Generated on Sat Jul 6 2013 10:54:34 for IT++ by Doxygen 1.8.2