|  |   | 
| (8 intermediate revisions by the same user not shown) | 
| Line 1: | Line 1: | 
| − | [[category: ARM Tutorials]] | + | #REDIRECT [[LPC1768: UART Programming]] | 
| − | [[User:Amruta|Amruta]] ([[User talk:Amruta|talk]]) 13:22, 17 March 2015 (IST)
 | + |  | 
| − | ----
 | + |  | 
| − | =Basics=
 | + |  | 
| − |   | + |  | 
| − | LPC1768 has 4 UARTS out of which UART0, UART2, UART3 are very similar while UART1 is little bit different from all these. | + |  | 
| − |   | + |  | 
| − | ===Registers===
 | + |  | 
| − | Let's have a brief review through some of the important UART registers.
 | + |  | 
| − |   | + |  | 
| − | ====RBR ( Receiver Buffer Register )====
 | + |  | 
| − | The RBR is the top byte of the UART receiver FIFO. The top byte of this FIFO contains
 | + |  | 
| − | the oldest character received.
 | + |  | 
| − |   | + |  | 
| − | The data byte is available in the register bits 0:7.
 | + |  | 
| − |   | + |  | 
| − | While accessing this register, the DLAB bit in LCR must be zero.
 | + |  | 
| − |   | + |  | 
| − | ====THR ( Transmit Holding Register )====
 | + |  | 
| − | The THR is the top byte of the UARTtransmitter FIFO. The top byte is the newest character in
 | + |  | 
| − | the this FIFO.
 | + |  | 
| − |   | + |  | 
| − | The data byte to be transmitted is written in the register bits 0:7.
 | + |  | 
| − |   | + |  | 
| − | While accessing this register, the DLAB bit in LCR must be zero.
 | + |  | 
| − |   | + |  | 
| − | ====DLL ( Divisor Latch LSB register ) and DLM ( Divisor Latch MSB register )====
 | + |  | 
| − | The DLL and DLM registers together form a 16-bit divisor where DLL contains the lower 8 bits of the
 | + |  | 
| − | divisor and DLM contains the higher 8 bits of the divisor. 
 | + |  | 
| − |   | + |  | 
| − | This holds the value used for UART baud rate generation.
 | + |  | 
| − |   | + |  | 
| − | While accessing this any of these registers, the DLAB bit in LCR must be one.
 | + |  | 
| − |   | + |  | 
| − | ====FCR ( FIFO Control Register )====
 | + |  | 
| − | This register controls the operation of the UART Rx and TX FIFOs.
 | + |  | 
| − |   | + |  | 
| − | {| class="wikitable" style="text-align:center; background-color:#ABCDEF;margin: 1em auto 1em auto"
 | + |  | 
| − | !colspan = '8'|FCR
 | + |  | 
| − | |-
 | + |  | 
| − | |31:8||7:6 ||5:4||3|| 2 || 1 || 0  
 | + |  | 
| − | |-
 | + |  | 
| − | |   Reserved   ||Rx Trigger Level||   Reserved   ||DMA Mode Select||Tx FIFO Reset||Rx FIFO Reset||FIFO Enable
 | + |  | 
| − | |}
 | + |  | 
| − |   | + |  | 
| − | '''Bit 0 - : FIFO Enable'''
 | + |  | 
| − | Write 1 enable both Tx and Rx FIFOs of UART and 0 to disable them.
 | + |  | 
| − |   | + |  | 
| − | This bit must be set for proper UART operation. 
 | + |  | 
| − |   | + |  | 
| − | '''Bit 1 - : Rx FIFO Reset'''
 | + |  | 
| − | Writing 0 has no impact on either of FIFOs.
 | + |  | 
| − |   | + |  | 
| − | Writing a logic 1 will clear all bytes in UART receiver FIFO, reset the pointer logic. 
 | + |  | 
| − |   | + |  | 
| − | This bit is self-clearing.
 | + |  | 
| − | '''Bit 2 - : Tx FIFO Reset'''
 | + |  | 
| − | Writing 0 has no impact on either of FIFOs.
 | + |  | 
| − |   | + |  | 
| − | Writing a logic 1 will clear all bytes in UART transmitter FIFO, reset the pointer logic. 
 | + |  | 
| − |   | + |  | 
| − | This bit is self-clearing.
 | + |  | 
