Your SlideShare is downloading. ×
cs.nyu.edu
Upcoming SlideShare
Loading in...5
×

Thanks for flagging this SlideShare!

Oops! An error has occurred.

×
Saving this for later? Get the SlideShare app to save on your phone or tablet. Read anywhere, anytime – even offline.
Text the download link to your phone
Standard text messaging rates apply

cs.nyu.edu

364

Published on

0 Comments
0 Likes
Statistics
Notes
  • Be the first to comment

  • Be the first to like this

No Downloads
Views
Total Views
364
On Slideshare
0
From Embeds
0
Number of Embeds
0
Actions
Shares
0
Downloads
15
Comments
0
Likes
0
Embeds 0
No embeds

Report content
Flagged as inappropriate Flag as inappropriate
Flag as inappropriate

Select your reason for flagging this presentation as inappropriate.

Cancel
No notes for slide

Transcript

  • 1. Data Communication and Networks Lecture 12 Data Link Layer December 2, 2004
  • 2. Our goals:
    • understand principles behind data link layer services:
      • error detection, correction
      • sharing a broadcast channel: multiple access
      • link layer addressing
      • reliable data transfer, flow control: done!
    • instantiation and implementation of various link layer technologies
  • 3. Link Layer
    • Services
    • Error detection and correction
    • Multiple access protocols
    • Link-Layer Addressing
    • Ethernet
  • 4. Link Layer Services
    • 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!
    • Reliable delivery between adjacent nodes
      • we learned how to do this already (chapter 3)!
      • 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?
  • 5. Link Layer Services (more)
    • Flow Control:
      • pacing between adjacent sending and receiving nodes
    • Error Detection :
      • errors caused by signal attenuation, noise.
      • receiver detects presence of errors:
        • signals sender for retransmission or drops frame
    • Error Correction:
      • receiver identifies and corrects bit error(s) without resorting to retransmission
    • Half-duplex and full-duplex
      • with half duplex, nodes at both ends of link can transmit, but not at same time
  • 6. Adaptors Communicating
    • link layer implemented in “adaptor” (aka NIC)
      • Ethernet card, PCMCI card, 802.11 card
    • sending side:
      • encapsulates datagram in a frame
      • adds error checking bits, rdt, flow control, etc.
    • receiving side
      • looks for errors, rdt, flow control, etc
      • extracts datagram, passes to rcving node
    • adapter is semi-autonomous
    • link & physical layers
    sending node rcving node datagram adapter adapter link layer protocol frame frame
  • 7. Link Layer
    • Services
    • Error detection and correction
    • Multiple access protocols
    • Link-Layer Addressing
    • Ethernet
  • 8. Error Detection
    • EDC= Error Detection and Correction bits (redundancy)
    • D = Data protected by error checking, may include header fields
    • Error detection not 100% reliable!
      • protocol may miss some errors, but rarely
      • larger EDC field yields better detection and correction
  • 9. Parity Checking Single Bit Parity: Detect single bit errors Two Dimensional Bit Parity : Detect and correct single bit errors 0 0
  • 10. Internet checksum
    • Sender:
    • treat segment contents as sequence of 16-bit integers
    • checksum: addition (1’s complement sum) of segment contents
    • sender puts checksum value into UDP checksum field
    • Receiver:
    • compute checksum of received segment
    • check if computed checksum equals checksum field value:
      • NO - error detected
      • YES - no error detected. But maybe errors nonetheless? More later ….
    Goal: detect “errors” (e.g., flipped bits) in transmitted segment (note: used at transport layer only )
  • 11. Cyclic Redundancy Check
    • For a block of k bits transmitter generates n bit sequence (FCS)
    • Transmit k+n bits which is exactly divisible by some number
    • Receiver divides frame by that number
      • If no remainder, assume no error
      • may be possible to correct error
  • 12. Cyclic Redundancy Check
    • Example: 16-Bit CRC for HDLC
    • Performed on Address, Control, Data Fields
    • Detects a Variety of Error Conditions
    • Data Message is Represented as a Polynomial, M i (x) = polynomial of order i =
    • a 0 + a 1 x + a 2 x 2 + a 3 x 3 + . . . + a i x i where a i = 0, 1
    • Data Message = a i a i-1 … a 3 a 2 a 1 a 0
    Start Frame Delimiter Source Address Destination Address Frame Control Data CRC
  • 13. CRC Generation
    • Given a Specific Polynomial G(x) called the generator, and a Data Message M(x), Calculate a Frame Check Sequence (FCS), or Checksum
    • Append the FCS (Checksum) to the Data Message for Transmission
    • At the Receiver, Recalculate the Checksum, and Check with the Transmitted Value
  • 14. CRC Algorithm
    • Multiply x r M(x), where r = degree of G(x)
      • Add r Zeros to M(x), or Shift M(x) Left
    • Divide x r M(x)/G(x) = R(x)
      • R(x) = Reminder of Divide Operation
    • Transmit x r M(x) + R(x) = T(x)
      • XOR the Shifted Message and R(x)
    • At the Receiver, Recalculate the R(x) and Check Equal to the Transmitted FCS
    • Errors Occurred in Transmission if Not equal
  • 15. CRC Error Detection
    • All Single Bit Errors
    • All Double Bit Errors
    • Any Odd Number of Errors
    • Any Burst Error for Which the Length of the Burst Error is Less Than the Length of the Divisor Polynomial, G(x)
    • Most Larger Burst Errors
    • Several G(x) Polynomials Have Been Used
  • 16. Example of G(x) Polynomials
    • CRC-12
      • X 12 + X 11 + X 3 + X 2 + X + 1
    • CRC-16
      • X 16 + X 15 + X 2 + 1
    • CRC-CCITT
      • X 16 + X 15 + X 5 + 1
    • CRC-32
      • X 32 + X 26 + X 23 + X 22 + X 16 + X 12 + X 11 + X 10
      • + X 8 + X 7 + X 5 + X 4 + X 2 + X + 1
    • CRC’s Are Implemented in Shift registers
  • 17. Example
    • The generator polynomial P = X2 + 1.
    • Receiver receives a frame F = 111001.  
    • 1101
    • -------
    • 101 / 111001
    • 101
    • ---
    • 100
    • 101
    • ---
    • 101
    • 101
    • ---
    • 0 remainder is zero: F is without error.
  • 18. Link Layer
    • Services
    • Error detection and correction
    • Multiple access protocols
    • Link-Layer Addressing
    • Ethernet
  • 19. Multiple Access Links and Protocols
    • Two types of “links”:
    • point-to-point
      • PPP for dial-up access
      • point-to-point link between Ethernet switch and host
    • broadcast (shared wire or medium)
      • traditional Ethernet
      • upstream HFC
      • 802.11 wireless LAN
  • 20. Multiple Access protocols
    • single shared broadcast channel
    • two or more simultaneous transmissions by nodes: interference
      • collision if node receives two or more signals at the same time
    • multiple access protocol
    • distributed algorithm that determines how nodes share channel, i.e., determine when node can transmit
    • communication about channel sharing must use channel itself!
      • no out-of-band channel for coordination
  • 21. Ideal Mulitple Access Protocol
    • Broadcast channel of rate R bps
    • 1. When one node wants to transmit, it can send at rate R.
    • 2. When M nodes want to transmit, each can send at average rate R/M
    • 3. Fully decentralized:
      • no special node to coordinate transmissions
      • no synchronization of clocks, slots
    • 4. Simple
  • 22. MAC Protocols: a taxonomy
    • Three broad classes:
    • Channel Partitioning
      • divide channel into smaller “pieces” (time slots, frequency, code)
      • allocate piece to node for exclusive use
    • Random Access
      • channel not divided, allow collisions
      • “ recover” from collisions
    • “ Taking turns”
      • Nodes take turns, but nodes with more to send can take longer turns
  • 23. Channel Partitioning MAC protocols: TDMA
    • TDMA: time division multiple access
    • access to channel in "rounds"
    • each station gets fixed length slot (length = pkt trans time) in each round
    • unused slots go idle
    • example: 6-station LAN, 1,3,4 have pkt, slots 2,5,6 idle
    • TDM (Time Division Multiplexing): channel divided into N time slots, one per user; inefficient with low duty cycle users and at light load.
    • FDM (Frequency Division Multiplexing): frequency subdivided.
  • 24. Channel Partitioning MAC protocols: FDMA
    • FDMA: frequency division multiple access
    • channel spectrum divided into frequency bands
    • each station assigned fixed frequency band
    • unused transmission time in frequency bands go idle
    • example: 6-station LAN, 1,3,4 have pkt, frequency bands 2,5,6 idle
    • TDM (Time Division Multiplexing): channel divided into N time slots, one per user; inefficient with low duty cycle users and at light load.
    • FDM (Frequency Division Multiplexing): frequency subdivided.
    frequency bands time
  • 25. Random Access Protocols
    • When node has packet to send
      • transmit at full channel data rate R.
      • no a priori coordination among nodes
    • two or more transmitting nodes ➜ “collision”,
    • random access MAC protocol specifies:
      • how to detect collisions
      • how to recover from collisions (e.g., via delayed retransmissions)
    • Examples of random access MAC protocols:
      • slotted ALOHA
      • ALOHA
      • CSMA, CSMA/CD, CSMA/CA
  • 26. Slotted ALOHA
    • Assumptions
    • all frames same size
    • time is divided into equal size slots, time to transmit 1 frame
    • nodes start to transmit frames only at beginning of slots
    • nodes are synchronized
    • if 2 or more nodes transmit in slot, all nodes detect collision
    • Operation
    • when node obtains fresh frame, it transmits in next slot
    • no collision, node can send new frame in next slot
    • if collision, node retransmits frame in each subsequent slot with prob. p until success
  • 27. Slotted ALOHA
    • Pros
    • single active node can continuously transmit at full rate of channel
    • highly decentralized: only slots in nodes need to be in sync
    • simple
    • Cons
    • collisions, wasting slots
    • idle slots
    • nodes may be able to detect collision in less than time to transmit packet
    • clock synchronization
  • 28. Pure (unslotted) ALOHA
    • unslotted Aloha: simpler, no synchronization
    • when frame first arrives
      • transmit immediately
    • collision probability increases:
      • frame sent at t 0 collides with other frames sent in [t 0 -1,t 0 +1]
  • 29. CSMA (Carrier Sense Multiple Access)
    • CSMA : listen before transmit:
    • If channel sensed idle: transmit entire frame
    • If channel sensed busy, defer transmission
    • Human analogy: don’t interrupt others!
  • 30. CSMA collisions collisions can still occur: propagation delay means two nodes may not hear each other’s transmission collision: entire packet transmission time wasted spatial layout of nodes note: role of distance & propagation delay in determining collision probability
  • 31. CSMA/CD (Collision Detection)
    • CSMA/CD: carrier sensing, deferral as in CSMA
      • collisions detected within short time
      • colliding transmissions aborted, reducing channel wastage
    • collision detection:
      • easy in wired LANs: measure signal strengths, compare transmitted, received signals
      • difficult in wireless LANs: receiver shut off while transmitting
    • human analogy: the polite conversationalist
  • 32. CSMA/CD collision detection
  • 33. “Taking Turns” MAC protocols
    • channel partitioning MAC protocols:
      • share channel efficiently and fairly at high load
      • inefficient at low load: delay in channel access, 1/N bandwidth allocated even if only 1 active node!
    • Random access MAC protocols
      • efficient at low load: single node can fully utilize channel
      • high load: collision overhead
    • “ taking turns” protocols
      • look for best of both worlds!
  • 34. “Taking Turns” MAC protocols
    • Polling:
    • master node “invites” slave nodes to transmit in turn
    • concerns:
      • polling overhead
      • latency
      • single point of failure (master)
    • Token passing:
    • control token passed from one node to next sequentially.
    • token message
    • concerns:
      • token overhead
      • latency
      • single point of failure (token)
  • 35. Summary of MAC protocols
    • What do you do with a shared media?
      • Channel Partitioning, by time, frequency or code
        • Time Division, Frequency Division
      • Random partitioning (dynamic),
        • ALOHA, S-ALOHA, CSMA, CSMA/CD
        • carrier sensing: easy in some technologies (wire), hard in others (wireless)
        • CSMA/CD used in Ethernet
        • CSMA/CA used in 802.11
      • Taking Turns
        • polling from a central site, token passing
  • 36. Link Layer
    • Services
    • Error detection and correction
    • Multiple access protocols
    • Link-Layer Addressing
    • Ethernet
  • 37. MAC Addresses and ARP
    • 32-bit IP address:
      • network-layer address
      • used to get datagram to destination IP subnet
    • MAC (or LAN or physical or Ethernet) address:
      • used to get datagram from one interface to another physically-connected interface (same network)
      • 48 bit MAC address (for most LANs) burned in the adapter ROM
  • 38. LAN Addresses and ARP Each adapter on LAN has unique LAN address Broadcast address = FF-FF-FF-FF-FF-FF = adapter 1A-2F-BB-76-09-AD 58-23-D7-FA-20-B0 0C-C4-11-6F-E3-98 71-65-F7-2B-08-53 LAN (wired or wireless)
  • 39. LAN Address (more)
    • MAC address allocation administered by IEEE
    • manufacturer buys portion of MAC address space (to assure uniqueness)
    • Analogy:
    • (a) MAC address: like Social Security Number
    • (b) IP address: like postal address
    • MAC flat address ➜ portability
      • can move LAN card from one LAN to another
    • IP hierarchical address NOT portable
      • depends on IP subnet to which node is attached
  • 40. ARP: Address Resolution Protocol
    • Each IP node (Host, Router) on LAN has ARP table
    • ARP Table: IP/MAC address mappings for some LAN nodes
    • < IP address; MAC address; TTL>
      • TTL (Time To Live): time after which address mapping will be forgotten (typically 20 min)
    1A-2F-BB-76-09-AD 58-23-D7-FA-20-B0 0C-C4-11-6F-E3-98 71-65-F7-2B-08-53 LAN 237.196.7.23 237.196.7.78 237.196.7.14 237.196.7.88 Question: how to determine MAC address of B knowing B’s IP address?
  • 41. ARP protocol: Same LAN (network)
    • A wants to send datagram to B, and B’s MAC address not in A’s ARP table.
    • A broadcasts ARP query packet, containing B's IP address
      • Dest MAC address = FF-FF-FF-FF-FF-FF
      • all machines on LAN receive ARP query
    • B receives ARP packet, replies to A with its (B's) MAC address
      • frame sent to A’s MAC address (unicast)
    • A caches (saves) IP-to-MAC address pair in its ARP table until information becomes old (times out)
      • soft state: information that times out (goes away) unless refreshed
    • ARP is “plug-and-play”:
      • nodes create their ARP tables without intervention from net administrator
  • 42. Routing to another LAN
    • walkthrough: send datagram from A to B via R
    • assume A know’s B IP address
    • Two ARP tables in router R, one for each IP network (LAN)
    • In routing table at source Host, find router 111.111.111.110
    • In ARP table at source, find MAC address E6-E9-00-17-BB-4B, etc
    A R B
  • 43.
    • A creates datagram with source A, destination B
    • A uses ARP to get R’s MAC address for 111.111.111.110
    • A creates link-layer frame with R's MAC address as dest, frame contains A-to-B IP datagram
    • A’s adapter sends frame
    • R’s adapter receives frame
    • R removes IP datagram from Ethernet frame, sees its destined to B
    • R uses ARP to get B’s MAC address
    • R creates frame containing A-to-B IP datagram sends to B
    A R B
  • 44. Link Layer
    • Services
    • Error detection and correction
    • Multiple access protocols
    • Link-Layer Addressing
    • Ethernet
  • 45. Ethernet
    • “ dominant” wired LAN technology:
    • cheap $20 for 100Mbs!
    • first widely used LAN technology
    • Simpler, cheaper than token LANs and ATM
    • Kept up with speed race: 10 Mbps – 10 Gbps
    Metcalfe’s Ethernet sketch
  • 46. Star topology
    • Bus topology popular through mid 90s
    • Now star topology prevails
    • Connection choices: hub or switch (more later)
    hub or switch
  • 47. Ethernet Frame Structure
    • Sending adapter encapsulates IP datagram (or other network layer protocol packet) in Ethernet frame
    • Preamble:
    • 7 bytes with pattern 10101010 followed by one byte with pattern 10101011
    • used to synchronize receiver, sender clock rates
  • 48. Ethernet Frame Structure (more)
    • Addresses: 6 bytes
      • if adapter receives frame with matching destination address, or with broadcast address (eg ARP packet), it passes data in frame to net-layer protocol
      • otherwise, adapter discards frame
    • Type: indicates the higher layer protocol (mostly IP but others may be supported such as Novell IPX and AppleTalk)
    • CRC: checked at receiver, if error is detected, the frame is simply dropped
  • 49. Unreliable, connectionless service
    • Connectionless: No handshaking between sending and receiving adapter.
    • Unreliable: receiving adapter doesn’t send acks or nacks to sending adapter
      • stream of datagrams passed to network layer can have gaps
      • gaps will be filled if app is using TCP
      • otherwise, app will see the gaps
  • 50. Ethernet uses CSMA/CD
    • No slots
    • adapter doesn’t transmit if it senses that some other adapter is transmitting, that is, carrier sense
    • transmitting adapter aborts when it senses that another adapter is transmitting, that is, collision detection
    • Before attempting a retransmission, adapter waits a random time, that is, random access
  • 51. Ethernet CSMA/CD algorithm
    • 1. Adaptor receives datagram from net layer & creates frame
    • 2. If adapter senses channel idle, it starts to transmit frame. If it senses channel busy, waits until channel idle and then transmits
    • 3. If adapter transmits entire frame without detecting another transmission, the adapter is done with frame !
    • 4. If adapter detects another transmission while transmitting, aborts and sends jam signal
    • 5. After aborting, adapter enters exponential backoff : after the mth collision, adapter chooses a K at random from {0,1,2,…,2 m -1}. Adapter waits K · 512 bit times and returns to Step 2
  • 52. Ethernet’s CSMA/CD (more)
    • Jam Signal: make sure all other transmitters are aware of collision; 48 bits
    • Bit time: .1 microsec for 10 Mbps Ethernet ; for K=1023, wait time is about 50 msec
    • Exponential Backoff:
    • Goal : adapt retransmission attempts to estimated current load
      • heavy load: random wait will be longer
    • first collision: choose K from {0,1}; delay is K · 512 bit transmission times
    • after second collision: choose K from {0,1,2,3}…
    • after ten collisions, choose K from {0,1,2,3,4,…,1023}
    See/interact with Java applet on AWL Web site: highly recommended !
  • 53. 10BaseT and 100BaseT
    • 10/100 Mbps rate; latter called “fast ethernet”
    • T stands for Twisted Pair
    • Nodes connect to a hub: “star topology”; 100 m max distance between nodes and hub
    twisted pair hub
  • 54. Manchester encoding
    • Used in 10BaseT
    • Each bit has a transition
    • Allows clocks in sending and receiving nodes to synchronize to each other
      • no need for a centralized, global clock among nodes!
    • Hey, this is physical-layer stuff!
  • 55. Gbit Ethernet
    • uses standard Ethernet frame format
    • allows for point-to-point links and shared broadcast channels
    • in shared mode, CSMA/CD is used; short distances between nodes required for efficiency
    • uses hubs, called here “Buffered Distributors”
    • Full-Duplex at 1 Gbps for point-to-point links
    • 10 Gbps now !
  • 56. Link Layer
    • 5.1 Introduction and services
    • 5.2 Error detection and correction
    • 5.3Multiple access protocols
    • 5.4 Link-Layer Addressing
    • 5.5 Ethernet
    • 5.6 Interconnections: Hubs and switches
    • 5.7 PPP
    • 5.8 Link Virtualization: ATM
  • 57. Link Layer
    • 5.1 Introduction and services
    • 5.2 Error detection and correction
    • 5.3Multiple access protocols
    • 5.4 Link-Layer Addressing
    • 5.5 Ethernet
    • 5.6 Hubs and switches
    • 5.7 PPP
    • 5.8 Link Virtualization: ATM
  • 58. Point to Point Data Link Control
    • one sender, one receiver, one link: easier than broadcast link:
      • no Media Access Control
      • no need for explicit MAC addressing
      • e.g., dialup link, ISDN line
    • popular point-to-point DLC protocols:
      • PPP (point-to-point protocol)
      • HDLC: High level data link control (Data link used to be considered “high layer” in protocol stack!
  • 59. PPP Design Requirements [RFC 1557]
    • packet framing: encapsulation of network-layer datagram in data link frame
      • carry network layer data of any network layer protocol (not just IP) at same time
      • ability to demultiplex upwards
    • bit transparency: must carry any bit pattern in the data field
    • error detection (no correction)
    • connection liveness: detect, signal link failure to network layer
    • network layer address negotiation: endpoint can learn/configure each other’s network address
  • 60. PPP non-requirements
    • no error correction/recovery
    • no flow control
    • out of order delivery OK
    • no need to support multipoint links (e.g., polling)
    Error recovery, flow control, data re-ordering all relegated to higher layers!
  • 61. PPP Data Frame
    • Flag: delimiter (framing)
    • Address: does nothing (only one option)
    • Control: does nothing; in the future possible multiple control fields
    • Protocol: upper layer protocol to which frame delivered (eg, PPP-LCP, IP, IPCP, etc)
  • 62. PPP Data Frame
    • info: upper layer data being carried
    • check: cyclic redundancy check for error detection
  • 63. Byte Stuffing
    • “ data transparency” requirement: data field must be allowed to include flag pattern <01111110>
      • Q: is received <01111110> data or flag?
    • Sender: adds (“stuffs”) extra < 01111110> byte after each < 01111110> data byte
    • Receiver:
      • two 01111110 bytes in a row: discard first byte, continue data reception
      • single 01111110: flag byte
  • 64. Byte Stuffing flag byte pattern in data to send flag byte pattern plus stuffed byte in transmitted data
  • 65. PPP Data Control Protocol
    • Before exchanging network-layer data, data link peers must
    • configure PPP link (max. frame length, authentication)
    • learn/configure network
    • layer information
      • for IP: carry IP Control Protocol (IPCP) msgs (protocol field: 8021) to configure/learn IP address

×