NuttX-7.24
----------

The 124th release of NuttX, Version 7.24, was made on March 2, 2018,
and is available for download from the Bitbucket.org website. Note
that release consists of two tarballs: nuttx-7.24.tar.gz and
apps-7.24.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:

- SMP: Introduce spin_lock_irqsave() and spin_unlock_irqrestore().
These APIs are simplified version of enter_critical_section()
and leave_critical_section() to protect data (e.g. registers) in
SMP mode. By using these APIs inside drivers, performance will
be improved. From Masayuki Ishikawa.
- System Timer: Replace critical section APIs with spinlock APIs.
(64bit only). If SMP=n or SMP=y && SPINLOCK_IRQ=n, this works
in the same way as before. If SMP=y && SPINLOCK_IRQ=y, performance
will be improved. From Masayuki Ishikawa.
- POSIX Timers: Replace critical section APIs with spin lock APIs in
clock_gettime.c. This change will improve performance for SMP
systems but nothing changes for non-SMP systems. In SMP mode,
the running TCB is not always at the g_readytorun.head. From
Masayuki Ishikawa.
- SMP: Introduce spin_lock_wo_note() and spin_unlock_wo_note(). These
APIs are used in sched_note.c to protect instrumentation data. The
difference between these APIs to existing spin_lock() and
spin_unlock() is that they do not perform instrumentation to avoid
recursive call when SCHED_INSTRUMENTATION_SPINLOCKS=y. From
Masayuki Ishikawa.
- Interrupts: Add a configuration option to show interrupt
information via a procfs file.

* File Systems/Block and MTD Drivers

- VFS: Add support for truncate() and ftruncate().
- FAT, SmartFS, UserFS, UnionFS, TmpFS, NFS: Add truncate() support.
- FAT. Effectively handles the situation when a new file position is
within the current sector. Accelerates the work of the FS with a
multitude of operations to write small pieces of data within the
current sector. From Aleksandr Vyhovanec.

* Graphics/Display Drivers:

- HiletGo OLED: Add configuration support for HiletGo SSD1306 OLED.
- lcd/ft80x: This commit adds an FTDI/BridgeTek FT80x GUI driver. It
is untested (I don't even have hardware yet) and, hence, it is
marked as EXPERIMENTAL).

* Networking/Network Drivers:

- 6LoWPAN: Adds configuration options for specifying preloaded
address contexts for compression From Anthony Merlino.
- TCP: Introduce tcp receive window control based on I/O buffer.
NOTE: The algorithm is still experimental but useful for http
streaming. From Masayuki Ishikawa.
- UDP: Add an implementation of UDP write buffering.
- Routing Tables: Adding ftruncate() support eliminates an issue
in file-based routing table management system.
- Telnet: Add support for Telnet character mode From Masayuki
Ishikawa.

* Other Common Device Drivers:

- drivers/input/ft5x06.c: Add a driver for the FT5x06 capacitive,
multi-touch, touchscreen controller.
- drivers/input/ft5x06: Add a polled mode of operation for the FT5x06
in attempt to work around the fact that the LPCXpresso-LPC54628
chose a non-interrupt pin for the FT5x06 interrupt. Driver is still
not yet functional.
- drivers/power/bq2429x.c: Add trickle charging mode From Juha
Niskanen.
- drivers/sensors: Add support to MAX44009 ambient light sensor.
From Juha Niskanen.
- drivers/sensors: Added support for LIS3DH accelerometer sensor.
From Matt Thompson.
- drivers/eeprom: EEPROM driver for AT24xx compatible EEPROMs.
From Sebastien Lorquet.

* Simulation

- sim: Add support for a RAM MTD driver and initialization for use
with SmartFS.
- sim: Add support for testing NXFFS.

* ARM:

- ARMv7-A, ARMv7-R, ARMv7-M: Add atomic read-add-write and
read-subtract-write functions.

* Infineon XMC4xxx:

- XMC4xxx: Refactor PLL setup, refactored PLL/CLK config, easier,
checks for correctness, call go_os_start if STACK_COLORIZED, smarter
config of EXTCLK output freq. From David Alessio.

* Infineon XMC4xxx Boards:

- Add FPU to xmc4 ostest. Remove +x from makefiles, preserve
.gdbinit across make clean, add FPU support to ostest on xmc4,
add FPU test to ostest on xmc4 From David Alessio.

* Microchip/Atmel SAMD/L Drivers:

