Communication methods. Communication methods



Similar documents
Elettronica dei Sistemi Digitali Costantino Giaconia SERIAL I/O COMMON PROTOCOLS

Ethernet. Ethernet Frame Structure. Ethernet Frame Structure (more) Ethernet: uses CSMA/CD

SPI I2C LIN Ethernet. u Today: Wired embedded networks. u Next lecture: CAN bus u Then: wireless embedded network

Project 4: Pseudo USB Simulation Introduction to UNIVERSAL SERIAL BUS (USB) STANDARD

Lecture 3: Signaling and Clock Recovery. CSE 123: Computer Networks Stefan Savage

Local Area Networks transmission system private speedy and secure kilometres shared transmission medium hardware & software

2. What is the maximum value of each octet in an IP address? A. 128 B. 255 C. 256 D. None of the above

EECC694 - Shaaban. Transmission Channel

Real-time Operating Systems Lecture 27.1

Process Control and Automation using Modbus Protocol

Computers Are Your Future Prentice-Hall, Inc.

USER GUIDE EDBG. Description

Computer Organization & Architecture Lecture #19

The I2C Bus. NXP Semiconductors: UM10204 I2C-bus specification and user manual HAW - Arduino 1

Based on Computer Networking, 4 th Edition by Kurose and Ross

Computer Systems Structure Input/Output

Serial Communications

Objectives. Basics of Serial Communication. Simplex vs Duplex. CMPE328 Microprocessors (Spring ) Serial Interfacing. By Dr.

Fast Ethernet and Gigabit Ethernet. Networks: Fast Ethernet 1

Computer Network. Interconnected collection of autonomous computers that are able to exchange information

Objectives. Lecture 4. How do computers communicate? How do computers communicate? Local asynchronous communication. How do computers communicate?

EECS 122: Introduction to Computer Networks Multiaccess Protocols. ISO OSI Reference Model for Layers

AVR151: Setup and Use of the SPI. Introduction. Features. Atmel AVR 8-bit Microcontroller APPLICATION NOTE

COMPUTER HARDWARE. Input- Output and Communication Memory Systems

Chapter 9A. Network Definition. The Uses of a Network. Network Basics

Welcome to the Introduction to Controller Area Network web seminar My name is William Stuart, and I am a Applications Engineer for the Automotive

RS-485 Protocol Manual

UMBC. ISA is the oldest of all these and today s computers still have a ISA bus interface. in form of an ISA slot (connection) on the main board.

RTT 60.5 msec receiver window size: 32 KB

Remote Serial over IP Introduction on serial connections via IP/Ethernet

Wireless Personal Area Networks (WPANs)

DECT Module UM-9802 Datasheet

CSE331: Introduction to Networks and Security. Lecture 6 Fall 2006

Introduction the Serial Communications Huang Sections 9.2, 10.2 SCI Block User Guide SPI Block User Guide

Single channel data transceiver module WIZ2-434

Fast Ethernet and Gigabit Ethernet. Computer Networks: Fast and Gigabit Ethernet

LAN Switching Computer Networking. Switched Network Advantages. Hubs (more) Hubs. Bridges/Switches, , PPP. Interconnecting LANs

INTRODUCTION TO COMMUNICATION SYSTEMS AND TRANSMISSION MEDIA

Application Note 83 Fundamentals of RS 232 Serial Communications

AND8336. Design Examples of On Board Dual Supply Voltage Logic Translators. Prepared by: Jim Lepkowski ON Semiconductor.

Chapter 7 Low-Speed Wireless Local Area Networks

ESSENTIALS. Understanding Ethernet Switches and Routers. April 2011 VOLUME 3 ISSUE 1 A TECHNICAL SUPPLEMENT TO CONTROL NETWORK

Chapter 2 - The TCP/IP and OSI Networking Models

CS423: Lectures 2-4, Physical Layer. George Varghese. April 16, 2008

Serial Communications

BLUETOOTH SERIAL PORT PROFILE. iwrap APPLICATION NOTE

Solution. (Chapters ) Dr. Hasan Qunoo. The Islamic University of Gaza. Faculty of Engineering. Computer Engineering Department

