Download presentation
Presentation is loading. Please wait.
Published byKerry Carroll Modified over 9 years ago
1
جلسه هشتم شبکه های کامپیوتری به نــــــــــــام خدا
2
Data link layer Data Link Layer Purpose: Ensure reliable, efficient communication between neighbor nodes Four specific functions: Provide services to network layer Framing Error handling Flow control Operation Perspective 2
3
Services Provided to Network Layer Services Provided to Network Layer: 1. Unacknowledged Connectionless 2. Acknowledged Connectionless 3. Acknowledged connection oriented 3
4
Services Provided to Network Layer Unacknowledged connectionless Just send frames towards the destination No connection is established, No connection released No acknowledge of received frames No attempt to recover lost frames Appropriate in case of: Real-time traffic: speech, video: Short delay more important than 100% reliability Low error channels: leave error correction to higher layers Most LAN’s are using this service class 4
5
Service to Network Layer Acknowledged connectionless Each frame is acknowledged, but no connection is Established Acknowledgment is a service that can be performed by the transport layer as well Data link layer provides this service to avoid long delays that could be caused if frames are not acknowledged Specially important over un-reliable channels such as Wireless Example: 802.11 (WiFi) 5
6
Service to Network Layer Acknowledged Connection Oriented Establishes a connection before sending data Each frame is numbered Data link layer guarantees the delivery of a SINGLE copy of EVERY frame (With acknowledged connectionless, it is possible to receive multiple copies of a frame due to a lost ACK) Releases the connection at the end of conversation (To release software and hardware resources tied up to the connection) Provides a reliable bit stream to Network Layer 6
7
Framing Character Count Use character count symbols to specify the end of frame Sensitive to error. Difficult to recover if sync is lost Character stuffing Insert ASCII known characters to specify boundaries (FLAG) Insert ESC before accidental FLAGs or ESCs of binary files. To be removed by the receiver’s data link layer Choice of marking characters (ESC, FLAG) Depends on 8 bit ASCII character set 7
8
Framing Bit Stuffing Use a flag bit pattern (01111110) Stuff a zero after 5 1’s if it happened in user data Easy to recover the frame if sync is lost Coding Violation Send physical layer signals that can not be associated with valid data sets to indicate frame Boundaries 8
9
Error Detection and Correction 9 Error handling Errors usually occur in bursts Advantage: fewer frames are corrupted Disadvantage: burst errors harder to detect and correct Two approaches: Detection Correction Both require extra bits per data word or message Idea: add r extra bits to frame data Not all 2 m+r codes are legal (only 2 m codes are legal) n = m + r bits code word, m bits for data and r bits added for error control
10
Error Detection and Correction 10 Hamming distance The Hamming distance (HD) of 2 code words a and b is the number of bit positions in which a and b are different: HD (a,b)= Number of ones in (a XOR b) Note that HD (a,b) bit errors are required to convert a into b (or vice versa ) If a code-set is designed to ensure a minimal hamming distance HDmin between any two valid code-words: If HDmin = d + 1 : d bit errors can be detected If HDmin = 2d + 1 : d bit errors can be corrected
11
Hamming distance 11 Example 1: parity Add (parity) bit to every data word such that total numbers of ones is even (or odd) HDmin = 2 single bit errors are detectable Example 2: 4 data words with HDmin = 5 double errors can be corrected 0000,0000,00 0000,0111,11 1111,1000,00 1111,1111,11 If 0000.0001.11 arrives, what is the original?
12
Hamming Code 12 How many redundant (r) bits do we need for a single bit error correction? Assume m bit message with r bits added for single error correction (n = m+r bits) How many legal code-words? 2 m How many illegal codes per code-words? n*(2 m ) (n+1)*(2 m ) (m+r+1)<=2 r This is the minimum number of bits (r) we need to correct a single error in n bits with r parity bits Example: M=8 => r>=4 ; M=16 => r>=5 ; M=240 => r>=8 Error detection with retransmission often much more efficient than error Correction Example: Error rate 10 -6 ---- Block size 1000 bits Single bit error correcting requires 10 bits / block Single bit error detection requires 1 bit / block Retransmission of 1 block (= 1001 bits) per 1000 blocks is more efficient
13
Cyclic Redundancy Check (CRC) 13 View bit sequence as polynomial, e.g. (degree 5):110001=> x^5 + x^4 + x^0 Idea: add r bits such that resulting polynomial is dividable by a certain polynomial; if not an error occurred Polynomial Arithmetic (modulo 2): Add and Subtract are identical: use bit wise XOR (no carry/borrow needed) Div: just like binary division, except of using the above subtract CRCs can easily be constructed and checked in hardware using a linear feedback shift register (LFSR) Standard polynomials: CRC-12 = x12 +x11 + x3 + x2 + x +1 CRC-16 = x16 +x15 +x2 +1 CRC-CCITT = x16 +x12 +x5 +1
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.