- SAMD: SAMD External Interrupt Controller (EIC) support From Matt
Thompson.
- SAMD/L: Added Analog Comparator basic initialization From Matt
Thompson.
- SAMD/L: Added FDPLL clock support. Fixed sequence of OSC32K
calibration setup. From Matt Thompson.
- SAMD/L: Added loading factory USB calibration data from NVRAM.
From Matt Thompson.
- SAMD/L: Added experimental DMA support to SPI driver. spi_exchange()
uses a pair of DMA channels for TX and RX. From Matt Thompson.

* Microchip/Atmel SAM3/4 Boards:

- Flip&Click SAM3X: Add board support for the Mikroe Flip&Click
SAM3X.
- Flip&Click SAM3X: Adds basic board support for the HiletGo OLED.

* Microchip PIC32MZ

- PIC32MZEF: Add architectural support for the PIC32MZEF family.

* Microchip PIC32MZ Boards

- Flip&Click PIC32MZ: Adds board support for the Mikroe Flip&Click
PIC32MZ board.
- Flip&Click PIC32MZ: Add board support for HiletGo OLED.
- Flip&Click PIC32MZ: Add an nxlines configuration for use in
testing the custom HiletGo Click board.

* NXP Freescale LPC43xx Drivers:

- LPC43xx: Adapt LPC176x RTC driver for the LPC43xx. From Gintaras
Drukteinis.
- LPC43xx: Add Windowed Watchdog Timer (WWDT) driver. Tested on
LPC4357 but should be compatible for all LPC43xx MCUs.
From Gintaras Drukteinis.
- Leverage the LPC54xx SD/MMC back to the LPC43xx (where it came from
originally).

* NXP Freescale LPC43xx Boards:

- Bambino-200e: Add LPC43 SDMMC board support to Bambino-200E. From
Alan Carvalho de Assis.

* NXP Freescale LPC54xx:

- LPC546xx: Added basic architectural support for the LPC546xx
family.

* NXP Freescale LPC54xx Drivers:

- LPC546xx: Basic NSH configuration includes support for UARTs,
SysTick timer, GPIOs, LEDs, and buttons
- LPC546xx: Additional drivers include EMC, I2C, Ethernet
- LPC546xx: Implement GPIO interrupt support.
- LPC546xx: And unverified SPI driver is included.
- LPC546xx: Ported LPC1788 LCD driver to use the LPC54xx pin.
- LPC546xx: Bring in LPC43xx SD/MMC driver from
https://github.com/Smoothieware/smoothie-nuttx/tree/master/nuttx/arch/arm/src/lpc43xx
and adapt for use with the LPC43xx
- LPC546xx: Add DMA driver ported from the LPC43xx GPDMA driver.
- LPC546xx: Bring in WWDT driver from LPC43.
- LPC546xx: Add an RTC driver and a RTC character driver lower half.
- LPC546xx: Add support for a random number generator.
- LPC546xx: Add an Ethernet driver.

* NXP Freescale LP54xx Boards:

- LCXpresso-LPC54628: Added support for the LPCXpresso-LPC54628
board. The initial bring-up used a basic NSH port.
- LCXpresso-LPC54628: On-board SDRAM is also supported
- LCXpresso-LPC54628: Add support for I2C2 and for the I2C tool to
the NSH configuration.
- LCXpresso-LPC54628: Add support for the USER button. Enable the
apps/examples/button test in the NSH configuration.
- LCXpresso-LPC54628: Add the fb configuration for testing the LCD.
- LCXpresso-LPC54628: Add support for the the FT5x06 touchscreen
controller. Enable the driver as well as the apps/examples
touchscreen test.
- LCXpresso-LPC54628: Add an NxWM configuration.
- LCXpresso-LPC54628: Add logic to bring up SDMMC.
- LCXpresso-LPC54628: Add logic to register the RTC character driver
if it is enabled. Enable the RTC and RTC character driver in the
NSH configuration.
- LCXpresso-LPC54628: Add a netnsh configuration that was be used to
test the Ethernet driver.
- LCXpresso-LPC54628: Add LittlevGL graphics demo configuration.

* On Semiconductor LC823450

