NuttX-7.28
----------

The 128th release of NuttX, Version 7.28, was made on January 19, 2019,
and is available for download from the Bitbucket.org website. Note
that release consists of two tarballs: nuttx-7.28.tar.gz and
apps-7.28.tar.gz. These are available from:

https://bitbucket.org/nuttx/nuttx/downloads
https://bitbucket.org/nuttx/apps/downloads

Both may be needed (see the top-level nuttx/README.txt file for build
information).

Additional new features and extended functionality:

* Core OS:

- Critical Section Monitor: Adds data collection logic in support of
pre-task monitoring critical sections and pre-emption state. From Gregory
Nutt
- Critical Section Monitor: Add support for global pre-emption and
global critical sections to monitor as suggested by Xiang Xaio. From
Gregory Nutt
- Interrupt Time: Measurement of interrupt handler duration used to
be available only in Tickless mode since it used the high resolution
Tickless timer to measure interrupt time. This change adds
CONFIG_SCHED_IRQMONITOR_GETTIME which, if enabled, will force the
interrupt duration calculation to use the same high-resolution,
platform-specific timer as is used with the Critical Section Monitor.
This leads to two improvements: (1) You can now measure interrupt
duration in non-Tickless mode, and (2) in either mode, the interrupt
duration and the critical section measures will use the same
high-resolution timer and should, therefore, never be any discrepancy
due to different clock sources. From Gregory Nutt
- Context Switching Protection: Add debug assertions before each call
to up_block_task() to assure that there is no attempt to block an
IDLE task. From Dave Marples
- init Task: Allow the init task priority to be configurable. From
David Sidrane
- pthreads: Implement pthread_key_delete(). This involves some minor
changes to the group data structure. From Gregory Nutt

* File Systems/Block and MTD Drivers

- ProcFS: Extended the process ID ProcFS output to show per-thread
maximum time for pre-emption disabled and maximum time within a
critical section. From Gregory Nutt
- NXFFS: Pass unrecognized IOCTL commands to the contained MTD
driver. From Daniel P. Carvalho
- LittleFS: Adds an initial port the ARM mbed littlefs to NuttX. This does
not include FLASH formatting utilities. Depends on CONFIG_MTD_BYTE_WRITE.
From lihaichen
- AT25 MTD Driver: Added support for AT25DF081A serial flash chip.
From Marc Rosen
- MTD Configdata Device: Extends the MTD configdata device with the
following features / additions:
1. Configurable option to use named config items instead of enumerated
ID/Instance numbers.
2. Ability to iterate through the existing configdata items in the
/dev/config device.
3. Ability to "unset" a configdata item.
4. Ability to perform "flash_eraseall" on the /dev/config device.
From Ken Pettit

* Networking/Network Drivers:

- Telnet Driver: Add NAWS and poll interface to telnet for screen size
negotiation used with termcurses. From Ken Pettit

* Wireless/Wireless Drivers:

- BLE HIC Core: Add second RX work function From Lwazi Dube
- BLE IOCTL Commands: Add SIOCBTCONNECT and SIOCBTDISCONNECT ioctl
commands From Lwazi Dube
- CC2564: Add cc2564 HCI UART driver. From Lwazi Dube

* Graphics/Display Drivers:

- Sitronix ST7032i: Add support to Alphanumeric Sitronix ST7032i
display From Alan Carvalho de Assis
- NXP TDA19988: This commit brings in a complete, but untested,
implementation of a driver for the TI TDA19988 HDMI Encoder. This encoder
is used on the Beaglebone Black board. Since this driver is untested, it
requires CONFIG_EXPERIMENTAL in the configuration. From Gregory Nutt

* Crypto:

- crypto/aes.c: This change provides an improved AES cipher API in
addition to the existing routines. The reasons for this new API are:
1) better performance, giving the possibility to avoid re-setting-up
the key for each AES block when the same key is used multiple times.
This is important for the current single user of AES, which is
related to storage and FTL. And 2) suitable for simultaneous use of
multiple AES keys, which will be required by the upcoming crypto
framework. It retains compatibility with the previous API, so there
is no need to change anything else right now. From Sebastien Lorquet

* Other Common Device Drivers:

- MMCSD SDIO: The mmcsd_sdio driver makes calls for dcache
invalidation through the chip specific architecture function
SDIO_DMARECVSETUP(). I changed the arch/arm/stm32f7 chips to use
arch_invalidate_dcache_by_addr() instead of arch_invalidate_dcache().

This commit includes additional changes to mmcsd_sdio.c. I
created SDIO_DMADELYDINVLDT() (DMA delayed invalidate) to
invalidate store-into mode dcaches after the DMA transfer. I
have been using SDIO_DMADELYDINVLDT() for several weeks now and
it has fixed the problems that I previously reported regarding
non-cache aligned buffer invalidation errors (for my store-through
dcache). However, it does not permit use of unaligned DMA buffers
for store-into mode dcaches.

SDIO_DMADELYDINVLDT() is a NoOp unless the chip specific Kconfig
file selects CONFIG_ARCH_HAVE_SDIO_DELAYED_INVLDT. I have modified
all the stm32f7 chips to select it. From Bob Feretich
- SPI Lower Half Interface: Extend the HW features supported by SPI.
It now supports a deferred DMA trigger hardware configuration. From
Dave Marples
- DS28E17 1-Wire Driver: Optimize I2C write followed by read to same
address. From Juha Niskanen
- LMP92001: Add support for the TI LMP92001 Multi-channle DAC/ADC
device. From Abdelatif Guettouche.
- EEPROM Character Driver: Add support to Microchip AT24CM02 From
Alan Carvalho de Assis
- Microchip MCP73871: Add support to Microchip MPC73871 Battery Charger.
From Alan Carvalho de Assis
- MCP7941x: Add support for the Microchip MCP741x external RTC. From Ouss4
- Sensirion SCD30: Driver for Sensirion SCD30 CO2 sensor. From Jussi
Kivilinna
- Sensirion SGP30: Driver for Sensirion SCD30 gas sensor. From Jussi
Kivilinna
- Sensirion SPS30: Driver for Sensirion SCD30 particulate matter sensor.
From Jussi Kivilinna
- USB CDC/ACM Device: When implemented usb cdc on nrf52840, I found
some issues with cdc driver:
1. Lost data when receiving buffer is full;
2. Low-water mask implement issue;
3. Re-flush cdc buffer when enabling
4. Serial dma is conflict with cdc , modify the serial.h
From Levin Li