The Bus (PCI and PCI-Express)

Communicating with devices

USART and Asynchronous Communication

CSMA/CA. Information Networks p. 1

Data Communications & Networks. Session 3 Main Theme Data Encoding and Transmission. Dr. Jean-Claude Franchitti

Wired & Wireless LAN Connections

TCOM 370 NOTES 99-6 VOICE DIGITIZATION AND VOICE/DATA INTEGRATION

CS263: Wireless Communications and Sensor Networks

11/22/

USB2.0 <=> I2C V4.4. Konverter Kabel und Box mit Galvanischetrennung

Software User Guide UG-461

Modbus and ION Technology

Module 5. Broadcast Communication Networks. Version 2 CSE IIT, Kharagpur

: Instructor

What is a bus? A Bus is: Advantages of Buses. Disadvantage of Buses. Master versus Slave. The General Organization of a Bus

Ethernet. Ethernet. Network Devices

Atmel Norway XMEGA Introduction

IT Data Communication and Networks (Optional)

Pmod peripheral modules are powered by the host via the interface s power and ground pins.

How To Encode Data From A Signal To A Signal (Wired) To A Bitcode (Wired Or Coaxial)

Voice over IP. Demonstration 1: VoIP Protocols. Network Environment

IDE/ATA Interface. Objectives. IDE Interface. IDE Interface

Data Link Protocols. TCP/IP Suite and OSI Reference Model

Using Xbee in Serial Communication

Attenuation (amplitude of the wave loses strength thereby the signal power) Refraction Reflection Shadowing Scattering Diffraction

EnOcean Radio Protocol 2. September 26, 2013 SPECIFICATION V1.0. Subject to modifications EnOcean Radio Protocol 2 V1.0 Page 1/19

Unit of Learning # 2 The Physical Layer. Sergio Guíñez Molinos sguinez@utalca.cl

Introduction, Rate and Latency

Figure 1.Block diagram of inventory management system using Proximity sensors.

WPAN. Contents. S Wireless Personal, Local, Metropolitan, and Wide Area Networks 1

ECE 358: Computer Networks. Homework #3. Chapter 5 and 6 Review Questions 1

Introduction to Ethernet

Selecting the Optimum PCI Express Clock Source

IEEE 1394 Card. Version 1.0

Multiplexing on Wireline Telephone Systems

TCOM 370 NOTES LOCAL AREA NETWORKS AND THE ALOHA PROTOCOL

Analog vs. Digital Transmission

Introduction To Computer Networks


Eliminate Risk of Contention and Data Corruption in RS-485 Communications

Network Monitoring White Paper

Lizy Kurian John Electrical and Computer Engineering Department, The University of Texas as Austin

AN141 SMBUS COMMUNICATION FOR SMALL FORM FACTOR DEVICE FAMILIES. 1. Introduction. 2. Overview of the SMBus Specification. 2.1.

FIBER OPTIC APPLICATION IN A PROFIBUS NETWORK

PCS0100en Persy Control Services B.V. Netherlands

LIN (Local Interconnect Network):

VMR6512 Hi-Fi Audio FM Transmitter Module

Tutorial.

WIRELESS ETHERNET (IEEE )

What is Easy-Radio? Devices Covered. Frequency Hopping Transceiver. Where x00 denotes frequency of operation. E.g. 400 = 433MHz

WUA Mbps Wireless USB Network Adapter

Communication Networks. MAP-TELE 2011/12 José Ruela

Local Interconnect Network Training. Local Interconnect Network Training. Overview

Transcription:

Communication methods Communication methods Media and signalling conventions used to transmit data between digital devices Different physical layers methods including: wires, radio frequency (RF), optical (IR) Different encoding schemes including: amplitude, frequency, and pulse-width modulation Modulation Technique Waveform No encoding (Baseband) On-Off Keying (OOK) Frequency Shift Keying (FSK) Binary Phase Shift Keying (BPSK) CSE 466 - Winter 2008 Communication 1 Communication methods Dimensions to consider bandwidth number of wires serial/parallel speed bits/bytes/words per second timing methodology synchronous or asynchronous number of destinations/sources arbitration scheme daisy-chain, centralized, distributed protocols provide some guarantees as to correct communication CSE 466 - Winter 2008 Communication 2