- LC823450 SMP improvements: (1) Apply irq_spin APIs to
modifyregXX, (2) Do not use modifyreg32() to enable Mutex, (3)
Modify IRQ control for i2s. Apply irq_spin APIs to
dma/syscontrol/usbdev. From Masayuki Ishikawa.
- LC823450: LC823450 http streaming improvements: (1) Use spinlock
APIs in lc823450_gpio.c. (3) Fix a potential race condition in
up_enable_irq(), (3) Use spinlock APIs instead of critical section
APIs, (4) Enable HRT_TIMER in lc823450_timerisr.c. (5) Use spinlock
APIs instead of critical section APIs. (6) Fix race conditions in
dma/usbdev. From Masayuki Ishikawa.
- LC823450: Introduce DVFS. This version only supports manual mode
and Vdd1 is fixed to 1.2V. From Masayuki Ishikawa.

* On Semiconductor LC823450 Drivers

- LC823450: Refactor timer driver. Add MTM timer APIs for DVFS.
Introduce up_rtc_gettime() for CONFIG_RTC_HIRES. Introduce idle
time calculation in DVFS. Also, DVFS autonomous mode based on CPU
idle time is supported. NOTE: voltage control is still disabled.
From Masayuki Ishikawa.

* On Semiconductor LC823450 Boards

- LC823450-XGEVK: I2S interrupt will be handled on CPU0 with this
change. Assign CPU1 to lpwork. This change will improve load
balancing for networking with RNDIS. From Masayuki Ishikawa.
- LC823450-XGEVK: Enable SPINLOCK_IRQ and NXPLAYER in rndis. From
Masayuki Ishikawa.
- LC823450-XGEVK: LC823450 http streaming improvements: (1) In SMP
mode, H/W interrupts should be handled on CPU0 to avoid deadlocks.
(2) Call up_enable_irq() to assign CPU0 for IRQ handling. (3)
Enable HRT_TIMER, LC823450_MTM0_TICK, SPINLOCK_IRQ, (4) Enable
NET_TCP_RWND_CONTROL, NXPLAYER_HTTP_STREAMING_SUPPORT (rndis only)
From Masayuki Ishikawa.
- LC823450-XGEVK: Enable DVFS in lc823450_bringup.c. Enable DVFS
in audio and rndis. Add Telnet character mode to rndis. From
Masayuki Ishikawa.
- LC823450-XGEVK: Explicitly assign I2S IRQ handling to CPU0. From
Masayuki Ishikawa.
- LC823450-XGEVK: Enable RTC_HIRES instead of RTC_DATETIME (audio/
rndis). Disable TCP_WRITE_BUFFERS and change SCHED_LPWORKPRIORITY
(rndis). Update SMP and DVFS related part. From Masayuki Ishikawa.

* STMicro STM32:

- STM32 F7: Add support for the STM32F72x/73x family. From Bob
Feretich.

* STMicro STM32 Drivers:

- STM32 HRTIM: Add interface to change outputs SET/RST configuration.
From Mateusz Szafoni.
- STM32 HRTIM: Add interface to get timer clock frequency,
calculation, add compare/capture registers significant bits
checking. From Mateusz Szafoni.
- STM32 HRTIM: Add interface to set timer frequency, fix slave timers
reset configuration, change POWER_INFO to TIMER_INFO From Mateusz
Szafoni.
- STM32 HRTIM: Add repetition support and fix enum overflow From
Mateusz Szafoni.
- STM32 HRTIM: Add HRTIM push-pull mode configuration. From
raiden00pl.
- STM32 FLASH: Add progmem support for STM32L15XX From Juha Niskanen.

* STMicro STM32 Boards:

- configs/photon: Adds BOARD_TIMn_FREQUENCY macros From Anthony
Merlino.
- configs/indium-f7: Adds support for the RAF Research Indium-F7
board. From Bob Feretich.
- Rename the configs/stm32f0discovery board directory to
configs/stm32f051-discovery. There are others stm32f0discovery
boards with different MCUs and different peripherals on the board.
From Alan Carvalho de Assis.
- configs/stm32f072b-discovery: Adds support for stm32f072b-disco
board. This is the board. I added the LEDs of this board and tested
the compilation. From Alan Carvalho de Assis.
- configs/stm32f103-minimum: Add AT24 EEPROM support on STM32F103-
Minimum board From Alan Carvalho de Assis.
- configs/stm32f103-minimum: Add support to BMP180 on BluePill
(stm32f103-minimum) board. From Alan Carvalho de Assis.
- configs/stm32f334-disco: Add buck converter and boost converter
logic. From Mateusz Szafoni.
- configs/stm32f103-minimum: Add zerocross support to STM32F103-
Minimum board From Alan Carvalho de Assis.
- configs/stm32f103-minimum: Add OLED SSD1306 support to
STM332F103-Minimum From Alan Carvalho de Assis.
- configs/stm32f103-minimum: Add board support to MAX6675 Thermocouple
sensor From Alan Carvalho de Assis.
- configs/stm32f746g-disco: Add stm32f746g-disco Ethernet configuration.
Add USART1 support (connected to the USB virtual serial port) From
Louis Mayencourt.
- configs/viewtool-stm32f107: Add support for FT80X initialization.
Add ft80x configuration that will eventually be used for testing the
ft80x if I ever receive hardware.

