nuttx/Documentation/applications/system/spi/index.rst
2024-08-15 13:36:50 +08:00

250 lines
7.8 KiB
ReStructuredText
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

================
``spi`` SPI Tool
================
The SPI Tool provides a way to debug SPI related problems. This README file will
provide usage information for the SPI tools.
Contents
--------
- System Requirements
* SPI Driver
* Configuration Options
- Help
- Common Line Form
- Common Command Options
* "Sticky" Options
* Environment variables
* Common Option Summary
- Command summary
* ``bus``
* ``dev``
* ``get``
* ``set``
* ``verf``
- SPI Build Configuration
* NuttX Configuration Requirements
* SPI Tool Configuration Options
System Requirements
-------------------
The SPI tool is designed to be implemented as a NuttShell (NSH) add-on. Read the
``apps/nshlib/README.md`` file for information about add-ons.
Configuration Options
~~~~~~~~~~~~~~~~~~~~~
- ``CONFIG_NSH_BUILTIN_APPS`` Build the tools as an NSH built-in command.
- ``CONFIG_SPITOOL_MINBUS`` Smallest bus index supported by the hardware
(default ``0``).
- ``CONFIG_SPITOOL_MAXBUS`` Largest bus index supported by the hardware
(default ``3``).
- ``CONFIG_SPITOOL_DEFFREQ`` Default frequency (default: ``40000000``).
- ``CONFIG_SPITOOL_DEFMODE`` Default mode, where::
0 = CPOL=0, CPHA=0
1 = CPOL=0, CPHA=1
2 = CPOL=1, CPHA=0
3 = CPOL=1, CPHA=1
- ``CONFIG_SPITOOL_DEFWIDTH`` Default bit width (default ``8``).
- ``CONFIG_SPITOOL_DEFWORDS`` Default number of words to exchange (default ``1``).
Help
----
The SPI tools supports some help output. That help output can be view by
entering either::
nsh> spi help
or::
nsh> spi ?
Here is an example of the help output. It shows the general form of the command
line, the various SPI commands supported with their unique command line options,
and a more detailed summary of the command SPI command options::
nsh> Usage: spi <cmd> [arguments]
Where <cmd> is one of:
Show help : ?
List buses : bus
SPI Exchange : exch [OPTIONS] [<hex senddata>]
Show help : help
Where common _sticky_ OPTIONS include:
[-b bus] is the SPI bus number (decimal). Default: 0 Current: 2
[-f freq] SPI frequency. Default: 4000000 Current: 4000000
[-m mode] Mode for transfer. Default: 0 Current: 0
[-u udelay] Delay after transfer in uS. Default: 0 Current: 0
[-w width] Width of bus. Default: 8 Current: 8
[-x count] Words to exchange. Default: 1 Current: 4
**Notes**:
- An environment variable like $PATH may be used for any argument.
- Arguments are _sticky_. For example, once the SPI bus is specified, that
bus will be re-used until it is changed.
**Warning**:
- The SPI commands may have bad side effects on your SPI devices. Use only at
your own risk.
Command Line Form
-----------------
The SPI is started from NSH by invoking the ``spi`` command from the NSH command
line. The general form of the ``spi`` command is::
spi <cmd> [arguments]
Where ``<cmd>`` is a "sub-command" and identifies one SPI operation supported by
the tool. ``[arguments]`` represents the list of arguments needed to perform the
SPI operation. Those arguments vary from command to command as described below.
However, there is also a core set of common ``OPTIONS`` supported by all commands.
So perhaps a better representation of the general SPI command would be::
spi <cmd> [OPTIONS] [arguments]
Where ``[OPTIONS]`` represents the common options and and arguments represent the
operation-specific arguments.
Common Command Options
-----------------------
"Sticky" Options
~~~~~~~~~~~~~~~~
In order to interact with SPI devices, there are a number of SPI parameters that
must be set correctly. One way to do this would be to provide to set the value
of each separate command for each SPI parameter. The SPI tool takes a different
approach, instead: The SPI configuration can be specified as a (potentially
long) sequence of command line arguments.
These arguments, however, are _sticky_. They are sticky in the sense that once
you set the SPI parameter, that value will remain until it is reset with a new
value (or until you reset the board).
Environment Variables
~~~~~~~~~~~~~~~~~~~~~
**Note** also that if environment variables are not disabled (by
``CONFIG_DISABLE_ENVIRON=y``), then these options may also be environment
variables. Environment variables must be preceded with the special character
``$``. For example, ``PWD`` is the variable that holds the current working directory
and so ``$PWD`` could be used as a command line argument. The use of environment
variables on the SPI tools command is really only useful if you wish to write
NSH scripts to execute a longer, more complex series of SPI commands.
Common Option Summary
~~~~~~~~~~~~~~~~~~~~~
- ``[-b bus]`` is the SPI bus number (decimal). Default: ``0``
Which SPI bus to commiuncate on. The bus must have been initialised as a
character device in the config in the form ``/dev/spiX`` (e.g. ``/dev/spi2``).
The valid range of bus numbers is controlled by the configuration settings
``CONFIG_SPITOOL_MINBUS`` and ``CONFIG_SPITOOL_MAXBUS``.
The bus numbers are small, decimal numbers.
- ``[-m mode]`` SPI Mode for transfer.
Which of the available SPI modes is to be used. Options are::
0 = CPOL=0, CPHA=0
1 = CPOL=0, CPHA=1
2 = CPOL=1, CPHA=0
3 = CPOL=1, CPHA=1
- ``[-u udelay]`` Delay after transfer in uS. Default: ``0``
Any extra delay to be provided after the transfer. Not normally needed from
the command line.
- ``[-x count]`` Words to exchange Default: ``1``
The number of words to be transited over the bus. For sanitys sake this is
limited to a relatively small number (``40`` by default). Any data on the
command line is sent first, padded by ``0xFF``'s while any remaining data are
received.
- ``[-w width]`` is the data width (varies according to target). Default: ``8``
Various SPI devices support different data widths. This option is untested.
- ``[-f freq]`` SPI frequency. Default: ``4000000`` Current: ``4000000``
The ``[-f freq]`` sets the frequency of the SPI device. The default is very
conservative.
Command Summary
---------------
List buses: ``bus [OPTIONS]``
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
This command will simply list all of the configured SPI buses and indicate which
are supported by the driver and which are not::
BUS EXISTS?
Bus 1: YES
Bus 2: NO
The valid range of bus numbers is controlled by the configuration settings
``CONFIG_SPITOOL_MINBUS`` and ``CONFIG_SPITOOL_MAXBUS``.
Exchange data: ``exch [OPTIONS] <Optional TX Data>``
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
This command triggers an SPI transfer, returning the data back from the far end.
As an example you can exchange (send and receive) 4 bytes (-x 4) on SPI2 (-b 2) using the command below with the ``loopback`` approach.
This approach requires that you connect the MOSI pin directly to the MISO pin (NOTE: SCLK and CS are not directly involved, but you still can see the clock and chip select waveforms if you decide to use an oscilloscope or more properly a logic analyzer to analyze these pins)::
nsh> spi exch -b 2 -x 4 aabbccdd
Received: AA BB CC DD
Note that the ``TX Data`` are always specified in hex, and are always two digits
each, case insensitive.
SPI Build Configuration
-----------------------
NuttX Configuration Requirements
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
The SPI tools requires the following in your NuttX configuration:
1. Application configuration.
Using ``make menuconfig``, select the SPI tool. The following definition should
appear in your ``.config`` file::
CONFIG_SYSTEM_SPI=y
2. Device-specific SPI driver support must be enabled::
CONFIG_SPI_DRIVER=y
The SPI tool will then use the SPI character driver to access the SPI bus.
These devices will reside at ``/dev/spiN`` where ``N`` is the SPI bus number.
**Note**: The SPI driver ``ioctl`` interface is defined in
``include/nuttx/spi/spi.h``.