Bandwidth Serial Single wire or channel to trasmit information one bit at a time Requires synchronization between sender and receiver Sometimes includes extra wires for clock and/or handshaking Good for inexpensive connections (e.g., terminals) Good for long-distance connections (e.g., LANs) Examples: RS-232, Ethernet, I2C, IrDA, USB, Firewire, Bluetooth Parallel Multiple wires to transmit information one byte or word at a time Good for high-bandwidth requirements (CPU to disk) More expensive wiring/connectors/current requirements Examples: SCSI-2, PCI bus (PC), PCMCIA (Compact Flash) Issues Encoding, data transfer rates, cost of connectors and wires, modularity, error detection and/or correction CSE 466 - Winter 2008 Communication 3 Speed Serial low-speed, cheap connections RS-232 1K 20K bits/sec, copper wire medium-speed efficient connections I2C 10K-400K bits/sec, board traces IrDA 9.6K-4M bits/sec, line-of-sight, 0.5-6.0m high-speed, expensive connections USB 1.5M bytes/sec, USB2 60M bytes/sec Ethernet 1.5M-1G bits/sec, twisted-pair or co-axial Firewire 12.5-50M bytes/sec Parallel low-speed, not too wide SCSI-2 10M bytes/sec, 8 bits wide PCI bus, 250M bytes/sec, 32 bits wide PCMCIA (CF+), 9-10M bytes/sec, 16 bits wide high-speed, very wide memory systems in large multi-processors 200M-2G bytes/sec, 128-256 bits wide CSE 466 - Winter 2008 Communication 4

Speed Issues length of the wires (attenuation, noise, capacitance) connectors (conductors and/or transducers) environment (RF/IR interference, noise) current switching (spikes on supply voltages) number and types of wires (cost of connectors, cross-talk) flow-control (if communicating device can t keep up) CSE 466 - Winter 2008 Communication 5 Timing methodology Asynchronous less wires (no clock) no skew concerns synchronization overhead appropriate for loosely-coupled systems (CPU and peripherals) common in serial schemes Synchronous clock wires and skew concerns no synchronization overhead can be high-speed if delays are small and can be controlled appropriate for tightly-couple systems (CPU and memory/disk) common in parallel schemes CSE 466 - Winter 2008 Communication 6

Timing methodology Issues clock period and wire delay synchronization and skew encoding of timing and data information handshaking flow-control power consumption CSE 466 - Winter 2008 Communication 7 Number of devices communicating Single source single destination point-to-point cheap connections, no tri-stating necessary Single source multiple destination fanout limitations addressing scheme to direct data to one destination Multiple source multiple destination arbitration between senders tri-stating capability is necessary collision detection addressing scheme priority scheme fairness considerations CSE 466 - Winter 2008 Communication 8

Arbitration schemes Daisy-chain or token passing devices either act or pass to next fixed priority order as many wires as devices fairness issues Centralized request to central arbiter central arbiter implements priority scheme wires from/to each device can be costly can be dynamically changing priority/fairness Distributed no central arbiter common set of wires (or ether) observed by all devices fixed priority/fairness scheme CSE 466 - Winter 2008 Communication 9 Serial case studies RS-232 (IEEE standard) serial protocol for point-to-point, low-cost, low-speed applications for PCs I2C (Philips) up to 400Kbits/sec, serial bus for connecting multiple components Ethernet (popularized by Xerox) most popular local area network protocol with distributed arbitration IrDA (Infrared Data Association) up to 115kbps wireless serial (Fast IrDA up to 4Mbs) Firewire (Apple now IEEE1394) 12.5-50Mbytes/sec, consumer electronics (video cameras, TVs, audio, etc.) SPI (Motorola) 10Mbits/sec, commonly used for microcontroller to peripheral connections USB (Intel followed by USB-2) 12-480Mbits/sec, isochronous transfer, desktop devices Bluetooth (Ericsson cable replacement) 700Kbits/sec, multiple portable devices, special support for audio CSE 466 - Winter 2008 Communication 10

