# 6.111 Serial Data Demo Miren Bamforth - Fall 2015 #### Serial and Parallel Links 13 # **Intro to Serial Data** #### Serial Communications - Sending information one bit at a time vs. many bits in parallel - Serial: good for long distance (save on cable, pin and connector cost, easy synchronization). Requires "serializer" at sender, "deserializer" at receiver - Parallel: issues with clock skew, crosstalk, interconnect density, pin count. Used to dominate for short-distances (eg, between chips). - BUT modern preference is for parallel, but independent serial links (eq, PCI-Express x1,x2,x4,x8,x16) as a hedge against link failures. - A zillion standards - Asynchronous (no explicit clock) vs. Synchronous (CLK line in addition to DATA line). - Recent trend to reduce signaling voltages: save power, reduce transition times - Control/low-bandwidth Interfaces: SPI, I<sup>2</sup>C, 1-Wire, PS/2, AC97 - Networking: RS232, Ethernet, T1, Sonet - Computer Peripherals: USB, FireWire, Fiber Channel, Infiniband, SATA, Serial Attached SCSI 6.111 Foll 2015 Lecture 13 14 #### HOW STANDARDS PROLIFERATE: (SEE: A/C CHARGERS, CHARACTER ENCODINGS, INSTANT MESSAGING, ETC.) SITUATION: THERE ARE 14 COMPETING STANDARDS. 500N: SITUATION: THERE ARE 15 COMPETING STANDARDS. #### RS232 (aka "serial port") - Labkit: simple bidirectional data connection with computer. - Characteristics - Large voltages => special interface chips (1/mark: -12V to -3V, O/space: 3V to 12V) - Separate xmit and rcv wires: full duplex - Slow transmission rates (1 bit time = 1 baud); most interfaces support standardized baud rates: 1200, 2400, 4800, 9600, 19.2K, 38.4K, 57.6K, 115.2K - Format - · Wire is held at 1/mark when idle - · Start bit (1 bit of "0" at start of transmission) - · Data bits (LSB first, can be 5 to 8 bits of data) - Parity bit (none, even, odd) - Stop bits (1, 1.5 or 2 bits of 1/mark at end of symbol) - Most common 8-N-1: eight data bits, no parity, one stop bit #### RS232 interface - Transmit: easy, just build FSM to generate desired waveform with correct bit timing - · Receive: - Want to sample value in middle of each bit time - Oversample, eg, at 16x baud rate - Look for 1->0 transition at beginning of start bit - Count to 8 to sample start bit, then repeatedly count to 16 to sample other bits - Check format (start, data, parity, stop) before accepting data. Figure from http://www.arcelect.com/rs232.htm 6,111 Fall 2015 Lecture 13 16 #### SPI (Serial Peripheral Interface) - · Simple, 3-wire interface + devices selects - SCLK generated by master (1-70MHz). Assert data on one edge, sample data on the other. Default state of SCLK and assignment of edges is often programmable. - Master Out Slave In (MOSI) data shifted out of master register into slave register - Master In Slave Out (MISO) data shifted out of slave register and into master register - Selects (usually active low) determine which device is active. Assertion often triggers an action in the slave, so master waits some predetermined time then shifts data. 6,111 Fall 2015 Lecture 13 17 #### I<sup>2</sup>C (Inter-Integrated Circuit) - 2 open-drain wires (SCL = clock, SDA = data) - Multiple-master, each transmission addresses a particular device, many devices have many different sub-addresses (internal registers) - Format (all addresses/data send MSB first): - Sender: Start [S] bit (SDA \ while SCL high) - Sender: One or more 8-bit data packets, each followed by 1-bit ACK - Data changed when SCL low, sampled at SCL↑ - · Receiver: Active-low ACK generated after each data packet - Sender: Stop [P] bit (SDA while SCL high) - SCL and SDA have pullup resistors, senders only drive low, go highimpedance to let pullups make line high (so multiple drivers okay!) - Receiver can hold SCL low to stretch clock timing, sender must wait until SCL goes high before moving to next bit. - Multiple senders can contend using SDA for arbitration 6,111 Fall 2015 Lecture 13 Figures from Wikipedia 18 #### USB (Universal Serial Bus) - 2-wire (D+,D-) for high-speed, bidirectional polled transmission between master and addressable endpoints in multiple devices. Full speed (12Mbps) and High speed (480Mbps) data rates. - Multi-level tiered-star topology (127 devices, including hubs) - FTDI UM245R USB-to-FIFO module for bidirectional data transfer using a handshake protocol, also asynchronous "bit-bang" mode with selectable baud rates. - 24-pin DIP module, wire to user pins - Drivers for Windows workstations in lab Figures from ftdi.com 6,111 Fall 2015 Lecture 13 24 #### Serial data in summary: - Serial allows communication with few wires between devices - Common protocols: UART, SPI, I2C, etc - Asynchronous vs Synchronous ### **Intro to Serial Data** # **Synchronous Serial Data** # Asynchronous means no clock...so how do we know when to look for data bits? Predetermined timing specifications are the key to asynchronous serial data! #### Lab 5b: - 2.4ms start bit - 1.2ms 1 bit - 0.6ms 0 bit # **Asynchronous Serial Data: Lab 5b** ``` STARTING: begin // sample whenever expired is true to read the start bit if (expired) begin if (ir_clean) begin if (start_counter < 5'b11111) begin start counter <= start counter + 1; end end else if (!ir_clean && ir_prev) begin if (start counter > 5'b11100) begin state <= READING;</pre> bit counter <= 4'd0; start <= 1'b1; end else begin start_counter <= 5'b00000; state <= IDLE: end end ir prev <= ir clean;</pre> end end ``` # **Asynchronous Serial Data: Lab 5b** The DMX512 protocol is characterized as a asynchronous serial data stream that runs at 250 kHz. As a result, each "bit" will be 4 $\mu$ s long. DMX512 has one start bit (low), eight bits of data, 2 stop bits and no parity. Figure 4. DMX512 Timing Diagram Table 1. DMX512 Timing Chart | | Min | Тур | Max | Unit | |----------------------------------|-----|-----|---------|------| | Break | 88 | 88 | 1000000 | us | | Mark After Break (MAB) | | 8 | | us | | Frame Width | | 44 | | us | | Start/Data/Stop bits | | 4 | | us | | Mark Time Between Frames (MTBF) | 0 | N/A | 1000000 | us | | Mark Time Between Packets (MTBP) | 0 | N/A | 1000000 | us | # **Asynchronous Serial Data: DMX512** ``` // always block controls dmx output sc counter <= sc_counter + 1; always @(posedge clk) begin four us counter <= FOUR US COUNTER MIN: if (reset) begin state <= BREAK: else four us counter <= four us counter + 1; end else begin // dmx out control case(state) if (sc counter < 4'd9) begin BREAK: begin // bits 0 to 8 are low // hold low for 88 us to 1 sec dmx out <= LOW; // choose 100 us which is approx, 2700 cycles at 27MHz if (break_counter < BREAK_COUNTER_MAX) begin else if (sc counter == 4'd9) begin // dmx_out is low during break // bit 9 is high dmx out <= LOW: dmx out <= HIGH: break counter <= break counter + 1; else if (sc counter == 4'd10) begin else begin // bit 10 is high // once we have waited for long enough, go to next state // go to the next state state <= MAB: dmx out <= HIGH: break counter <= BREAK COUNTER MIN; sc_counter <= SC_COUNTER_MIN; dmx out <= HIGH: state <= MTB FRAMES; end end end end MAB: begin MTB FRAMES: begin // The mark between frames is up to 1 second long // hold high for 8us to 1 sec // choose 10 us which is approx, 270 cycles at 27MHz // choose 10 us which is approx. 270 cycles at 27MHz if (mab counter < MAB COUNTER MAX) begin if (mtbframes counter < MTBFRAMES COUNTER MAX) begin // dmx is high during mark after break // dmx is high during mark time between frames dmx out <= HIGH; dmx out <= HIGH: mab counter <= mab counter + 1; // request the data for the next channel data output now if (mtbframes_counter == MTBFRAMES_COUNTER_MIN) begin else begin // if we have sent all of the frames already, go to // once we have waited long enough, go to next state the mtb packets state state <= START CODE: if (addr count == ADDR COUNT MAX) begin mab counter <= MAB COUNTER MIN; mtbframes_counter <= MTBFRAMES_COUNTER_MIN; // keep it high for now; the next state will change it addr count <= ADDR COUNT MIN; dmx out <= HIGH: state <= MTB PACKETS: // reset 4us counter too four us counter <= FOUR US COUNTER MIN; else begin end request pulse <= HIGH; end request addr <= addr count; START CODE: begin addr_count <= addr_count + 1; // The start code is formatted like the channel data with a mtbframes counter <= mtbframes counter + 1; value of zero. In order, its bits are: 0 0000 0000 11. The first bit is the start bit (low) and the last two bits are stop bits (high). else begin // The total start code is 44us, so each bit is held for 4us request pulse <= LOW: ``` if (four us counter == FOUR US COUNTER MAX) begin ## **Asynchronous Serial Data: DMX512** Some useful links: RS-232: http://www.arcelect.com/rs232.htm UART, I2C, SPI guide (ignore the device-specific info): <a href="https://tessel.io/blog/108840925797/a-web-developers-guide-to-communication-protocols">https://tessel.io/blog/108840925797/a-web-developers-guide-to-communication-protocols</a> USB: <a href="http://www.beyondlogic.org/usbnutshell/usb1.shtml">http://www.beyondlogic.org/usbnutshell/usb1.shtml</a> DMX512: <a href="http://www.elationlighting.com/pdffiles/dmx-101-handbook.pdf">http://www.elationlighting.com/pdffiles/dmx-101-handbook.pdf</a> #### **Serial Data Resources**