| − | '''Bit 3 - : DMA Mode Select'''
 | + |  | 
| − | When the FCR[0]is set, this bit selects the DMA mode
 | + |  | 
| − | '''Bit 7:6 - : Rx Trigger Level'''
 | + |  | 
| − |   | + |  | 
| − | ====LCR ( Line Control Register )====
 | + |  | 
| − | {| class="wikitable" style="text-align:center; background-color:#ABCDEF;margin: 1em auto 1em auto"
 | + |  | 
| − | !colspan = '8'|LCR
 | + |  | 
| − | |-
 | + |  | 
| − | |31:8||7||6 ||5:4||3|| 2 || 1 : 0  
 | + |  | 
| − | |-
 | + |  | 
| − | | Reserved||DLAB||Break Control||Parity Select||Parity Enable||Stop Bit||Word Length
 | + |  | 
| − | |}
 | + |  | 
| − |   | + |  | 
| − | '''Bit 1:0 - Word Length Select '''
 | + |  | 
| − | {| class="wikitable" style="text-align:center; background-color:#C0C0C0;;"
 | + |  | 
| − | !Value || Character Length
 | + |  | 
| − | |-
 | + |  | 
| − | |00|| 5 bit
 | + |  | 
| − | |-
 | + |  | 
| − | |01|| 6 bit
 | + |  | 
| − | |-
 | + |  | 
| − | |10|| 7 bit
 | + |  | 
| − | |-
 | + |  | 
| − | |11|| 8 bit
 | + |  | 
| − | |-
 | + |  | 
| − | |}
 | + |  | 
| − | '''Bit 2 - Stop Bit Select '''
 | + |  | 
| − |   | + |  | 
| − | Writing 0 select 1 stop bit while writing 0 selects 2 stop bits 
 | + |  | 
| − |   | + |  | 
| − | '''Bit 3 - Parity Enable'''
 | + |  | 
| − |   | + |  | 
| − | Write 1 to enable parity generation and 0 to disable it.
 | + |  | 
| − |   | + |  | 
| − | '''Bit 5:4 - Parity Select'''
 | + |  | 
| − | {| class="wikitable" style="text-align:center; background-color:#C0C0C0;"
 | + |  | 
| − | !Value || Parity
 | + |  | 
| − | |-
 | + |  | 
| − | |00|| Odd Parity
 | + |  | 
| − | |-
 | + |  | 
| − | |01|| Even Parity
 | + |  | 
| − | |-
 | + |  | 
| − | |10|| Forced '1' sticky parity
 | + |  | 
| − | |-
 | + |  | 
| − | |11|| Forced '0' sticky parity
 | + |  | 
| − | |-
 | + |  | 
| − | |}
 | + |  | 
| − |   | + |  | 
| − |   | + |  | 
| − | '''Bit 6 - Break Control'''
 | + |  | 
| − |   | + |  | 
| − | Write 1 to enable  break transmission and 0 to disable it.
 | + |  | 
| − |   | + |  | 
| − | '''Bit 7 - DLAB : Divisor Latch Bit'''
 | + |  | 
| − |   | + |  | 
| − | Write 1 to enable access to Divisor Latches and 0 to disable the access.
 | + |  | 
| − |   | + |  | 
| − | ====LSR ( Line Status Register )====
 | + |  | 
| − | {| class="wikitable" style="text-align:center; background-color:#ABCDEF;margin: 1em auto 1em auto"
 | + |  | 
| − | !colspan = '9'|LSR
 | + |  | 
| − | |-
 | + |  | 
| − | |31:8|| 7 || 6 || 5 ||   4   || 3 || 2 || 1 || 0  
 | + |  | 
| − | |-
 | + |  | 
| − | |Reserved||RXFE||TEMT||THRE||   BI   || FE || PE || OV || RDR
 | + |  | 
| − | |}
 | + |  | 
| − | '''Bit 0 - RDR : Receiver Data Ready'''
 | + |  | 
| − |   | + |  | 
| − | It gives the status of UART Rx FIFO.
 | + |  | 
| − | {| class="wikitable" style="text-align:center; background-color:#C0C0C0;"
 | + |  | 
| − | !Bit Value || FIFO Status
 | + |  | 
| − | |-
 | + |  | 
| − | |0|| Empty
 | + |  | 
| − | |-
 | + |  | 
| − | |1|| Not Empty
 | + |  | 
| − | |-
 | + |  | 
| − | |}
 | + |  | 