RS-232 (standard serial line) Point-to-point, full-duplex Synchronous or asynchronous Flow control Variable baud (bit) rates Cheap connections (low-quality and few wires) Variations: parity bit; 1, 1.5, or 2 stop bits start bit 8 data bits parity bit stop bit CSE 466 - Winter 2008 Communication 11 RS-232 wires TxD transmit data TxC transmit clock RTS request to send CTS clear to send all wires active low "0" = -12v, "1" = 12v RxD receive data RxC receive clock DSR data set ready DTR data terminal ready special driver chips that generate ±12v from 5v Ground CSE 466 - Winter 2008 Communication 12

Transfer modes Synchronous clock signal wire is used by both receiver and sender to sample data Asynchronous no clock signal in common data must be oversampled (16x is typical) to find bit boundaries Flow control handshaking signals to control rate of transfer CSE 466 - Winter 2008 Communication 13 Inter-Integrated Circuit Bus (I2C) Modular connections on a printed circuit board Multi-point connections (needs addressing) Synchronous transfer (but adapts to slowest device) Similar to Controller Area Network (CAN) protocol used in automotive applications Similar to TWI (Two-Wire Interface) on ATmegas +Vcc SCL SDA device 1 device 2 device n CSE 466 - Winter 2008 Communication 14

Serial data format SDA going low while SCL high signals start of data SDA going high while SCL high signals end of data SDA can change when SCL low SCL high (after start and before end) signals that a data bit can be read SDA SCL START STOP CSE 466 - Winter 2008 Communication 15 Byte transfer Byte followed by a 1 bit acknowledge from receiver Open-collector wires sender allows SDA to rise receiver pulls low to acknowledge after 8 bits SDA 1 2 3 4 5 6 7 8 ack SCL Multi-byte transfers first byte contains address of receiver all devices check address to determine if following data is for them second byte usually contains address of sender CSE 466 - Winter 2008 Communication 16

Clock synchronization Synchronous data transfer with variable speed devices go as fast as the slowest device involved in transfer Each device looks at the SCL line as an input as well as driving it if clock stays low even when being driven high then another device needs more time, so wait for it to finish before continuing rising clock edges are synchronized clk 1 clk 2 SCL CSE 466 - Winter 2008 Communication 17 Arbitration Devices can start transmitting at any time wait until lines are both high for some minimum time multiple devices may start together - clocks will be synchronized All senders will think they are sending data possibly slowed down by receiver (or another sender) each sender keeps watching SDA - if ever different (driving high, but its really low) then there is another driver sender that detects difference gets off the bus and aborts message Device priority given to devices with early 0s in their address 00.111 has higher priority than 01 111 CSE 466 - Winter 2008 Communication 18

