2014-11-04 18:25:20 +00:00
|
|
|
.. _pyb.UART:
|
|
|
|
|
2014-10-31 22:21:37 +00:00
|
|
|
class UART -- duplex serial communication bus
|
|
|
|
=============================================
|
2014-10-31 01:37:19 +00:00
|
|
|
|
|
|
|
UART implements the standard UART/USART duplex serial communications protocol. At
|
|
|
|
the physical level it consists of 2 lines: RX and TX. The unit of communication
|
|
|
|
is a character (not to be confused with a string character) which can be 8 or 9
|
|
|
|
bits wide.
|
|
|
|
|
|
|
|
UART objects can be created and initialised using::
|
|
|
|
|
|
|
|
from pyb import UART
|
|
|
|
|
|
|
|
uart = UART(1, 9600) # init with given baudrate
|
|
|
|
uart.init(9600, bits=8, parity=None, stop=1) # init with given parameters
|
|
|
|
|
2015-06-10 22:29:56 +01:00
|
|
|
.. only:: port_pyboard
|
|
|
|
|
|
|
|
Bits can be 7, 8 or 9. Parity can be None, 0 (even) or 1 (odd). Stop can be 1 or 2.
|
|
|
|
|
|
|
|
*Note:* with parity=None, only 8 and 9 bits are supported. With parity enabled,
|
|
|
|
only 7 and 8 bits are supported.
|
|
|
|
|
|
|
|
.. only:: port_wipy
|
|
|
|
|
2015-09-13 14:59:45 +01:00
|
|
|
Bits can be 5, 6, 7, 8. Parity can be ``None``, ``UART.EVEN`` or ``UART.ODD``. Stop can be 1 or 2.
|
2014-10-31 20:28:10 +00:00
|
|
|
|
2014-10-31 01:37:19 +00:00
|
|
|
|
|
|
|
A UART object acts like a stream object and reading and writing is done
|
|
|
|
using the standard stream methods::
|
|
|
|
|
|
|
|
uart.read(10) # read 10 characters, returns a bytes object
|
|
|
|
uart.readall() # read all available characters
|
|
|
|
uart.readline() # read a line
|
|
|
|
uart.readinto(buf) # read and store into the given buffer
|
|
|
|
uart.write('abc') # write the 3 characters
|
|
|
|
|
2015-09-07 08:23:46 +01:00
|
|
|
.. only:: port_pyboard
|
|
|
|
|
|
|
|
Individual characters can be read/written using::
|
|
|
|
|
|
|
|
uart.readchar() # read 1 character and returns it as an integer
|
|
|
|
uart.writechar(42) # write 1 character
|
|
|
|
|
|
|
|
To check if there is anything to be read, use::
|
2014-10-31 01:37:19 +00:00
|
|
|
|
2015-09-07 08:23:46 +01:00
|
|
|
uart.any() # returns True if any characters waiting
|
2014-10-31 01:37:19 +00:00
|
|
|
|
2015-09-07 08:23:46 +01:00
|
|
|
*Note:* The stream functions ``read``, ``write``, etc. are new in MicroPython v1.3.4.
|
|
|
|
Earlier versions use ``uart.send`` and ``uart.recv``.
|
2014-10-31 01:37:19 +00:00
|
|
|
|
2015-09-07 08:23:46 +01:00
|
|
|
.. only:: port_wipy
|
|
|
|
|
|
|
|
To check if there is anything to be read, use::
|
2014-10-31 01:37:19 +00:00
|
|
|
|
2015-09-07 08:23:46 +01:00
|
|
|
uart.any() # returns the number of characters available for reading
|
2014-10-31 01:37:19 +00:00
|
|
|
|
|
|
|
Constructors
|
|
|
|
------------
|
|
|
|
|
2015-06-10 22:29:56 +01:00
|
|
|
.. only:: port_pyboard
|
|
|
|
|
|
|
|
.. class:: pyb.UART(bus, ...)
|
|
|
|
|
|
|
|
Construct a UART object on the given bus. ``bus`` can be 1-6, or 'XA', 'XB', 'YA', or 'YB'.
|
|
|
|
With no additional parameters, the UART object is created but not
|
|
|
|
initialised (it has the settings from the last initialisation of
|
|
|
|
the bus, if any). If extra arguments are given, the bus is initialised.
|
|
|
|
See ``init`` for parameters of initialisation.
|
|
|
|
|
|
|
|
The physical pins of the UART busses are:
|
|
|
|
|
|
|
|
- ``UART(4)`` is on ``XA``: ``(TX, RX) = (X1, X2) = (PA0, PA1)``
|
|
|
|
- ``UART(1)`` is on ``XB``: ``(TX, RX) = (X9, X10) = (PB6, PB7)``
|
|
|
|
- ``UART(6)`` is on ``YA``: ``(TX, RX) = (Y1, Y2) = (PC6, PC7)``
|
|
|
|
- ``UART(3)`` is on ``YB``: ``(TX, RX) = (Y9, Y10) = (PB10, PB11)``
|
|
|
|
- ``UART(2)`` is on: ``(TX, RX) = (X3, X4) = (PA2, PA3)``
|
|
|
|
|
|
|
|
.. only:: port_wipy
|
|
|
|
|
|
|
|
.. class:: pyb.UART(bus, ...)
|
|
|
|
|
2015-09-07 08:23:46 +01:00
|
|
|
Construct a UART object on the given bus. ``bus`` can be 0 or 1.
|
2015-09-11 13:57:48 +01:00
|
|
|
If the bus is not given, the default one will be selected (0) or the selection
|
|
|
|
will be made based on the given pins.
|
2014-10-31 01:37:19 +00:00
|
|
|
|
|
|
|
Methods
|
|
|
|
-------
|
|
|
|
|
2015-06-10 22:29:56 +01:00
|
|
|
.. only:: port_pyboard
|
|
|
|
|
|
|
|
.. method:: uart.init(baudrate, bits=8, parity=None, stop=1, \*, timeout=1000, flow=None, timeout_char=0, read_buf_len=64)
|
|
|
|
|
|
|
|
Initialise the UART bus with the given parameters:
|
|
|
|
|
|
|
|
- ``baudrate`` is the clock rate.
|
|
|
|
- ``bits`` is the number of bits per character, 7, 8 or 9.
|
|
|
|
- ``parity`` is the parity, ``None``, 0 (even) or 1 (odd).
|
|
|
|
- ``stop`` is the number of stop bits, 1 or 2.
|
|
|
|
- ``flow`` sets the flow control type. Can be None, ``UART.RTS``, ``UART.CTS``
|
|
|
|
or ``UART.RTS | UART.CTS``.
|
|
|
|
- ``timeout`` is the timeout in milliseconds to wait for the first character.
|
|
|
|
- ``timeout_char`` is the timeout in milliseconds to wait between characters.
|
|
|
|
- ``read_buf_len`` is the character length of the read buffer (0 to disable).
|
|
|
|
|
|
|
|
This method will raise an exception if the baudrate could not be set within
|
|
|
|
5% of the desired value. The minimum baudrate is dictated by the frequency
|
|
|
|
of the bus that the UART is on; UART(1) and UART(6) are APB2, the rest are on
|
|
|
|
APB1. The default bus frequencies give a minimum baudrate of 1300 for
|
|
|
|
UART(1) and UART(6) and 650 for the others. Use :func:`pyb.freq <pyb.freq>`
|
|
|
|
to reduce the bus frequencies to get lower baudrates.
|
|
|
|
|
|
|
|
*Note:* with parity=None, only 8 and 9 bits are supported. With parity enabled,
|
|
|
|
only 7 and 8 bits are supported.
|
|
|
|
|
|
|
|
.. only:: port_wipy
|
|
|
|
|
2015-09-11 13:57:48 +01:00
|
|
|
.. method:: uart.init(baudrate=9600, bits=8, parity=None, stop=1, \*, pins=(TX, RX, RTS, CTS))
|
2015-06-10 22:29:56 +01:00
|
|
|
|
|
|
|
Initialise the UART bus with the given parameters:
|
|
|
|
|
|
|
|
- ``baudrate`` is the clock rate.
|
|
|
|
- ``bits`` is the number of bits per character, 7, 8 or 9.
|
2015-09-13 14:59:45 +01:00
|
|
|
- ``parity`` is the parity, ``None``, ``UART.EVEN`` or ``UART.ODD``.
|
2015-06-10 22:29:56 +01:00
|
|
|
- ``stop`` is the number of stop bits, 1 or 2.
|
2015-09-07 08:23:46 +01:00
|
|
|
- ``pins`` is a 4 or 2 item list indicating the TX, RX, RTS and CTS pins (in that order).
|
|
|
|
Any of the pins can be None if one wants the UART to operate with limited functionality.
|
|
|
|
If the RTS pin is given the the RX pin must be given as well. The same applies to CTS.
|
|
|
|
When no pins are given, then the default set of TX and RX pins is taken, and hardware
|
|
|
|
flow control will be disabled. If pins=None, no pin assignment will be made.
|
2014-10-31 20:28:10 +00:00
|
|
|
|
|
|
|
.. method:: uart.deinit()
|
|
|
|
|
|
|
|
Turn off the UART bus.
|
|
|
|
|
2015-09-07 08:23:46 +01:00
|
|
|
.. only:: port_pyboard
|
|
|
|
|
|
|
|
.. method:: uart.any()
|
|
|
|
|
|
|
|
Return ``True`` if any characters waiting, else ``False``.
|
|
|
|
|
2015-09-11 13:57:48 +01:00
|
|
|
.. method:: uart.writechar(char)
|
|
|
|
|
|
|
|
Write a single character on the bus. ``char`` is an integer to write.
|
|
|
|
Return value: ``None``.
|
|
|
|
|
2015-09-07 08:23:46 +01:00
|
|
|
.. only:: port_wipy
|
|
|
|
|
|
|
|
.. method:: uart.any()
|
2014-10-31 20:28:10 +00:00
|
|
|
|
2015-09-07 08:23:46 +01:00
|
|
|
Return the number of characters available for reading.
|
2014-10-31 20:28:10 +00:00
|
|
|
|
2014-10-31 01:37:19 +00:00
|
|
|
.. method:: uart.read([nbytes])
|
|
|
|
|
2014-10-31 20:28:10 +00:00
|
|
|
Read characters. If ``nbytes`` is specified then read at most that many bytes.
|
|
|
|
|
2015-06-10 22:29:56 +01:00
|
|
|
.. only:: port_pyboard
|
2014-10-31 22:21:37 +00:00
|
|
|
|
2015-06-10 22:29:56 +01:00
|
|
|
*Note:* for 9 bit characters each character takes two bytes, ``nbytes`` must
|
|
|
|
be even, and the number of characters is ``nbytes/2``.
|
|
|
|
|
|
|
|
Return value: a bytes object containing the bytes read in. Returns ``b''``
|
|
|
|
on timeout.
|
|
|
|
|
|
|
|
.. only:: port_wipy
|
2015-09-07 08:23:46 +01:00
|
|
|
|
2015-06-10 22:29:56 +01:00
|
|
|
Return value: a bytes object containing the bytes read in. Returns ``b''``
|
|
|
|
on timeout.
|
2014-10-31 01:37:19 +00:00
|
|
|
|
|
|
|
.. method:: uart.readall()
|
|
|
|
|
2014-10-31 20:28:10 +00:00
|
|
|
Read as much data as possible.
|
2014-10-31 01:37:19 +00:00
|
|
|
|
2014-10-31 22:21:37 +00:00
|
|
|
Return value: a bytes object.
|
|
|
|
|
2014-10-31 01:37:19 +00:00
|
|
|
.. method:: uart.readchar()
|
|
|
|
|
|
|
|
Receive a single character on the bus.
|
2014-10-31 20:28:10 +00:00
|
|
|
|
2014-10-31 01:37:19 +00:00
|
|
|
Return value: The character read, as an integer. Returns -1 on timeout.
|
|
|
|
|
|
|
|
.. method:: uart.readinto(buf[, nbytes])
|
|
|
|
|
2014-10-31 22:21:37 +00:00
|
|
|
Read bytes into the ``buf``. If ``nbytes`` is specified then read at most
|
|
|
|
that many bytes. Otherwise, read at most ``len(buf)`` bytes.
|
|
|
|
|
|
|
|
Return value: number of bytes read and stored into ``buf``.
|
2014-10-31 01:37:19 +00:00
|
|
|
|
|
|
|
.. method:: uart.readline()
|
|
|
|
|
2014-10-31 22:21:37 +00:00
|
|
|
Read a line, ending in a newline character.
|
|
|
|
|
|
|
|
Return value: the line read.
|
2014-10-31 01:37:19 +00:00
|
|
|
|
|
|
|
.. method:: uart.write(buf)
|
|
|
|
|
2015-06-10 22:29:56 +01:00
|
|
|
.. only:: port_pyboard
|
|
|
|
|
|
|
|
Write the buffer of bytes to the bus. If characters are 7 or 8 bits wide
|
|
|
|
then each byte is one character. If characters are 9 bits wide then two
|
|
|
|
bytes are used for each character (little endian), and ``buf`` must contain
|
|
|
|
an even number of bytes.
|
2014-10-31 22:21:37 +00:00
|
|
|
|
2015-06-10 22:29:56 +01:00
|
|
|
Return value: number of bytes written.
|
|
|
|
|
|
|
|
.. only:: port_wipy
|
|
|
|
|
|
|
|
Write the buffer of bytes to the bus.
|
|
|
|
|
|
|
|
Return value: number of bytes written.
|
2014-10-31 01:37:19 +00:00
|
|
|
|
2015-02-13 19:04:24 +00:00
|
|
|
.. method:: uart.sendbreak()
|
|
|
|
|
|
|
|
Send a break condition on the bus. This drives the bus low for a duration
|
|
|
|
of 13 bits.
|
|
|
|
Return value: ``None``.
|
2015-06-10 22:29:56 +01:00
|
|
|
|
|
|
|
.. only:: port_wipy
|
|
|
|
|
|
|
|
.. method:: uart.callback(value, priority=1, handler=None)
|
|
|
|
|
|
|
|
Create a callback to be triggered when data is received on the UART.
|
|
|
|
|
|
|
|
- ``value`` sets the size in bytes of the Rx buffer. Every character
|
|
|
|
received is put into this buffer as long as there's space free.
|
|
|
|
- ``priority`` level of the interrupt. Can take values in the range 1-7.
|
|
|
|
Higher values represent higher priorities.
|
|
|
|
- ``handler`` an optional function to be called when new characters arrive.
|
|
|
|
|
|
|
|
.. note::
|
|
|
|
|
|
|
|
The handler will be called whenever any of the following two conditions are met:
|
|
|
|
|
|
|
|
- 4 new characters have been received.
|
|
|
|
- At least 1 new character is waiting in the Rx buffer and the Rx line has been
|
|
|
|
silent for the duration of 1 complete frame.
|
|
|
|
|
|
|
|
This means that when the handler function is called there might be 1, 2, 3 or 4
|
|
|
|
characters waiting.
|
|
|
|
|
|
|
|
Return a callback object.
|
|
|
|
|
|
|
|
Constants
|
|
|
|
---------
|
|
|
|
|
2015-09-07 08:23:46 +01:00
|
|
|
.. only:: port_pyboard
|
|
|
|
|
|
|
|
.. data:: UART.RTS
|
|
|
|
.. data:: UART.CTS
|
|
|
|
|
|
|
|
to select the flow control type
|
|
|
|
|
|
|
|
.. only:: port_wipy
|
|
|
|
|
|
|
|
.. data:: UART.RX_ANY
|
|
|
|
|
|
|
|
IRQ trigger sources
|