xref: /freebsd/share/man/man4/uart.4 (revision b64c5a0ace59af62eff52bfe110a521dc73c937b)
1.\"-
2.\" SPDX-License-Identifier: BSD-2-Clause
3.\"
4.\" Copyright (c) 2003 Marcel Moolenaar
5.\" All rights reserved.
6.\"
7.\" Redistribution and use in source and binary forms, with or without
8.\" modification, are permitted provided that the following conditions
9.\" are met:
10.\"
11.\" 1. Redistributions of source code must retain the above copyright
12.\"    notice, this list of conditions and the following disclaimer.
13.\" 2. Redistributions in binary form must reproduce the above copyright
14.\"    notice, this list of conditions and the following disclaimer in the
15.\"    documentation and/or other materials provided with the distribution.
16.\"
17.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18.\" IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19.\" OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20.\" IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21.\" INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22.\" NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23.\" DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24.\" THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25.\" (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26.\" THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27.\"
28.Dd December 5, 2024
29.Dt UART 4
30.Os
31.Sh NAME
32.Nm uart
33.Nd Universal Asynchronous Receiver/Transmitter serial driver
34.Sh SYNOPSIS
35.Cd "device uart"
36.Pp
37.Cd "device puc"
38.Cd "device uart"
39.Pp
40.Cd "device scc"
41.Cd "device uart"
42.Pp
43In
44.Pa /boot/device.hints :
45.Cd hint.uart.0.disabled="1"
46.Cd hint.uart.0.baud="38400"
47.Cd hint.uart.0.port="0x3f8"
48.Cd hint.uart.0.flags="0x10"
49.Pp
50With
51.Ar flags
52encoded as:
53.Bl -tag -compact -width 0x000000
54.It 0x00010
55device is potential system console
56.It 0x00080
57use this port for remote kernel debugging
58.It 0x00100
59set RX FIFO trigger level to ``low'' (NS8250 only)
60.It 0x00200
61set RX FIFO trigger level to ``medium low'' (NS8250 only)
62.It 0x00400
63set RX FIFO trigger level to ``medium high'' (default, NS8250 only)
64.It 0x00800
65set RX FIFO trigger level to ``high'' (NS8250 only)
66.El
67.\"
68.Sh DESCRIPTION
69The
70.Nm
71device driver provides support for various classes of UARTs implementing the
72EIA RS-232C (CCITT V.24) serial communications interface.
73Each such interface is controlled by a separate and independent instance of
74the
75.Nm
76driver.
77The primary support for devices that contain multiple serial interfaces or
78that contain other functionality besides one or more serial interfaces is
79provided by the
80.Xr puc 4 ,
81or
82.Xr scc 4
83device drivers.
84However, the serial interfaces of those devices that are managed by the
85.Xr puc 4 ,
86or
87.Xr scc 4
88driver are each independently controlled by the
89.Nm
90driver.
91As such, the
92.Xr puc 4 ,
93or
94.Xr scc 4
95driver provides umbrella functionality for the
96.Nm
97driver and hides the complexities that are inherent when elementary components
98are packaged together.
99.Pp
100The
101.Nm
102driver has a modular design to allow it to be used on differing hardware and
103for various purposes.
104In the following sections the components are discussed in detail.
105Options are described in the section that covers the component to which each
106option applies.
107.\"
108.Ss CORE COMPONENT
109At the heart of the
110.Nm
111driver is the core component.
112It contains the bus attachments and the low-level interrupt handler.
113.\"
114.Ss HARDWARE DRIVERS
115The core component and the kernel interfaces talk to the hardware through the
116hardware interface.
117This interface serves as an abstraction of the hardware and allows varying
118UARTs to be used for serial communications.
119.\"
120.Ss SYSTEM DEVICES
121System devices are UARTs that have a special purpose by way of hardware
122design or software setup.
123For example, Sun UltraSparc machines use UARTs as their keyboard interface.
124Such an UART cannot be used for general purpose communications.
125Likewise, when the kernel is configured for a serial console, the
126corresponding UART will in turn be a system device so that the kernel can
127output boot messages early on in the boot process.
128.\"
129.Ss KERNEL INTERFACES
130The last but not least of the components is the kernel interface.
131This component ultimately determines how the UART is made visible to the
132kernel in particular and to users in general.
133The default kernel interface is the TTY interface.
134This allows the UART to be used for terminals, modems and serial line IP
135applications.
136System devices, with the notable exception of serial consoles, generally
137have specialized kernel interfaces.
138.\"
139.Sh HARDWARE
140The
141.Nm
142driver supports the following classes of UARTs:
143.Pp
144.Bl -bullet -compact
145.It
146NS8250: standard hardware based on the 8250, 16450, 16550, 16650, 16750 or
147the 16950 UARTs.
148.It
149SCC: serial communications controllers supported by the
150.Xr scc 4
151device driver.
152.El
153.\"
154.Sh Pulse Per Second (PPS) Timing Interface
155The
156.Nm
157driver can capture PPS timing information as defined in RFC 2783.
158The API, accessed via
159.Xr ioctl 2 ,
160is available on the tty device.
161To use the PPS capture feature with
162.Xr ntpd 8 ,
163symlink the tty callout device
164.Va /dev/cuau?
165to
166.Va /dev/pps0.
167.Pp
168The
169.Va hw.uart.pps_mode
170tunable configures the PPS capture mode for all uart devices;
171it can be set in
172.Xr loader.conf 5 .
173The
174.Va dev.uart.0.pps_mode
175sysctl configures the PPS capture mode for a specific uart device;
176it can be set in
177.Xr loader.conf 5
178or
179.Xr sysctl.conf 5 .
180.Pp
181The following capture modes are available:
182.Bl -tag -compact -offset "mmmm" -width "mmmm"
183.It 0x00
184Capture disabled.
185.It 0x01
186Capture pulses on the CTS line.
187.It 0x02
188Capture pulses on the DCD line.
189.El
190.Pp
191The following values may be ORed with the capture mode to configure
192capture processing options:
193.Bl -tag -compact -offset "mmmm" -width "mmmm"
194.It 0x10
195Invert the pulse (RS-232 logic low = ASSERT, high = CLEAR).
196.It 0x20
197Attempt to capture narrow pulses.
198.El
199.Pp
200Add the narrow pulse option when the incoming PPS pulse width is small
201enough to prevent reliable capture in normal mode.
202In narrow mode the driver uses the hardware's ability to latch a line
203state change; not all hardware has this capability.
204The hardware latch provides a reliable indication that a pulse occurred,
205but prevents distinguishing between the CLEAR and ASSERT edges of the pulse.
206For each detected pulse, the driver synthesizes both an ASSERT and a CLEAR
207event, using the same timestamp for each.
208To prevent spurious events when the hardware is intermittently able to
209see both edges of a pulse, the driver will not generate a new pair of
210events within a half second of the prior pair.
211Both normal and narrow pulse modes work with
212.Xr ntpd 8 .
213.Pp
214Add the invert option when the connection to the uart device uses TTL
215level signals, or when the PPS source emits inverted pulses.
216RFC 2783 defines an ASSERT event as a higher-voltage line level, and a CLEAR
217event as a lower-voltage line level, in the context of the RS-232 protocol.
218The modem control signals on a TTL-level connection are typically
219inverted from the RS-232 levels.
220For example, carrier presence is indicated by a high signal on an RS-232
221DCD line, and by a low signal on a TTL DCD line.
222This is due to the use of inverting line driver buffers to convert between
223TTL and RS-232 line levels in most hardware designs.
224Generally speaking, a connection to a DB-9 style connector is an RS-232
225level signal at up to 12 volts.
226A connection to header pins or an edge-connector on an embedded board
227is typically a TTL signal at 3.3 or 5 volts.
228.Sh Special Devices
229The
230.Nm
231driver also supports an initial-state and a lock-state control
232device for each of the callin and the callout "data" devices.
233The termios settings of a data device are copied
234from those of the corresponding initial-state device
235on first opens and are not inherited from previous opens.
236Use
237.Xr stty 1
238in the normal way on the initial-state devices to program
239initial termios states suitable for your setup.
240.Pp
241The lock termios state acts as flags to disable changing
242the termios state.
243E.g., to lock a flag variable such as CRTSCTS, use
244.Em stty crtscts
245on the lock-state device.
246Speeds and special characters
247may be locked by setting the corresponding value in the lock-state
248device to any nonzero value.
249E.g., to lock a speed to 115200, use
250.Dq Li stty 115200
251on the initial-state device and
252.Dq Li stty 1
253on the lock-state device.
254.Pp
255Correct programs talking to correctly wired external devices
256work with almost arbitrary initial states and almost no locking,
257but other setups may benefit from changing some of the default
258initial state and locking the state.
259In particular, the initial states for non (POSIX) standard flags
260should be set to suit the devices attached and may need to be
261locked to prevent buggy programs from changing them.
262E.g., CRTSCTS should be locked on for devices that support
263RTS/CTS handshaking at all times and off for devices that do not
264support it at all.
265CLOCAL should be locked on for devices that do not support carrier.
266HUPCL may be locked off if you do not
267want to hang up for some reason.
268In general, very bad things happen
269if something is locked to the wrong state, and things should not
270be locked for devices that support more than one setting.
271The CLOCAL flag on callin ports should be locked off for logins
272to avoid certain security holes, but this needs to be done by
273getty if the callin port is used for anything else.
274.Sh Console Tuneable
275The
276.Nm
277driver can be designated as a system console.
278.Bl -tag -width indent
279.It Va hw.uart.console
280Contains a number of
281.Pa /etc/remote
282like tag:value pairs, separated by commas.
283.Bl -tag -width indent
284.It Cm \&bd
285Busy Detect.
286Enable the so-called
287.Dq Busy Detect
288quirk for the device.
289For NS 16550-compatible devices, this will use heuristics to ensure that the
290UART is no longer busy before manipulating line control.
291DesignWare-based UARTs need this due to a design flaw in the UART.
292.It Cm \&br
293Baudrate.
294The data rate (bits per second) used for communications on the serial port.
295When the device clock rate (see below) is set to 0, then the baud rate will be
296used with the divisor to compute the device clock rate the first time the device
297is initialized.
298Only the traditional baud rates are allowed.
299Rates larger than 19200 must be a multiple of 19200.
300Baud rates between 1200 and 19200 must be a multiple of 1200.
301Otherwise the baud rate must be a multiple of 75.
302A value of '0' instructs the
303.Nm
304driver to not program the baud rate divisor and use the hardware as-is.
305.It Cm \&ch
306Channel.
307Defaults to 0.
308Has no effect on UARTs with only one channel.
309.It Cm \&db
310Data bits.
311Defaults to 8.
312.It Cm \&dt
313Device type.
314Specify the uart class to use for this device.
315.Bl -tag -width indent
316.It ns8250
317Traditional PC UART National Semiconductor 16550 and compatible devices.
318.It pl011
319Common ARM UART, based on ARM Limited designs.
320.El
321.It Cm \&io
322I/O port address.
323Specifies the address of a UART in an Intel processor's I/O space.
324Mutually exclusive with
325.Sq mm .
326.It Cm \&mm
327Memory mapped I/O address.
328Specifies the physical address of a memory-mapped UART.
329Mutually exclusive with
330.Sq io .
331.It Cm \&pa
332Parity.
333The type of parity to use when sending data
334to the host.
335This may be one of ``even'',
336``odd'', ``none'', ``zero'' (always set bit 8 to zero),
337``one'' (always set bit 8 to 1).
338The default is even parity.
339.It Cm \&rs
340Register shift.
341Number of bits to shift left the base register offset.
342.It Cm \&rw
343Register width.
344Size of operations to read and write the registers of the device.
345.It Cm \&sb
346Stopbits.
347Defaults to 1.
348.It Cm \&xo
349Device clock (xtal oscillator).
350Base frequency of the oscillator to use for the device.
351When set to 0, and the baud rate is also set, the UART's initialization
352code will compute this the first time and use that after.
353Automatically computed values can be as large as 5% when the base
354frequency is a poor match to the traditional baud rates.
355.El
356.El
357.Sh FILES
358.Bl -tag -width "/dev/ttyu?.init" -compact
359.It Pa /dev/ttyu?
360for callin ports
361.It Pa /dev/ttyu?.init
362.It Pa /dev/ttyu?.lock
363corresponding callin initial-state and lock-state devices
364.Pp
365.It Pa /dev/cuau?
366for callout ports
367.It Pa /dev/cuau?.init
368.It Pa /dev/cuau?.lock
369corresponding callout initial-state and lock-state devices
370.El
371.Sh EXAMPLES
372.Dl hw.uart.console="io:0x2f8,br=115200"
373.Pp
374When the kernel is using a serial console port, it should use
375COM2 instead of COM1 and set the baud rate to 115200.
376.Sh SEE ALSO
377.Xr cu 1 ,
378.Xr puc 4 ,
379.Xr scc 4 ,
380.Xr ttys 5
381.\"
382.Sh HISTORY
383The
384.Nm
385device driver first appeared in
386.Fx 5.2 .
387.Sh AUTHORS
388The
389.Nm
390device driver and this manual page were written by
391.An Marcel Moolenaar Aq Mt marcel@xcllnt.net .
392