* Tools:

- tools/logparser: Add a tool which will help me to convert git logs
to ChangeLog format.

* NSH: apps/nshlib:

- apps/nshlib: Add support for a truncate command. This will be used
to test the new ftruncate file system support.
- apps/nshlib: Add support for Telnet character mode. From Masayuki
Ishikawa.
- apps/nshlib: Add support for '-n' option to the echo command. From
Masayuki Ishikawa.
- apps/nshlib: Add irqinfo command.

* Examples/Tests: apps/examples:

- apps/examples/userfs: Add truncate() support for userfs.
- apps/examples/lvgldemo: Add lvgldemo example for LittlevGL.
- apps/examples/veml6070: Add VEML6070 Application Example. From
Alan Carvalho de Assis.
- apps/examples/bmp180: Add BMP180 application example. From Alan
Carvalho de Assis.
- apps/examples/ft80x: Add a test of the FT80x based on FTDI
SampleApp. Includes tests of GPU primitives and graphics co-
processor commands.

* Network Utilities: apps/netutils:

- apps/netutils/netlib: Add default route in netlib_set_dripv4addr().
From Masayuki Ishikawa.

* Graphics: apps/graphics:

- apps/graphics/littlevgl: Add littlevgl library. From Alan Carvalho
de Assis.
- apps/graphics/ft80x: Add the FTDU FT80x GUI support library.
Consists of some display list helpers, audio helpers, touch helpers,
RAM access, register access etc.

* System Utilities (apps/system)

- apps/system/nxplayer: Add support for HTTP streaming in nxplayer.
From Masayuki Ishikawa.
- apps/system/setlogmask: Adds 'setlogmask' application that allows
you to set the syslog priority via a simple command. From Anthony
Merlino.
- apps/system/usbmsc: Added Kconfig options to configure write
protection for each LUN. From Fabio D'Urso.
- system/stackmonitor: Re-design the stack monitor so that it does not
make forbidden calls directly into the OS, breaking the portable POSIX
OS interface. It now properly uses the PROCFS file system to glean
information about stack usage.

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:

