Tera Term Serial Macro Example
Lesson 9 UART Simply Embedded. An embedded system often requires a means for communicating with the external world for a number of possible reasons. It could be to transferring data to another device, sending and receiving commands, or simply for debugging purposes. One of the most common interfaces used in embedded systems is the universal asynchronous receivertransmitter UART. When a board arrives in the hands of the softwarefirmware team, the first step is typically to get the debug console functional. The debug console is a serial interface which historically is implemented as RS 2. PC serial port. These days most PCs not longer have a serial port, so it is more commonly seen implemented using USB, however the concept is the same. In this lesson, we will learn a bit about the theory behind UART and RS 2. UART driver for the MSP4. LED during runtime. It is important to distinguish the difference between the terms UART and RS 2. The UART is the peripheral on the microcontroller which can send and receive serial data asynchronously, while RS 2. RS 2. 32 has no dependency on any higher level protocol, however it does have a simple layer 1 physical layer set of standards which must be followed. The UART module may support several features which allow it to interface with various signaling standard such as RS 2. RS 4. 85 another serial interface commonly used in industrial applications. RS 2. 32. RS 2. The minimum connection required for bidirectional communication is three signals transmit TX, receive RX, and ground. The separate RX and TX lines mean that data can flow in both directions at the same time. This is called full duplex and it is the standard means for communicating over serial. Tera Term Serial Macro Example' title='Tera Term Serial Macro Example' />Tera Term. TeraTerm is an Open Source project Sourceforge and is a venerable product. It works well enough but I have never been comfortable with it. Tera Term is easily one of the most powerful free Terminal Emulation Software that I have come across and the power of it lies in its scripting language TTL. MSCA Aes Marie SkodowskaCurie nas Competncias, Formao e Progresso na Carreira 3. As announced earlier, this blog will host an open space once a month to field questions and encourage discussion among my readers, and this is the week. All the. Words in science are often used in different ways from ordinary English. California Driver History Report Abbreviations For Example. Completely different meanings even occur in different branches of physiology, e. Tera Term Serial Macro Example' title='Tera Term Serial Macro Example' />However, depending on the higher level protocols, there may be a need to block the transmitter while receiving. This is called half duplex. Hardware flow control can also be enabled in order to mitigate the flow of data. Two optional lines RTS and CTS are provided for this function. Typically RS 2. 32 is used without hardware flow control and at full duplex. We are not going to go into details on all the possible configurations, however you can read about it here if you are interested. RS 2. 32 signals are different than than what we are used to in the digital world because the voltage switches between negative and positive values. The standard defines signals which typically vary from 5. V to 5. V, but can as much as 1. V to 1. 5V. The idle state of the line is at the negative voltage level and is referred to as a mark. The logical value of a mark is one 1. The positive voltage is called a space, and indicates a logic zero 0. To begin a transmission of data, a start bit space is sent to the receiver. Then the data is transmitted. The data can be in several possible formats depending what is supported by both devices. To end a transmission, a stop bit mark is sent to the receiver, and the held in the idle state. At least one stop bit is required, but two stop bits are often supported as well. When hooking up RS 2. MCU it is important to remember that the voltage levels supported by the IO are different 0. V 3. 3. V, so an external transceiver is required to convert the signals to the appropriate levels. If you try to connect RS 2. MSP4. 30 or most other microcontrollers it will not work and likely cause some damage. The MAX2. 32 and variants are some of of the most common RS 2. It is extremely simple to use and can be easily breadboarded. Here is an example of one I have built Fortunately, the MSP4. Launchpad has a serial to USB converter built right onto the the board so this additional equipment is not required. Therefore, we wont cover how to build it in this tutorial, but if you would like to know more feel free to shoot me an email. We will look in more detail at the MSP4. Universal asynchronous receivertransmitter UARTUART peripherals typically have several configurable parameters required to support different standards. There are five parameters which must be configured correctly to establish a basic serial connection Baud rate Baud rate is the number of symbols or modulations per second. Basically, the baud rate indicates how many times the lines can change state high or low per second. Since each symbol represents one bit, the bit rate equals the baud rate. For example, if the baud rate is 9. Number of data bits The number of data bits transmitted is typically between 5 and 8, with 7 and 8 being the most common since an ASCII character is 7 bits for the standard set and 8 bits for the extended. Parity The parity can be even, odd, mark or space. The UART peripheral calculates the number of 1s present in the transmission. If the parity is configured to even and the number of 1s is even then the parity bit is set zero. If the number of 1s is odd, the parity bit is set to a 1 to make the count even. If the parity is configured to odd, and the number of 1s is odd, then parity bit is set to 0. Otherwise it is set to 1 to make the count odd. Mark and space parity mean that the parity bit will either be one or zero respectively for every transmission. Stop bits The number of stop bits is most commonly configurable to either one or two. On some devices, half bits are supported as well, for example 1. The number of stop bits determines how much of a break is required between concurrent transmissions. Endianess Some UART peripherals offer the option to send the data in either LSB least significant bit or MSB most significant bit. Serial communication of ASCII characters is almost always LSB. All of these parameters must be set to the same configuration on both devices for successful communication. The following image is an example of a UART transmission. Image courtesy of one of our very active members, Yury. Thanks Here we have a 5 bit transmission with an odd parity. Since there are an odd number of 1s in the transmission, the parity bit is 0. The data bit closest to the start bit is the LSB. The number of stop bits is not defined since we only see one transmission. However if there was 1 stop bit and we were running at 9. O1. Other common configuration include 9. E1 9. 60. 0 baud, 7 bits data, even parity and 1 stop bit. N1 9. 60. 0 baud, 8 bits data, no parity and 1 stop bit. N1 1. 15. 20. 0 baud, 8 bits data, no parity and 1 stop bit. The MSP4. 30 UARTThe MSP4. USCI universal serial communications interface which supports multiple types of serial interfaces. There are two variants of the USCI module each of which support specific interfaces USCIA UART and SPIUSCIB SPI and I2. CA given device may have none, one or more of each of these modules, depending on its implementation. It is important to check in the datasheet to see exactly what is supported in the device being used. Since USCIA actually supports multiple standards, there are many registers and settings. We will only concentrate on those relative to this lesson. The register map for the USCIA module is as follows TI MSP4. Family Reference Manual SLAU1. JThe first register, UCAx. CTL0 or USCIAx Control Register 0 contains the configuration for the protocol. TI MSP4. 30x. 2xx Family Reference Manual SLAU1. JUCPEN Parity enable. Parity disabled. 1 Parity enabled. UCPAR Parity mode selection. Odd parity. 1 Even parity. UCMSB MSB most significant bit first selection. UC7. BIT Data length. UCSPB Number of stop bits. One stop bit. 1 Two stop bits. UCMODEx USCI mode asynchronous mode only valid when UCSYNC0.