mirror of
https://github.com/apache/nuttx.git
synced 2025-01-13 10:58:49 +08:00
documentation: work on quickstart, add tabs sphinx extension
This commit is contained in:
parent
c1878406b5
commit
94e1a9247c
9 changed files with 362 additions and 216 deletions
|
@ -9,6 +9,7 @@ verify_ssl = true
|
||||||
m2r2 = "*"
|
m2r2 = "*"
|
||||||
sphinx_rtd_theme = "*"
|
sphinx_rtd_theme = "*"
|
||||||
Sphinx = "*"
|
Sphinx = "*"
|
||||||
|
sphinx-tabs = "*"
|
||||||
|
|
||||||
[requires]
|
[requires]
|
||||||
python_version = "3"
|
python_version = "3"
|
||||||
|
|
28
Documentation/Pipfile.lock
generated
28
Documentation/Pipfile.lock
generated
|
@ -1,7 +1,7 @@
|
||||||
{
|
{
|
||||||
"_meta": {
|
"_meta": {
|
||||||
"hash": {
|
"hash": {
|
||||||
"sha256": "0f506aecc0f6e03287fd75ac128cf2d561b32ce607fd0559eab0a95641181d8c"
|
"sha256": "947fcd26ed23c573b22e756acb18187f74ed08821f8274f42643d782d9f6636c"
|
||||||
},
|
},
|
||||||
"pipfile-spec": 6,
|
"pipfile-spec": 6,
|
||||||
"requires": {
|
"requires": {
|
||||||
|
@ -28,6 +28,7 @@
|
||||||
"sha256:1aac2ae2d0d8ea368fa90906567f5c08463d98ade155c0c4bfedd6a0f7160e38",
|
"sha256:1aac2ae2d0d8ea368fa90906567f5c08463d98ade155c0c4bfedd6a0f7160e38",
|
||||||
"sha256:d670ea0b10f8b723672d3a6abeb87b565b244da220d76b4dba1b66269ec152d4"
|
"sha256:d670ea0b10f8b723672d3a6abeb87b565b244da220d76b4dba1b66269ec152d4"
|
||||||
],
|
],
|
||||||
|
"markers": "python_version >= '2.7' and python_version not in '3.0, 3.1, 3.2, 3.3'",
|
||||||
"version": "==2.8.0"
|
"version": "==2.8.0"
|
||||||
},
|
},
|
||||||
"certifi": {
|
"certifi": {
|
||||||
|
@ -49,6 +50,7 @@
|
||||||
"sha256:0c5b78adfbf7762415433f5515cd5c9e762339e23369dbe8000d84a4bf4ab3af",
|
"sha256:0c5b78adfbf7762415433f5515cd5c9e762339e23369dbe8000d84a4bf4ab3af",
|
||||||
"sha256:c2de3a60e9e7d07be26b7f2b00ca0309c207e06c100f9cc2a94931fc75a478fc"
|
"sha256:c2de3a60e9e7d07be26b7f2b00ca0309c207e06c100f9cc2a94931fc75a478fc"
|
||||||
],
|
],
|
||||||
|
"markers": "python_version >= '2.7' and python_version not in '3.0, 3.1, 3.2, 3.3, 3.4'",
|
||||||
"version": "==0.16"
|
"version": "==0.16"
|
||||||
},
|
},
|
||||||
"idna": {
|
"idna": {
|
||||||
|
@ -56,6 +58,7 @@
|
||||||
"sha256:b307872f855b18632ce0c21c5e45be78c0ea7ae4c15c828c20788b26921eb3f6",
|
"sha256:b307872f855b18632ce0c21c5e45be78c0ea7ae4c15c828c20788b26921eb3f6",
|
||||||
"sha256:b97d804b1e9b523befed77c48dacec60e6dcb0b5391d57af6a65a312a90648c0"
|
"sha256:b97d804b1e9b523befed77c48dacec60e6dcb0b5391d57af6a65a312a90648c0"
|
||||||
],
|
],
|
||||||
|
"markers": "python_version >= '2.7' and python_version not in '3.0, 3.1, 3.2, 3.3'",
|
||||||
"version": "==2.10"
|
"version": "==2.10"
|
||||||
},
|
},
|
||||||
"imagesize": {
|
"imagesize": {
|
||||||
|
@ -63,6 +66,7 @@
|
||||||
"sha256:6965f19a6a2039c7d48bca7dba2473069ff854c36ae6f19d2cde309d998228a1",
|
"sha256:6965f19a6a2039c7d48bca7dba2473069ff854c36ae6f19d2cde309d998228a1",
|
||||||
"sha256:b1f6b5a4eab1f73479a50fb79fcf729514a900c341d8503d62a62dbc4127a2b1"
|
"sha256:b1f6b5a4eab1f73479a50fb79fcf729514a900c341d8503d62a62dbc4127a2b1"
|
||||||
],
|
],
|
||||||
|
"markers": "python_version >= '2.7' and python_version not in '3.0, 3.1, 3.2, 3.3'",
|
||||||
"version": "==1.2.0"
|
"version": "==1.2.0"
|
||||||
},
|
},
|
||||||
"jinja2": {
|
"jinja2": {
|
||||||
|
@ -70,6 +74,7 @@
|
||||||
"sha256:89aab215427ef59c34ad58735269eb58b1a5808103067f7bb9d5836c651b3bb0",
|
"sha256:89aab215427ef59c34ad58735269eb58b1a5808103067f7bb9d5836c651b3bb0",
|
||||||
"sha256:f0a4641d3cf955324a89c04f3d94663aa4d638abe8f733ecd3582848e1c37035"
|
"sha256:f0a4641d3cf955324a89c04f3d94663aa4d638abe8f733ecd3582848e1c37035"
|
||||||
],
|
],
|
||||||
|
"markers": "python_version >= '2.7' and python_version not in '3.0, 3.1, 3.2, 3.3, 3.4'",
|
||||||
"version": "==2.11.2"
|
"version": "==2.11.2"
|
||||||
},
|
},
|
||||||
"m2r2": {
|
"m2r2": {
|
||||||
|
@ -116,6 +121,7 @@
|
||||||
"sha256:e249096428b3ae81b08327a63a485ad0878de3fb939049038579ac0ef61e17e7",
|
"sha256:e249096428b3ae81b08327a63a485ad0878de3fb939049038579ac0ef61e17e7",
|
||||||
"sha256:e8313f01ba26fbbe36c7be1966a7b7424942f670f38e666995b88d012765b9be"
|
"sha256:e8313f01ba26fbbe36c7be1966a7b7424942f670f38e666995b88d012765b9be"
|
||||||
],
|
],
|
||||||
|
"markers": "python_version >= '2.7' and python_version not in '3.0, 3.1, 3.2, 3.3'",
|
||||||
"version": "==1.1.1"
|
"version": "==1.1.1"
|
||||||
},
|
},
|
||||||
"mistune": {
|
"mistune": {
|
||||||
|
@ -130,6 +136,7 @@
|
||||||
"sha256:4357f74f47b9c12db93624a82154e9b120fa8293699949152b22065d556079f8",
|
"sha256:4357f74f47b9c12db93624a82154e9b120fa8293699949152b22065d556079f8",
|
||||||
"sha256:998416ba6962ae7fbd6596850b80e17859a5753ba17c32284f67bfff33784181"
|
"sha256:998416ba6962ae7fbd6596850b80e17859a5753ba17c32284f67bfff33784181"
|
||||||
],
|
],
|
||||||
|
"markers": "python_version >= '2.7' and python_version not in '3.0, 3.1, 3.2, 3.3'",
|
||||||
"version": "==20.4"
|
"version": "==20.4"
|
||||||
},
|
},
|
||||||
"pygments": {
|
"pygments": {
|
||||||
|
@ -137,6 +144,7 @@
|
||||||
"sha256:647344a061c249a3b74e230c739f434d7ea4d8b1d5f3721bc0f3558049b38f44",
|
"sha256:647344a061c249a3b74e230c739f434d7ea4d8b1d5f3721bc0f3558049b38f44",
|
||||||
"sha256:ff7a40b4860b727ab48fad6360eb351cc1b33cbf9b15a0f689ca5353e9463324"
|
"sha256:ff7a40b4860b727ab48fad6360eb351cc1b33cbf9b15a0f689ca5353e9463324"
|
||||||
],
|
],
|
||||||
|
"markers": "python_version >= '3.5'",
|
||||||
"version": "==2.6.1"
|
"version": "==2.6.1"
|
||||||
},
|
},
|
||||||
"pyparsing": {
|
"pyparsing": {
|
||||||
|
@ -144,6 +152,7 @@
|
||||||
"sha256:c203ec8783bf771a155b207279b9bccb8dea02d8f0c9e5f8ead507bc3246ecc1",
|
"sha256:c203ec8783bf771a155b207279b9bccb8dea02d8f0c9e5f8ead507bc3246ecc1",
|
||||||
"sha256:ef9d7589ef3c200abe66653d3f1ab1033c3c419ae9b9bdb1240a85b024efc88b"
|
"sha256:ef9d7589ef3c200abe66653d3f1ab1033c3c419ae9b9bdb1240a85b024efc88b"
|
||||||
],
|
],
|
||||||
|
"markers": "python_version >= '2.6' and python_version not in '3.0, 3.1, 3.2, 3.3'",
|
||||||
"version": "==2.4.7"
|
"version": "==2.4.7"
|
||||||
},
|
},
|
||||||
"pytz": {
|
"pytz": {
|
||||||
|
@ -158,6 +167,7 @@
|
||||||
"sha256:b3559a131db72c33ee969480840fff4bb6dd111de7dd27c8ee1f820f4f00231b",
|
"sha256:b3559a131db72c33ee969480840fff4bb6dd111de7dd27c8ee1f820f4f00231b",
|
||||||
"sha256:fe75cc94a9443b9246fc7049224f75604b113c36acb93f87b80ed42c44cbb898"
|
"sha256:fe75cc94a9443b9246fc7049224f75604b113c36acb93f87b80ed42c44cbb898"
|
||||||
],
|
],
|
||||||
|
"markers": "python_version >= '2.7' and python_version not in '3.0, 3.1, 3.2, 3.3, 3.4'",
|
||||||
"version": "==2.24.0"
|
"version": "==2.24.0"
|
||||||
},
|
},
|
||||||
"six": {
|
"six": {
|
||||||
|
@ -165,6 +175,7 @@
|
||||||
"sha256:30639c035cdb23534cd4aa2dd52c3bf48f06e5f4a941509c8bafd8ce11080259",
|
"sha256:30639c035cdb23534cd4aa2dd52c3bf48f06e5f4a941509c8bafd8ce11080259",
|
||||||
"sha256:8b74bedcbbbaca38ff6d7491d76f2b06b3592611af620f8426e82dddb04a5ced"
|
"sha256:8b74bedcbbbaca38ff6d7491d76f2b06b3592611af620f8426e82dddb04a5ced"
|
||||||
],
|
],
|
||||||
|
"markers": "python_version >= '2.7' and python_version not in '3.0, 3.1, 3.2, 3.3'",
|
||||||
"version": "==1.15.0"
|
"version": "==1.15.0"
|
||||||
},
|
},
|
||||||
"snowballstemmer": {
|
"snowballstemmer": {
|
||||||
|
@ -190,11 +201,20 @@
|
||||||
"index": "pypi",
|
"index": "pypi",
|
||||||
"version": "==0.5.0"
|
"version": "==0.5.0"
|
||||||
},
|
},
|
||||||
|
"sphinx-tabs": {
|
||||||
|
"hashes": [
|
||||||
|
"sha256:537857f91f1b371f7b45eb8ac83001618b3e3178c78df073d2cc4558a8e66ef5",
|
||||||
|
"sha256:54132c8a57aa19bba6e17fe26eb94ea9df531708ff3f509b119313b32d0d5aff"
|
||||||
|
],
|
||||||
|
"index": "pypi",
|
||||||
|
"version": "==1.3.0"
|
||||||
|
},
|
||||||
"sphinxcontrib-applehelp": {
|
"sphinxcontrib-applehelp": {
|
||||||
"hashes": [
|
"hashes": [
|
||||||
"sha256:806111e5e962be97c29ec4c1e7fe277bfd19e9652fb1a4392105b43e01af885a",
|
"sha256:806111e5e962be97c29ec4c1e7fe277bfd19e9652fb1a4392105b43e01af885a",
|
||||||
"sha256:a072735ec80e7675e3f432fcae8610ecf509c5f1869d17e2eecff44389cdbc58"
|
"sha256:a072735ec80e7675e3f432fcae8610ecf509c5f1869d17e2eecff44389cdbc58"
|
||||||
],
|
],
|
||||||
|
"markers": "python_version >= '3.5'",
|
||||||
"version": "==1.0.2"
|
"version": "==1.0.2"
|
||||||
},
|
},
|
||||||
"sphinxcontrib-devhelp": {
|
"sphinxcontrib-devhelp": {
|
||||||
|
@ -202,6 +222,7 @@
|
||||||
"sha256:8165223f9a335cc1af7ffe1ed31d2871f325254c0423bc0c4c7cd1c1e4734a2e",
|
"sha256:8165223f9a335cc1af7ffe1ed31d2871f325254c0423bc0c4c7cd1c1e4734a2e",
|
||||||
"sha256:ff7f1afa7b9642e7060379360a67e9c41e8f3121f2ce9164266f61b9f4b338e4"
|
"sha256:ff7f1afa7b9642e7060379360a67e9c41e8f3121f2ce9164266f61b9f4b338e4"
|
||||||
],
|
],
|
||||||
|
"markers": "python_version >= '3.5'",
|
||||||
"version": "==1.0.2"
|
"version": "==1.0.2"
|
||||||
},
|
},
|
||||||
"sphinxcontrib-htmlhelp": {
|
"sphinxcontrib-htmlhelp": {
|
||||||
|
@ -209,6 +230,7 @@
|
||||||
"sha256:3c0bc24a2c41e340ac37c85ced6dafc879ab485c095b1d65d2461ac2f7cca86f",
|
"sha256:3c0bc24a2c41e340ac37c85ced6dafc879ab485c095b1d65d2461ac2f7cca86f",
|
||||||
"sha256:e8f5bb7e31b2dbb25b9cc435c8ab7a79787ebf7f906155729338f3156d93659b"
|
"sha256:e8f5bb7e31b2dbb25b9cc435c8ab7a79787ebf7f906155729338f3156d93659b"
|
||||||
],
|
],
|
||||||
|
"markers": "python_version >= '3.5'",
|
||||||
"version": "==1.0.3"
|
"version": "==1.0.3"
|
||||||
},
|
},
|
||||||
"sphinxcontrib-jsmath": {
|
"sphinxcontrib-jsmath": {
|
||||||
|
@ -216,6 +238,7 @@
|
||||||
"sha256:2ec2eaebfb78f3f2078e73666b1415417a116cc848b72e5172e596c871103178",
|
"sha256:2ec2eaebfb78f3f2078e73666b1415417a116cc848b72e5172e596c871103178",
|
||||||
"sha256:a9925e4a4587247ed2191a22df5f6970656cb8ca2bd6284309578f2153e0c4b8"
|
"sha256:a9925e4a4587247ed2191a22df5f6970656cb8ca2bd6284309578f2153e0c4b8"
|
||||||
],
|
],
|
||||||
|
"markers": "python_version >= '3.5'",
|
||||||
"version": "==1.0.1"
|
"version": "==1.0.1"
|
||||||
},
|
},
|
||||||
"sphinxcontrib-qthelp": {
|
"sphinxcontrib-qthelp": {
|
||||||
|
@ -223,6 +246,7 @@
|
||||||
"sha256:4c33767ee058b70dba89a6fc5c1892c0d57a54be67ddd3e7875a18d14cba5a72",
|
"sha256:4c33767ee058b70dba89a6fc5c1892c0d57a54be67ddd3e7875a18d14cba5a72",
|
||||||
"sha256:bd9fc24bcb748a8d51fd4ecaade681350aa63009a347a8c14e637895444dfab6"
|
"sha256:bd9fc24bcb748a8d51fd4ecaade681350aa63009a347a8c14e637895444dfab6"
|
||||||
],
|
],
|
||||||
|
"markers": "python_version >= '3.5'",
|
||||||
"version": "==1.0.3"
|
"version": "==1.0.3"
|
||||||
},
|
},
|
||||||
"sphinxcontrib-serializinghtml": {
|
"sphinxcontrib-serializinghtml": {
|
||||||
|
@ -230,6 +254,7 @@
|
||||||
"sha256:eaa0eccc86e982a9b939b2b82d12cc5d013385ba5eadcc7e4fed23f4405f77bc",
|
"sha256:eaa0eccc86e982a9b939b2b82d12cc5d013385ba5eadcc7e4fed23f4405f77bc",
|
||||||
"sha256:f242a81d423f59617a8e5cf16f5d4d74e28ee9a66f9e5b637a18082991db5a9a"
|
"sha256:f242a81d423f59617a8e5cf16f5d4d74e28ee9a66f9e5b637a18082991db5a9a"
|
||||||
],
|
],
|
||||||
|
"markers": "python_version >= '3.5'",
|
||||||
"version": "==1.1.4"
|
"version": "==1.1.4"
|
||||||
},
|
},
|
||||||
"urllib3": {
|
"urllib3": {
|
||||||
|
@ -237,6 +262,7 @@
|
||||||
"sha256:91056c15fa70756691db97756772bb1eb9678fa585d9184f24534b100dc60f4a",
|
"sha256:91056c15fa70756691db97756772bb1eb9678fa585d9184f24534b100dc60f4a",
|
||||||
"sha256:e7983572181f5e1522d9c98453462384ee92a0be7fac5f1413a1e35c56cc0461"
|
"sha256:e7983572181f5e1522d9c98453462384ee92a0be7fac5f1413a1e35c56cc0461"
|
||||||
],
|
],
|
||||||
|
"markers": "python_version >= '2.7' and python_version not in '3.0, 3.1, 3.2, 3.3, 3.4' and python_version < '4'",
|
||||||
"version": "==1.25.10"
|
"version": "==1.25.10"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
|
@ -58,3 +58,23 @@ table.valign-top td {
|
||||||
vertical-align: top !important;
|
vertical-align: top !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Make <kbd> elements look nice */
|
||||||
|
|
||||||
|
kbd {
|
||||||
|
margin: 0px 0.1em;
|
||||||
|
padding: 0.1em 0.6em;
|
||||||
|
border-radius: 3px;
|
||||||
|
border: 1px solid rgb(204, 204, 204);
|
||||||
|
color: rgb(51, 51, 51);
|
||||||
|
line-height: 1.4;
|
||||||
|
font-family: Arial,Helvetica,sans-serif;
|
||||||
|
font-size: 10px;
|
||||||
|
display: inline-block;
|
||||||
|
box-shadow: 0px 1px 0px rgba(0,0,0,0.2), inset 0px 0px 0px 2px #ffffff;
|
||||||
|
background-color: rgb(247, 247, 247);
|
||||||
|
-moz-box-shadow: 0 1px 0px rgba(0, 0, 0, 0.2), 0 0 0 2px #ffffff inset;
|
||||||
|
-webkit-box-shadow: 0 1px 0px rgba(0, 0, 0, 0.2), 0 0 0 2px #ffffff inset;
|
||||||
|
-moz-border-radius: 3px;
|
||||||
|
-webkit-border-radius: 3px;
|
||||||
|
text-shadow: 0 1px 0 #fff;
|
||||||
|
}
|
||||||
|
|
|
@ -53,6 +53,7 @@ extensions = [
|
||||||
"m2r2",
|
"m2r2",
|
||||||
'sphinx.ext.autosectionlabel',
|
'sphinx.ext.autosectionlabel',
|
||||||
'sphinx.ext.todo',
|
'sphinx.ext.todo',
|
||||||
|
'sphinx_tabs.tabs'
|
||||||
]
|
]
|
||||||
|
|
||||||
source_suffix = [ '.rst', '.md' ]
|
source_suffix = [ '.rst', '.md' ]
|
||||||
|
|
|
@ -145,6 +145,25 @@ In case you need to leave a TODO note in the documentation to point that somethi
|
||||||
which is available via the ``sphinx.ext.todo`` extension. This will let the reader of the documentation also know that the documentation
|
which is available via the ``sphinx.ext.todo`` extension. This will let the reader of the documentation also know that the documentation
|
||||||
is not yet finished somewhere and may further motivate a contribution.
|
is not yet finished somewhere and may further motivate a contribution.
|
||||||
|
|
||||||
|
User Indications
|
||||||
|
----------------
|
||||||
|
|
||||||
|
To indicate a keypress, menu action or GUI button selection, use the following:
|
||||||
|
|
||||||
|
.. code-block:: RST
|
||||||
|
|
||||||
|
Go into menu :menuselection:`File --> Save As`, click :guilabel:`&OK` or press :kbd:`Enter`.
|
||||||
|
|
||||||
|
which would render as:
|
||||||
|
|
||||||
|
Go into menu :menuselection:`File --> Save As`, click :guilabel:`&OK` or press :kbd:`Enter`.
|
||||||
|
|
||||||
|
Tabbed examples
|
||||||
|
---------------
|
||||||
|
|
||||||
|
To indicate different instructions/examples for different scenarios (for example, different Operating
|
||||||
|
Systems) use the `tabs <https://github.com/executablebooks/sphinx-tabs>`_ extension (see link for examples).
|
||||||
|
|
||||||
Tips
|
Tips
|
||||||
====
|
====
|
||||||
|
|
||||||
|
|
|
@ -1,57 +1,82 @@
|
||||||
.. include:: /substitutions.rst
|
.. include:: /substitutions.rst
|
||||||
.. _compiling:
|
.. _compiling:
|
||||||
|
|
||||||
|
=========
|
||||||
Compiling
|
Compiling
|
||||||
=========
|
=========
|
||||||
|
|
||||||
Now that we've installed Apache NuttX prerequisites and downloaded the source code, we are ready to compile the source code
|
Now that we've installed Apache NuttX prerequisites and downloaded the source code,
|
||||||
into an executable binary file that can be run on the embedded board.
|
we are ready to compile the source code into an executable binary file that can
|
||||||
|
be run on the embedded board.
|
||||||
|
|
||||||
#. List Possible Apache NuttX Base Configurations
|
Initialize Configuration
|
||||||
|
========================
|
||||||
|
|
||||||
Find your hardware and a good starting application in the list of base configurations. In the application list,
|
The first step is to initialize NuttX configuration for a given board, based from
|
||||||
``nsh`` is the Apache NuttX Shell, an interactive commandline that's a good starting place if you're new.
|
a pre-existing configuration. To list all supported configurations you can do:
|
||||||
|
|
||||||
.. code-block:: bash
|
.. code-block:: console
|
||||||
|
|
||||||
$ cd nuttx
|
$ cd nuttx
|
||||||
$ ./tools/configure.sh -L | less
|
$ ./tools/configure.sh -L | less
|
||||||
|
|
||||||
|
The output is in the format ``<board name>:<board configuration>``. You will see that
|
||||||
|
generally all boards support the ``nsh`` configuration which is a good sarting point
|
||||||
|
since it enables booting into the interactive command line
|
||||||
|
:doc:`/components/nsh/index`.
|
||||||
|
|
||||||
#. Initialize Configuration
|
To choose a configuration you pass the ``<board name>:<board configuration>`` option
|
||||||
|
to ``configure.sh`` and indicate your host platform, such as:
|
||||||
|
|
||||||
Pick one of the board:application base configuration pairs from the list, and feed it to the
|
.. code-block:: console
|
||||||
configuration script. The ``-l`` tells use that we're on Linux. macOS and Windows builds are
|
|
||||||
possible, this guide doesn't cover them yet.
|
|
||||||
|
|
||||||
.. code-block:: bash
|
|
||||||
|
|
||||||
$ cd nuttx
|
$ cd nuttx
|
||||||
$ # this is the basic layout of the command:
|
$ ./tools/configure.sh -l stm32f4discovery:nsh
|
||||||
$ # ./tools/configure.sh -l <board-name>:<config-dir>
|
|
||||||
$ # for example:
|
The ``-l`` tells use that we're on Linux (macOS and Windows builds are
|
||||||
$ ./tools/configure.sh -l sama5d2-xult:nsh
|
possible). Use the ``-h`` argument to see all available options.
|
||||||
|
|
||||||
#. Customize Your Configuration (Optional)
|
Customize Your Configuration (Optional)
|
||||||
|
=======================================
|
||||||
|
|
||||||
This step is optional. Right now, this is mainly to get familiar with how it works– you don't need to change
|
This step is optional. Right now, this is mainly to get familiar with how it
|
||||||
any of the options now, but knowing how to do this will come in handy later.
|
works– you don't need to change any of the options now, but knowing how
|
||||||
|
to do this will come in handy later.
|
||||||
|
|
||||||
There are a lot of options. We'll cover a few of them here. Don't worry about the complexity– you don't have to use most of the options.
|
There are a lot of options. We'll cover a few of them here.
|
||||||
|
Don't worry about the complexity– you don't have to use most of the options.
|
||||||
|
|
||||||
.. code-block:: bash
|
.. code-block:: console
|
||||||
|
|
||||||
$ make menuconfig
|
$ cd nuttx/
|
||||||
|
$ make menuconfig
|
||||||
|
|
||||||
|
.. todo::
|
||||||
|
Explain some useful options.
|
||||||
|
|
||||||
#. Compile NuttX
|
Build NuttX
|
||||||
|
===========
|
||||||
|
|
||||||
.. code-block:: bash
|
We can now build NuttX. To do so, you can simply run:
|
||||||
|
|
||||||
$ make clean; make
|
.. code-block:: console
|
||||||
|
|
||||||
#. Install the Executable Program on Your Board
|
$ cd nuttx/
|
||||||
|
$ make make
|
||||||
|
|
||||||
|
The build will complete by generating the binary outputs
|
||||||
|
inside `nuttx` directory. Typically this includes the `nuttx`
|
||||||
|
ELF file (suitable for debugging using `gdb`) and a `nuttx.bin`
|
||||||
|
file that can be flashed to the board.
|
||||||
|
|
||||||
|
To clean the build, you can do:
|
||||||
|
|
||||||
This step is a bit more complicated, depending on your board. It's covered in the section
|
.. code-block:: console
|
||||||
:ref:`Running Apache NuttX <running>`.
|
|
||||||
|
$ make clean
|
||||||
|
|
||||||
|
It is recommended that after manually modifying the configuration you first clean
|
||||||
|
before building.
|
||||||
|
|
||||||
----
|
----
|
||||||
|
|
||||||
|
|
|
@ -11,183 +11,153 @@ version, you may need to change some of the commands.
|
||||||
Prerequisites
|
Prerequisites
|
||||||
-------------
|
-------------
|
||||||
|
|
||||||
Install prerequisites for building using Linux
|
.. tabs::
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
|
|
||||||
#. Install system packages
|
.. tab:: Linux
|
||||||
|
|
||||||
|
#. Install system packages
|
||||||
|
|
||||||
.. code-block:: bash
|
.. code-block:: console
|
||||||
|
|
||||||
$ sudo apt install \
|
$ sudo apt install \
|
||||||
bison flex gettext texinfo libncurses5-dev libncursesw5-dev \
|
bison flex gettext texinfo libncurses5-dev libncursesw5-dev \
|
||||||
gperf automake libtool pkg-config build-essential gperf \
|
gperf automake libtool pkg-config build-essential gperf genromfs \
|
||||||
libgmp-dev libmpc-dev libmpfr-dev libisl-dev binutils-dev libelf-dev \
|
libgmp-dev libmpc-dev libmpfr-dev libisl-dev binutils-dev libelf-dev \
|
||||||
libexpat-dev gcc-multilib g++-multilib picocom u-boot-tools util-linux
|
libexpat-dev gcc-multilib g++-multilib picocom u-boot-tools util-linux
|
||||||
|
|
||||||
#. Give yourself access to the serial console device
|
#. Give yourself access to the serial console device
|
||||||
|
|
||||||
This is done by adding your Linux user to the ``dialout`` group:
|
This is done by adding your Linux user to the ``dialout`` group:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
$ sudo usermod -a -G dialout $USER
|
||||||
|
$ # now get a login shell that knows we're in the dialout group:
|
||||||
|
$ su - $USER
|
||||||
|
|
||||||
|
.. tab:: macOS
|
||||||
|
|
||||||
.. code-block:: console
|
.. code-block:: console
|
||||||
|
|
||||||
$ sudo usermod -a -G dialout $USER
|
$ brew tap discoteq/discoteq
|
||||||
$ # now get a login shell that knows we're in the dialout group:
|
$ brew install flock
|
||||||
$ su - $USER
|
$ brew install x86_64-elf-gcc # Used by simulator
|
||||||
|
$ brew install u-boot-tools # Some platform integrate with u-boot
|
||||||
|
|
||||||
Install prerequisites for building and using Apache NuttX (macOS)
|
.. tab:: Windows / WSL
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
|
|
||||||
.. code-block:: bash
|
If you are are building Apache NuttX on windows and using WSL follow
|
||||||
|
that installation guide for Linux. This has been verified against the
|
||||||
|
Ubunutu 18.04 version.
|
||||||
|
|
||||||
$ brew tap discoteq/discoteq
|
There may be complications interacting with
|
||||||
$ brew install flock
|
programming tools over USB. Recently support for USBIP was added to WSL 2
|
||||||
$ brew install x86_64-elf-gcc # Used by simulator
|
which has been used with the STM32 platform, but it is not trivial to configure:
|
||||||
$ brew install u-boot-tools # Some platform integrate with u-boot
|
https://github.com/rpasek/usbip-wsl2-instructions
|
||||||
|
|
||||||
Install prerequisites for building and using Apache NuttX (Windows -- WSL)
|
.. tab:: Windows/Cygwin
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
|
|
||||||
If you are are building Apache NuttX on windows and using WSL follow
|
Download and install `Cygwin <https://www.cygwin.com/>`_ using the minimal
|
||||||
that installation guide for Linux. This has been verified against the
|
installation in addition to these packages::
|
||||||
Ubunutu 18.04 version.
|
|
||||||
|
|
||||||
There may be complications interacting with
|
make bison libmpc-devel
|
||||||
programming tools over USB. Recently support for USBIP was added to WSL 2
|
gcc-core byacc automake-1.15
|
||||||
which has been used with the STM32 platform, but it is not trivial to configure:
|
gcc-g++ gperf libncurses-devel
|
||||||
https://github.com/rpasek/usbip-wsl2-instructions
|
flex gdb libmpfr-devel
|
||||||
|
git unzip zlib-devel
|
||||||
Install prerequisites for building and using Apache NuttX (Windows -- Cygwin)
|
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
To complete the installation of prerequisites, you need to install `kconfig-frontends`
|
||||||
Download and install `Cygwin <https://www.cygwin.com/>`_ using the minimal
|
as instructed in the :doc:`quickstart` guide.
|
||||||
installation in addition to these packages::
|
|
||||||
|
|
||||||
make bison libmpc-devel
|
|
||||||
gcc-core byacc automake-1.15
|
|
||||||
gcc-g++ gperf libncurses-devel
|
|
||||||
flex gdb libmpfr-devel
|
|
||||||
git unzip zlib-devel
|
|
||||||
|
|
||||||
Install Required Tools (All Platforms)
|
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
|
|
||||||
There are a collection of required tools that need to be built to build most Apache NuttX configurations:
|
|
||||||
|
|
||||||
.. code-block:: bash
|
|
||||||
|
|
||||||
$ mkdir buildtools
|
|
||||||
$ export NUTTXTOOLS=`pwd`/buildtools
|
|
||||||
$ export NUTTXTOOLS_PATH=$NUTTXTOOLS/bin:$NUTTXTOOLS/usr/bin
|
|
||||||
$ git clone https://bitbucket.org/nuttx/tools.git tools
|
|
||||||
|
|
||||||
*NOTE:* You will need to add ``NUTTXTOOLS_PATH`` to your environment ``PATH``
|
|
||||||
|
|
||||||
#. Install gperf tool
|
|
||||||
|
|
||||||
This required to build ``kconfig-frontends``.
|
|
||||||
|
|
||||||
.. code-block:: console
|
|
||||||
|
|
||||||
$ cd tools/
|
|
||||||
$ wget http://ftp.gnu.org/pub/gnu/gperf/gperf-3.1.tar.gz
|
|
||||||
$ tar zxf gperf-3.1.tar.gz
|
|
||||||
$ cd gperf-3.1
|
|
||||||
$ ./configure --prefix=$NUTTXTOOLS
|
|
||||||
$ make
|
|
||||||
$ make install
|
|
||||||
|
|
||||||
#. Install kconfig-frontends tool
|
|
||||||
|
|
||||||
This is necessary to run the ``./nuttx/tools/configure.sh`` script as well as using the ncurses-based menuconfig system.
|
|
||||||
|
|
||||||
.. code-block:: console
|
|
||||||
|
|
||||||
$ cd tools/
|
|
||||||
$ cd kconfig-frontends
|
|
||||||
$ # on MacOS do the following:
|
|
||||||
$ patch < ../kconfig-macos.diff -p 1
|
|
||||||
$ ./configure --prefix=$NUTTXTOOLS --enable-mconf --disable-shared --enable-static --disable-gconf --disable-qconf --disable-nconf
|
|
||||||
$ # on Linux do the following:
|
|
||||||
$ ./configure --prefix=$NUTTXTOOLS --enable-mconf --disable-gconf --disable-qconf
|
|
||||||
$ touch aclocal.m4 Makefile.in
|
|
||||||
$ make
|
|
||||||
$ make install
|
|
||||||
|
|
||||||
#. Install gen-romfs (optional)
|
|
||||||
|
|
||||||
|
|
||||||
This is required if you want to build ROM-based file systems.
|
|
||||||
|
|
||||||
.. code-block:: console
|
|
||||||
|
|
||||||
$ cd tools/
|
|
||||||
$ tar zxf genromfs-0.5.2.tar.gz
|
|
||||||
$ cd genromfs-0.5.2
|
|
||||||
$ make install PREFIX=$NUTTXTOOLS
|
|
||||||
|
|
||||||
Get Source Code (Stable)
|
|
||||||
------------------------
|
|
||||||
Apache NuttX releases are published on the project `Downloads <https://nuttx.apache.org/download/>`_ page and distributed
|
|
||||||
by the Apache mirrors. Be sure to download both the nuttx and apps tarballs.
|
|
||||||
|
|
||||||
|
|
||||||
Get Source Code (Development)
|
|
||||||
------------------------------
|
|
||||||
Apache NuttX is `actively developed on GitHub <https://github.com/apache/incubator-nuttx/>`_. If you want
|
|
||||||
to use it, modify it or help develop it, you'll need the source code.
|
|
||||||
|
|
||||||
You can either clone the public repositories:
|
|
||||||
|
|
||||||
.. code-block:: console
|
|
||||||
|
|
||||||
$ mkdir nuttx
|
|
||||||
$ cd nuttx
|
|
||||||
$ git clone https://github.com/apache/incubator-nuttx.git nuttx
|
|
||||||
$ git clone https://github.com/apache/incubator-nuttx-apps apps
|
|
||||||
|
|
||||||
Or, download the `tarball <https://github.com/apache/incubator-nuttx/tarball/master>`_:
|
|
||||||
|
|
||||||
.. code-block:: console
|
|
||||||
|
|
||||||
$ curl -OL https://github.com/apache/incubator-nuttx/tarball/master
|
|
||||||
$ curl -OL https://github.com/apache/incubator-nuttx-apps/tarball/master
|
|
||||||
# optionally, zipball is also available (for Windows users).
|
|
||||||
|
|
||||||
Later if we want to make modifications (for instance, to improve NuttX and save them in our own branch,
|
|
||||||
or submit them back to the project), we can do that easily using git to track our changes and submit them
|
|
||||||
upstream to the NuttX project.
|
|
||||||
|
|
||||||
Install a Cross-Compiler Toolchain
|
Install a Cross-Compiler Toolchain
|
||||||
----------------------------------
|
----------------------------------
|
||||||
|
|
||||||
With Apache NuttX, you compile the operating system and your application on your desktop or laptop computer, then install the
|
To build Apache NuttX you need the appropriate toolchain
|
||||||
binary file on your embedded computer. This guide assumes your computer is an
|
according to your target platform. Some Operating Systems
|
||||||
`ARM <https://en.wikipedia.org/wiki/ARM_architecture>`_ CPU. If it isn't, you'll need a different tool chain.
|
such as Linux distribute toolchains for various architectures.
|
||||||
|
This is usually an easy choice however you should be aware
|
||||||
|
that in some cases the version offered by your OS may have
|
||||||
|
problems and it may better to use a widely used build from
|
||||||
|
another source.
|
||||||
|
|
||||||
There are hints on how to get the latest tool chains for most supported architectures in the Apache NuttX CI helper
|
The following example shows how to install a toolchain for
|
||||||
`script <https://github.com/apache/incubator-nuttx-testing/blob/master/cibuild.sh>`_ and Docker `container <https://github.com/apache/incubator-nuttx-testing/blob/master/docker/linux/Dockerfile>`_
|
ARM architecture:
|
||||||
|
|
||||||
Download the right flavor of the
|
.. tabs::
|
||||||
`ARM Embedded GNU Toolchain <https://developer.arm.com/tools-and-software/open-source-software/developer-tools/gnu-toolchain/gnu-rm>`_
|
|
||||||
for your embedded processor's CPU.
|
|
||||||
|
|
||||||
Unpack it into ``/opt/gcc`` and add the bin directory to your path. For instance:
|
.. code-tab:: console Ubuntu (deb)
|
||||||
|
|
||||||
|
$ apt install gcc-arm-none-eabi binutils-arm-none-eabi
|
||||||
|
|
||||||
|
.. tab:: From arm.com
|
||||||
|
|
||||||
|
First, create a directory to hold the toolchain:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
$ usermod -a -G users $USER
|
||||||
|
$ # get a login shell that knows we're in this group:
|
||||||
|
$ su - $USER
|
||||||
|
$ sudo mkdir /opt/gcc
|
||||||
|
$ sudo chgrp -R users /opt/gcc
|
||||||
|
$ sudo chmod -R u+rw /opt/gcc
|
||||||
|
$ cd /opt/gcc
|
||||||
|
|
||||||
|
Download and extract toolchain:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
$ HOST_PLATFORM=x86_64-linux # use "mac" for macOS.
|
||||||
|
$ # For windows there is a zip instead (gcc-arm-none-eabi-9-2019-q4-major-win32.zip)
|
||||||
|
$ wget https://developer.arm.com/-/media/Files/downloads/gnu-rm/9-2019q4/gcc-arm-none-eabi-9-2019-q4-major-${HOST_PLATFORM}.tar.bz2
|
||||||
|
$ tar xf gcc-arm-none-eabi-9-2019-q4-major-${HOST_PLATFORM}.tar.bz2
|
||||||
|
|
||||||
|
Add the toolchain to your `PATH`:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
$ echo "export PATH=/opt/gcc/gcc-arm-none-eabi-9-2019-q4-major/bin:$PATH" >> ~/.bashrc
|
||||||
|
|
||||||
|
You can edit your shell's rc files if you don't use bash.
|
||||||
|
|
||||||
.. code-block:: console
|
.. tip::
|
||||||
|
There are hints on how to get the latest tool chains for most supported
|
||||||
|
architectures in the Apache NuttX CI helper
|
||||||
|
`script <https://github.com/apache/incubator-nuttx-testing/blob/master/cibuild.sh>`_
|
||||||
|
and Docker `container <https://github.com/apache/incubator-nuttx-testing/blob/master/docker/linux/Dockerfile>`_
|
||||||
|
|
||||||
$ usermod -a -G users $USER
|
Get Source Code
|
||||||
$ # get a login shell that knows we're in this group:
|
---------------
|
||||||
$ su - $USER
|
|
||||||
$ sudo mkdir /opt/gcc
|
Now that all required tools are installed, you need to download NuttX source-code.
|
||||||
$ sudo chgrp -R users /opt/gcc
|
|
||||||
$ sudo chmod -R u+rw /opt/gcc
|
.. tabs::
|
||||||
$ cd /opt/gcc
|
|
||||||
$ HOST_PLATFORM=x86_64-linux # use "mac" for macOS.
|
.. tab:: Development (Git)
|
||||||
$ # For windows there is a zip instead (gcc-arm-none-eabi-9-2019-q4-major-win32.zip)
|
|
||||||
$ curl -L -o gcc-arm-none-eabi-9-2019-q4-major-${HOST_PLATFORM}.tar.bz2 https://developer.arm.com/-/media/Files/downloads/gnu-rm/9-2019q4/gcc-arm-none-eabi-9-2019-q4-major-${HOST_PLATFORM}.tar.bz2
|
Apache NuttX is `actively developed on GitHub <https://github.com/apache/incubator-nuttx/>`_.
|
||||||
$ tar xf gcc-arm-none-eabi-9-2019-q4-major-${HOST_PLATFORM}.tar.bz2
|
If you intend to contribute changes or you simply need the absolute latest version,
|
||||||
$ # add the toolchain bin/ dir to your path...
|
you should clone the Git repositories:
|
||||||
$ # you can edit your shell's rc files if you don't use bash
|
|
||||||
$ echo "export PATH=/opt/gcc/gcc-arm-none-eabi-9-2019-q4-major/bin:$PATH" >> ~/.bashrc
|
.. code-block:: console
|
||||||
|
|
||||||
|
$ mkdir nuttx
|
||||||
|
$ cd nuttx
|
||||||
|
$ git clone https://github.com/apache/incubator-nuttx.git nuttx
|
||||||
|
$ git clone https://github.com/apache/incubator-nuttx-apps apps
|
||||||
|
|
||||||
|
The development source code is also available as a compressed archive, should you need it:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
$ curl -OL https://github.com/apache/incubator-nuttx/tarball/master
|
||||||
|
$ curl -OL https://github.com/apache/incubator-nuttx-apps/tarball/master
|
||||||
|
# optionally, zipball is also available (for Windows users).
|
||||||
|
|
||||||
|
.. tab:: Stable Release
|
||||||
|
|
||||||
|
Apache NuttX releases are published on the project `Downloads <https://nuttx.apache.org/download/>`_
|
||||||
|
page and distributed by the Apache mirrors. Be sure to download both the `nuttx` and `apps` tarballs.
|
||||||
|
|
||||||
----
|
----
|
||||||
|
|
||||||
|
|
|
@ -52,25 +52,22 @@ computer, you're using an ARM microcontroller on your embedded board, and you're
|
||||||
|
|
||||||
NuttX is configured using ``kconfig`` system via an interactive menu system (``menuconfig``). It also includes the ``kconfig-tweak`` utility that can be used to quickly change debug settings without going into the menu system.
|
NuttX is configured using ``kconfig`` system via an interactive menu system (``menuconfig``). It also includes the ``kconfig-tweak`` utility that can be used to quickly change debug settings without going into the menu system.
|
||||||
|
|
||||||
|
.. tabs::
|
||||||
|
|
||||||
|
.. code-tab:: console Ubuntu 20.04 LTS and later
|
||||||
|
|
||||||
On Ubuntu 20.04 LTS and later, you can do:
|
$ apt install kconfig-frontends
|
||||||
|
|
||||||
.. code-block:: console
|
.. code-tab:: console MacOS, Ubuntu 18.04 LTS and earlier
|
||||||
|
|
||||||
$ apt install kconfig-frontends
|
$ cd tools/kconfig-frontends
|
||||||
|
$ # on MacOS do the following:
|
||||||
On MacOS, and Ubuntu 18.04 LTS and earlier, you need to install manually:
|
$ patch < ../kconfig-macos.diff -p 1
|
||||||
|
$ ./configure --enable-mconf --disable-shared --enable-static --disable-gconf --disable-qconf --disable-nconf
|
||||||
.. code-block:: console
|
$ # on Linux do the following:
|
||||||
|
$ ./configure --enable-mconf --disable-nconf --disable-gconf --disable-qconf
|
||||||
$ cd tools/kconfig-frontends
|
$ make
|
||||||
$ # on MacOS do the following:
|
$ make install
|
||||||
$ patch < ../kconfig-macos.diff -p 1
|
|
||||||
$ ./configure --enable-mconf --disable-shared --enable-static --disable-gconf --disable-qconf --disable-nconf
|
|
||||||
$ # on Linux do the following:
|
|
||||||
$ ./configure --enable-mconf --disable-nconf --disable-gconf --disable-qconf
|
|
||||||
$ make
|
|
||||||
$ make install
|
|
||||||
|
|
||||||
#. List Possible Apache NuttX Base Configurations
|
#. List Possible Apache NuttX Base Configurations
|
||||||
|
|
||||||
|
@ -106,8 +103,8 @@ computer, you're using an ARM microcontroller on your embedded board, and you're
|
||||||
|
|
||||||
$ make menuconfig
|
$ make menuconfig
|
||||||
|
|
||||||
Use your arrows to navigate the menu and ``ENTER`` key to enable/disable options. To exit and save your configuration, go back to the main menu, choose ``<Exit>`` and select "yes" when asked if you want to save.
|
Use your arrows to navigate the menu and :kbd:`Enter` key to enable/disable options. To exit and save your configuration, go back to the main menu, choose ``<Exit>`` and select "yes" when asked if you want to save.
|
||||||
|
|
||||||
#. Compile Apache NuttX
|
#. Compile Apache NuttX
|
||||||
|
|
||||||
.. code-block:: bash
|
.. code-block:: bash
|
||||||
|
|
|
@ -1,13 +1,110 @@
|
||||||
.. include:: /substitutions.rst
|
.. include:: /substitutions.rst
|
||||||
.. _running:
|
.. _running:
|
||||||
|
|
||||||
|
=======
|
||||||
Running
|
Running
|
||||||
=======
|
=======
|
||||||
|
|
||||||
Embedded boards have different ways to get your program onto them and get them running. This guide assumes your board
|
In order to finally run NuttX on your board, you first have to flash the NuttX
|
||||||
has a JTAG connector, and you have a JTAG hardware debugger like a
|
binary. As an easy start, it is recommended that you choose a well supported board
|
||||||
`Segger J-Link <https://www.segger.com/products/debug-probes/j-link/>`_. `JTAG <https://en.wikipedia.org/wiki/JTAG>`_
|
which also integrates the debugger/programmer in the board itself exposed via USB
|
||||||
is a set of standards that let you attach a hardware device to your embedded board, and then remotely control the CPU.
|
connector.
|
||||||
|
|
||||||
|
A good choice is a Nucleo or Discovery board from ST Microelectronics,
|
||||||
|
as there is a wide choice of suported boards for the STM32 architecture in NuttX.
|
||||||
|
Also, these boards expose an UART port over the USB connection which allows you
|
||||||
|
to interact with NuttX via the interactive console without any extra hardware.
|
||||||
|
For the purposes of this guide, we will use the Nucleo F103RB board.
|
||||||
|
|
||||||
|
Flashing
|
||||||
|
========
|
||||||
|
|
||||||
|
There are various tools you can use to flash the NuttX binary to your Nucleo
|
||||||
|
board. One common option is to use `openocd` which supports a large number
|
||||||
|
of programmers and target microcontrollers.
|
||||||
|
|
||||||
|
To install the stable version of openocd you can do:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
$ apt install openocd
|
||||||
|
|
||||||
|
.. todo:: add instructions for other platforms
|
||||||
|
|
||||||
|
You should note that openocd project has not made stable releases for long
|
||||||
|
time and support for newer hardware will probably be only available in the
|
||||||
|
latest Git version. To install it you should:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
$ git clone git://git.code.sf.net/p/openocd/code openocd
|
||||||
|
$ cd openocd
|
||||||
|
$ ./bootstrap
|
||||||
|
$ ./configure --prefix install/
|
||||||
|
$ make install
|
||||||
|
|
||||||
|
The resulting installation will be under ``openocd/install``. You can add
|
||||||
|
``openocd/install/bin`` to your ``PATH``.
|
||||||
|
|
||||||
|
Now, to flash the binary to your board, connect the USB cable and do:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
$ cd nuttx/
|
||||||
|
$ openocd -f interface/st-link-v2.cfg -f target/stm32f1x.cfg -c 'init' \
|
||||||
|
-c 'program nuttx/nuttx.bin verify reset' -c 'shutdown'
|
||||||
|
|
||||||
|
Access NuttShell
|
||||||
|
================
|
||||||
|
|
||||||
|
Once you flash your board, it will reset and offer a prompt over the serial
|
||||||
|
console. With the Nucleo board, you can simply open the terminal program
|
||||||
|
of your choice where you will see the ``nsh>`` prompt:
|
||||||
|
|
||||||
|
.. tabs::
|
||||||
|
|
||||||
|
.. code-tab:: console picocom (CLI)
|
||||||
|
|
||||||
|
$ picocom -b 115200 /dev/ttyUSB0
|
||||||
|
|
||||||
|
.. code-tab:: console gtkterm (GUI)
|
||||||
|
|
||||||
|
$ gtkterm -s 115200 -p /dev/ttyUSB0
|
||||||
|
|
||||||
|
|
||||||
|
Debugging
|
||||||
|
=========
|
||||||
|
|
||||||
|
Using ``openocd`` you can also debug NuttX. To do so, first run:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
$ openocd -f interface/st-link-v2.cfg -f target/stm32f1x.cfg
|
||||||
|
|
||||||
|
which will start a GDB server. Then, start ``gdb`` as:
|
||||||
|
|
||||||
|
.. code-block:: console
|
||||||
|
|
||||||
|
$ cd nuttx/
|
||||||
|
$ gdb-multiarch nuttx/nuttx
|
||||||
|
|
||||||
|
Inside ``gdb`` console, connect to the ``openocd`` server with:
|
||||||
|
|
||||||
|
.. code-block::
|
||||||
|
|
||||||
|
(gdb) target extended-remote :3333
|
||||||
|
|
||||||
|
You can debug using standard ``gdb`` commands.
|
||||||
|
|
||||||
|
Advanced Debugging with JTAG
|
||||||
|
----------------------------
|
||||||
|
|
||||||
|
If your board does not have an embedded programmer and uses
|
||||||
|
`JTAG <https://en.wikipedia.org/wiki/JTAG>`_ connector instead,
|
||||||
|
things are a bit different. This guide assumes you have a JTAG hardware debugger like a
|
||||||
|
`Segger J-Link <https://www.segger.com/products/debug-probes/j-link/>`_.
|
||||||
|
JTAG is a set of standards that let you
|
||||||
|
attach a hardware device to your embedded board, and then remotely control the CPU.
|
||||||
You can load code, start, stop, step through the program, and examine variables and memory.
|
You can load code, start, stop, step through the program, and examine variables and memory.
|
||||||
|
|
||||||
#. Attach the Debugger Cables
|
#. Attach the Debugger Cables
|
||||||
|
@ -18,28 +115,19 @@ You can load code, start, stop, step through the program, and examine variables
|
||||||
communicate with to load code and start, stop, and step the embedded board's CPU. Your command line may be
|
communicate with to load code and start, stop, and step the embedded board's CPU. Your command line may be
|
||||||
different from this one.
|
different from this one.
|
||||||
|
|
||||||
.. code-block:: bash
|
.. code-block:: console
|
||||||
|
|
||||||
$ JLinkGDBServer -device ATSAMA5D27 -if JTAG -speed 1000 -JTAGConf -1,-1
|
$ JLinkGDBServer -device ATSAMA5D27 -if JTAG -speed 1000 -JTAGConf -1,-1
|
||||||
|
|
||||||
#. Launch the GNU Debugger
|
#. Launch the GNU Debugger
|
||||||
|
|
||||||
In another terminal window, launch the GDB for your platform. In the case of this guide, this came with the
|
In another terminal window, launch the GDB. In the case of this guide, this came with the
|
||||||
ARM Embedded GNU Toolchain we downloaded in the Install step.
|
ARM Embedded GNU Toolchain we downloaded in the Install step.
|
||||||
|
|
||||||
.. code-block:: bash
|
.. code-block:: console
|
||||||
|
|
||||||
$ arm-none-eabi-gdb
|
$ cd nuttx/
|
||||||
|
$ gdb-multiarch nuttx/nuttx
|
||||||
#. Connect to the board's serial console
|
|
||||||
|
|
||||||
Usually you connect a USB-to-serial adapter to the board's serial console so you can see debug logging or
|
|
||||||
execute Apache NuttX Shell (nsh) commands. You can access the serial console from Linux with the ``picocom`` terminal
|
|
||||||
program. From another terminal, do this:
|
|
||||||
|
|
||||||
.. code-block:: bash
|
|
||||||
|
|
||||||
$ picocom -b 115200 /dev/ttyUSB0
|
|
||||||
|
|
||||||
#. Set gdb to talk with the J-Link
|
#. Set gdb to talk with the J-Link
|
||||||
|
|
||||||
|
@ -66,7 +154,6 @@ You can load code, start, stop, step through the program, and examine variables
|
||||||
|
|
||||||
::
|
::
|
||||||
|
|
||||||
(gdb) file nuttx
|
|
||||||
(gdb) load nuttx
|
(gdb) load nuttx
|
||||||
`/home/adamf/src/nuttx-sama5d36-xplained/nuttx/nuttx' has changed; re-reading symbols.
|
`/home/adamf/src/nuttx-sama5d36-xplained/nuttx/nuttx' has changed; re-reading symbols.
|
||||||
Loading section .text, size 0x9eae4 lma 0x20008000
|
Loading section .text, size 0x9eae4 lma 0x20008000
|
||||||
|
|
Loading…
Reference in a new issue