- System Timer: Change the way that the 64-bit time is sampled.
Previously, we disabled interrupts before sampling the 64-bit
timer since the uint64_t access is not atomic on most CPUs. However,
disabling (local) interrupts does not work in the SMP case. In that
case, the timer interrupt may be running on only one of the CPUs;
disabling interrupts on a different CPU will provide no protection
from timer rollover. To work around this, logic was added that
samples 64-bit timer is sampled twice and if 32-bit rollover was
detected between samples, then loops until there is no rollover.
- POSIX Timers: In SMP mode, running TCB is not always at the head of
the g_readytorun list. This change removes DEBUGASSERT() to avoid
this condition. From Masayuki Ishikawa.
- Spinlocks: Add memory barrier operations in spin_unlock(). In ARM
document regarding memory barriers, SP_DMB() must be issued before
changing a spinlock state to SP_UNLOCKED. However, we found that
SP_DSB() is also needed to ensure that spin_unlock() works
correctly for network streaming aging test. From Masayuki Ishikawa.
- Sporadic Scheduler: Fix compiler error in Sporadic Scheduler when
priority inheritance is enabled. Noted by eunb.song@samsung.com
- Priority Inheritance: Fix some priority inheritance related issues
noted during review of logic. Also add some REVISIT comments for some issues noted in the design.
- boardctl: Remove the BOARDIOC_TSCTEST_TEARDOWN and
BOARDIOC_TSCTEST_SETUP boardctl() commands. Remove all
implementations of board_tsc_teardown(). Each board now initializes
the touchscreen controller as a normal part of its board bring-up.
board_tsc_setup() is gone; the touchscreen controller is now treated
like any other on-board device.
- configs: CONFIG_MAX_TASKS must be a power of 2.
- SMP: Introduce a new global IRQ clearing logic and tasklist
protection. The previous implementation of clearing global IRQ in
sched_addreadytorun() and sched_removereadytorun() was done too
early. As a result, nxsem_post() would have a chance to enter the
critical section even nxsem_wait() is still not in blocked state.
This patch moves clearing global IRQ controls from
sched_addreadytorun() and sched_removereadytorun() to
sched_resumescheduler() to ensure that nxsem_post() can enter the
critical section correctly. For this change,
sched_resumescheduler.c is always necessary for SMP configuration.
In addition, by this change, task_exit() had to be modified so that
it calls sched_resumescheduler() because it calls
sched_removescheduler() inside the function, otherwise it will cause
a deadlock. However, I encountered another DEBUGASSERT() in
sched_cpu_select() during HTTP streaming aging test on LC823450-XGEVK.
Actually sched_cpu_select() accesses the g_assignedtasks which might
be changed by another CPU. Similarly, other tasklists might be
modified simultaneously if both CPUs are executing scheduling logic.
To avoid this, I introduced tasklist protection APIs. With these
changes, SMP kernel stability has been much improved. From Masayuki
Ishikawa.
- SMP: Fix this_task() to be an atomic operation. In the previous
implementation, this_task() was defined in sched.h by using just a
macro current_task(this_cpu()). However, I found that this is not
atomic and actually sometimes switching CPU happened in executing
the macro when we tested audio steaming plus executing commands via
Telnet. This change resolves this issue by implementing atomic
this_task()in sched_thistask.c which is newly introduced. From
Masayuki Ishikawa.
- SMP: Implements a global scheduler lock capability as part of SMP
support. This allows the scheduler to be locked with no knowledge
or access to the TCB of the currently running task. This is
necessary because accessing the TCB of the currently running task
is, itself, a non-atomic operation. This global scheduler lock
capability was add just to support that atomic access to the TCB.
- SMP: Extend the last global lock change to work with the
LC823450-XGEVK which does not support the atomic fetch add but
does support disabling interprocessor interrupts. Disabling
interprocessor interrupts will also guarantee that the TCB address
calculation is atomic.
- SMP: Fix a infinite recursion problems that a recent changes
introduced into the i.MX6 SMP implementation. This is not seen
with the LC823450 because you can disable inter-processor interrupts
in that architecture; but you cannot in the ARMv7-A/GIC architecture.
- SMP: Remove SMP related logic in sig_dispatch.c. This change
prevents from a deadlock in up_schedulesigaction.c where inter-CPU
signal handling is actually implemented. arch/arm/src/armv7-m: Fix
signal handling for SMP. In previous implementation, signal handling
for SMP was incorrect. Thus, for example, if an inter-CPU signal
happened an incorrect tcb was signaled and caused ASSERT(). This
change fixes the issues and works for both inter-CPU signal handling
and signal handling on the same CPU. From Masayuki Ishikawa.
- Tasking: Add nxtask_create(). Kthread_create() and nxtask_create()
are internal OS functions and should not modify the errno variable.
Convert legitimate uses of task_create() to nxtask_create().
Review handling of returned values from all uses of kthread_create()
(as well as nxtask_create()).
- Tasking: Threads started by board bring-up logic should be kernel
threads, not user tasks.
- Tasking: Threads started by drivers should be kernel threads, not
user tasks.
- Semaphore Usage: Added ECANCELED condition to DEBUGASSERT's
checking sem_wait result From Dmitriy Linikov.

- errno: Add new internal OS function nxsched_setaffinity() that is
identical to sched_isetaffinity() except that it does not modify the
errno value. All usage of sched_setaffinity() within the OS is
replaced with nxsched_setaffinity().
- errno: Internal functions sched_reprioritize() and
sched_setpriority() no longer modify the errno value. Also renamed
to nxsched_reprioritize() and sched_setpriority().
- errno: Add new internal OS function nxsched_getscheduler() that is
identical to sched_getscheduler() except that it does not modify the
errno value. All usage of sched_getscheduler() within the OS is
replaced with nxsched_getscheduler().
- errno: Add new internal OS function nxsched_setparam() that is
identical to sched_setparam() except that it does not modify the
errno value. All usage of sched_setparam() within the OS is
replaced with nxsched_setparam().
- errno: Add new internal OS function nxsched_getparam() that is
identical to sched_getparam() except that it does not modify the
errno value (actually, the previous value erroneously neglected to
set the errno value to begin with, but this fixes both issues). All
usage of sched_getparam() within the OS is replaced with
nxsched_getparam().
- errno: wd_start() is an internal OS function and should not set the
errno value. Reviewed and updated every call to wd_start() to
verify if return value is used and if so if the errno value is
accessed.
- errno: Fix several inappropriate accesses to get_errno() that were
missed in previous changes (some going back to nuttx-7.23). Add new
nxsched_setscheduler() and nxsched_getaffinity() which are
equivalent to their counterparts without the nx on front. These
versions do not modify the errno value. Changed all calls within
the OS to use these newer versions of the functions.
- errno: binfmt/, configs/, graphics/, libc/, mm/, net/, sched/: OS
references to the errno variable should always use the set_errno(),
get_errno() macros.
- drivers/, fs/ and libc/: OS references to the errno variable should
always use the set_errno(), get_errno() macros.

