The D16550 is a soft Core of Universal Asynchronous Receiver/Transmitter (UART), functionally identical to the TL16C550A. It allows serial transmission in two modes – UART and FIFO. In the FIFO mode, internal FIFOs are activated allowing 16 bytes (plus 3 bits of error data per byte in the RCVR FIFO) to be stored in both, receive and transmit directions. The D16550 performs serial-to-parallel conversion on data characters received from a peripheral device or MODEM, and parallel-to-serial conversion on data characters received from the CPU. The CPU can read a complete status of the UART at any time during the functional operation. Reported status information includes a type and condition of transfer operations performed by the UART, as well as any error conditions (parity, overrun, framing or break interrupt). The D16550 includes a programmable baud rate generator, which is capable of dividing a timing reference clock input by divisors of 1 to (216-1) and producing a 16 × clock for driving internal transmitter logic. Provisions are also included to use this 16 × clock to drive receiver logic. Our soft core incorporates complete MODEM control capability and a processor-interrupt system. What’s more important, interrupts can be programmed to your requirements, minimizing computing required to handle the communication link. A separate BAUD CLK line allows to set an exact transmission speed, while UART internal logic is clocked with CPU frequency. During the Synthesis process, configuration capability allows you to enable or disable Modem Control Logic and FIFO’s, or change the FIFO’s size. So, in applications with area limitation and where the UART works only in the 16450 mode, disabling Modem Control and FIFO’s allow to save about 50% of logic resources. Our trustworthy Core is perfect for applications where the UART core and microcontroller are clocked by the same clock signal and are implemented inside the same ASIC or FPGA chip. We recommend it also for a standalone implementation, where several UARTs are required to be implemented inside a single chip and driven by some off-chip devices. Thanks to a universal interface, the D16550 core implementation and verification are very simple, just by eliminating a number of clock trees in the complete system. The D16550 includes fully automated test bench with a complete set of tests, allowing easy package validation at each stage of SoC design flow. Please remember that our soft core is a technology independent design, so can be implemented in variety of process technologies.