-
Notifications
You must be signed in to change notification settings - Fork 6.5k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
doc: hardware: peripherals: eeprom: reorganize and add EEPROM shell page
Reorganize the EEPROM periheral documentation to make room for subpages with additional details. Add a page describing the EEPROM shell module. Signed-off-by: Henrik Brix Andersen <[email protected]>
- Loading branch information
1 parent
0d0c5af
commit ff99ec8
Showing
6 changed files
with
112 additions
and
7 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
7 changes: 2 additions & 5 deletions
7
doc/hardware/peripherals/eeprom.rst → doc/hardware/peripherals/eeprom/api.rst
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
.. _eeprom: | ||
|
||
Electrically Erasable Programmable Read-Only Memory (EEPROM) | ||
############################################################ | ||
|
||
Overview | ||
******** | ||
|
||
EEPROMs have an erase block size of 1 byte, a long lifetime, and allow | ||
overwriting data on byte-by-byte access. | ||
|
||
.. toctree:: | ||
:maxdepth: 2 | ||
|
||
api.rst | ||
shell.rst |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,91 @@ | ||
.. _eeprom_shell: | ||
|
||
EEPROM Shell | ||
############ | ||
|
||
.. contents:: | ||
:local: | ||
:depth: 1 | ||
|
||
Overview | ||
******** | ||
|
||
The EEPROM shell provides an ``eeprom`` command with a set of subcommands for the :ref:`shell | ||
<shell_api>` module. It allows testing and exploring the :ref:`EEPROM <eeprom_api>` driver API | ||
through an interactive interface without having to write a dedicated application. The EEPROM shell | ||
can also be enabled in existing applications to aid in interactive debugging of EEPROM issues. | ||
|
||
In order to enable the EEPROM shell, the following :ref:`Kconfig <kconfig>` options must be enabled: | ||
|
||
* :kconfig:option:`CONFIG_SHELL` | ||
* :kconfig:option:`CONFIG_EEPROM` | ||
* :kconfig:option:`CONFIG_EEPROM_SHELL` | ||
|
||
For example, building the :ref:`hello_world` sample for the :ref:`native_sim` with the EEPROM shell: | ||
|
||
.. zephyr-app-commands:: | ||
:zephyr-app: samples/hello_world | ||
:board: native_sim | ||
:gen-args: -DCONFIG_SHELL=y -DCONFIG_EEPROM=y -DCONFIG_EEPROM_SHELL=y | ||
:goals: build | ||
|
||
See the :ref:`shell <shell_api>` documentation for general instructions on how to connect and | ||
interact with the shell. The EEPROM shell comes with built-in help (unless | ||
:kconfig:option:`CONFIG_SHELL_HELP` is disabled). The built-in help messages can be printed by | ||
passing ``-h`` or ``--help`` to the ``eeprom`` command or any of its subcommands. All subcommands | ||
also support tab-completion of their arguments. | ||
|
||
.. tip:: | ||
All of the EEPROM shell subcommands take the name of an EEPROM peripheral as their first argument, | ||
which also supports tab-completion. A list of all devices available can be obtained using the | ||
``device list`` shell command when :kconfig:option:`CONFIG_DEVICE_SHELL` is enabled. The examples | ||
below all use the device name ``eeprom@0``. | ||
|
||
EEPROM Size | ||
*********** | ||
|
||
The size of an EEPROM can be inspected using the ``eeprom size`` subcommand as shown below: | ||
|
||
.. code-block:: console | ||
uart:~$ eeprom size eeprom@0 | ||
32768 bytes | ||
Writing Data | ||
************ | ||
|
||
Data can be written to an EEPROM using the ``eeprom write`` subcommand. This subcommand takes at | ||
least three arguments; the EEPROM device name, the offset to start writing to, and at least one data | ||
byte. In the following example, the hexadecimal sequence of bytes ``0x0d 0x0e 0x0a 0x0d 0x0b 0x0e | ||
0x0e 0x0f`` is written to offset ``0x0``: | ||
|
||
.. code-block:: console | ||
uart:~$ eeprom write eeprom@0 0x0 0x0d 0x0e 0x0a 0x0d 0x0b 0x0e 0x0e 0x0f | ||
Writing 8 bytes to EEPROM... | ||
Verifying... | ||
Verify OK | ||
It is also possible to fill a portion of the EEPROM with the same pattern using the ``eeprom fill`` | ||
subcommand. In the following example, the pattern ``0xaa`` is written to 16 bytes starting at offset | ||
``0x8``: | ||
|
||
.. code-block:: console | ||
uart:~$ eeprom fill eeprom@0 0x8 16 0xaa | ||
Writing 16 bytes of 0xaa to EEPROM... | ||
Verifying... | ||
Verify OK | ||
Reading Data | ||
************ | ||
|
||
Data can be read from an EEPROM using the ``eeprom read`` subcommand. This subcommand takes three | ||
arguments; the EEPROM device name, the offset to start reading from, and the number of bytes to | ||
read: | ||
|
||
.. code-block:: console | ||
uart:~$ eeprom read eeprom@0 0x0 8 | ||
Reading 8 bytes from EEPROM, offset 0... | ||
00000000: 0d 0e 0a 0d 0b 0e 0e 0f |........ | |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters