Interfacing The Serial/RS-232 Port Hardware Serial Port Registers Programming.

Slides:



Advertisements
Similar presentations
Serial Interface Dr. Esam Al_Qaralleh CE Department
Advertisements

INPUT-OUTPUT ORGANIZATION
Serial Communications Interface (SCI) Michael LennardZachary PetersBao Nguyen.
11-1 ECE 424 Design of Microprocessor-Based Systems Haibo Wang ECE Department Southern Illinois University Carbondale, IL I/O System Design.
DATA COMMUNICATIONS Some organisations concerned with standards: EIA - Electroonic Industries Association (RS standards including RS-232) IEEE - Institute.
I/O Unit.
Serial I/O - Programmable Communication Interface
FIU Chapter 7: Input/Output Jerome Crooks Panyawat Chiamprasert
Interrupts What is an interrupt? What does an interrupt do to the “flow of control” Interrupts used to overlap computation & I/O – Examples would be console.
Asynchronous Communication Hardware  Data within a DTE is usually stored and moved in a parallel fashion.  Data sent across the channel is generally.
Testing Communication Systems  When point-to-point communication between two DTEs is not functioning, which DTE is at fault? Or which DTE is correctly.
1 מעבדה במבוא לתקשורת מועבר ע ” י דני סיטרון כל החומר על הקורס ( החומר שיילמד, תרגילים, ציונים, שעות קבלה …) נמצא ב :
Communication Lab - Interrupts 1/13 Sequential Programming  Our C++ programs are sequential ( סדרתיים), they start at the first instruction and end at.
PC Modem Control The 8250 UART supplied with the PC supports a limited number of RS-232-C modem functions: The UART can be programmed to interrupt the.
COMP3221: Microprocessors and Embedded Systems
7-1 Digital Serial Input/Output Two basic approaches  Synchronous shared common clock signal all devices synchronised with the shared clock signal data.
Input/Output and Communication
1 The 9-Pin Connector Pin abbreviations (numbers in parentheses are the 25D pin numbers): 1. CD (8) 2. RD (Rx) (3) 3. TD (Tx) (2) 4. DTR (20) 5. SG (Ground)
Serial Communications Standards (Partly Excerpted from Simpl Primer) Cabling Configuration Protocol.
ECE 371- Unit 11 Introduction to Serial I/O. TWO MAJOR CLASSES OF SERIAL DATA INTERFACES ASYNCHRONOUS SERIAL I/O - USES “FRAMING BITS” (START BIT AND.
INTERRUPTS PROGRAMMING
1 מעבדה במבוא לתקשורת בהתאם לאמונה שלי שתלמיד שאינו שולט באנגלית לא יכול להתהדר בתואר אקדמי במדעי המחשב, אזי : זה השקף האחרון בעברית שתראו בקורס.
INPUT-OUTPUT ORGANIZATION
University of Tehran 1 Interface Design Serial Communications Omid Fatemi.
Technology Training that Works Hands of Data Communications, Networking & TCP/IP Troubleshooting.
INPUT/OUTPUT ARCHITECTURE By Truc Truong. Input Devices Keyboard Keyboard Mouse Mouse Scanner Scanner CD-Rom CD-Rom Game Controller Game Controller.
Transmission Modes Serial Transmission  One bit is transmitted on a circuit at a time  Usually there is one transmit circuit and one receive circuit.
Computers in Surveying SVY2301 / E4006 Automated Surveying.
The 8051 Microcontroller and Embedded Systems
Serial Port I/O Serial port sends and receives data one bit at a time. Serial communication devices are divided into: Data Communications Equipment (DCE),
1 System Resources. 2 Interrupt Request (IRQ) Channels Interrupt Request (IRQ) Channels Direct Memory Access (DMA) Channels Direct Memory Access (DMA)
MICROPROCESSOR INPUT/OUTPUT
Universal Synchronous/Asynchronous Receiver/Transmitter (USART)
© Janice Regan, CMPT 300, May CMPT 300 Introduction to Operating Systems Principles of I/0 hardware.
1 Microprocessor-based Systems Course 9 Design of the input/output interfaces (continue)
Universal Asynchronous Receiver/Transmitter (UART)
Microprocessors 2 lesson Subjects lesson 7 Planning Interrupts Serial communication /USART Questions.
CHAPTER SERIAL PORT PROGRAMMING. Basics of Serial Communication Computers transfer data in two ways: ◦ Parallel  Often 8 or more lines (wire conductors)
Serial Communications
Advanced Embedded Systems Design Lecture 8 Serial I/O BAE Fall 2004 Instructor: Marvin Stone Biosystems and Agricultural Engineering Oklahoma.
Advanced Microprocessor1 I/O Interface Programmable Interval Timer: 8254 Three independent 16-bit programmable counters (timers). Each capable in counting.
 8251A is a USART (Universal Synchronous Asynchronous Receiver Transmitter) for serial data communication.  Programmable peripheral designed for synchronous.
Universal Asynchronous Receiver/Transmitter (UART)
1 Transmission of Digital Data : Interface and Modems.
1 מעבדה במבוא לתקשורת מועבר ע ” י אליעזר גנסבורגר ( מעובד מחומר שנלקט ע " י דניאל סיטרון ) כל החומר על הקורס ( החומר שיילמד, תרגילים, ציונים, שעות קבלה.
IT3002 Computer Architecture
بسم الله الرحمن الرحيم MEMORY AND I/O.
Example 1 Program the divisor Latch for 300 baud. Assume Xin=1.8432MHz The Base Address: 0x3F8 0RX_TX / Divisor.low 1IER: Interrupt Enable Reg. / Divisor.high.
8251 USART.
BASICS OF SERIAL COMMUNICATIONS BIRLA VISHWKARMA MAHAVIDYALAYA ELECTRONICS & TELECOMMUNICATION DEPARTMENT PRESENTING BY: ABHISHEK SINGH AMANDEEP.
Tiva C TM4C123GH6PM UART Embedded Systems ECE 4437 Fall 2015 Team 2:
Lecture 15. Modem Controller Register 4310 DTR 0 = Polling Operator 1 = Interrupts Enabled RTS 1 =Self Test 0 =Normal.
Lecture # 14. RS – 232C Standard Standard for physical dimensions of the connectors. PC (DTE) Modem RS – 232C Cable Connected via serial port (DCE)
The HCS12 SCI Subsystem A HCS12 device may have one or two serial communication interface. These two SCI interfaces are referred to as SCI0 and SCI1. The.
Serial mode of data transfer
RS-232 Communications.
CS-401 Computer Architecture & Assembly Language Programming
Input/Output and Communication
SERIAL PORT PROGRAMMING
1 Input-Output Organization Computer Organization Computer Architectures Lab Peripheral Devices Input-Output Interface Asynchronous Data Transfer Modes.
RS-232 Communications.
Serial Communication: RS-232 (IEEE Standard)
E3165 DIGITAL ELECTRONIC SYSTEM
UART Serial Port Programming
Serial Communication Interface: Using 8251
Serial Communication Interface
UART PC16550 (Universal Asynchronous Receiver/Transmitter) By Derwyn Hollobaugh
CHAPTER SERIAL PORT PROGRAMMING. Basics of Serial Communication Computers transfer data in two ways: ◦ Parallel  Often 8 or more lines (wire.
8051SERIAL PORT PROGRAMMING
AVR UART The UART, or Universal Asynchronous Receiver Transmitter, provides hardware support for a serial port on AVR processors Signaling is compatible.
Presentation transcript:

Interfacing The Serial/RS-232 Port Hardware Serial Port Registers Programming

Interfacing the Serial / RS232 Port The Serial Port is harder to interface than the Parallel Port.

When receiving data and change in status from I/O Ports, two methods are available 1. POLLING Poll the port, which involves reading the status of the port at fixed intervals to determine whether any data has been received or a change of status has occurred. If so, then branch to a routine to service the ports requests. 2 INTERRUPT HANDLING when a I/O Port/Device needs attention as a byte has been received or status has changed, then it sends a Interrupt Request (IRQ) to the processor. Once the processor receives an Interrupt Request, it finishes its current instruction, places a few things on the stack, and executes the appropriate Interrupt Service Routine (ISR) which can remove the byte from the port and place it in a buffer. Once the ISR has finished, the processor returns to where it left off.

Hardware Interrupts The Programmable Interrupt Controller (PIC) handles hardware interrupts. Most PC's will have two of them located at different addresses. One handles IRQ's 0 to 7 and the other, IRQ's 8 to 15, giving a total of 15 individual IRQ lines The first PIC, located at Base Address 0x20h controls IRQ 0 to IRQ 7. The second PIC located at a base address of 0xA0h controls IRQs 8 to 15.

. BitDisable IRQFunction 7IRQ7Parallel Port 6IRQ6Floppy Disk Controller 5IRQ5Reserved/Sound Card 4IRQ4Serial Port 3IRQ3Serial Port 2IRQ2PIC2 1IRQ1Keyboard 0IRQ0System Timer PIC1 (0x21) outportb(0x21,(inportb(0x21) & 0xF7); to enable IRQ3. outportb(0x21,(inportb(0x21) | 0x08); used to disable IRQ3

BitDisable IRQFunction 7IRQ15Reserved 6IRQ14Hard Disk Drive 5IRQ13Maths Co-Processor 4IRQ12PS/2 Mouse 3IRQ11Reserved 2IRQ10Reserved 1IRQ9Redirected IRQ2 0IRQ8Real Time Clock End of Interrupt (EOI): This is sent to the PIC at the end of the Interrupt Service Routine so that the PIC can reset the In Service Register. An EOI can be sent using outportb(0x20,0x20); for PIC1 or outportb(0xA0,0x20); for PIC2 PIC2 (0xA1)

Hardware Properties

any device connected to the serial port will need the serial transmission converted back to parallel so that it can be used This can be done using a UART Devices which use serial cables for their communication are split into two categories. 1.DCE (Data Communications Equipment) 2.DTE (Data Terminal Equipment.) Data Communications Equipment are devices such as modem, TA adapter, plotter etc while Data Terminal Equipment is Computer or Terminal.

Serial Ports come in two "sizes" There are the D-Type 25 pin connector and the D-Type 9 pin connector

D-25 Pin No: D-9 Pin No:Abbrevi- ation Full Name Pin2Pin3TXDTransmit Data Pin 3 Pin 2RDReceive Data Pin 4 Pin 7RTSRequest To Send Pin 5Pin 8CTSClear To Send Pin 6 DSRData Set Ready Pin 7Pin 5SGSignal Ground Pin 8Pin 1CDCarrier Detect Pin 20Pin 4DTRData Terminal Ready

Pin Functions Abbreviation Full NameFunction TD Transmit DataSerial Data Output (TXD) RD Receive DataSerial Data Input (RXD) CTSClear to Send This line indicates that the Modem is ready toexchange data. DCDData Carrier DetectWhen the modem detects a "Carrier" from the modem at the other end of the phone line, this Line becomes active. DSRData Set ReadyThis tells the UART that the modem is ready to establish a link.

AbbreviationFull NameFunction DTRData Terminal Ready This is the opposite to DSR. This tells the Modem that the UART is ready to link. RTSRequest To Send This line informs the Modem that the UART is ready to exchange data. RIRing IndicatorGoes active when modem detects a ringing signal from the PSTN.

NULL MODEMS A Null Modem is used to connect two DTE's together.

Above is method of wiring Null Modem It only requires 3 wires (TD, RD & SG) to be wired. Null Modems make to computer think it is talking to a modem rather than another computer. Any data transmitted from the first computer must be received by the second thus TD is connected to RD. The second computer must have the same set-up thus RD is connected to TD. Signal Ground (SG) must also be connected so both grounds are common to each computer. The Data Terminal Ready is looped back to Data Set Ready and Carrier Detect on both computers. When the Data Terminal Ready is asserted active, then the Data Set Ready and Carrier Detect immediately become active. At this point the computer thinks the Virtual Modem to which it is connected is ready and has detected the carrier of the other modem.

Request to Send and Clear To Send, As both computers communicate together at the same speed, flow control is not needed thus these two lines are also linked together on each computer. When the computer wishes to send data, it asserts the Request to Send high and as it's hooked together with the Clear to Send, It immediately gets a reply that it is ok to send and does so. Line RTS tells the Modem that UART is ready to exchange data, and the loop back to the line CTS indicate that the Modem is ready to excahange data. When the DTR is set,which tells the modem that UART is ready to make link & this signal is looped back to DSR, which tells UART that modem is ready to make link & carrier detect tells modem that the other end of the line is active.

Flow Control Sooner or later data is going to get lost as buffers overflow, thus flow control is used. Flow control has two basic varieties, Hardware or Software. Software flow control, sometimes expressed as Xon/Xoff uses two characters Xon and Xoff. Xon is normally indicated by the ASCII 17 character where as the ASCII 19 character is used for Xoff. when the computer fills the buffer of modem, the modem sends a Xoff character to tell the computer to stop sending data. Once the modem has room for more data it then sends a Xon character and the computer sends more data.

Hardware flow control is also known as RTS/CTS flow control. It uses two wires in serial cable rather than extra characters transmitted in data lines. Thus hardware flow control will not slow down transmission times like Xon-Xoff does. When the computer wishes to send data it takes active the Request to Send line. If the modem has room for this data, then the modem will reply by taking active the Clear to Send line and the computer starts sending data. If the modem does not have the room then it will not send a Clear to Send.

THE UART UART stands for Universal Asynchronous Receiver / Transmitter. The 8250 series, which includes the 16450, 16550, 16650, & UARTS are the most commonly found type in your PC. It’s is usually integrated with serial cards.

The introduced two new pins at 24 and 29. These are Transmit Ready at 24 and Receive Ready at 29 which can be implemented with DMA (Direct Memory Access). These Pins have two different modes of operation. Mode 0 supports single transfer DMA where as Mode 1 supports Multi-transfer DMA. Mode 0 is also called the mode. This mode is selected when the FIFO buffers are disabled via Bit 0 of the FIFO Control Register or When the FIFO buffers are enabled but DMA Mode Select = 0. (Bit 3 of FCR) In this mode RXRDY is active low when at least one character (Byte) is present in the Receiver Buffer.. RXRDY will go inactive high when no more characters are left in the Receiver Buffer.

TXRDY will be active low when there are no characters in the Transmit Buffer. It will go inactive high after the first character / byte is loaded into the Transmit Buffer. *later*

Serial Port's Registers Port Addresses & IRQ's NameAddressIRQ COM 13F84 COM 22F83 COM 33E84 COM 42E83 Above are the standard port addresses.

Start AddressFunction 0000:0400COM1's Base Address 0000:0402COM2's Base Address 0000:0404COM3's Base Address 0000:0406COM4's Base Address The above table shows the address at which we can find the Communications (COM) ports addresses in the BIOS Data Area. Each address will take up 2 bytes.

#include void main(void) { unsigned int far *ptraddr; /* Pointer to location of Port Addresses*/ unsigned int address; /* Address of Port */ int a; ptraddr=(unsigned int far *)0x ; for (a = 0; a < 4; a++) { address = *ptraddr; if (address == 0) printf("No port found for COM%d \n",a+1); else printf("Address assigned to COM%d is %Xh\n",a+1,address); *ptraddr++; }

REGISTERS 12 registers Through only 8 port addresses Table of Registers

Base AddressDLABRead/WriteAbr.Register Name + 0 =0Write-Transmitter Holding Buffer =0Read-Receiver Buffer =1Read/Write-Divisor Latch Low Byte + 1 =0Read/WriteIERInterrupt Enable Register =1Read/Write-Divisor Latch High Byte + 2 -ReadIIR Interrupt Identification Register -WriteFCRFIFO Control Register + 3-Read/WriteLCRLine Control Register + 4-Read/WriteMCRModem Control Register + 5-ReadLSRLine Status Register + 6-ReadMSRModem Status Register + 7-Read/Write-Scratch Register Table 5 : Table of Registers

When DLAB is set to '0' or '1' some of the registers change. This is how the UART is able to have 12 registers (including the scratch register) through only 8 port addresses. DLAB stands for Divisor Latch Access Bit.. When DLAB is set to '1' via the line control register, two registers become available from which we can set your speed of communications measured in bits per second. the UART is fitted with a Programmable Baud Rate Generator which is controlled by these two registers. The first register (Base + 0) when DLAB = 1 stores the "Divisor latch low byte" where as the second register (base + 1 when DLAB = 1) stores the "Divisor latch high byte.“

Speed (BPS)Divisor (Dec) Divisor Latch High Byte Divisor Latch Low Byte h00h h80h hC0h h30h h18h h0Ch h06h h03h h02h h01h

BitNotes Bit 7 Reserved Bit 6 Reserved Bit 5 Enables Low Power Mode (16750) Bit 4 Enables Sleep Mode (16750) Bit 3 Enable Modem Status Interrupt Bit 2 Enable Receiver Line Status Interrupt Bit 1 Enable Transmitter Holding Register Empty Interrupt Bit 0 Enable Received Data Available Interrupt Interrupt Enable Register(IER) :

 Read/Write Register  DLAB=0  Setting Bit 0 high enables the Received Data Available Interrupt which generates an interrupt when the receiving register/FIFO contains data to be read by the CPU.  Bit 1 enables Transmit Holding Register Empty Interrupt. This interrupts the CPU when the transmitter buffer is empty.  Bit 2 enables the receiver line status interrupt. The UART will interrupt when the receiver line status changes.  Likewise for bit 3 which enables the modem status interrupt.

Interrupt Identification Register (IIR) Table of IIR

Bit Notes Bits 6 and 7 Bit 6Bit 7 00No FIFO 01FIFO Enabled but Unusable 11FIFO Enabled Bit 564 Byte Fifo Enabled (16750 only) Bit 4Reserved Bit 3 0Reserved on 8250, Time-out Interrupt Pending Bits 1 and 2 Bit 2Bit 1 00Modem Status Interrupt 01 Transmitter Holding Register Empty Interrupt 10Received Data Available Interrupt 11Receiver Line Status Interrupt Bit 0 0Interrupt Pending 1No Interrupt Pending

 Read only register  Bits 6 and 7 give status on the FIFO Buffer.  Bit 0 which shows whether an interrupt has occurred. If an interrupt has occurred it's status will shown by bits 1 and 2.

FIRST IN / FIRST OUT Control Register ( FCR ) Table of FCR

BitNotes Bits 6 and 7 Bit 7Bit 6Interrupt Trigger Level 001 Byte 014 Bytes 108 Bytes 1114 Bytes Bit 5Enable 64 Byte FIFO (16750 only) Bit 4Reserved Bit 3 DMA Mode Select. Change status of RXRDY & TXRDY pins from mode 1 to mode 2. Bit 2Clear Transmit FIFO Bit 1Clear Receive FIFO Bit 0Enable FIFO's

The FIFO register is a write only register. Bit 0 enables the operation of the receive and transmit FIFO's. Writing a '0' to this bit will disable the operation of transmit and receive FIFO's, thus you will loose all data stored in these FIFO buffers. Bit's 1 and 2 control the clearing of the transmit or receive FIFO's. Bits 6 and 7 are used to set the triggering level on the Receive FIFO. For example if bit 7 was set to '1' and bit 6 was set to '0' then the trigger level is set to 8 bytes. When there is 8 bytes of data in the receive FIFO then the Received Data Available interrupt is set. See (IIR)

LINE CONTROL REGISTER (LCR) Table

Bit 7 1Divisor Latch Access Bit 0 Access to Receiver buffer, Transmitter buffer & Interrupt Enable Register Bit 6Set Break Enable Bits 3, 4 And 5 Bit 5Bit 4Bit 3Parity Select XX0No Parity 001Odd Parity 011Even Parity 101 High Parity (Sticky) 111 Low Parity (Sticky) Bit 2 Length of Stop Bit 0One Stop Bit 1 2 Stop bits for words of length 6,7 or 8 bits or 1.5 Stop Bits for Word lengths of 5 bits. Bits 0 And 1 Bit 1Bit 0Word Length 005 Bits 016 Bits 107 Bits 118 Bits

The Line Control register sets the basic parameters for communication. Bit 7 is the Divisor Latch Access Bit or DLAB for short. Bits 3,4 and 5 select parity, bit 3 controls parity. Bit 2 sets the length of the stop bits. Setting this bit to '0' will produce one stop bit. Bits 0 and 1 set the word length.

BitNotes Bit 7Reserved Bit 6Reserved Bit 5Autoflow Control Enabled (16750 only) Bit 4LoopBack Mode Bit 3Aux Output 2 Bit 2Aux Output 1 Bit 1Force Request to Send Bit 0Force Data Terminal Ready Modem Control Register (MCR) The Modem Control Register is a Read/Write Register

BitNotes Bit 7Error in Received FIFO Bit 6Empty Data Holding Registers Bit 5Empty Transmitter Holding Register Bit 4Break Interrupt Bit 3Framing Error Bit 2Parity Error Bit 1Overrun Error Bit 0Data Ready Line Status Register (LSR)

The line status register is a read only register. Bit 7 is the error in received FIFO bit. Bit 0 shows data ready, which means that a byte has been received by the UART and is at the receiver buffer ready to be read

BitNotes Bit 7Carrier Detect Bit 6Ring Indicator Bit 5Data Set Ready Bit 4Clear To Send Bit 3Delta Data Carrier Detect Bit 2Trailing Edge Ring Indicator Bit 1Delta Data Set Ready Bit 0Delta Clear to Send Modem Status Register (MSR)

Bit 0 of the modem status register shows delta clear to send. delta meaning a change in, thus delta clear to send means that there was a change in the clear to send line, since the last read of this register. This is the same for bits 1 and 3. Bits 4 to 7 show the current state of the data lines when read.