Inter-Integrated Circuit Bus (I2C) Supports data transfers from 0 to 400KHz Philips (and others) provide many devices microcontrollers with built-in interface A/D and D/A converters parallel I/O ports memory modules LCD drivers real-time clock/calendars DTMF decoders frequency synthesizers video/audio processors CSE 466 - Winter 2008 Communication 19 Ethernet (Xerox local area network) Local area network up to 1024 stations up to 2.8 km distance 10Mbits/sec serially on shielded co-axial cable 1.5Mbits/sec on twisted pair of copper pair Developed by Xerox in late 70s still most common LAN right now being displaced by fiber-optics (can't handle video/audio rates or make required service guarantees) High-level protocols to ensure reliable data transmission CSMA-CD: carrier sense multiple access with collision detection CSE 466 - Winter 2008 Communication 20

Ethernet layered organization Physical and data-link layers are our focus Client Layer Transport Layer Data-link Layer Physical Layer To Host Host-specific Interface Data-link Controller Physical Channel Data Encapsulation Link Management Serial Encode and Decode Transmit and Receive Electrical Interface Ethernet Cable Ethernet Controller Board Transceiver parallel data serial data CSE 466 - Winter 2008 Communication 21 Serial data format Manchester encoding signal and clock on one wire (XORed together) "0" = low-going transition "1" = high-going transition 0 1 0 1 0 1 1 0 0 Extra transitions between 00 and 11 need to be filtered preamble at beginning of data packet contains alternating 1s and 0s allows receivers to get used to where important transitions should be and ignore extra ones (this is how synchronization is achieved) preamble is 48 bits long: 10101... 01011 CSE 466 - Winter 2008 Communication 22

Ethernet packet Packets size: 64 to 1518 bytes + 6 bytes of preamble preamble (6 bytes) destination address (6 bytes) source address (6 bytes) type (2 bytes) data (46-1500 bytes) checksum (4 bytes) compute from data CSE 466 - Winter 2008 Communication 23 Arbitration Wait for line to be quiet for a while then transmit detect collision average value on wire should be exactly between 1 and 0 if not, then two transmitters are trying to transmit data If collision, stop transmitting wait a random amount of time and try again if collide again, pick a random number from a larger range (2x) and try again Exponential backoff on collision detection Try up to 16 times before reporting failure CSE 466 - Winter 2008 Communication 24

Extending Ethernet Segments, repeaters, and gateways segment: a single cable repeater: transfers all messages on one segment to another and vice-versa gateway: selectively forwards messages to other segments and helps isolate traffic Segment Repeater Gateway CSE 466 - Winter 2008 Communication 25 Infrared Data Association Consortium of over 160 companies Meet needs of the mobile professional Short interactions with other devices (file transfer, printing) Possibly using others peripherals (visiting a customer s office) Goals: Suitable replacement for cables Interoperability Minimal cost Point-and-shoot model (intended use and to reduce interference) History: First standard developed in 1994 Revisions as recently as late 1998 (i.e., still active) CSE 466 - Winter 2008 Communication 26

IrDA: Infrared Data Association Characteristics of IR: Implementation costs rise significantly around 1-10 GHz one important exception is IR at around 500 THz very inexpensive Signals above 100 GHz cannot penetrate walls Most signals below 300 GHz are regulated by the FCC Radio (RF) Microwaves Visible Infrared (IR) Ultraviolet X-Rays Gamma Rays 10 9 10 12 10 14 10 15 10 17 10 20 $ FCC Freq. (Hz) CSE 466 - Winter 2008 Communication 27 Speed Components include: Transmitter (LED) and paired receiver (photodiode) IrDA supports wide range of speeds 2400 bps to 4 Mbps Exact physical-layer protocol used depends on speed of IrDA connection Uses highest speed available on both devices determined when connection is established Future promises even higher speeds: 16-50 Mbps is not too far off Comparison to other wireless technologies: Low-power RF (e.g., Bluetooth) slightly slower (.5-2 Mbps max) Bound by walls, easy to control, intentional aspect Much lower-power than high-speed RF (e.g., 802.11a at 50Mbps) CSE 466 - Winter 2008 Communication 28

Low-speed Modulation Speed: 2400 bps - 115 kbps ( Serial Infrared, or SIR) Only 0 s require pulse (and thus power) ; pulse < full bit time Standard UART byte framing Pulse is constant 1.6 µs long (so duty cycle varies with speed) Average duty cycle: 9% 1 0 0 1 0 0 Speed: 576 kbps - 1 Mbps similar to SIR (pulse only for 0 s ; pulse < full bit time) pulse lasts 1/4 of bit time (so pulse varies with speed) Average duty cycle: 12.5% 1 0 0 1 0 0 Speed: 4 Mbps ( Fast Infrared, or FIR) uses four-pulse-position-modulation scheme (4PPM) pulse during exactly 1/4 of each symbol boundary 4PPM makes synchronization easier to maintain Duty cycle: 25% (independent of data) Lowest power/bit 00 0110 11 CSE 466 - Winter 2008 Communication 29 Range Linear: IrDA standard requires 0-1 m Realistically, some transceivers work at up to 10 m Angular: Limited to a narrow cone (15 half-angle) Helps reduce interference between devices 0-1 m CSE 466 - Winter 2008 Communication 30

IrDA Protocol Stack Analogous to the standard layered network model Consists of both required and optional components Application Layer Transport Layer Network Layer Data-link Layer Physical Layer Standard Network Model IrCOMM IrLAN IrOBEX TinyTP IrLMP IrLAP Physical Layer IrDA Protocol Stack Serial and parallel port emulation IrDA interface acts as a local-area network IR Object Exchange transfer of objects Segmentation and re-assembly automatically break-up large packets (and put back together correctly) Per-channel flow control Multiplexes several virtual connections on a single IrLAP connection (logical service access points LSAPs) Handle connections/disconnections Implement reliable transfer CSE 466 - Winter 2008 Communication 31 Protocol Overhead Very simple model (point-to-point), so can expect reduced protocol overhead For layers in IrDA protocol stack, overhead per packet/frame is: IrLAP = 2 bytes IrLMP = 2 bytes TinyTP = 1 byte Total: 5 bytes For perspective, compare to TCP/IP over Ethernet: Ethernet = 18 bytes minimum IP = 20 bytes Total: 58 bytes (minimum) TCP = 20 bytes IrDA takes advantage of its simpler model, and keeps protocol overhead very low. CSE 466 - Winter 2008 Communication 32

Firewire Interconnection for high-bandwidth consumer electronic devices e.g., still and video cameras, MP3 players, digital video recorders IEEE 1394a standard 12.5-400 Mbits/sec (soon to be 800 Mbits/sec with 1394b) Most consumer devices use 100 Mbits/sec Up to 63 devices connected at once on 4.5m cables Up to 16 cables can be daisy-chained to 72m Devices connect for power as well as communication Hot-swappable devices Asynchronous and isochronous data transfers CSE 466 - Winter 2008 Communication 33 Firewire Electrical/Mechanical Spec 4-6 wires depending on whether device needs power Tree arrangement each branch is bandwidth limited DV Monitor PC with IEEE 1394 Digital VCR IEEE 1394 Hard Drive Digital Camcorder Digital Camcorder CSE 466 - Winter 2008 Communication 34

Firewire data format Data is transferred in addressed packets, and is transactionbased Transfers can be asynchronous or isochronous Asynchronous transfers are used mainly for bus configuration, setting up transfers and handshaking, but are also used for bulk data transfer to and from hard disk drives, etc. Isochronous transfers are used for transporting timesensitive data like digital video and audio Data packets have a 64-bit address header 10-bit network address 6-bit node address 48-bits for data memory addresses at the receiving node Ability to address 1023 networks of 63 nodes, each with up to 281TB (terabytes) of data addresses CSE 466 - Winter 2008 Communication 35 Firewire data format (cont d) Bus manager One device on the bus (usually a PC) Isochronous resource manager Allocates bus bandwidth for isochronous data transfers based on time-domain multiplexing (TDM) that guarantees a proportion of the total time slots to each device Bandwidth allocation unit is 20.3ns, 6144 of them in a basic cycle of 125us 25us of every cycle is always reserved for asynchronous control data transfers, so a maximum of 4195 units are available for isochronous transfers Typically a stream from a DV camcorder to a PC or DVR might need to be allocated a channel of ~1800 bandwidth units, for about 30Mb/s Asynchronous transfers can have multiple data packets per basic cycle, within the 25us reserved for this type of signalling CSE 466 - Winter 2008 Communication 36

Firewire signalling Data-strobe signalling Avoids two signals where both change at the same time Keeps noise levels low Strobe easily derived at transmitter Strobe = Clock xor Data Clock is easily recovered at receiver Clock = Data xor Strobe 1 0 1 1 0 1 1 Data Strobe Clock CSE 466 - Winter 2008 Communication 37 Serial Peripheral Interface Common serial interface on many microcontrollers Simple 8-bit exchange between two devices Master initiates transfer and generates clock signal Slave device selected by master One-byte at a time transfer Data protocols are defined by application Must be in agreement across devices CSE 466 - Winter 2008 Communication 38

SPI Block Diagram 8-bits transferred in each direction every time Master generates clock Shift enable used to select one of many slaves CSE 466 - Winter 2008 Communication 39 SPI on the ATmega16 Prescaler for clock rate Interrupt on receive and on send complete Automatically generates SS CSE 466 - Winter 2008 Communication 40

SPI Registers CSE 466 - Winter 2008 Communication 41 Using SPI as a Master void SPI_MasterInit(void) { /* Set MOSI and SCK output, all others input */ DDRB = _BV(DD_MOSI) _BV(DD_SCK); /* Enable SPI, Master, set clock rate fclk/16 */ SPCR = _BV(SPE) _BV(MSTR) _BV(SPR0); } void SPI_MasterTransmit(char cdata) { /* Start transmission */ SPDR = cdata; /* Wait for transmission complete */ while(!(spsr & _BV(SPIF))) ; } CSE 466 - Winter 2008 Communication 42

Using SPI as a Slave void SPI_SlaveInit(void) { /* Set MISO output, all others input */ DDRB = _BV(DD_MISO); /* Enable SPI */ SPCR = _BV(SPE); } char SPI_SlaveReceive(void) { /* Wait for reception complete */ while(!(spsr & _BV(SPIF))) ; /* Return data register */ return SPDR; } CSE 466 - Winter 2008 Communication 43 Data Payload on SPI Data is exchanged between master and slave Master always initiates May need to poll slave (or interrupt-driven) Decide on how many bytes of data have to move in each direction Transfer the maximum for both directions One side may get more than it needs May disable one side or the other Decide on format of bytes in packet Starting byte and/or ending byte? Can they be distinguished from data in payload? Length information or fixed size? SPI buffer Write into buffer, specify length, master sends it out, gets data New data arrives at slave, slave interrupted, provides data to go to master, reads data from master in buffer CSE 466 - Winter 2008 Communication 44

Sample code for FTDI SPI int main(void) { FTDI466API usbdevice; char buffer[256]; unsigned char rxbuffer[256]; unsigned char txbuffer[256]; DWORD numbytestosend; DWORD bytessent; DWORD numbytestoread; DWORD bytesreceived; // setup USB device for MPSSE mode bool setup = usbdevice.open(); if(!setup) return 0; cout << "INITIALIZING SPI" << endl; // setup for SPI communication txbuffer[0] = 0x80; // setup PORT txbuffer[1] = 0x08; // make CS high txbuffer[2] = 0x0B; // outputs: SK, DO, CS, inputs: DI, GPIOL1-L4 txbuffer[3] = 0x86; // set clk divisor to Tx at 200kHz txbuffer[4] = 0x1D; // speed low byte txbuffer[5] = 0x00; // speed high byte txbuffer[6] = 0x85; // disconnect TDI/DO output from TDO/DI input for loopback testing numbytestosend = 7; CSE 466 - Winter 2008 Communication 45 Sample code for FTDI SPI (cont d) // send the instructions to the USB device bytessent = usbdevice.write(txbuffer, numbytestosend); if(bytessent!= numbytestosend) cerr << "Not all the bytes were sent when initializing MPSSE" << endl; // see if there were any error codes when setting up SPI numbytestoread = usbdevice.getreceivequeuesize(); if(numbytestoread > 0) { bytesreceived = usbdevice.read(rxbuffer, numbytestoread); if(bytesreceived!= numbytestoread) cerr << "Problem when trying to retrieve the error bytes" << endl; } for(unsigned int i = 0; i < bytesreceived; i++) cout << "Error Byte: " << rxbuffer[i] << endl; CSE 466 - Winter 2008 Communication 46

Sample code for FTDI SPI (cont d) // loop to demonstrate the SPI protocol for(int loop = 0; loop < 10; loop++) { Sleep(1000); txbuffer[0] = 0x80; // setup PORT txbuffer[1] = 0x00; // make CS low txbuffer[2] = 0x0B; // outputs: SK, DO, CS, inputs: DI, GPIOL1-L4 txbuffer[3] = 0x35; // clock out on negative edge, in on negative edge, MSB txbuffer[4] = 0x04; // low byte of length : note a length of zero is 1 byte, 1 is 2 bytes txbuffer[5] = 0x00; // high byte of length txbuffer[6] = 0x71; // payload txbuffer[7] = 0x72; txbuffer[8] = 0x73; txbuffer[9] = 0x74; txbuffer[10] = 0x75; txbuffer[11] = 0x80; // setup PORT txbuffer[12] = 0x08; // make CS high txbuffer[13] = 0x0B; // outputs: SK, DO, CS, inputs: DI, GPIOL1-L4 numbytestosend = 14; // send bytes bytessent = usbdevice.write(txbuffer, numbytestosend); if(bytessent!= numbytestosend) cerr << "Not all the bytes were sent when initializing MPSSE" << endl; CSE 466 - Winter 2008 Communication 47 Sample code for FTDI SPI (cont d) Sleep(5); // make sure the usb device has enough time to execute command - 5 ms latency timeout is set // get number of bytes in the received queue numbytestoread = usbdevice.getreceivequeuesize(); cout << "Received " << numbytestoread << " Bytes" << endl; if(numbytestoread > 0) { // get the received bytes bytesreceived = usbdevice.read(rxbuffer, numbytestoread); } } if(bytesreceived!= numbytestoread) cerr << "Problem when trying to retrieve the bytes from the receive queue" << endl; else { // print out the bytes received over SPI in hex for(unsigned int i=0; i < bytesreceived; i++) cout << itoa(rxbuffer[i],buffer,16) << " "; cout << endl; } CSE 466 - Winter 2008 Communication 48

Universal Serial Bus Connecting peripherals to PCs Ease-of-use Low-cost Up to 127 devices (optionally powered through bus) Transfer rates up to 480 Mb/s Variable speeds and packet sizes Full support for real-time data for voice, audio, and video Protocol flexibility for mixed-mode isochronous data transfers and asynchronous messaging PC manages bus and allocates slots (host controller) Can have multiple host controllers on one PC Support more devices than 127 CSE 466 - Winter 2008 Communication 49 USB Peripherals CSE 466 - Winter 2008 Communication 50

USB Tree of devices one root controller CSE 466 - Winter 2008 Communication 51 USB Data Transfer Data transfer speeds Low is <0.8v, high is >2.0v differential 480Mb/sec, 12Mb/sec, 1.5Mb/sec Data is NRZI encoded (data and clock on one wire) SYNC at beginning of every packet CSE 466 - Winter 2008 Communication 52

NRZI Encoding NRZI Non-return to zero inverted Toggles a signal to transmit a 0 and leaves the signal unchanged for a 1 Also called transition encoding Long string of 0s generates a regular waveform with a frequency half the bit rate Long string of 1s generates a flat waveform bit stuff a 0 every 6 consecutive 1s to guarantee activity on waveform CSE 466 - Winter 2008 Communication 53 NRZI Encoding (cont d) CSE 466 - Winter 2008 Communication 54

USB Data Transfer Types Control Transfers: Used to configure a device at attach time and can be used for other device-specific purposes, including control of other pipes on the device. Bulk Data Transfers: Generated or consumed in relatively large and bursty quantities and have wide dynamic latitude in transmission constraints. Interrupt Data Transfers: Used for timely but reliable delivery of data, for example, characters or coordinates with human-perceptible echo or feedback response characteristics. Isochronous Data Transfers: Occupy a prenegotiated amount of USB bandwidth with a prenegotiated delivery latency. (Also called streaming real time transfers) CSE 466 - Winter 2008 Communication 55 USB Packet Format Sync + PID + data + CRC Basic data packet Sync: 8 bits (00000001) PID: 8 bits (packet id type) Data: 8-8192 bits (1K bytes) CRC: 16 bits (cyclic redundancy check sum) Other data packets vary in size May be as short as only 8 bits of PID CSE 466 - Winter 2008 Communication 56

USB Protocol Stack FTDI USB chip implements right side Communicates to physical device through SPI CSE 466 - Winter 2008 Communication 57 More Communication Later Bluetooth Popular radio frequency protocol We ll discuss after looking at wireless sensors IEEE 802.15.4 (Zigbee) we ll start using this in Lab 6 Up and coming sensor protocol Ultra-wide-band (UWB) Ultra-low-power future home wireless CompactFlash/SD Popular parallel bus protocol We ll discuss (time permitting) at end of quarter CSE 466 - Winter 2008 Communication 58