#### Data Link Layer The Data Link layer can be further subdivided into: I. Logical Link Control (LLC): error and flow control 2. Media Access Control (MAC): framing and media application access different link protocols may provide different services, transport e.g., Ethernet doesn't provide reliable delivery (error recovery) network MAC topics: LLC • framing and MAC address assignment MAC LAN forwarding • IP to MAC address resolution • IP to MAC: Address Resolution Protocol (ARP) • MAC to IP: Reverse ARP (RARP), BOOTstrap Protocol (BOOTP), Dynamic Host Configuration Protocol (DHCP) media access control









# Transparent Bridges/Switches and Backward Learning

How does a bridge know which segment a node is located at?

Each switch has a switch table, entry in switch table:

- <MAC Address, interface, timestamp>
- stale entries in table dropped (TTL can be 60 min)

switch *learns* which hosts can be reached through which interfaces

- when a frame is received, switch "learns" location of sender: incoming interface connects to the LAN segment through which a sender may be reached
- records sender/interface pair in switch table
- called "backward learning"





















#### **Transmission Errors**

Three kinds of transmission errors:

- I. sent signal changed (received wrong data)
- 2. sent signal destroyed (doesn't receive data)
- 3. spurious signal created (received random data)

Caused by noise on the channel: interference, cosmic rays

### **Error Control**

Ways to detect errors, general idea:

- sender computes some info from data
- sender sends this info along with data
- receiver does the same computation and compares it with the sent info

Not often used for largely reliable links, but useful for unreliable links such as wireless

Used at the transport layer also (the Internet is an unreliable "link")

Field: Information Theory

#### **Error Control**

#### Two types of error control:

- I. error detecting code
- 2. error correcting code (ECC), a.k.a. forward error correction/control (FEC)

Examples error detecting code:

- parity check
- checksum
- cyclic redundancy check (CRC)

### **Error Control**

Trade-offs between alternate methods:

- complexity of info computation,
- bandwidth transmission overhead, and
- degree of protection (# of bit errors that can be detected)

No error detection method is fool-proof

### Parity Check

- uses an extra bit (parity bit) for error checking
- even parity: total # of I bits (incl. the parity bit) is an even number
- odd parity: total # of I bits is odd
- single-bit parity examples:

0100101, even-parity bit =

0101101, even-parity bit =

- what happens when an error is detected?
- discard data and if reliability is required, have sender retransmit
- problem: can not detect even # of flipped bits



#### Error Correction vs. Detection

- ECC generally requires more redundant bits than just detection
- It is generally cheaper to retransmit data only when error has been detected than to transmit redundant data *all the time*

FEC is most useful when:

- I. link is very noisy, e.g., wireless link
- 2. retransmission will take too long, e.g.,
  - satellite communication
  - deep space probe transmission
  - real-time audio/video streaming



#### Checksum Disadvantage: • with 16-bit checksum, 1 in 64K corrupted packet will not be detected (probability of a random 16-bit number matching the checksum of a corrupted packet is $1/2^{16}$ ) **Data Item** Checksum Data Item Checksum In Binary In Binary Value Value 00001 00011 1 3 00010 2 00000 0 00011 3 00001 1 00001 1 00011 3 totals 7 7 $\Rightarrow$ under current Internet conditions (error rate etc.), I in every 300M packet accepted corrupted! # checksum ~#pkts Layer Mogul (1992) measured on a busy NFS errors caught server that has been up 40 days: ethernet (CRC) 446 1.7x10<sup>8</sup> IP 14 1.7×10<sup>8</sup> UDP

5

350

TCP

1.4x10<sup>8</sup>

3×107

#### Cyclic Redundancy Check Goal of any error detection/correction code: maximize probability of detecting error with minimal redundant info 32-bit CRC protects against most bit errors in messages thousands of bytes long, also used in storage systems (CD, DVD) CRC is based on finite fields math Consider a binary message as a representation of an n-degree polynomial, with the coefficient of each term being 1 or 0 depending on the bit in the message, with the most significant (leftmost) bit representing the highest degree term • For example: 1011 represents $1x^3 + 0x^2 + 1x^1 + 1x^0 = x^3 + x + 1$ An *m*-bit message represents a polynomial of m-1 degree

#### **Polynomial Arithmetic**

The math says you can divide one such polynomial by another such polynomial of lower or equal degree by dividing the binary representation of the polynomials, e.g., to divide  $x^{5}+x^{3}+x^{2}+x$  by  $x^{3}+1$ , divide 101110 by 1001

Polynomial arithmetic is done using modulo-2 arithmetic, with no carry and borrow: 1+1 = 0+0 = 0 and 1+0 = 0+1 = 1, e.g.,

| 10011011   | 11110000   | 01010101   |
|------------|------------|------------|
| 11001010 + | 10100110 - | 10101111 - |
|            |            |            |
|            |            |            |

Note that both addition and subtraction are identical to XOR







### **CRC** Hardware Implementation

CRC can be cheaply implemented in hardware by implementing the longdivision to compute R as a combination of linear feedback shift register (LFSR) and XOR gates

The shift registers and XOR gates represents the G:

- the 0-th term of G occupies the leftmost bit of the shift registers
- each XOR gate represents a modulo-2 addition in G
- the message is fed into the circuit most significant (leftmost) bit first
- each bit of the message causes the current content of the shift registers to be shifted right by one bit
- when the message is exhausted, the shift registers contain R
- for example, computing CRC with  $G = x^2 + 1$  can be implemented as:



#### Link Layer Services

Half-duplex and full-duplex

• with half duplex, nodes at both ends of link can transmit, but not at same time

Framing, link access:

- encapsulate datagram into frame, adding header, trailer
- · channel access if shared medium
- "MAC" addresses used in frame headers to identify source, dest
- different from IP address!

Error Detection:

- errors caused by signal attenuation, noise.
- receiver detects presence of errors:
  - signals sender for retransmission or drops frame

### Link Layer Services

#### Error Correction:

 receiver identifies and corrects bit error(s) without resorting to retransmission

#### Flow Control:

• pacing between adjacent sending and receiving nodes

#### Reliable delivery between adjacent nodes

- seldom used on low bit error link (fiber, some twisted pair)
- wireless links: high error rates
- Q: why both link-level and end-end reliability?

### Flow Control

What is flow control?

• receiver telling sender to slow down

Why do you need flow control?

• slow or busy receiver

- don't want to overflow receiver's buffer
- Flow control protocols at data link layer (single hop):
- XON/XOFF
- •Stop & Wait Protocol (SWP)
- •Sliding Window Protocol

Similar issues and mechanisms apply at the transport layer











## Sliding Window

Send w number of pkts before waiting for an ACK (can have w outstanding, i.e., unACKed, pkts)



On receiving an ACK, slide window (over data) by I pkt (S&W is sliding window with w = I)

Throughput of the sliding window protocol  $(T_w)$ :

$$T_w = T_g * w$$

send window size w limited by buffer size at receiver ( $w_R$ ):

#### $T_w = T_g *MIN(w, w_R)$