| − |   | + |  | 
| − | '''Bit 1 - OV : Overrun Error'''
 | + |  | 
| − |   | + |  | 
| − | '''Bit 2 - PE : Parity Error'''
 | + |  | 
| − |   | + |  | 
| − | '''Bit 3 - FE : Framing Error'''
 | + |  | 
| − |   | + |  | 
| − | '''Bit 4 - BI : Break Interrupt'''
 | + |  | 
| − |   | + |  | 
| − | All of above bits gives respective status.
 | + |  | 
| − |   | + |  | 
| − | {| class="wikitable" style="text-align:center; background-color:#C0C0C0;"
 | + |  | 
| − | !Bit Value || Status
 | + |  | 
| − | |-
 | + |  | 
| − | |0|| Inactive
 | + |  | 
| − | |-
 | + |  | 
| − | |1|| Active
 | + |  | 
| − | |-
 | + |  | 
| − | |}
 | + |  | 
| − |   | + |  | 
| − | '''Bit 5 - THRE : Transmitter Holding Register Empty''' 
 | + |  | 
| − |   | + |  | 
| − | It is set immediately upon detection of an empty THR and is cleared on a THR write.
 | + |  | 
| − |   | + |  | 
| − | '''Bit 6 - TEMT : Transmitter Empty'''
 | + |  | 
| − |   | + |  | 
| − | It is set when both THR and TSR are empty and is cleared when
 | + |  | 
| − | either the TSR or the THR contain valid data.
 | + |  | 
| − |   | + |  | 
| − | '''Bit 7 - RXFE : Error in RX FIFO '''
 | + |  | 
| − |   | + |  | 
| − | It is set when UART RBR contains at least one UART RX error and is cleared if RBR contains no UART RX errors or UFCR[0]=0.
 | + |  | 
| − |   | + |  | 
| − | =Schematic=
 | + |  | 
| − | =Code=
 | + |  | 
| − |   | + |  | 
| − | Let's make a Decimal Counter with UART .
 | + |  | 
| − |   | + |  | 
| − | Initialize the UART0 with 9600 baud-rate.
 | + |  | 
| − |   | + |  | 
| − | Display the initial message and go on displaying incremented count taking some pause.
 | + |  | 
| − |   | + |  | 
| − | To know more about UART library, [[UART|check this]].
 | + |  | 
| − | <syntaxhighlight>
 | + |  | 
| − | #include "lpc17xx.h" //Device specific header file
 | + |  | 
| − | #include "uart.h"	//Explore Embedded UART library which contains the uart routines
 | + |  | 
| − | #include "delay.h" //Explore Embedded  library containing the delay routines
 | + |  | 
| − |   | + |  | 
| − | /* start the main program */
 | + |  | 
| − | int main()
 | + |  | 
| − | {
 | + |  | 
| − | 	uint16_t cnt=0;
 | + |  | 
| − |         
 | + |  | 
| − |         /* Setup and initialize the microcontroller system */
 | + |  | 
| − | 	SystemInit();
 | + |  | 
| − |   | + |  | 
| − | 	/* Initialize the UART before Transmitting/Receiving any data */
 | + |  | 
| − | 	UART_Init(UART0,9600);
 | + |  | 
| − |   | + |  | 
| − | 	UART_Printf("5digit decimal counter: ");
 | + |  | 
| − |   | + |  | 
| − | 	/* Transmit the counter till 9999 */
 | + |  | 
| − | 	while(cnt < 9999)
 | + |  | 
| − | 	{
 | + |  | 
| − | 		/* Transmit the 4-digit counter value and go to next line */
 | + |  | 
| − | 		UART_Printf("\n\r%4u",cnt);
 | + |  | 
| − | 		
 | + |  | 
| − | 		/* Increment the counter value after 1-sec */
 | + |  | 
| − | 		DELAY_sec(1);
 | + |  | 
| − | 		cnt++;
 | + |  | 
| − | 	}
 | + |  | 
| − | 	while(1);
 | + |  | 
| − | }
 | + |  | 
| − | </syntaxhighlight>
 | + |  | 
| − | {{DISQUS}}
 | + |  |