<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <!-- CSMA.html (C) K. J. Turner 18/12/14 --> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <title>CSMA/CD ("Ethernet")</title> <link rev="made" href="http://www.cs.stir.ac.uk/~kjt/"/> <script type="text/javascript" language="JavaScript"> <!-- var simulator; var serviceCount; var serviceMode; function validInteger(name, value, min, max) { if (!value.match("\\d+") || value < min || value > max) { alert("Value for " + name + " must be in range " + min + " to " + max); return false; } else return true; } function set() { retryLimit = document.settings.retryLimit.value; if (validInteger("Retry Limit", retryLimit, 0, 5)) { simulator.setParameter("retryLimit", retryLimit); simulator.restart(); } } //--> </script> </head> <body background="simulator.jpeg" onload="simulator=document.ProtocolSimulator; set();"> <div style="text-align: center"> <h1>CSMA/CD (Ethernet)</h1> <img src="simulator.gif" alt="Simulator Logo"/> </div> <h2>Protocol Description</h2> <p> CSMA/CD (Carrier Sense, Multiple Access, Collision Detection) illustrates how multiple systems can share a common communications medium. CSMA/CD is best known in the form of Ethernet - a kind of LANs (Local Area Network). LANs have a MAC layer (Medium Access Control) that operates the data link protocol. </p> <p> Many systems (known as stations) can be attached to an Ethernet - the Multiple Access aspect. A station will not transmit if it finds that another station is already using the Ethernet - the Carrier Sense aspect. However, it is still possible for two stations to transmit at almost the same time. While a station is transmitting, it may find that another station has already begun its own transmission - the Collision Detection aspect. In such a case, each station backs off and tries again - hopefully avoiding a collision on the second or later attempt. </p> <p> An Ethernet is a broadcast medium: whatever one station sends is received by all others. Each message carries the address of its intended destination; only the station with this address will act on the message. A transmission takes a very short (but not zero) time to arrive at its destination. Since stations will be at different distances from each other, the transmission time between them varies. The maximum transmission time between any two stations is called the slot time. </p> <p> Ethernet does not provide any guarantee of correct delivery, so its protocol can be simple. Instead, a higher-level protocol such as TCP (Transmission Control Protocol) is responsible for detecting and correcting errors. </p> <p> Transmission proceeds in one of the following ways: </p> <dl> <dt><b>Normal:</b></dt> <dd> The station transmits its message from start to finish. When the message has been fully received at the intended destination, that station processes the message. </p> </dd> <dt><b>Deferral:</b></dt> <dd> <p> In fact, a station listens for a transmission from another station before beginning its own transmission. If it hears such a transmission, it defers to the other station. Once that transmission has finished, the station begins its own transmission. </p> </dd> <dt><b>Collision:</b></dt> <dd> <p> However, this does not avoid interference. For example, a distant station may have started transmission but its signal has not yet arrived. The local station may therefore think the network is not in use and begin its own transmission. Both transmissions will then collide in the network. This can be detected by the transmitting stations, but this is not always fully reliable. The stations therefore ensure that the collision is properly detected by sending a jam signal. </p> <p> Following this, each station backs off a random delay (a number of slot times) before retrying its transmission. Ideally, one station should choose a smaller delay and so start retransmitting before the other one. </p> <p> For the first retransmission, the random delay is 0 or 1 slot times. Since two stations may choose the same delay, there is a 50% chance that they retry at the same point (and therefore collide again). On further collisions, the maximum delay is doubled (0 to 2, 0 to 4, etc.). A limit is set on the maximum number of retries. </p> </dd> </dl> <p> For this simulation, only two stations are involved; addresses are therefore not required. For simplicity, the protocol simulation below assumes that the LAN works perfectly (no message corruption, loss or misordering). However, interference among transmissions is still a source of potential error that the protocol must cope with. </p> <h2>Protocol Parameters</h2> <p> By default, the simulation has a retry limit of 0. Since this means that retries are not allowed, the simulation internally ensures that collisions cannot occur. Retry limits from 1 to 5 can be used, but the possibility of collisions complicates the behaviour. Click Change Settings after altering the retry limit. This will restart the whole simulation. </p> <form name="settings"> <center> <table cellspacing="5"> <tr> <td align="right">Retry Limit (0 = no collisions, 5 maximum):</td> <td><input name="retryLimit" size="4" value="0"></td> </tr> <tr> <td align="center" colspan="2"> <input type="button" name="btnSet" value="Change Settings" onclick="set()"/> </td> </tr> </table> </center> </form> <h2>Protocol Simulation</h2> <p> The protocol simulation shows a time-sequence diagram with two stations, the MAC entities that support them, and a LAN that carries messages between them. Stations transmit messages in the format <var>DATA(Dn)</var>. Data messages are numbered <var>D0</var>, <var>D1</var>, etc.; no explicit data content is given. If the retry limit is reached, this is reported to a station with the message <var>FAIL(Retry Limit)</var>. Protocol messages have the form <var>START(Dn)</var> to start a transmission, <var>FINISH(Dn)</var> to finish the transmission, and <var>JAM</var> to jam transmission. </p> <center> <applet code="simulator.ProtocolSimulator.class" archive="ProtocolSimulator.jar" width="750" height="700" name="ProtocolSimulator"> <param name="protocol" value="CSMA"/> </applet> </center> <hr/> <p> <a href="index.html"><img src="uparrow.gif" alt="Up Arrow"/></a> Up one level to <a href="index.html">Protocol Simulators</a> </p> </body> </html>