* File System/Block and MTD Drivers:

- FAT: CONFIG_FAT_MAXFNAME may not exceed NAME_MAX (CONFIG_NAME_MAX)
- NFS: Correctly infer file type. The file type is in struct
nfs_statinfo_s's ns_type field, not in the ns_mode field. From
Michael Jung.
- NFS: Fix buffer corruption. In case multiple read requests to the
NFS server are required to fill up the user provided buffer,
nfs_read() might write behind the end of said buffer. This is fixed
with this change. From Michael Jung.
- VFS: reopen() should return NULL when oflags is less than 0, not
equal to 0. Because negative value is returned on failure of
lib_mode2offlags() which converts the mode string into file open
mode flag.
- ProcFS: Fix an error in a common function that manages read data.
- drivers/mmcsd: Respect SDIO_CAPS_DMABEFOREWRITE on CMD25. From
Evgeniy Bobkov.
- AT24xx: Correct page size for AT24C02 part. From Alexander
Oryshchenko.
- mtd_config.c: Add still more error handling (to detect bad
underlying flash implementations). Remove MTD_ERASE that was
erasing data block instead of erase block. This is a partial
revert of 4f18b4. Reported-by: Pascal Speck <iktek01@yahoo.com>

* Graphics/Display Drivers:

- drivers/lcd: Fix the default I2C address of SSD1306 OLED display
(7- vs 8-bit addressing) From Alan Carvalho de Assis.
- drivers/lcd: lcd_framebuffer.c does not need to include board-
specific board.h.
- include/lcd: Eliminate a warning from an SSD1306 header file by
adding a forward reference to struct i2c_master_s. From Sebastien
Lorquet.

* Networking/Network Drivers:

- ARP: Fix an error introduced when ICMP and ICMP6 socket support was
added in NuttX-7.3. A gratuitous ARP (or solicitation) was being
sent after receive of the ECHO replay (advertisement).
- ARP: Fix IGMP multicast address computation on NuttX network stack.
This change fixes the IGMP address computation to allow multicast
UDP messages. The destination address was created with the incorrect
bytes of the given IPv4 address. From Louis Mayencourt.
- ioctl: The existence of the network driver ioctl() method should
depend on CONFIG_NETDEV_IOCTL rather than CONFIG_NETDEV_PHY_IOCTL.
The former enables the method, the later enables a subset of
possible driver IOCTLs.
- TCP: Write buffering logic should not wait for a free buffer if
the socket was opened non-blocking.
- TCP: Fixed bad return value handling in psock_tcp_send(). send()
expects psock_tcp_send() to return a negated errno value, not -1
with the errno set (GN: I added same change for tcp_send_buffered.c
which has the same issue as tcp_send_unbuffered.c) From Pelle
Windestam.
- TCP: Fixes hardfault when network goes done and network monitoring
is in place. From Gianpaolo Ferroni Ariani.
- TCP: tcp_send_[un]buffered.c: Check routing table in
psock_send_addrchck(). Previously only ARP table was considered
when determining if the data will actually be sent. From Juho
Grundstrom.
- TCP: Generalize Juho Grundstrom's IPv4 change for IPv6 as well.
- UDP: Remove some conditional logic that was true if there is only a
single network device, but not true in the multi-device context.
- UDP: In sendto(), return EHOSTUNREACH if the network is down.

* Common Drivers:

- drivers/pipes: In poll logic, fix off-by-one error in calculation
of bytes in the buffer. Buffer calculation in pipe poll setup is
off-by-one when read index is larger than write index. This causes
poll() not getting POLLIN when buffer has one byte as calculation
gives zero bytes in buffer. From Jussi Kivilinna.
- drivers/audio: Improve stability of the WM8776 driver in SMP mode.
Apply irq_spin APIs to improve performance. Repeat to process a
message to avoid deadlock. From Masayuki Ishikawa.
- drivers/ioexpander: Fixed build of PCF8574 driver when its
interrupts aren't enabled by config. From Dmitriy Linikov.
- drivers/syslog: Fixes LOG_UPTO macro to include specified log level.
From Anthony Merlino.
- drivers/sensors: Fix HTS221 sensor reset with BOOT bit From Jussi
Kivilinna.
- drivers/loop: If we want to open read-only in losetup.c, flags
should be O_RDONLY not O_RDWR. From Fabio D'Urso.
- drivers/timers/ds3231.c: Correct some debug statements. From
Alexander Oryshchenko.
- drivers/sensors/lis2dh: Use realtime clock if monotonic is not
available From Juha Niskanen.
- drivers/i2c and drivers/spi: Fix compile error if
CONFIG_DISABLE_PSEUDOFS_OPERATIONS, fix bad NULL checks From Juha
Niskanen.

* ARMv7-A:

- Data Cache: Fix cp15_invalidate_dcache. In cases where more than
one dcache line was to be invalidated, a missing branch label
would result in a false branch target into cp15_flush_idcache. Also
the .size macro was fixed for both cp15_invalidate_dcache. From
Michael Jung.
- SMP: Port the signal-related SMP change by Masayuki Ishikawa to the
ARMv7-A family.

* Extensa:

- SMP: Port the signal-related SMP change by Masayuki Ishikawa to the
Xtensa family.

* Infineon XMC4xxx Drivers:

- XMC4xxx: Only setup USB clock when USB PLL is enabled From Alan
Carvalho de Assis.
- XMC4xxx: Fix USIC_BRG_SCLKCFG definition From Alan Carvalho
de Assis.

* Microchip PIC32MZ

- MIPS32: In up_idle, the kludge that was conditionally enabled if
the work queue was enable appears to be needed even when he work
queue is not enabled on the PIC32MZ.
- PIC32MZ: Fix some typos in debug instrumentation in pic32mz-gpio.c;
fix some typos related to UART5 configuration in pic32mz-serial.c.

* Microchip/Atmel SAMD/L:

- SPI: In sam_spibus_initialize(), the pinmux configuration was
smashing the previous CTRLA register configuration. There are
also some typos in samd_spi.h From Matt Thompson.
- SPI: Fixes g_spi2ops and g_spi2dev using incorrect values From Matt
Thompson.
- SPI: SPI must be disabled before changing the mode bits in CTRLA
register From Matt Thompson.
- DMA: Fix DMA controller support. From Matt Thompson.

* NXP/Freescale LPC17xx Drivers:

- LPC17xx: Disable LPC17 FDR when not used. If a boot loader set the
fractional divider (FDR) the baud rate in nuttx will be wrong
(multiplied by this fraction). So if it is not used, it should be
disabled. From Harald Gutsche.

* NXP/Freescale Kinetis Drivers:

- Kinetis: Correct some Ethernet PHY register bit tests for the
KSZ8081 PHY. From Stewart.

* On Semiconductor LC823450

- arch/arm/src/LC823450: Add SP_DMB() into lc823450_testset.c.
In LC823450, ldrex and strex are not supported. So we implemented
up_testset() with H/W Mutex. However, there was a bug in memory
access order. This change ensures correct memory access order in
up_testset() for LC823450. From Masatoshi Tateishi.

* STMicro STM32 Drivers:

- STM32 F3 RCC: A flash wait state configuration. Flash latency must
be fixed according to sysclk frequency. If this operation is not
done or done after PLL configuration, the STM32 fail to continue
boot operation if the frequency if greater than 24MHz according to
the board variable STM32_SYSCLK_FREQUENCY. Tested on stm32f334-disco
board. From Gwenhael Goavec-Merou.
- STM32 RTC: Make STM32 usable with an external RTC.
- STM32 SPI: Removed unnecessary (and incorrect) speed limitation.
From Alexander Oryshchenko.
- STM32 SPI: I have a SPI bus with both Mode 0 and Mode 3 devices
on it. After performing SPI I/O to a Mode 0 device, switching to a
Mode 3 device locked up the SPI interface. Only zeroes would be
read. I traced the reason for the lock-up to arm/arm/src/stm32f7/stm32_spi.c function spi_setmode(). Changing
the mode causes a spurious SPI clock transmission that confuses the
stm32f7 SPI input hardware. This problem is solved by (1) changing
the SPI mode with SPI (and perhaps DMA) disabled, and (2) flushing
the receive FIFO if the mode change results in garbage in the FIFO.
From Bob Feretich.
- STM32 and STM32 F7: Remove confusing, redundant, and misleading
definitions of STM32_BKP_BASE from the F2, F3, and F4 memory
maps. Unlike the F1, these parts do not have a separate BKP address
region. The BKP registers are with the RTCC address regions.
stm32_bkp.h should only be used for STM32 F1. stm32_rtcc.h should be
used to access BKP registers on F2, F3, and F4.
- STM32 and STM32 F7: Architecture-specific code is not permitted to
modify the errno variable.
- STM32 F4 I2C: Correct some recent changes to STM32F4 I2C that broke
poll mode of operation. From Alexander Oryshchenko.
- STM32 F4 I2C: Corrections to STM32 F4 I2C to restore functionality.
From Alexander Oryshchenko.
- STM32 F4 I2C: Corrections to STM32 F4 I2C to fix the NORESTART
flag. From Alexander Oryshchenko.
- STM32 F7: Fixes a bug in multi-block SD-card operations on the
STM32F7 platform. DBLOCKSIZE must be the size of SD-card block, not
the total amount of transferred bytes. From Evgeniy Bobkov.
- STM32 F7: Fix undefined variable when using USART1 for other
purposes than UART (e.g. SPI). From Frank Benkert.
- STM32 F7: Backport RTC alarm setting changes from STM32L4. Most
notably this fixes RTC getting stuck issue when both alarms were
used. Root cause was writing RTC ISR register contents to RTC CR
register. From Juha Niskanen.
- STM32 L4 Flash: Change flash programming to use page buffer for
unaligned writes. From Juha Niskanen.

* STMicro STM32 Boards:

- Nucleo-L432KC: Fix some bogus logic noted by Fanda.
- configs/nucleo-* and configs/stm32l476vg-disco: Fix more
stm32_userleds.c bogus logic From Juha Niskanen.
- Nucleo-L432KC: Fixed nucleo-l432kc broken build when
CONFIG_USERLED_LOWER defined From Fanda.
- Nucleo-L432KC: Issue #85: /dev/userleds is not working for
Nucleo-L432KC fixed From Fanda Vacek.
- STM32F429I-Disco: Separate SPI4 from MTD init. I was trying to
attach a non-MTD peripheral to an STM32F429I Discovery Board's SPI4
port and was hitting compilation problems, since CONFIG_MTD and
thus 'struct mtd_geometry_s' was not defined. This patch separates
SPI4 initialization logic from MTD initialization logic. From
Michael Jung.
- STM32F103-Minimum: Remove CONFIG_NX_LCDDRIVER dependence from
stm32_ssd1306.c From Alan Carvalho de Assis.

* C Library/Header Files:

- libc/stdio: In dtoa(), up_interrupt_context() is used in a debug
assertion. up_interrupt_context() is not available in the user-mode
phase of the PROTECTED or KERNEL build configurations. In those
configurations, enabling libc floating point support and debug
assertions will result in an undefined reference to
up_interrupt_context().
- libc/netdb: Fixed parsing of DNS response packets having compressed
names ending with pointer. There were troubles parsing response
packets which have compression of QNAME/NAME field when only
trailing part of the name (not the whole name) is replaced with
pointer to another part of the packet. This commit fixes parsing of
such packets. Also I added checks to keep parsing only in bounds of
the read part of DNS response packet. From Dmitriy Linikov.

* Tools

- tools/*.c: Add #define _GNU_SOURCE to all C files that call
asprintf() to eliminate a warning.
- tools/cvsparser.c: Add a check to avoid access past the end
of a fixed size array

* NSH: apps/nshlib:

- apps/nshlib: Fix compile error when CONFIG_NSH_DISABLESCRIPT is not
defined. The field np_flags does not exist if scripting is disabled.

* Examples/Tests: apps/examples:

- apps/examples/touchscreen: Eliminate BOARDIOC_TSCTEST_SETUP.

* Network Utilities: apps/netutils:

- apps/netutils/ftpc: Fix some corner-cases that could cause FTP to
access past the end of valid data.

* Wireless Utilities: apps/wireless:

- apps/wireless/ieee802154/i8shark: Fixes special XBee compensation
by purposely chopping off the FCS. From Anthony Merlino.