nuttx-mirror/Documentation/faq/index.rst
Alan Carvalho de Assis f830376ef2 DOC: Add how to get application on NSH
Signed-off-by: Alan C. Assis <acassis@gmail.com>
2024-06-06 02:39:56 +08:00

215 lines
7 KiB
ReStructuredText

.. todo::
Create new subsections as needed.
===
FAQ
===
NSH Tricks
==========
How to get an application available in the NSH?
-----------------------------------------------
You will need at least three things enabled inside NuttX menuconfig
to be able to see an application this displayed there:
BUILTIN, NSH_BUILTIN_APPS and the application itself.
Enabling BUILTIN::
Library Routines --->
[*] Support Builtin Applications
Enabling NSH_BUILTIN_APPS::
Application Configuration --->
NSH Library --->
[*] Enable built-in applications
Enabling Hello World Application::
Application Configuration --->
Examples --->
[*] "Hello, World!" example
After compilation you should see the hello at NSH:
.. code-block:: shell
NuttShell (NSH) NuttX-12.5.1
nsh> ?
help usage: help [-v] [<cmd>]
. cp exit mkdir set unset
[ cmp expr mkrd sleep uptime
? dirname false mount source usleep
alias dd fdinfo mv test xd
unalias df free pidof time
basename dmesg help printf true
break echo hexdump pwd truncate
cat env kill rm uname
cd exec ls rmdir umount
Builtin Apps:
hello nsh sh
nsh>
Note: if you want to see the applications physically at /bin you can
enable BINFS::
File Systems --->
[*] BINFS File System
How to increase the command line length?
----------------------------------------
You can increase the Max command line length from 64 to other value,
this way::
Application Configuration --->
NSH Library --->
Command Line Configuration --->
(64) Max command line length
How do I enable editing support on the command line?
----------------------------------------------------
You need to change Command Line Editor from "Minimal readline" to
"Command Line Editor", this way::
Application Configuration --->
NSH Library --->
Command Line Configuration --->
Command Line Editor (Command Line Editor) --->
How to enable command line history?
-----------------------------------
You need to enable these options in the menuconfig::
Application Configuration --->
System Libraries and NSH Add-Ons --->
-*- readline() Support --->
[*] Command line history
(80) Command line history length
(16) Command line history records
Note: If you are using the "Command Line Editor" instead of the "readline"
then you need to use this other option::
Application Configuration --->
System Libraries and NSH Add-Ons --->
-*- EMACS-like Command Line Editor --->
[*] Command line history
(80) Command line history length
(16) Command line history records
How to enable autocomplete on the command line?
-----------------------------------------------
You need to enable these options in the menuconfig::
Application Configuration --->
System Libraries and NSH Add-Ons --->
-*- readline() Support --->
[*] Tab completion
(64) Maximum built-in matches
(64) Maximum external command matches
Note: autocomplete is not enabled when "Command Line Editor" instead of the
"readline".
How to interrupt an NSH Application using Ctrl^C ?
--------------------------------------------------
You need to enable these options in the menuconfig::
RTOS Features --->
Signal Configuration --->
[*] Default signal actions --->
[*] SIGINT and SIGKILL
Device Drivers --->
Serial Driver Support --->
[*] Serial TERMIOS support
[*] Support SIGINT
(0x03) Serial parse SIGINT characters
Board Initialization
====================
How to start directly my application instead starting NSH?
----------------------------------------------------------
You can start you application directly instead of starting the default
NSH terminal. Lets support your application is called "hello", then you
will modify the ENTRYPOINT to call "hello_main" instead of "nsh_main"::
RTOS Features --->
Tasks and Scheduling --->
(hello_main) Application entry point
Why after putting my application on ENTRYPOINT it stops to work?
----------------------------------------------------------------
When you replace the ENTRYPOINT from "nsh_main" to your application some
initialization flow are changed, for instance the NSH_ARCHINIT is not
executed anymore and so some drivers initialization that are called from
it also stops to work.
You can fix it enabling the Board Late Initialization that will replace the
NSH_ARCHINIT to call those drivers initialization. Just enable it::
RTOS Features --->
RTOS hooks --->
[*] Custom board late initialization
Also you need to disable the architecture-specific initialization::
Application Configuration --->
NSH Library --->
[ ] Have architecture-specific initialization
Why isn't /dev/ttySx created when using USB Console even when UART is enabled?
------------------------------------------------------------------------------
If you don't use serial console then /dev/ttyS0 will not be created,
even if you enable the UART peripheral at "System Type".
You can fix it enabling the Serial Upper-Half Driver::
Device Drivers --->
Serial Driver Support --->
[*] Enable standard "upper-half" serial driver
Network
=======
How to detect Ethernet cable connection/disconnection?
------------------------------------------------------
NuttX supports Ethernet connection/disconnection events from Ethernet PHY
using signals (see ``nuttx/drivers/net/phy_notify.c``).
The network monitor thread at apps/netutils/netinit (see
``CONFIG_NETINIT_MONITOR``) will handle taking the network down if the cable
is unplugged and bringing it back up when the cable is restored.
It is important to note that your Ethernet controller driver of your
MCU needs to support CONFIG_ARCH_PHY_INTERRUPT (and implement
``arch_phy_irq()``).
How to define the MTU and MSS for the network packets?
------------------------------------------------------
As you probably know the "MSS = MTU - 40", so you just need to setup the MTU.
If you search for MTU in the menuconfig you will not find it, but you can
setup the MTU using the ``CONFIG_NET_ETH_PKTSIZE`` here::
Networking Support --->
Driver buffer configuration --->
(590) Ethernet packet buffer size
Then just figure it out using this formula:
MTU = NET_ETH_PKTSIZE - 14
MSS = MTU - 40
In this case you have MTU = 590 - 14 => MTU = 576!
And the MSS = 576 - 40 => MSS = 536.