class: title, smokescreen, shelf, bottom, no-footer background-image: url(images/spi_block.jpg) # 181U Spring 2020 ### Hardware Communication --- layout: true .footer[ - Geoffrey Brown, 2020 - 181U ] <style> h1 { border-bottom: 8px solid rgb(32,67,143); border-radius: 2px; width: 90%; } .smokescreen h1 { border-bottom: none; } .small.remark-slide-content.compact {font-size:1.2rem} .smaller.remark-slide-content.compact {font-size:1.1rem} .small-code.remark-slide-content.compact code {font-size:1.0rem} .very-small-code.remark-slide-content.compact code {font-size:0.9rem} .line-numbers{ /* Set "line-numbers-counter" to 0 */ counter-reset: line-numbers-counter; } .line-numbers .remark-code-line::before { /* Increment "line-numbers-counter" by 1 */ counter-increment: line-numbers-counter; content: counter(line-numbers-counter); text-align: right; width: 20px; border-right: 1px solid #aaa; display: inline-block; margin-right: 10px; padding: 0 5px; } </style> --- class: compact # Agenda <audio controls> <source src="protocol_2.mp3" type="audio/mpeg"> Your browser does not support the audio element. </audio> * Serial - Examples * SPI - Examples * I2C - Examples * Analog --- class: compact # Serial Protocol <audio controls> <source src="protocol_3.mp3" type="audio/mpeg"> Your browser does not support the audio element. </audio> data:image/s3,"s3://crabby-images/b35af/b35afb8573e34f1674ebca5aa26ed481dc8711b9" alt="" * Oldest protocol but still widely used. * Depends upon local clocks to decode digital waveform * Used for - UART (in lab, the serial interface is through a UART) - GPS receivers - Cell phone modules data:image/s3,"s3://crabby-images/fb0e2/fb0e221f09080bf1e60c4b55b49428f913150674" alt="" data:image/s3,"s3://crabby-images/af533/af5331a9536d7890faccc83f021c3dd5b4f94149" alt="" --- class: compact # Typical Configuration of Serial Device <audio controls> <source src="protocol_4.mp3" type="audio/mpeg"> Your browser does not support the audio element. </audio> data:image/s3,"s3://crabby-images/6f906/6f9065cf6fa85d21ef09bfbea5d9bb1366aea02a" alt="" data:image/s3,"s3://crabby-images/dfeaf/dfeaf7e51286c26928e3c49ce944510a1780362d" alt="" --- class: compact # Decoding Serial Protocol <audio controls> <source src="protocol_5.mp3" type="audio/mpeg"> Your browser does not support the audio element. </audio> data:image/s3,"s3://crabby-images/8ff7f/8ff7ff1c9f7644098952281860a05f78c8aa4fed" alt="" * Sender and Receiver each have local clocks that are within ~2% * Sender and Receiver programmed to use the same "baud rate" (9600-115200 baud) * Sender transmits a frame, making transitions at bit boundaries - frame has start bit (0), 8 bits, at least one stop bit (1) * Receiver samples the input signal looking for a start bit - after seeing start bit, skip 1.5 baud times to bit 0 - then skip 1 baud time for each bit --- class: compact # Serial Driver Software <audio controls> <source src="protocol_6.mp3" type="audio/mpeg"> Your browser does not support the audio element. </audio> * Serial (UART) hardware typically has - a send buffer - a receive buffer - a status register - a configuration register * Driver - configures baud rate and protocol (configuration register) - sending - write one byte to send buffer - wait for byte to be transmitted (check status register) - receiving - wait for byte to be received - read byte from receive buffer --- class: compact # Serial Drivers (cont.) <audio controls> <source src="protocol_7.mp3" type="audio/mpeg"> Your browser does not support the audio element. </audio> * Two types of drivers - Polling -- busy waiting. This is **very** inefficient - Interrupt driven -- interrupt handler keeps uart busy from queues fed/emptied by OS data:image/s3,"s3://crabby-images/fb0e2/fb0e221f09080bf1e60c4b55b49428f913150674" alt="" data:image/s3,"s3://crabby-images/56d7d/56d7dd8604158288183447e3bcccf3cd4d9070f5" alt="" --- class: very-small-code,compact,hljs-tomorrow-night-eighties,line-numbers,col-2 # UART Interrupt Handler <audio controls> <source src="protocol_8.mp3" type="audio/mpeg"> Your browser does not support the audio element. </audio> ```C void USART1_IRQHandler(void) { if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET) { uint8_t data; // buffer the data (or toss it if there's no room // Flow control will prevent this data = USART_ReceiveData(USART1) & 0xff; if (!Enqueue(&UART1_RXq, data)) RxOverflow = 1; } ``` <br> ```C if(USART_GetITStatus(USART1, USART_IT_TXE) != RESET) { uint8_t data; /* Write one byte to the transmit data register */ if (Dequeue(&UART1_TXq, &data)){ USART_SendData(USART1, data); } else { // if we have nothing to send, // disable the interrupt // and wait for a kick USART_ITConfig(USART1, USART_IT_TXE, DISABLE); TxPrimed = 0; } } } ``` --- class: very-small-code,compact,hljs-tomorrow-night-eighties,line-numbers # Interrupt Driven UART User Code <audio controls> <source src="protocol_9.mp3" type="audio/mpeg"> Your browser does not support the audio element. </audio> data:image/s3,"s3://crabby-images/c16a4/c16a4c25bb387642ec7c134f63ccf0f3c546920a" alt="" ```C int getchar(void) { uint8_t data; while (!Dequeue(&UART1_RXq, &data)); return data; } int putchar(int c) { while (!Enqueue(&UART1_TXq, c)); if (!TxPrimed) { TxPrimed = 1; USART_ITConfig(USART1, USART_IT_TXE, ENABLE); } } ``` --- class: compact # SPI <audio controls> <source src="protocol_10.mp3" type="audio/mpeg"> Your browser does not support the audio element. </audio> data:image/s3,"s3://crabby-images/0f92d/0f92d257eb75b970377e05ed07d8395f4476719b" alt="" * SPI is a point-to-point *synchronous* protocol with a single *master* and one or more *slaves* * In contrast, the serial protocol is point-to-point *asynchronous* (but with a specified time base) * Signals: - SCK : clock from master to slave - MOSI : data from master to slave ("Master Out Slave In") - MISO : data from slave to master ("Slave Out Master In") - SS : slave select (one for each slave) --- class: compact # SPI Logical Architecture <audio controls> <source src="protocol_11.mp3" type="audio/mpeg"> Your browser does not support the audio element. </audio> data:image/s3,"s3://crabby-images/fb0e2/fb0e221f09080bf1e60c4b55b49428f913150674" alt="" data:image/s3,"s3://crabby-images/84147/841478a9e623bb5ab6da647e93b14593eef660be" alt="" * On every clock event (typically 0->1 transition), the Master and Slave registers are "shifted" `master[0],master[1:7],slave[0],slave[1:7] = slave[7],master[0:6],master[7],slave[0:6]` --- class: compact # SPI Protocol <audio controls> <source src="protocol_12.mp3" type="audio/mpeg"> Your browser does not support the audio element. </audio> data:image/s3,"s3://crabby-images/6f906/6f9065cf6fa85d21ef09bfbea5d9bb1366aea02a" alt="" data:image/s3,"s3://crabby-images/12729/127294c688d64ef247091c9cf9e83b9f1e6f87d8" alt="" data:image/s3,"s3://crabby-images/fb0e2/fb0e221f09080bf1e60c4b55b49428f913150674" alt="" data:image/s3,"s3://crabby-images/c00b9/c00b917a8a5bb6fd20eba4723f71b751378f1ad1" alt="" --- class: compact,small # SPI Example -- serial EEPROM (memory) <audio controls> <source src="protocol_13.mp3" type="audio/mpeg"> Your browser does not support the audio element. </audio> data:image/s3,"s3://crabby-images/1f0ae/1f0aecd244597d90a186a450674371d3643db8b0" alt="" data:image/s3,"s3://crabby-images/9aae3/9aae3d68b25dfaa33668c2cc81a1f128468a55c2" alt="" data:image/s3,"s3://crabby-images/ab8cd/ab8cddacbaca6fdc6cd69c98932ccd0bce9fcc0c" alt="" * SPI protocol implements byte (or word) transfer * Every device has a message protocol implemented on top of this * For example, with serial eproms, the master sends a command followed by 0xFF and the slave responds with a value | Instruction | Description | Code | | -- | -- | -- | | WRSR | Write Status Register | 0x01 | | WRITE | Write Data | 0x02 | | READ | Read Data | 0x03 | | RDSR | Read Status Register | 0x05 | --- class: compact # SPI Example -- color LCD display <audio controls> <source src="protocol_14.mp3" type="audio/mpeg"> Your browser does not support the audio element. </audio> data:image/s3,"s3://crabby-images/6f906/6f9065cf6fa85d21ef09bfbea5d9bb1366aea02a" alt="" data:image/s3,"s3://crabby-images/fb40e/fb40e333e5a69ccfe69f068ad154506f203a8d7a" alt="" --- class: compact # SPI Example -- SD Card <audio controls> <source src="protocol_15.mp3" type="audio/mpeg"> Your browser does not support the audio element. </audio> data:image/s3,"s3://crabby-images/6f906/6f9065cf6fa85d21ef09bfbea5d9bb1366aea02a" alt="" data:image/s3,"s3://crabby-images/681d4/681d4c99827cc5d11fcc645e4aa6d8c0e877f299" alt="" --- class: compact # SPI Example -- SD Card Transactions <audio controls> <source src="protocol_16.mp3" type="audio/mpeg"> Your browser does not support the audio element. </audio> data:image/s3,"s3://crabby-images/63916/63916606e9f7ac8d04da21b90f0edd92fb4626a0" alt="" * CMD0 : Reset the SD card * CMD1 : Initialize the card * CMD13 : Request card status * CMD16 : Set block length * CMD17 : Read single block * CMD24 : Write single block --- class: compact # SPI Example -- Display/SD card reader <audio controls> <source src="protocol_17.mp3" type="audio/mpeg"> Your browser does not support the audio element. </audio> data:image/s3,"s3://crabby-images/6f906/6f9065cf6fa85d21ef09bfbea5d9bb1366aea02a" alt="" data:image/s3,"s3://crabby-images/c9ac4/c9ac434f2871c34c7e228b5b767dcfac39946df9" alt="" --- class: compact # I2C -- 2 wire broadcast bus <audio controls> <source src="protocol_18.mp3" type="audio/mpeg"> Your browser does not support the audio element. </audio> data:image/s3,"s3://crabby-images/fb0e2/fb0e221f09080bf1e60c4b55b49428f913150674" alt="" data:image/s3,"s3://crabby-images/b8fd0/b8fd0e3305d37562f3e88f421d4fc8746d83f70f" alt="" --- class: compact # I2C -- transactions <audio controls> <source src="protocol_19.mp3" type="audio/mpeg"> Your browser does not support the audio element. </audio> data:image/s3,"s3://crabby-images/fb0e2/fb0e221f09080bf1e60c4b55b49428f913150674" alt="" data:image/s3,"s3://crabby-images/c4543/c45437d082dd88301398e99663a3a5a744eb7214" alt="" --- class: compact # I2C Example -- Wii Nunchuck <audio controls> <source src="protocol_20.mp3" type="audio/mpeg"> Your browser does not support the audio element. </audio> data:image/s3,"s3://crabby-images/732ac/732aca26eaa21f7d4245113a0ede3a80b0ba06b3" alt="" data:image/s3,"s3://crabby-images/3759f/3759f5baba3ebea02b4067ed6d34e86a1a0937ed" alt="" data:image/s3,"s3://crabby-images/c962d/c962d24f6cb9540090f66b2ddb29666815a737d4" alt="" --- class: compact,small # Analog Signals (digital <-> voltage) <audio controls> <source src="protocol_21.mp3" type="audio/mpeg"> Your browser does not support the audio element. </audio> * Analog to Digital Converter (ADC) : samples analog signal an produces digital representation * Digital to Analog Converter (DAC) : converts digital representation into analog voltage * These may be integral to processor (e.g. STM32L476) or external devices * Frequently, the conversion must be "triggered" at regular intervals (for example sampling a continuous signal or converting an audio file to an analog signal). * Example architecture of a DAC channel: data:image/s3,"s3://crabby-images/6f906/6f9065cf6fa85d21ef09bfbea5d9bb1366aea02a" alt="" data:image/s3,"s3://crabby-images/4e4ea/4e4ea76a573dc9347ba197cb7e6c5d3b57831a8b" alt="" --- class: compact # Analog Conversion -- Successive approximation <audio controls> <source src="protocol_22.mp3" type="audio/mpeg"> Your browser does not support the audio element. </audio> data:image/s3,"s3://crabby-images/3c1d9/3c1d9799d8173381349df1ee2b245767b5e0ee28" alt="" data:image/s3,"s3://crabby-images/9dc11/9dc11e86a1f48ce8e65f57318f6355cc4b7c3a9e" alt="" data:image/s3,"s3://crabby-images/77188/7718840f95301b2078f9655be9a326871555e159" alt="" --- class: compact # Analog to Digital Converter Example <audio controls> <source src="protocol_23.mp3" type="audio/mpeg"> Your browser does not support the audio element. </audio> * STM32 ADC is complicated - multiple input sources including internal references - mulitple trigger conditions - complex programming data:image/s3,"s3://crabby-images/6f906/6f9065cf6fa85d21ef09bfbea5d9bb1366aea02a" alt="" data:image/s3,"s3://crabby-images/d9e99/d9e9910e14eedaeb8d09ae423817c6957e144c1f" alt="" --- class: compact # Summary <audio controls> <source src="protocol_24.mp3" type="audio/mpeg"> Your browser does not support the audio element. </audio> * Common hardware communication protocols - Serial (asynchronous point-to-point) - SPI (synchronous point-to-point) - I2C (synchronous master/slave bus)