* MIPS32:

- Configuration System: Allow Penguino for windows for the Windows
Ubuntu platform as well.

* Maxim Integrated MAX326xx

- MAX32660: Support for the MAX32660 was added (along with partial
support for other members of the MAX326xx family). The initial port
includes Clock configuration, timer, GPIO pin configuration, ICC,
and UART. Additional untested drivers are complete and ready for
testing: DMA, GPIO interrupts, SPI0 Master, TC, WDT. The following
drivers are not yet implemented: I2C and I2S.

* Maxim Integrated MAX326xx boards

- MAX32550-EVSYS: Basic support for the Maxim Integrated MAC3X660
EVSYS is included. A basic NSH configuration is available and is
fully functional. Includes unverified support for an SPI0-based
SD card.

* Microchip/Atmel SAMD21/L21 Drivers:

- SAMD21/L21: Adds a complete ADC header file for SAMD21 and a partially
complete ADC header file for the SAML21. From Alexander Vasiliev
- SAMD21/L21: Export sam_i2c_master_initialize(int bus) to be used by
board config. From Alan Carvalho de Assis

* Microchip PIC32MZ Drivers:

- PIC32MZ I2C: Add support for the I2C bus. From Ouss4

* ARMv7-A

- ARMv7-A MMU: Use TLBIMVA vs TLBIMVAAIS to invalidate the Cortex-A8
cache. From Petro Karashchenko

* ARMv7-M

- Cortex-M7 Cache: This commit adds a new function
arch_invalidate_dcache_by_addr(). It takes the same parameters as
arch_invalidate_dcache(), but performs invalidation of only the lines
in cache that need to be invalidated. This new function could be
used as a a direct replacement for arch_invalidate_dcache(). From
Bob Feretich
- ARMv7-M: In the current implementation we only use very high
priority interrupts (levels 0, 0x10 and 0x20 in CORTEX-M speak) but
that means there are loads of lower priority ones that are
effectively unused. I have *not* changed the semantics of these
levels but have 'shifted' them to be based around the midpoint of the
available interrupts (0x80) rather than at the top end....that allows
for interrupts to be defined above (or, indeed, below) them as needed
by the application. This should have no functional effect on
existing code but adds in a clean capability to define higher
priority interrupts. From Dave Marples

* Broadcom BCM2708:

- BCM2708: Remove all support for the BCM2708/2835. This was added
only for support of the RaspberryPi Zero board which was previously
removed. The support was minimal and unverified. The removed files
can still be found in the Obsoleted directory. From Gregory Nutt

* Broadcom BCM2708 Boards:

- Raspberry Pi Zero: Remove the partial support for the Raspberry Pi
Zero. This port was started with the best of intentions but was
never completed. The board support can still be found in the
Obsoleted repository. From Gregory Nutt

* Nordic NRF52 Boards:

- Improve LED handling #if~#endif in nrf52_autoleds.c and
nrf52_userleds.c
Add Adafruit Feather nRF52 board LED support
Add Adafruit Feather nRF52 board
Add nrf52-generic
Replace 'pca10040' with 'generic'
Copy from nrf52-pca10040 to nrf52-generic
From Zou Hanya

* NXP i.MX RT Drivers:

- i.MXRT: Add PIT, GPT, and QIMER(TMR) header files From David Sidrane
- i.MXRT: Add FLEXPWM. From David Sidrane
- i.MXRT: Add ADC chip header From David Sidrane
- i.MXRT Build: Include up_systemreset and up_stackcheck.c From David Sidrane
- i.MXRT GPIO: Add GPIO Support Input daisy selection. From David Sidrane
- i.MXRT Serial: Support independent input and output flow control. From
David Sidrane
- i.MXRT USB: Use single define for USB pin definitions. From David Sidrane
- IMXRT106X: Add FLEXCAN3 to pinmux header file. From David Sidrane

* NXP Freescale i.MX RT Boards:

- IMXRT1050-EVK: GPIO device driver support added and tested by
Pavlina Koleva and Ivan Ucherdzhiev. From Pavlina Koleva

* On Semi LPC23450:

- LPC23450: Add support for SPI flash boot. Also, remove unnecessary
code for the SPI flash boot. From Masayuki Ishikawa

* On Semi LPC23450 Boards:

- LC823450-XGEVK: Add linker script for SPI flash boot. From
Masayuki Ishikawa
- LC823450-XGEVK: Enable NFS client for RNDIS configuration. Also, some
stack size were adjusted to work with NFS From Masayuki Ishikawa

* Simulation

- Critical Section Monitor: Add low level timer support for simulation. From
Gregory Nutt

* STMicro STM32:

- Configuration: Simplify ARM core selection logic From Mateusz Szafoni
- Configuration: USB Host is an option. From David Sidrane
- STM32 L0: Brings in initial support for the STM23 L0. From Mateusz
Szafoni

* STMicro STM32 Drivers:

- STM32 ADC: Configurable ADC DMA mode (one shot mode, circular
mode). From Mateusz Szafoni
- STM32 ADC: Start conversion on startup is now possible if TIM
triggering selected. This can be useful to start ADC TIM conversion
for ADC IPv2 when opening ADC device.
- STM32 DAC: Unified naming for DAC interfaces From Mateusz Szafoni
- STM32 DMA: Add interfaces to interact with high priority DMA
interrupts. From Mateusz Szafoni
- STM32 DMA: Use STM32 DMA IP core version instead of chip family
names. From Mateusz Szafoni
- STM32 DMA: Add support for DMA v1 CSELR support. From Mateusz Szafoni
- STM32 HRTIM: Do not enable timers on startup if option from Kconfig
selected and add interface to enable/disable timers. From Mateusz
Szafoni
- STM32 PWM: Add timer enable/disable and frequency update to
low-level ops. From Mateusz Szafoni
- STM32 SPI: Implements the new deferred DMA trigger feature. From
Dave Marples
- STM32 F0 Build: Rename the stm32f0 directory to stm32f0l0 to make a
space for STM32 L0. Rename files, functions and defines, removing
the f0_ from the names in order to make them MCU agnostic. From
Gregory Nutt
- STM32 F0 GPIO: Add support for GPIO EXTI. From Mateusz Sfafoni
- STM32 F2 FLASH: stm32_flash_writeprotect() supported the same for
STM32F20XX as STM32F4XXX From Anthony Merlino
- STM34 F7 DMA: stm32f7 enable separate DMA per SPI configuration
From Daniel Agar
- STM32 F7 QEncoder: Ported the QEncoder from F4 to F7. From Eduard
Niesner
- STM32 F7 SPI: Port Dave Marples STM32 deferred trigger enhancement
to the STM32 F7 SPI drivers. From Gregory Nutt
- STM32 H7 SPI: Port Dave Marples STM32 deferred trigger enhancement
to the STM32 H7 SPI drivers. From Gregory Nutt
- STM32 L4 SPI: Port Dave Marples STM32 deferred trigger enhancement
to the STM32 L4 SPI drivers. From Gregory Nutt

* STMicro STM32 Boards:

- B-L072Z-LRWAN1: Add basic support for b-l072z-lrwan1. Nucleo boards
use as default ST LINK MCO as clock input from MCU and for this
HSEBYP must be enabled. From Mateusz Szafoni
- Nucleo-F103RB: Add board support. From Mateusz Szafoni
- Nucleo-F103RB: Add ADC and PWM examples. From Mateusz Szafoni
- Nucleo-F207ZG: Add board support. From Mateusz Szafoni
- Nucleo-F207ZG: Add ADC and PWM examples. From Mateusz Szafoni
- Nucleo-F302R8: Add high priority ADC interrupts example to the
'highpri' configuration. From Mateusz Szafoni
- Nucleo-F334R8: Add support for ADC injected sequence to the 'highpri'
configuration, add triggering from TIM1. From Mateusz Szafoni
- Nucleo-F334R8: Add example for the SPWM generation (custom STM32 PWM
usage). From Mateusz Szafoni
- Nucleo-F767ZI: Use on board USB UART as default console. Board is powered
by USB which can be used as UART link for upload and console. Previously
it was set to use Arduino shield which developer may not have. From Phil
Coval
- Nucleo-F767ZI: Add ethernet config based on nsh configuration plus
stm32f769i-disco/nsh-ethernet. From Phil Coval
- Nucleo-L073RZ: Add basic support for nucleo-l073rz. Nucleo boards
use as default ST LINK MCO as clock input from MCU and for this
HSEBYP must be enabled. From Mateusz Szafoni
- Nucleo-L152RE: Add board support. From Mateusz Szafoni
- STM32F4 Discovery: Add timing support for the critical section
monitor using the DWT CYCNT register. From Gregory Nutt
- STM32F4 Discovery: If the Critical Section Monitor, modify the
ITM_LAR register to assure that the DWT cycle counter is enabled.
Suggested by Dave Marples. From Gregory Nutt
- STM32F4 Discovery: Add board support to display ST7032i From Alan
Carvalho de Assis
- STM32F4 Discovery: Add loadable application build support in
Make.defs From Masayuki Ishikawa
- STM32F4 Discovery: Update RNDIS configuration: (1) Add NFS and adjusted
stack size for usermain and telnetd client. (2) Add support for loadable
application and ping. From Masayuki Ishikawa
- STM32F4 Discovery: Update nsh configuration: (1) Add
CONFIG_BOARD_INITIALIZE=y, (2) Add CONFIG_EXAMPLES_HELLO=y. From Masayuki
Ishikawa
- STM32F429I-DISCO: Add high priority ADC interrupts example to the
'highpri' configuration. From Mateusz Szafoni
- configs/nucleo-l073rz: Support for nrf24l01. From Mateusz Sfafoni

* TI CCxx:

- CC13x0 family and CC13x2/CC26x2: Basic, minimal support was added
for these two chip families. This is a Work-In-Progress: There is
just enough logic in place to support a simple NSH configuration.
However, the port is still missing certain, necessary hooks into the
TI ROM-based 'DriverLib'. As a result, the support is not fully code
complete and is totally untested. Support for the CC26x2, which is
nearly identical to the CC13x2 is fragmentary. Stay tuned.
Hopefully full support will be available in NuttX 7.29.

* TI CCxx Boards:

- LAUNCHL-CC1312R1: Board support is available for the TI
LAUNCHL-CC1312R1. That board support consists only of an unverified
NSH configuration. The primary purpose of this port for the time
being is simply support the core architecture bring-up.

* TI AM335x:

- AM335x: Adds initial support for the TI AM355x family.
- AM335x: Add minimal wdog logic needed to disable the watchdog timer.
Otherwise, the board is rebooted after certain time expires while NuttX is
running. From Petro Karashchenko
- AM335x: Switch to DMTimer2 for system tick generation. U-Boot does not
enable DMTimer1ms clocks hence it is not possible to use it until
implementation in am335x_clockconfig.c is ready. From Petro Karashchenko

* TI AM335x Boards:

- Beaglebone Black: Initial port for BeagleBone Black board support
(TI AM335x family based on Cortex-A8). Includes a basic functional NSH
configuration . From Petro Karashchenko

* TI Tiva:

- LM3S9B92: Add support for LM3S9B92. From Lwazi Dube

* TI Tiva Drivers:

- Tiva HCI UART: Port bluetooth HCI uart interface from stm32 to tiva
From Lwazi Dube

* TI Tiva Boards:

- TM4C1294-Launchpad: Add IRQBUTTONS support to tm4c1294 launchpad.
From Lwazi Dube

* Tools:

- tools/convert-comments.c: Add a tool to convert C++-style comments
to C89 C-style comments. From Gregory Nutt
- tools/detab.c: Add detab.c which will convert all tabs in a file to
spaces. From Gregory Nutt
- tools/lowhex.c: Add lowhex.c that will convert hexadecimal constants
in a file to use lower case representation. From Gregory Nutt
- tools/mkconfig.c: Add definitions to distinguish between tristate
'y' and 'm' options. From Gregory Nutt
- tools/nxstyle.c: Add logic to detect long lines. From Gregory Nutt
- tools/nxstyle.c: Add -h for help. From Gregory Nutt

* Libraries/Header Files:

- include/nuttx/lcd/edid.h: Add EDID definitions From Gregory Nutt
- libs/libc/netdb: Make DNS retries configurable From Juha Niskanen
- libs/libc/netdb: Harden query logic against DNS spoofing. This
commit implements most of the RFC 5452 guidelines for making DNS more
resilient. We now verify response matches against what was queried
and use unpredictable query IDs. It is also checked that response
come from correct DNS server. Also fixes a buffer overflow when
querying hostnames longer than CONFIG_NETDB_DNSCLIENT_NAMESIZE. From
Juha Niskanen
- libs/libc/netdb: Support multiple IP addresses per hostname From
Juha Niskanen

* NSH: apps/nshlib:

- apps/nshlib: Add support to use SLCD as NSH Console From Alan Carvalho de
Assis
- apps/nshlib: Add support for CROMFS start-up script. From David Sidrane
- apps/nshlib: Add var expansion in NSH parse. From Daniel Agar
- apps/nshlib: Display built-in apps using multi-column mode like the NSH
commands. From Ken Pettit
- apps/nshlib: In all multi-column help output, calculate an optimal column
width rather than using a hard-coded width that may or may not be
appropriate. Also make the number of rows presented dependent upon the
maximum width of the widest column. From Gregory Nutt
- apps/nshlib: Adds addroute command options for setting default gateway.
Like 'addroute default <ipaddr> <interface>'. From Anthony Merlino

* Examples/Tests: apps/examples:

- apps/examples/battery: Add Battery Charger Monitor Example From Alan
Carvalho de Assis

* System Utilities: apps/system

- apps/system/configdata: Adds an "cfgdata" command which allows
manipulation of the /dev/config items via the command line. One such use
for this utility would be to set a "macaddr" configdata item, etc. The
utility is sort-of like a u-boot env variable edit function:

For instance, to set a "macaddr" when the new CONFIG_MTD_CONFIG_NAMED
option is selected, you would do:

nsh> cfgdata set macaddr [0xfc 0x01 0x0b 0x45 0xa1 0x12]
(The brackets denotes an array of bytes)
nsh> cfgdata set hostname myboard

or using the old ID,INSTANCE numeric method:

nsh> cfgdata set 0,0 [0xfc 0x01 0x0b 0x45 0xa1 0x12]
(The brackets denotes an array of bytes)
nsh> cfgdata set 1,0 myboard

You can also display all config items:

nsh> cfgdata print all
Name Len Data
macaddr 6 0xFC 0x01 0x0B 0x45 0xA1 0x12
hostname 8 myboard

From Ken Pettit
- apps/system/critmon: Add a daemon to monitor critical section usage. From
Gregory Nutt
- apps/system/nsh: Set NSH priority if the NSH task was scheduled at a
different priority than the configured priority. From Gregory Nutt
- apps/system/nxplayer: Introduce CONFIG_NXPLAYER_MAINTHREAD_STACKSIZE. From
Masayuki Ishikawa
- apps/system/termcurses: Addition of termcurses libraries in
apps/system/termcurses From Ken Pettit
- apps/system/vi: New feature additions
1. Vi startup feature to prepend the current working directory to the
supplied filename if it does not start with '/' absolute path
specifier. This allows editing files in the current directory
without needing to fully qualify the filename.
2. Standard '~' empty screen line characters for proper identification
of empty '\n' only lines at the end of the file.
3. Moving into insert or append mode now prints '--INSERT--' in the
status line and clears it upon exit.
4. Integration with termcurses to detect special keystrokes and to
handle terminal type differences. Haven't yet converted all vt100
print codes to termcurses equivalents.
5. Support for up, down, left, right arrows, page-up, page-down keys in
command mode.
6. Added 'b' command to move cursor 'b'ack to previous word. Honors the
command repeat value for multiple word moves.
7. Added 'w' command to move cursor to next 'w'ord. Honors the command
repeat value for multiple word moves.
8. Added 'f' and 't' commands to find characters on the current line.
Honors the command repeat value.
9. Added the find 'n'ext command to repeat the previous find operation.
10. Added the 'H', 'M', and 'L' commands to move the cursor to top,
middle and bottom of the display.
11. Extended yank/paste to manage a paste buffer with character mode in
addition to line mode. Character mode allows cut / paste of
individual characters or groups of characters vs. full lines.
12. Added support in the 'd'elete and 'y'ank commands for character mode
deletions such as 'dw', 'dfa', '2yw', etc.
13. Added support in paste routine for multiple paste using command value
argument.
14. Added support for the 'D' and 'C' delete and change to end of line
commands.
15. Added support for 's'ubstitute key ('x' followed by insert mode).
16. Modified yank / paste allocation scheme to avoid repeated alloc and
free of paste buffer. Uses a minimum allocation size scheme and only
does free / realloc when paste does not fit. If the paste is smaller
than the current allocation and the current allocation is larger than
the threshold, then the buffer is freed and a smaller buffer
allocated. Otherwise the existing buffer is used.
17. Support for 'P'aste before current cursor position.
18. Support for '?' reverse search mode.
19. Support for 'J'oin next line with current line command.
20. Printing of current row,col in status line of display.
21. Command repeat '.' support for commands that modify text.
22. Support in replace / insert mode for arrow keys, PGUP / PGDN, HOME,
and END. Using these will cause the command repeat buffer to reset
such that only the last text addition after a cursor movement is saved.
23. Added 'X' delete previous command.
24. Added "gg" go to top of document command sequence.
25. Added "ZZ" save and quit command (equivalent to :wq).
26. Implemented '^' goto first non-whitespace on current line, along with
'+' and '-' goto first non-whitespace on next / previous line.
27. Added CR / LF goto first non-whitespace on next line in command
mode. From Ken Pettit ?

* Network Utilities: apps/netutils:

- apps/netutils/webserver: The webserver/httpd app is was broken when script
support was enabled (CONFIG_NETUTILS_HTTPD_SCRIPT_DISABLE). The root cause
has been tracked down to the "Content-length" not being available ahead of
time in this case (length of -1 passed to send_headers() ). On the other
hand, the server closing the socket does not result in FIN being sent to
the browser either (FIN not supported by NuttX yet).

Simple solution: Add support for HTTP Chunked Encoding to webserver/httpd.
The change is simple. It adds a configuration option to enable chunked
encoding. When enabled, the implementation will auto-detect the cases where
content length is not available ahead of time, and will automatically
engage chunked encoding transfers.

Without this patch, the browser/client hangs forever, as it is expecting
more data. With this patch, the browser displays the content. From Vlado
Vidovic

* Wireless Utilities: apps/wireless:

- apps/wireless/bluetooth/btsak: Add connect and disconnect commands to
btsak. From Lwazi Dube

* Graphic Utilities: apps/graphics:

- apps/graphics/pdcurs34: Integration of termcurses into pdcurses, plus
pdcurses updates for multi-thread support From Ken Pettit
- apps/graphics/pdcurs34: Adds a configuration option to pdcurses to enable
line-drawing character (ALTCHARSET) when using the short 16-bit chtype.
This is done by limiting the characters to 7-bit ASCII values and using the
8-th bit as the A_ALTCHARSET bit. This allows a significant RAM savings 4K
- 20K depending on terminal size) while still allowing the nicer
line-graphic characters for border drawing. From Ken Pettit

* Testing: apps/testing:

- apps/testing/ostest: Add test for pthread-specific data. From Gregory
Nutt

Bugfixes. Only the most critical bugfixes are listed here (see the
ChangeLog for the complete list of bugfixes and for additional, more
detailed bugfix information):

* Core OS:

- Assertions: Identify the running task correctly when dumping task
state information. It takes time to switch to the target task after
g_readytorun has been modified. If panic/assert happen during this
period, the dump will contain the incorrect and confusing information
due to the difference between the real running task and the return
value of this_task(). This change resolve this problem by adding
g_running_task to track the real running task through the context
switch. From Xiang Xiao
- Assertions: Correct duplicated logic from commit
dbf01d12b7321d1b48b68d3b69842a853b049376. Checking for PID == zero
is not a valid way to test for the IDLE task in all configurations!
This is only true in the single CPU configuration. In multiple CPU
configurations, there will be a separate IDLE task for each CPU with
a different PID and an alternative check must be used. NOTE: The
logic fixed in some places still lacks sufficient intelligence in SMP
mode to find the right stack for the CPU IDLE thread and could still
show the wrong stack. From Gregory Nutt
- Interrupt Prioritization: Remove all driver-specific logic that may
set the interrupt priority to anything but the default. There is no
good reason to change the interrupt priority unless you just want to
debug a difficult problem. OR if you want to use high priority
interrupts. In that case the specific interrupt priorities will need
to be set by board-specific logic. From Gregory Nutt
- Memory Management: Revert "This patch prevent heap corruption as in
below case." This solution to the problem noted by EunBong Song
results in major memory fragmentation and out-of-memory
conditions on the PX4 platform. On that platform the lower priority
work queue is very low priority and essentially never runs when the
system is busy. As a result, the systems gets slowly starved of
memory until failures and bad behaviors begin to occur. From Gregory Nutt
- Memory Management: This is a replacement for EunBong Song's reverted
change. This change adds (1) logic in getpid() to return an error instead
of the PID if the (apparent) currently executing task is not marked as
RUNNING. Then (2) mm_trysemaphore() (the root implementation of both
kmm_trysemaphore() and umm_trysemaphore()) will know that the (apparent)
running task cannot be the holder of the semaphore. How could the
non-running task be trying to get the MM semaphore? I think only in the
exact scenario that Eunbong Song has described. So this new solution
should provide the same protection as the original change but without the
bad consequences to memory usage. From Gregory Nutt (with corrections
from David Sidrane)
- Memory Management: In implementation of calloc(), verify that the number of
elements times the size of an element will not overflow type size_t. This
is required by the SEI CERT C coding style and resolves anonymous Bitbucket
Issue #139 From Gregory Nutt
- sigtimedwait(): Remove unnecessary disable of pre-emption. From
Gregory Nutt
- _exit(): Update all architecture-specific _exit() implementations
so that they correctly call the scheduler instrumentation layer for
the new task that runs when the old one exits. This missing
instrumentation was confusing the Critical Section Monitor logic with
uses this instrumentation to track the state of critical sections.
From Gregory Nutt
- sched_foreach(): sched_foreach() should not have to hold the
critical section over the entire traversal. It should be acceptable
to simply only the critical section while one entry is being
processed (the caller can always call sched_foreach within a critical
section is greater stability is needed). From Gregory Nutt
- task_spawn(): Correct description of input parameters to
task_spawn_exec(). Noted by: JeongchanKim From Gregory Nutt

* Crypto:

- crtypo/: This change:

Avoids the use of up_aesinitialize() entirely, which resolves
dependency problems, because this function does not make sure that
an actual hardware aes implementation was made available: each SoC
is now responsible to ensure the AES hardware is initialized before
first use. This applies to lpc43xx, stm32 and sam34.

Remove definitions of the NEVER used aes_init and aes_update
operations. The new AES API will be more suitable.

From Sebastien Lorquet

* File System/Block and MTD Drivers:

- opendir(): Corrects a problem with opendir() noted by Petteri
Aimonen in Bitbucket Issue 132: "opendir() fails for FAT filesystem
with trailing slash in path". I see the following behaviour on NuttX
7.26, where I have SD card mounted on /flash and a directory called
"frm" on it:

opendir("/flash") returns (DIR *) 0x1000c580
opendir("/flash/") returns (DIR *) 0x1000c5d0
opendir("/flash/frm") returns (DIR *) 0x1000c620
opendir("/flash/frm/") returns (DIR *) 0x0

From POSIX specs for opendir(): "A pathname ... that ends with one or
more trailing slashes shall be resolved as if a single dot character
( '.' ) were appended to the pathname." So for mount points,
opendir() works correctly, but for FAT32 filesystem it fails to open
directory if the path has a trailing slash...

NOTE: You would not see this problem if you call opendir() indirectly
in NSH (like 'ls -R /') because NSH contains logic to remove trailing
'/' characters from paths. From Gregory Nutt
- dup()/dup2(): dup() and dup2() were broken some time back.
fs_dupfd() was return returning OK on success, not the file
descriptor of the duplicated fd. From David Sidrane
- ProcFS: Remove the unnecessary critical section From Xiang Xiao
- CROMFS: Fix hardfault. From David Sidrane
- SmartFS MTD Driver: Fix smart_write_alloc_sector sector size mapping.
Was not correctly calculating the encoded sector size for small (256)
byte or large (>= 4096 byte) sectors. Noted by Daniel P. Carvalho.
Fix from Ken Pettit
- AT25 MTD Driver: Fixed missing opening parenthesis. From Marc Rosen
- MTD Configdata MTD Driver: Check return value mtdconfig_readbytes().
From Jussi Kivilinna
- S25FL1 MTD Driver: Minor change for the s25fl1 QSPI FLASH driver which
fixes additional sectorshift vs. pageshift confusion. From Ken Pettit

* Networking/Network Drivers:

- All network drivers! Change pre-processor logic that selects the
high priority work queue or gives preferential treatment to the high
priority work. All network logic must run on the low priority work
queue! Or suffer the consequences. From Gregory Nutt
- Socket Clone/Dup: On a failure to start the TCP monitor, the cloned
socket is closed but is not properly freed, leaving it attached to a
TCP connection structure with the wrong reference count. From
Gregory Nutt
- ARP: Fix whitespace after ARPHRD_IEEE80211 in ARP header file. From
Daniel Agar
- 6LoWPAN: Fixes decompression of ipaddr from MAC address. The logic
used to populate the IP from the radio address should match
sixlowpan_ipfromsaddr/sixlowpan_ipfromeaddr From Anthony Merlino
- 6LoWPAN: Fixes logic surrounding the Universal/Local bit. This bit
represents whether the IID is locally/globally administered. The U/L
bit is bit 1 of the MSB of the EUI-64. It should only be inverted in
cases where there is a full EUI-64. In cases where the IID is derived
from say, a short address, this bit should be forced to 0, indicating
that it is locally administered. See:
https://tools.ietf.org/html/rfc4291#section-2.5.1
https://tools.ietf.org/html/rfc4944#section-6
https://tools.ietf.org/html/rfc2464#section-4
From Anthony Merlino
- 6LoWPAN: IEEE802.15.4 stores and uses addresses in little endian
order. From Anthony Merlino
- 6LoWPAN: Address comment regarding avoiding double lookup of address
context. From Anthony Merlino
- 6LoWPAN: Record and restore d_buf on entry/exit of sixlowpan_input.
This avoids an issue where d_buf gets set to NULL by 6LoWPAN, and
then is used by forwarding logic from another network interface
before getting set back to the drivers internal buffer. From Anthony
Merlino
- 6LoWPAN: sixlowpan_input should always return 0 if the incoming frame was
consumed. From Anthony Merlino
- TUN Driver: Fixes a problem reported by Masayuki Ishikwawa: Recently I
noticed that ARP response packet is corrupted when I tried to run
bluekitchen with the latest tun.c in TAP mode. If I revert commit
8193c28e9126c9cb89042e80d6ebab7485a831e4, then it works again. From Xiang
Xiao
- Telnet Driver: Add missing logic to set read event flags in poll()
method. From Ken Pettit

* Wireless/Wireless Drivers:

- BLE: Fix uninitialized variables. From Lwazi Dube
- BLE GATT header file: Fix struct name. From Lwazi Dube
- BLE GATT: Remove unnecessary GATT ioctls From Lwazi Dube

* Graphics/Display Drivers:

- ST7032: Fix seek method. Was not taking into account the offset for the
SEEK_END case. Did not account for negative offsets. On errors, it was
clobbering the filep->f_pos setting. From Gregory Nutt
- PCF8574 Backpack: Fix seek method. Had the same problems as noted for
ST7032 driver. From Gregory Nutt

* Common Drivers:

- Button Upper Half: Fix two bad NULL checks From Juha Niskanen
- PWM Interface: Remove dependency on CONFIG_PWM for the upper-half
PWM header. This allows compilation for the lower-level PWM drivers
even if the upper-half PWM logic is not used. From Mateusz Szafoni
- Various I2C Drivers: In most I2C drivers, correct upper index value
in I2C trace dump. Eliminates the extra NONE event from the trace
dump output. From Ouss4
- Battery Gauge: Add missing initialization of semaphore. From Alan
Carvalho de Assis
- Batter Charger: Add missing initialization of semaphore. From Alan
Carvalho de Assis
- MCP73871: Fix Microchip MCP73871 Battery Charger driver to register
correctly as a battery charger. The first element of a 'struct
battery_charger_dev_s' should be a pointer to operations structure. From
Alan Carvalho de Assis
- MCP794xx: Fix MCP794xx driver to wait for OSCRUN and fix tm_year. From
Abdelatif Guettouche
- Numerous files: Fixes usage of CONFIG_BIG_ENDIAN; should be
CONFIG_ENDIAN_BIG From Anthony Merlino

* ARMv7-A:

- ARMv7-A MMU: Fix end address calculation for mmu_invalidate_region() API
From Petro Karashchenko

* ARMv7-M:

- ITM: Fix missing space causing macro issues From Alan Carvalho de
Assis
- Common Exception Handlers: This commit changes the lazy and non-lazy
exception handler to remove a couple of cpsid instructions from them
on ARMv7-m. If my understanding is correct then these interrupt
manipulations aren't doing anything anyway because prioritization
stops secondary interrupts arriving and, even if they did work, they
would have introduced race conditions for the period of time between
the interrupt arriving and further interrupts being disabled. From
Dave Marples
- MPU/Protected Mode Build: Revert "arch/arm/armv7-m: MPU:
mpu_log2regionceil needs take into account the offset too". Masayuki
Ishikawa reports that this commit breaks ALL PROTECTED mode builds. It
violates the basic requirements of the use of the MPU in protected mode.
Those basic requirements are:
1. The MPU region must be aligned to the base address of the memory
region being mapped (it may NEVER extend before the memory region).
That is, the following MUST always be zero: (base & ((1 << l2size) - 1))
2. The MPU region must never extend beyond the end of the memory region.
That is, the following must be true: size >= (1 << l2size)
From Gregory Nutt

* Microchip PIC32MX Drivers:

- PIC32MX Ethernet: Fix a comparison in a debug assertion. Should be
<= vs <. Noted by Anonymous in Bitbucket Issue 134. From Gregory Nutt

* Microchip PIC32MZ:

- PIC32MZ chip.h Header: Add a missing " in an error message. From Ouss4

* Microchip PIC32MZ Drivers:

- PIC32MZ Ethernet: Fix a comparison in a debug assertion. Should be
<= vs <. Noted by Anonymous in Bitbucket Issue 134. From Gregory Nutt

* Microchip/Atmel SAMD21/L21

- SAMD21/L21: Corrects behavior of the I2C_M_NOSTART flag. Also adds
a release a bus on RXNACK and corrects typo priv->flags to msg->flags
as priv->flags is never set. From Alexander Vasiliev
- SAMD21/L21: Fix SAMD2L2 arch to use calibrated oscillator value. Now
SAMD20 and SAMD21 should work fine without external crystal. Note that
SAML21 Xplained board has an external crystal and doesn't need this change,
unless you don't want to use the crystal. From Alexander Vasiliev
- SAMD21/L21 I2C Master: Adds calculation of a timeout and disables
interrupts in case of error. From Alexander Vasiliev

* Microchip/Atmel SAMD21/L21 Boards

- SAML21-Xplained: Fix removed MAXCOARSESTEP from saml21-xplained board.
From Alan Carvalho de Assis

* Microchip/Atmel SAMD51/Ex

- SAMD51/Ex: Alexander Vasiliev's fix to the SAMD21 I2C Master (commit
b1110ba91c549572e94c24ebed202643233deee3) should probably also be
applied to the SAMD51 I2C Master which is identical. From Gregory Nutt

* Microchip/Atmel SAMV7

- SAMV7 Serial: Fix case where TTYS0 is not defined. From Ken Pettit

* Maxim Integrated MAX326xx

- MAX326xx: WFI instruction in IDLE loop seems to interfere with
stability. Commented out for now. Needs to be investigated further.
From Gregory Nutt

* NXP i.MXRT Drivers:

- i.MXRT FLEXPWM: Correct duplicated definitions From David Sidrane
- i.MXRT SERIAL: Fix TTYS0 defined definitions of higher numbered ports
From David Sidrane
- i.MXRT LPSPI: Removed unused clock, that borked the build. From David
Sidrane
- i.MXRT LPI2C: I2C Reset rework From David Sidrane

* On Semi LC823450:

- LC823450: Fix up_allocate_heap() in lc823450_allocateheap2.c. This
change fixes heap size and also implements up_addregion(). From
Masayuki Ishikawa
- LC823450: Fix go_os_start() in lc823450_start.c. I found a bug in
go_os_start() that it returns immediately because it does not compare
r1 to zero. This commit fixes this bug. Also, this commit fixes its
description. From Masayuki Ishikawa
- Other Architectures: Masayuki Ishikawa's change to go_os_start() was
also to all MCU-specific start-up functions that support
go_os_start(). From Gregory Nutt

* On Semi LC823450 Boards:

- LC823450-XEVK: Fix IOB params in rndis/defconfig. These parameters
work for HTTP audio streaming. From Masayuki Ishikawa
- LC823450-XGEVK: Change RNDIS MAC address assignment in rndis
configuration. In previous implementation, mac[0] was assigned to
0xaa for RNDIS host to avoid MAC address conflicts with RNDIS
device.. However, I noticed that this assignment causes a random MAC
address generation on ubuntu16.04 or later which is inconvenient to
set up network interface. This new assignment scheme fixes this
issue. From Masayuki Ishikawa
- LC823450-XGEVK: Fix overlapped memory settings in memory.ld. From
Masayuki Ishikawa

* STMicro STM32 Drivers:

- STM32: Remove redundant STM32 family definitions from chip.h header
file. It is already done in arch/arm/src/stm32/Kconfig From Mateusz
Szafoni
- STM32 ADC: There is no DMA CFG bit for the basic IPv1 ADC. From
Mateusz Szafoni
- STM32 ADC: Refactor adc_reset. It should be easier to maintain this
code if it's divided into smaller functions From Mateusz Szafoni
- STM32 F0 Clocking: Fixes the problem in GPIO port clocks. Only port
A clock was enabled although the comment states otherwise. From Juha
Paalijärvi
- STM32 F7 I2C: I2C out of bounds access on priv->msgv. Error in if
statement. It was checking for msgc > 0. If message count is 1, only
index 0 is valid on priv->msgv. Therefore random values in memory
were used to set next_norestart. From David Sidrane
- STM32 H7 I2C: Applied David Sidrane's I2C fix to the identical logic
for STM32 H7. From Gregory Nutt
- STM32 L4 I2C: Applied David Sidrane's I2C fix to the identical logic
for STM32 L4. From Gregory Nutt

* STMicro STM32 Drivers:

- STM32 ADC: Fix RCC reset logic. From Mateusz Szafoni
- STM32 ADC: Fix compilation errors for chips with one ADV TIM. From
Mateusz Szafoni
- STM32 DMA: Add missing DMA channel configuration.
- STM32 PWM: STM32 MOE is not being appropriately handled for PWM for
advanced timers. It is only ever reset and so no PWM train is
generated. This change addresses this. Noted by Dave Marples. From
Mateusz Szafoni
- STM32 PWM: Fix compilation errors if the upper-half PWM logic is not
enabled. From Mateusz Szafoni
- STM32 SPI: STM32F446 & STM32F469 correct PC1 SPI assignments From
David Sidrane
- STM32 TIM: Fix compilation error if there is no TIM8. From Mateusz
Szafoni
- STM32 F0: Fix GPIO EXTI lines assignment for STM32 M0. From Mateuz Szafoni
- STM32 F3 I2C: Remove the extra NONE event from the trace dump
output. From Ouss4
- STM32 F4 I2C: Remove the extra NONE event from the trace dump
output. From Ouss4
- STM32 F7 I2C: Use clock_t for ticks instead of uint32_t to hold system
time. From Jussi Kivilinna
- STM32 L4 I2C: Use clock_t for ticks instead of uint32_t to hold system
time. From Jussi Kivilinna

* STMicro STM32 Boards:

- STM32F429I-DISCO: Fix lvgl demo removing STM32_FB_CMAP. From Alan
Carvalho de Assis
- STM32VL Discovery: Fix SRAM and FLASH size in the linker script.
There is STM32F100RB with 8KB RAM and 128KB FLASH on the STM32VL
Discovery kit. Invalid memory size could cause a hard fault. From
Matous Pokorny
- STM32VL Discovery: Fix memory size configuration and documentation.
There is STM32F100RB instead of STM32F100RC on the STM32 VL Discovery
kit. From Matous Pokorny
- Viewtool-STM32F107: Change RNDIS MAC address assignment in rndis
configuration. In previous implementation, mac[0] was assigned to
0xaa for RNDIS host to avoid MAC address conflicts with RNDIS
device.. However, I noticed that this assignment causes a random MAC
address generation on ubuntu16.04 or later which is inconvenient to
set up network interface. This new assignment scheme fixes this
issue. From Masayuki Ishikawa

* TI Tiva:

- Tiva LM/TM4C Start-Up: Remove option CONFIG_TIVA_BOARD_CLOCKCONFIG. It is
not used and unnecessary. Fix some naming. up_clockconfig() is
inappropriate. Change tiva_clockconfig() to tiva_clock_reconfigure()
then we can change up_clockconfig() to tive_clock_configure(). From
Gregory Nutt
- Tiva LM/TM4C GPIO Interrupts: Fix tiva gpio interrupts From Lwazi Dube
- Tiva LM/TM4C: Improve GPIO interrupt support by removing unnecessary,
hard-coded per-MCU defines and using the existing Kconfig configuration
options instead. From Lwazi Dube

* TI Tiva Drivers:

- Tiva TM4C Serial: After commit
51b78034ac8d1fdf598107bf4093f0beccd5b80b, my tiva console does not
work - enter key produces garbage characters. This commit fixes the
problem for me. From Lwazi Dube

* C Library/Header Files:

- include/dsp.h: Fix missing semicolon error in dsp.h From MYAPICI
- include/nuttx/compiler.h: Correct support of C-version-specific features.
Cannot depend on GCC version because -std=c89 may be used on comomand
line. Need instead to use __STDC_VERSION__ to determine if a feature is
supported. Also add conditional support inline, depending on C99. From
Gregory Nutt
- libs/libc/stdio: fread() should always set EOF if fewer than the
requested number of bytes was not read. Per Anthony Merlino. From
Gregory Nutt

* Build System:

- sched/irq/Make.defs: Fix warning about irq_csection.o appearing
multiple times in the same rule. From Gregory Nutt

* Tools:

- tools/gencromfs.c: "gencromfs.c:1171:3: warning: ignoring return
value of 'asprintf'", declared with attribute warn_unused_result
[-Wunused-result]. From David Sidrane
- tools/gencromfs.c: Fix build on macOS. From David Sidrane

* NSH Library: apps/nshlib:

- apps/nshlib: Fixes an error in the NSH parser. There was a bug when
executing an nsh shell script which contains a redirection. When the
command in the script is executed, it sets the vtbl->np.np_redirect flag
(as it should), but then doesn't restore it, leaving it set at the end of
the script execution. Then the vtbl->np.np_redirect flag is set when the
'sh' command completes, causing a restore from un-initialized variables,
thus leading to a crash. See the code snippet below for an example test
case.

Test case:

NuttShell (NSH)
nsh> mkrd -s 1024 40
nsh> mkfatfs /dev/ram0
nsh> mount -t vfat /dev/ram0 /tmp
nsh> echo "echo 1 > /dev/null" > /tmp/test.sh
nsh> cat /tmp/test.sh
echo 1 > /dev/null
nsh> sh /tmp/test.sh
...

The nsh prompt doesn't get printed. You can type a couple of commands,
but then the system will crash because of bad pointers. From Ken Pettit
- apps/nshlib: Fix buffer overrun when redirected to a file. SAVE_SIZE
must be the same as sizeof(struct serialsave_s). From Masayuki Ishikawa

* System Utilities: apps/system:

- system/system.c: Fixes build error; There is no result variable, use
errcode instead. From Anthony Merlino
- apps/system/vi: Bug fixes:
1. Deletion of last line in file using 'dd' caused infinite loop
searching for 'nextline'. Fixed.
2. Insertion of line above 1st line using 'O' caused line to be
inserted on 2nd line. Fixed.
3. Paste buffer from 'dd' was being free'd after the 'p'aste operation,
preventing multiple paste opportunity. Fixed.
4. The cursor was not being bound to the line end and was allowed to
'hover' over the '\n' EOL character. This caused weird (relative to
standard vi) insertion locations and cursor movement with 'a'ppend
and 'i'nsert. Fixed.
5. The 'vi_shrinkpos' position didn't take the end of file pointer into
account when calculating 'curpos', 'prevpos' variables causing
weirdness when deleting things near the end of the file. Fixed.
6. The 'yy'ank command was improperly deleting the text from the
document instead of simply yanking to the paste buffer. Fixed.
7. The 'dd'elete line function was not copying the deleted line to the
paste buffer as part of the delete operation. Fixed.
8. The bottom line of the screen was sometimes being used for document
text and other times for command / find entry. Fixed by reserving
the bottom the bottom line for status / command only.
9. When scrolling up / down through a file, the cursor position was not
preserved and moved further and further to the left column based on
the line lengths of the lines visited. Fixed.
10. The display was being COMPLETELY redrawn with each keystroke,
causing the responsiveness to be unbearable. Fixed. Added logic to
dynamicall indicated which portions of the screen need to be updated
(full display, current line to end of screen, current line only,
none).
11. The individual display line updates were being performed a character
at a time by calling the vi_putch() function, causing slow
performance, especially in telnet or USBCDC sessions where there is
a lot of overhead per packet. Fixed by calling vi_write() instead
with a block of characters with breaks as needed for TAB exansion.
12. The forward delete 'x' operation allowed deletion through '\n'
characters causing lines to be joined. This is different from
standard vi where 'x' at the end of a line performs a delete
backward operation. Fixed.
13. When in 'ex' or find sub-modes (':' or '/' bottom line modes),
hitting backspace with empty text did not return the operation to
command mode like it does in standard vi. Fixed.
14. Performing a 'find' opertation would only search from the current
cursor position to the end of the file and did not wrap like in
standard vi. Fixed.
15. Loading a file that was larger than the initial text allocation
would force a call to 'vi_extendtext', marking the file as modified
when in fact it hadn't even been loaded yet. Fixed.
16. Combined vi_insert_mode and vi_replace_mode into a single function
to save code space since they are nearly identical routines.
17. In command mode, backspace was deleting characters which is
different from standard vi. Backspace in command mode normally
simply moves the cursor left / to the previous line. Fixed.
18. Added code to handle boundary conditions when the file is new and
commands are applied to an empty file.
19. Fixed vi_shrinktext so it doesn't allocate a zero-length buffer when
the last character in the file is deleted.
20. The 'x' command was not copying to the paste buffer. Fixed.
21. Fixed parsecolon routine to properly deal with ":wq" command sequence.
From Ken Pettit

* Wireless Utilities: apps/wireless:

- apps/wireless/bluetooth/btsak: 'bt bnep0 info' outputs a reversed addr. It
should print BDAddr: aa:bb:cc:dd:ee:ff instead of BDAddr:
ff:ee:dd:cc:bb:aa. From Lwazi
- apps/wireless/bluetooth/btsak: Fix some errors in btsak. From Lwazi Dube
- apps/wireless/bluetooth/btsak/btsak_main.c: Fix address parsing. From
Lwazi Dube
- apps/wireless/bluetooth/btsak: Remove unnecessary gatt get commands. From
Lwazi Dube
- apps/wireless/bluetooth/btsak/btsak_scan.c: Fix reversed address. From
Lwazi Dube
- apps/wireless/ieee802154/i8sak: Fixes issues related to re-running
daemon. Releases lock when releasing daemon. Re-sets daemon_shutdown so
that a subsequent daemon launch does not immediately return. From Anthony
Merlino