NuttX-7.26 ---------- The 126th release of NuttX, Version 7.26, was made on September 8, 2018, and is available for download from the Bitbucket.org website. Note that release consists of two tarballs: nuttx-7.26.tar.gz and apps-7.26.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: - General: Eliminate use of the non-standard type systime_t and replace it the equivalent, standard type clock_t From Gregory Nutt. - General: Replace non critical PANIC with DEBUGPANIC to save the code space From Xiang Xiao. - General: Replace all ASSERT with DEBUGASSERT to save the code space From Xiang Xiao. - Initialization: Add option to mount block device for INIT_FILEPATH case. From anchao. - clock(): clock_systimer() is no longer a system interface. It has been replaced with the equivalent, standard interface clock(). Moved the implementation of clock() from the C library into the OS core. This is necessary because it calls the (now) internal OS function clock_systimer(). clock() is now accessed only via a system call in certain configurations. From Gregory Nutt. - clock Utilities: Move clock_timespec_[add|subtract] to include/nuttx/clock.h From Xiang Xiao. - Binary Loader: Add binfmt_initialize(). All binary formats are now registered centrally vs. in board-specific logic. This simplifies the usage of the binfmt subsystem. From Xiang Xiao. - Binary Loader: Reference default symtab name to binfmt From anchao. - mm: Add mm_heapmember function and reimplement kmm_heapmember base on mm_heapmember since this function is very useful if multiple heaps exist. From Xiang Xiao. - mm: Add {kumm/kmm}_calloc API. Add calloc API for manage user memory and kernel memory in Flat Build/Kernel Build without kernel heap. From zhuyanlin. - pthreads: Add support static pthread stack. Add standard pthread_attr_setstack() and pthread_attr_getstack(). In all cases where the stack is released, add check to see which allocator must be used to free the stack: The user or the kernel allocator. From xuanlin. - Semaphores: Apply the semaphore wait function nxsem_wait_uninterruptible(). This function is a wrapped version of nxsem_wait() that is uninterruptible and convenient for use. From liuhaiyang. - Signals: Add default signal action to SIGKILL. From ligd. - Signals: Update the signal default action logic to support sigaction(). signaction() must be able to handle and input action of SIG_DFL to setup the default signal action; it mast also return SIG_DFL it is replacing the default action. From Gregory Nutt. - Signals: Default Signal Actions. Change some types to superficially simplify. Add configuration options to enabled default signal behaviors on a per-signal basis. I don't think users are prepared for SIGALRM to terminate the task (which is the correct default behavior if you don't change it). Extend the implementation of default signals so that it is totally table driven and extensible by simply mondifying the content of const tables. From Gregory Nutt. - Signals: Add support for SIGINT in addition to SIGKILL. - Signals: Add logic and an interface to determine if a signal can be caught or ignored. sigaction now correctly returns EINVAL on any attempt to catch or ignore such signals (only SIGKILL for now and only if CONFIG_SIG_DEFAULT=y). From Gregory Nutt. - Signals: Add support for default signal actions for SIGSTOP, SIGSTP, and SIGCONT. Add procfs support to show stopped tasks. From Gregory Nutt. - Signals: Add nxsig_action() to solve a chicken and egg problem: We needed to use sigaction to set default actions, but sigaction() would refuse to set actions if the default actions could not be caught or ignored. From Gregory Nutt. - Signals: Add configuration option to selectively enabled/disable default signal actions for SIGSTOP/SIGSTP/SIGCONT and SIGKILL/SIGINT. - Signals: If a task/thread was already blocked when SIGSTOP/SIGSTP was received, it will restart in the running state. It will appear that to the task/thread that the blocked condition was interrupt by a signal and returns the EINTR error. From Gregory Nutt. - Signals: Update signal default STOP action. If waitpid was called with the WUNTRACED then wake up waitpid(). From Gregory Nutt. - IRQs: Monitor the IRQ execution time. This is very useful for measuring the interrupt latency. From Xiang Xiao. - IRQ Dispatch: Add support interrupt chains in NuttX. IRQ chain is very useful in these cases: (1) Multiple hardware connect to the same request line(e.g. PCI), (2) Need multiple driver to support one hardware block (like Linux MFD) From zhuguangqing. - Work Queue: Modify high priority work queue to support multiple threads. From ligd. - System Calls: Add support for getpeername() and get_sockname() system calls. From Gregory Nutt. - System Calls: svcall/sycall logic needs to get the ucontext argument from R4 instead of stack since all syscall parameters pass from registers in syscall.h From Xiang Xiao. - CPU Load Measurement: Support the CPU load measurement using timer_lowerhalf_s interface From Xiang Xiao. - Assertions: Change CONFIG_BOARD_RESET_ON_CRASH to CONFIG_BOARD_RESET_ON_ASSERT, arch/: Implement call to board_reset() if in all implementations of up_assert() when CONFIG_BOARD_RESET_ON_ASSERT=y. From Xiang Xiao. - boardctl(): Add support for board_app_finalinitialize() From ligd. - Architecture Interface: Add prototype for an architecture-specific up_trigger_irq function. From dongjianli. - Architecture Interface: Add the garbage collection hook so each architecture can do custom memory cleanup if necessary. From Xiang Xiao. - Architecture Interface: Add architecture-specific prototypes for conversions between physical and virtual address. From ligd. * File Systems/Block and MTD Drivers - ProcFS: Add support for a procfs entry that will permit examining the environment of any task. From Gregory Nutt. - ProcFS: Add support for proc/self/, a convenient way for getting information about the currently running task. From Gregory Nutt. - HostFS: Add support for open() append mode From anchao. - HostFS: Add ftruncate support. From Xiang Xiao. - HostFS: Remove ARCH_SIM dependence since other architectures (e.g., arm semihosting) could support hostfs too From Xiang Xiao. - HostFS: Support remote directory names without a trailing '/' From ligd. - HostFS: Add re-try when hostfs mount() fails From ligd. - NFS: Update NFS client mount to VER3 From zhangyuan7. - Partitions: Add PTABLE parser fs/partion: Add a partition parser framework fs/driver/fs_blockpartition.c: Add register_blockpartition for block partition From Xiang Xiao. - MTD: Add gd25 driver From wangyanjiong. - MTD: In MTD partitions, copy the partition name to internal buffer so that the caller can free the name argument From Xiang Xiao. - MTD: Support initialization of an FTL block device with a custom name From Xiang Xiao. - MTD: FTL: Reduce size of stack buffer from 64 to a maximum size as determined from NAME_MAX. From Gregory Nutt. - VFS poll(): Send poll() notification when the Tx buffer is flushed From ligd. - VFS fstat(): Add file_fstat() function for internal OS use. From ligd. - VFS fcntl(): Add file_fcntl, psock_fcntl, and psock_dupsd for use within the kernel. From Xiang Xiao. - VFS dup2(): Addpsock_dupsd for use within the kernel. From Xiang Xiao. - VFS poll(): Add poll use in kernel space. From dongjianli. - VFS select(): Make select be more consistent with Linux man page: 'The timeout ... Some code calls select() with all three sets empty, nfds zero, and a non-NULL timeout as a fairly portable way to sleep with subsecond precision.' From anchao. * Networking/Network Drivers: - Sockets: Add getpeername() support From ligd. - sockopt(): Move psock check from [get|set]sockopt to psock_[get|set]sockopt From Xiang Xiao. - getsockname(): Add psock_getsockname function From Xiang Xiao. - Netlink Sockets: This brings in a fragmentary, experimental implementation of NETLINK sockets. There is not too much to that socket support on this initial commit, just the netlink socket framework. However, I decided to bring it into master because there is a enough that I would not want to lose what is in place. And since it is dependent on CONFIG_EXPERIMENTAL, its presence on master should be innocuous. From Gregory Nutt. - Interface Indexes: Add driver interface index support. Add implementation of if_nametoindex() and if indextoname(). Raw AF_PACKET sockets now depend on CONFIG_NETDEV_IFINDEX. Add syscall support for if_nametoindex() and if_indextoname(). Includes an algorithm to prevent an interface index from being reused until all network interfaces have by assigned once. The prevents removable devices from being removed, unregistered and re-installed, re-registered and keeping the same interface index. From Gregory Nutt. - Driver Interface: Add devif_loopback() to check the loopback case where a packet is being sent to itself. Modify the net driver to call this function in this case. This function will simply re-inject the packet back into the network and the network driver will not put anything on the wire. From Xiang Xiao. - Network Devices: Remove all references to CONFIG_NET_USER_DEVFMT. That feature is now unconditionally enabled. This was done because (1) the feature does not require very much additional memory, and (2) it causes confusion in the configuration due to the additional complexity. Any network drivers that fail to zero the device structure interface name field (d_ifname) because calling netdev_register() will, however, get a nasty surprise. From Gregory Nutt. - Network Devices: Add support for Microchip LAN91C111 driver From Xiang Xiao. - Network Devices: netdev_findby_ipv[4|6]addr return netdev_default() as last resort but don't return loopback device if another network device is in the UP state. From Xiang Xiao. - Network Device IOCTLs: Add si_ioctl callback and net_ioctl_arglen so usrsock could forward the ioctl to the remote end/ From dongjianli. - IPv6: Rename g_ipv6_allzeroaddress with the more meaning g_ipv6_unspecaddr since the all-zero address is the IPv6 unspecified address (sometime IN6_ADDR_ANY). Replace more inline tests for IPv6 multicast with common net_is_addr_mcast() macro. From Gregory Nutt. - ARP: arp_find() now checks if the target IP belongs to one of the local network devices. From Xiang Xiao. - ARP: Make the function arp_find() thread-safe. It now returns a copy of the MAC address from the ARP table entry, rather than a potentially unstable reference to the ARP table entry. From Gregory Nutt. - TCP: Re-work of TCP receive window size algorithm. The new logic is based only on the ability to buffer TCP read-ahead data. From Gregory Nutt. - UDP: Add support for the UDP_BINDTODEVICE protocol socket option From Sebastien Lorquet. - Slip: Uncomment the prompt of NET_SLIP_PKTSIZE in Kconfig file. From Xiang Xiao. - USRSOCK: Combine some the duplicated logic. From Xiang Xiao. - USRSOCK: Optimize option dependence From Xiang Xiao. - USRSOCK: Add the listen/accept/getpeername/ioctl support From dongjianli. * Other Common Device Drivers: - Analog DAC: Add driver for digital to analog converter DAC7571. Nucleo-L422KC: Add support for a connect DAC7571 converter. From Daniel Pereira Carvalho. - Audio Interface: Change member samp of apb to pointer so driver can customize sample buffer allocation From ZhongAn. - Audio Interface: Add ioctl cmd 'AUDIOIOC_SETBUFFERINFO' so user space could config the buffer From ZhongAn. - Audio Interface: Add hardware format support From anchao. - I2S Interface: Add i2s_rxchannels and i2s_txchannels methods to the I2S lower half interface. From ZhongAn. - Audio: Move the I2S character driver to a dedicated folder. From Xiang Xiao. - Audio: Add audio_i2s device driver. From ZhongAn. - Audio: Add the composite audio driver From Xiang Xiao. - Crypto: Move dev_urandom.c into new crypto folder. From Xiang Xiao. - GPIO driver: Add gpio_pin_unregister function to GPIO driver driver/ioexpander: Add pinset struct to GPIO driver for interrupt pins larger than 64. Initialize pintype/inttype when registering ioexpander device. Add SETPINTYPE ioctl command to the GPIO driver. From zhuyanlin. - I2C Interface: Add a definition to distinguish a new START of messages from a repeated start. No lower-half I2C drivers actually implement this new flag bit, however. In I2C write/read logic use new repeated START definition where appropriate. Rename I2C_M_NORESTART to I2C_M_NOSTART since it may be used in other contexts than a repeated start. Add comments to clarify setup for repeated start. From Gregory Nutt. - I2C: Add the standard speed macros. From dongjiuzhu. - Leds: Add support to MAX7219 to control 7-segment displays. From Alan Carvalho de Assis. - Power: PM: Add pm_stay and pm_relax function so special apps(e.g. mediaplayer) could disable suspend during playback much like linux kernel counterpart From Xiang Xiao. - Power: PM: Add pm_querystate function From zhuguangqing. - Power: PM: Don't update the power state in work thread: (1) Simplify the code logic and remove the work queue dependence, (2) Power calculation is too simple to delay into the work queue From Xiang Xiao. - Power: PM: Decrease the power state in the reverse order. Since the child driver need power off before parent driver. From zhuguangqing. - Power: PM: Make power manager service available as soon as possible: (1) Initialize g_pmglobals at the definition, (2) skip hold the lock if OS isn't ready From Xiang Xiao. - Power: PM: Add PM_RESTORE to notify driver that device exit WFI so the driver could restore state. For example, WDT may stop counting before enter low power state and restore the counting again in PM_RESTORE notification From zhuguangqing. - Power: PM: Add timer to decrease PM level automatically. From ligd. - PTYs: Add support so that a PTY can poll for both IN/OUT event simultaneously. From ligd. - PWM: Move pwm.c into pwm folder From Xiang Xiao. - RTC Interface: Extend struct rtc_time by adding. From Xiang Xiao. tm_nsec if RTC supports hiresolution time. From Xiang Xiao. - Sensors: Add support for Telair T6713 carbon dioxide sensor. From Juha Niskanen. - Sensors: Add support for LSM303AGR and LSM6DSL sensors From DisruptiveNL. - Sensors: Add driver for DHTxx sensor. From Ouss4. - syslog: Enable a partial, crippled version of syslog_flush(); Call syslog_flush() from assertion handling logic of all architectures. From Gregory Nutt. - syslog: Channel configuration. Decouple SYSLOG_SERIAL_CONSOLE and ARCH_LOWPUTC. Since some hardware can output log to the special debug channel not serial. From anchao. - syslog: Support pre-pending a prefix string to log output if enabled. This very useful to identify which CPU send out the log in AMP SoC. From anchao. - Serial: Add Ctrl-C/Ctrl-X support. From ligd. - Serial: Support UART direct write for non console device From xuanlin. - Serial: It is no longer necessary to restrict Ctrl-C handling to the FLAT build sched/signal: Add a new configuration option to select signal default actions, separate handling of signal default actions from both task startup logic and from the serial TTY Ctrl-C logic. Add a signal set in the group structure to keep track of what signals have been set to the default action. In dispatching signals in PROTECTED or KERNEL mode, use this signal set to determine if the default signal handler is attached and dispatch the signal in kernel mode for the default actions. From Gregory Nutt. - Serial: Integrate new Ctrl-C logic with the ISIG flag in the termios c_lflag. From Gregory Nutt. - Serial: Use SIGINT instead of SIGKILL when control-C is pressed. From Gregory Nutt. - Serial: Add support for Ctrl-Z. This works just like the recently added Ctrl-C support except that SIGSTP is sent when the Ctrl-Z characters is encountered vs. SIGINT. From Gregory Nutt. - 16550 UART: Add a configuration, analogous to the STM32 configuration option, to suppress the NuttX standard re-ordering for /dev/ttySN for special case of the 16550 UART. - 16550 UART: Add CONFIG_SERIAL_UART_ARCH_MMIO option so the a memory mapped device doesn't need to provide uart_getreg() and uart_putreg() implementations. - 16550 UART: Add stub implementations of DMA-related methods in the 16550 UART v-table. From ligd. - 16550 UART: Add serial termios handling From anchao. - 16550 UART: Support 16550 auto hardware flow control drivers/serial/uart_16550.c: Add configuration option CONFIG_16550_SUPRESS_INITIAL_CONFIG. This is identical to the standard configuration in arch/Kconfig CONFIG_SUPPRESS_UART_CONFIG, but with scope of only the 16550 driver. From Xiang Xiao. - syslog: Make timestamp output same as linux kernel. It's very useful if NuttX syslog retarget to Linux syslog. From Xiang Xiao. - Timers: Add maxtimeout method to the struct timer_ops_s interface From Xiang Xiao. - Timers: Add a new method to the struct oneshot_operations_s interface to get the current time from a oneshot timer driver (if it is available from the lower half) From Xiang Xiao. - Timers: Implement timer arch API on top of timer driver. From Xiang Xiao. - Timers: Implement alarm arch API on top of oneshot driver interface. From Xiang Xiao. - Timers: Implement RTC arch API on top of RTC driver interface. From Xiang Xiao. - CDC/ECM: Adds USB device support for CDC/ECM From Michael Jung. - USB Host: Add support for the Maxim M3421E USB host driver. Not yet fully tested. From Gregory Nutt. * General Architecture-Specific: - All architectures: Make sure the up_irq_enable() is available on all architectures. From Gregory Nutt. * Simulation - Simulator Configurations: Add dsptest configuration. From Mateusz Szafoni. - Simulator: In network driver (1) Remove up_comparemac() check for matching MAC address. Let's trust that the tap device just return the packet which belong to us like other real network device hardware. (2) Add network device statistics support. From Xiang Xiao. * ARM: - ARM (all): Add CONFIG_DEBUG_MEMFAULT to Kconfig. From Masayuki Ishikawa. - ARM: (1) Add semihost support for syslog, (2) Add semihost support for HostFS From Gregory Nutt. * ARMv6-M: - ARMv6-M: Introduce CONFIG_DEBUG_HARDFAULT_INFO to up_hardfault.c From Masayuki Ishikawa. * ARMv7-M: - ARMv7-M: Removes support for the dedicated vector handling from the many older architectures. Only common vectors are now supported. From Gregory Nutt. - ARMv7-M: Introduce CONFIG_DEBUG_HARDFAULT_INFO to up_hardfault.c From Masayuki Ishikawa. - ARMv7-M: Implement SYSTICK timer driver From Xiang Xiao. - Simulator: Add loadable demo for arch sim. From anchao. - ARMv7-M: Add logic to trigger ARMv7-M interrupts and exceptions. From Gregory Nutt (from sample logic by Xiang Xiao). - ARMv7-M: Add NVIC definitions needed by up_trigger_irq(). From Gregory Nutt. * ARMv7-R: - ARMv7-R: Add general interrupt controller. This is based on ARMv7-A gic controller code. From EunBong Song. - ARMv7-R: Add invalidate dcache in arm_head.S. From EunBong Song. * Infineon XMC4xxx Drivers: - XMC4 GPIO: Add a specific bit encoding to GPIO driver for opendrain GPIO pin. From Alan Carvalho de Assis. * Infineon XMC4xxx Boards: - XMC4500-Relax: Add support to MAX6675 on XMC4500-Relax board. From Alan Carvalho de Assis. * Microchip PIC32MX Boards; - PIC32MX: Update some PIC32MX configurations so that either the MPLAB or Penguino toolchains may be used. From Gregory Nutt. * Microchip/Atmel SAMD2x/L2x: - SAMD2x/L2x: Rename all usage of samdl/SAMDL to samd2l2/SAMD2L2 to make room in the name space for samd5e5/SAMD5E5 From Gregory Nutt. * Microchip/Atmel SAMD5x/E5x: - SAMD5x/E5: Add a port to the SAMD5x/E5x MCU family. From Gregory Nutt. * Microchip/Atmel SAMD5x/E5x Drivers: - SAMD5x/E5x SPI/I2C: Bring in untested SPI and I2C drivers from SAMD2L2. From Gregory Nutt. - SAMD5x/E5x DMA: Leverage the SAMD2L2 DMA controller. From Gregory Nutt. - SAMD5x/E5x USB: Bring the SAMDL2 USB driver into the SAMD5E5 port. From Gregory Nutt. * Microchip/Atmel SAMD5x/E5x Boards: - Metro M4: Add support for the Adafruit Metro M4 board. From Gregory Nutt. - Metro M4: Add an option to build the Metro M4 image to run out of SRAM. This ought to be a safer and quicker way to do the initial bring-up (having bricked the first Metro M4 due to a bad FLASH image). From Gregory Nutt. - Metro M4: Add a configuration option to use OSCULP32K instead of XOSC32K. From Gregory Nutt. - Metro M4: After some final fixes related to the SERCOM console, the basic NSH configuration appears fully functional. From Gregory Nutt. - Metro M4: Verify the CMCC and enable it by default in the NSH configuration. From Gregory Nutt. * Microchip/Atmel SAMv7 Drivers: - SAMv7 CAN: Add ability for CAN BUS_OFF autorecovery according ISO11898-1:2015. With this change we added an ioctl for triggering the autorecovery sequence for BUS_OFF to the CAN-driver and the SAMV7 low-level driver. According the datasheet: If the device goes Bus_Off, it will set MCAN_CCCR.INIT of its own accord, stopping all bus activities. Once MCAN_CCCR.INIT has been cleared by the processor (application), the device will then wait for 129 occurrences of Bus Idle (129 * 11 consecutive recessive bits) before resuming normal operation. At the end of the Bus_Off recovery sequence, the Error Management Counters will be reset. During the waiting time after the resetting of MCAN_CCCR.INIT, each time a sequence of 11 recessive bits has been monitored, a Bit0 Error code is written to MCAN_PSR.LEC, enabling the processor to readily check up whether the CAN bus is stuck at dominant or continuously disturbed and to monitor the Bus_Off recovery sequence. MCAN_ECR.REC is used to count these sequences. From Frank Benkert. * NXP Freescale i.MX RT Drivers: - i.MXRT RTC: Add support for the i.MXRT RTC. This is code complete (with limited features and options) but untested. The HPRTC is functional. However, if the LPSRTC is enabled, then there is a hang during LPSRTC initialization. It appears that there is some problem in providing clocking and initializing the LPSRTC domain. From Gregory Nutt. - i.MXRT SNVS: Add trivial SNVS from Rev 1. of the Reference Manual. From Gregory Nutt. - i.MXRT LSPI: IMXRT1050 LPSPI register and bit definitions added. From Ivan Ucherdzhiev. - i.MXRT Serial: IMXRT1050 LPUART TERMIOS support added. From Ivan Ucherdzhiev. * NXP Freescale i.MX RT Boards: - IMXRT1050-EVK: Add knsh configuration. PROTECTED mode NSH build. From Gregory Nutt. * NXP Freescale Kinetis: - Kinetis: Add DMA support. From David Sidrane. * NXP Freescale Kinetis Drivers: - Kinetis: Use circular DMA as an option to augment the RX FIFOs in the Serial driver. From David Sidrane. * NXP LPC54xx: - LPC54xx: The LPC54608 can only run at a maximum frequency of 180Mhz. This configuration requires uses the clk_in, external crystal clock, to drive the PLL. When that input was selected, the board bootup failed waiting for the PLL to lock. After referring the driver from NXP, we should turn on power sources for the ext clock if system pll input select clk_in. NOTE that the LPC54628 did not require this step... perhaps because the system oscillator power was already enabled. From kxjiang. - LC823450: Add support for mpu and userspace LC823450-XGEVK: Add kostest PROTECTED build LC823450-XGEVK: Add knsh PROTECTED build From Masayuki Ishikawa. * NXP LPC54xx Boards: - Lpcxpresso-LPC54628: Update lvgl board config to use the new version From Alan Carvalho de Assis. * On Semi LPC23450 Drivers: - LC823450 Bluetooth: Add lc823450 Bluetooth support. From Masayuki Ishikawa. - LC823450 I2S: Add tx start threshold to lc823450_i2s.c In addition, lc823450_i2s_send() now accepts byte-aligned stream. From Masayuki Ishikawa. - LC823450 SPI: Add SPI flash driver for lc823450. NOTE: Only bus accelerator mode is supported. From Masayuki Ishikawa. - LC823450: Change C-Buffer under-level control. The under-level setting was changed from 1KB to 55KB. In previous implementation, the setting can be changed by the tx threshold but it is fixed at startup. Also, check write size and adjust alignment if needed. From Masayuki Ishikawa. * On Semi LPC23450 Boards: - LC823450-XGEVK: Add loopback test for digital MIC on lc823450 via i2schar driver. From Masayuki Ishikawa. - LC823450-XGEVK: Add lc832450 elf test. From Masayuki Ishikawa. - LC823450-XGEVK: Add posix_spawn configuration From Masayuki Ishikawa. * STMicro STM32: - STM32 L4: Add initial support to STM32L4+ chips From Juha Niskanen. - STM32 H7: A partial port to the STMicro STM32H7 by Simon Laube was brought in from the PX4 repositories. Numerous changes were make(by Mateusz Szafone). The basic STM32 H7 NSH configuration is now functional, thanks to Mateusz Szafoni. * STMicro STM32 Drivers: - STM32 F0, F1-F4, F7, L4, H7: Added Single Wire Kconfig variable. From David Sidrane. - STM32 DAC: Set OUTEN bit for DAC1CH2 and DAC2CH1 power/motor. Direction parameter is now int8 + add overload fault. From Mateusz Szafoni. - STM32 F1-F4 ADC: Allow multiple channels without DMA on STM32L15XX. From Juha Niskanen. - STM32 F1: Add FLASH register definitions for F1 parts that have dual banked FLASH. From Dmitriy Linikov. - STM32 F2: Added progmem interface support for STM32 F2 From Dmitriy Linikov. - STM32 F4: Ports STM32 LTDC and STM32 DMA2D to use the framebuffer interface From Marco Krahl. - STM32 F7: This change ports Marco Krahl's STM32F4 framebuffer overlays for the LTDC and DMA2D into the STM32F7. That driver was same as the STM32 F4 driver. From Gregory Nutt. - STM32 F7: Port input capture from stm32. From Juha Niskanen. - STM32 F7 FLASH: Ported the STM32 F2/F4 driver to the STM32 F7 platform. From Evgeniy Bobkov. - STM32 F7 SDMMC: Add SDIO card support to SDMMC driver. From Ramtin Amin. - STM32 F7 Serial: Previous logic would invalidate the data cache as each byte was read from the DMA buffer. This change adds logic to invalidate the data cache less frequently by monitoring the state of the Rx DMA buffer cache coherency and invalidating only regions as necessary. From Evgeniy Bobkov. - STM32 F7: Add up_stackcheck.c From Daniel Agar. - STM32 F7: Port the low-level PM functions to STM32 F7. From Juha Niskanen. - STM32 L4: STM32L4 has fetchadd and testset From Juha Niskanen. - STM32 L4: Added custom pin mapping for STM32L4X2XX processors. From Daniel P. Carvalho. - STM32 L4 FLASH: stm32l4xrxx: allow board to override flash wait states From Juha Niskanen. - STM32 L4: Some updates to analog peripherals ADC, COMP and DFSDM for STM32L4XR From Juha Niskanen. - STM32 L4: Add getstatus and getperiod() method to the timer driver (includes coding standard changes made prior to commit) From Goden Freemans. - STM32 H7: Remove old references to RXDMA. Add configuration - STM32 H7: Remove old references to RXDMA. Add configuration option to select the Rx FIFO threshold level. From Gregory Nutt. * STMicro STM32 Boards: - STM32F103 Minimum: Add blackpill LED support From Russ Webber. - Viewtool-STM32F107: Add a TCP performance test using apps/examples/tcpblaster. From Gregory Nutt. - Viewtool-STM32F107: Add support for the MAX3421E to the Viewtool-STM32F107 board support From Gregory Nutt. - STM32F334-DISCO: Use a PID controller from libdsp in the BuckBoost driver. From Mateusz Szafoni. - STM32F4-Discovery: Remove STM32F4BB dependence from RNDIS; add RAMDISK support. From Alan Carvalho de Assis. - STM32F4-Discovery Add board support for MAX7219 as numeric display controller. From Alan Carvalho de Assis. - Olimex-STM32-P407: Add kernel ELF (kelf) configuration. From Gregory Nutt. - Olimex-STM32-P407: Add a kmodule configuration that can be used for testing installation of kernel modules in the protected build. From Gregory Nutt. - Olimex-STM32-P407: Add logic to support initialization of the kernel module symbol table installed in the pass1/ directory during the application phase of the build. The kmodule configuration appears to be fully functional. From Gregory Nutt. - Olimex-STM32-P407: Add board support for the DHTxx sensor. From Ouss4. - STM32F476G-DISCO: Add support for STM32F746G-disco board LCD. From Marcin Wyrwas. - STM32F476G-DISCO: Add a configuration to build working nxdemo application From Fanda. - STM32F476G-DISCO: Add support for STM32F746G-disco board SDRAM Changed fb config to use SDRAM. From Marcin Wyrwas. - STM32F476G-DISCO: Add touchscreen support and a LittlevGL demo for STM32F746G-DISCO From Marcin Wyrwas. - Nucleo-L476RG: Add support for an external SPI-driven SD card on the Nucleo-L476RG. From Gregory Nutt. - Nucleo-L476RG: Add support for LSM303AGR and LSM6DSL sensors From DisruptiveNL. - Nucleo-H743ZI: Use Nucleo Virtual console as default console in the NSH configuration From Mateusz Szafoni. - STM32L4R9-DISCO: Add stm32l4r9ai-disco support. From Juha Niskanen. - B-L475E-IOT01A: Add timer driver support. From Goden Freemans. * Libraries/Header Files: - libc endian: Add support for endian.h. From Gregory Nutt. - libc net: Add inet_aton() From Juha Niskanen. - libc netdb: Add getaddrinfo() and friends. From Juha Niskanen. - libc termios: Add lib_cfmakeraw.c From Masayuki Ishikawa. - libc stdlib: Add implementation of random() and srandom(). From Gregory Nutt. - libc unistd: Add a crippled version of daemon(). From Gregory Nutt. - libdsp: All floats with f-sufix libdsp: (1) add precision option for library, (2) add debug option for library and assertions in functions, (3) add current samples correction for SVM3, (4) add some motor control specific functions, (5) add basic speed observer, (6) fix phase shift in SMO observe, (7) add more logic to FOC. From Mateusz Szafoni. - include/nuttx/compiler.h, include/poll.h: Add logic to determine if the compiler supports anonymous structures and unions. From Gregory Nutt. - include/nuttx/mutex.h: Add inline wrapper functions to more clearly support semaphores when used as mutexs. From QianWenfa. - include/nuttx/nuttx.h: Added nuttx.h header file which is analogous to the linux.h header file. Currently, it contains on the definition of the container_of() macro. From zhuyanlin. - include/queue.h: Add dq_tail marco From zhuguangqing. - include/stdio.h: Add prototypes for popen() and pclose(). Actual implementation is in apps/system/popen() From Gregory Nutt. - include/sys/param.h: Add a dummy sys/param.h header file. This is not a standard file but is used by other systems and having the dummy file may minimize some porting efforts. From Gregory Nutt. * Tools: - nuttx/tools/kconfig2html.c: Due to new usage, tool needs to be able to handle configuration files with names other than Kconfig. From Gregory Nutt. - nuttx/tools/kconfig2html.c: Update tool to handle tristate types. From Gregory Nutt. - nuttx/tools/Config.mk: Add function CATFILE definition. Currently only used in apps/builtin/Makefile. From Gregory Nutt. - nuttx/tools/Config.mk: Add the recursive wildcard function, RWILDCARD, to Config.mk. From Gregory Nutt. - nuttx/tools/testbuild.sh: Add an option to specify the location of nuttx directory. From Gregory Nutt. - nuttx/tools/refresh.sh: Add a --prompt option that will let you use --silent but will prompt before overwriting the original defconfig. From Gregory Nutt. - nuttx/tools/link.sh. Update link.sh per suggestions by Mark so that it can be used with MSYS vs copydir.sh. From Gregory Nutt. - nuttx/tools/mkexport.sh: Save the System.map file and User.map file (if it exists) in the export package so that it can be used to extract addresses. From Gregory Nutt. - nuttx/tools/mkexport.sh: Save the name of the STRIP tool too. From Gregory Nutt. - nuttx/tools/nxstyle.c: Add capability to detect multiple blank lines. Single spacing required by the coding standard. Also coding standard fixes to server .c files for problems found during testing nxstyle. From Gregory Nutt. - apps/tools: Add +x to mksymtab.sh. From Masayuki Ishikawa. - apps/tools/define.sh and define.bat: Move a copy of define.bat and sh from nuttx/tools to apps/tools so that they will be available for the import build. From Gregory Nutt. * Build System: - Apps/ Build System. The apps/ build system has undergone a major renovation to better support building applications as ELF modules. Module selections have changed from 'bool' to 'tristate' types. This means that building an ELF now is as simple setting the value to 'm'. This effort required many changes, too many to summarize here. The solution was contributed by Masayuki Ishikawa, Anchao An, and Xiang Xiao (and myself to a lesser extent). - NuttX/ Build System: This change extends support for the two-pass build. Its primary purpose is to incorporate source logic generated by applications into the kernel phase of the build. In the two pass build, the application logic is built during the first phase, pass 1. In that phase, the application may generate and install source files in the pass1/directory. The operating system is built during phase 2 of the build. At that time, those source files in the pass1/ directory will be built and incorporated into the kernel address space. The primary purpose of the pass1/ directory is to such application-generated kernel symbol tables. For an example of the use of this feature, look at apps/examples/module/drivers/Makefile. Kernel symbol tables are needed to support kernel modules. Of course, addition board-specific logic in, say, configs/<board>/src would have to be included to make use of the application-installed symbol tables. From Gregory Nutt. - Remove CONFIG_ARCH_CALIBRATION. It is awkward to use and no longer necessary now that we have apps/examples/calib_udelay. From Gregory Nutt. - Build System: With recent changes to apps/ all configurations that build applications as modules must now also select CONFIG_APPS_LOADABLE. From anchao. - Build System: Add dynamic application loadable support. From anchao. - Build System: Add configuration CONFIG_ARCH_GNU_NO_WEAKFUNCTIONS to suppress use of weak functions. Some gnu derived toolchains do not support weak symbols. From Xiang Xiao. - Kconfig: Move 'option modules' from NSH_FILE_APPS to BUILD_LOADABLE From anchao. - apps/ Build System: Introduce a build system for loadable apps for nsh. Add 'option modules' to NSH_FILE_APPS so that a user can change an application configuration to tristate (y/n/m) - apps/import: Add Makefile.symtab which can be used to compile the dynamically created symbol table C file. Also adds tools/mksymtab.sh. From Gregory Nutt. * NSH: apps/nshlib: - apps/nshlib: Add parsing support for back-slash quoted characters. Currently only implemented properly if CONFIG_NSH_ARGCAT is also selected. This commit is in response to Bitbucket Issue 11 opened by Maciej Wójcik From Gregory Nutt. - apps/nshlib: Add inverted logic support in the form of 'if ! <cmd>' From Beat Küng. - apps/nshlib: Expand reboot and poweroff commands to include a second, optional mode argument From ligd. - apps/nshlib: Add a force flag (-f) to mksmartfs command. SmartFS will be formatted only if (1) the FLASH does not already hold a SmartFS, or (2) the force flag is set. From Xiang Xiao. - apps/nshlib: NSH prompt string is now configurable. nsh> is still the default. From Xiang Xiao. - apps/nshlib: Add control-C support for terminating built-in and exec'ed file tasks. From ligd. - apps/nshlib: Call BOARDIOC_FINALINIT after start-up script (or immediately after BOARIOC_INIT is there is no start-up script). From ligd. - apps/nshlib: When using waitpid() to wait for a built-in application or a file application to exit. Add the WUNTRACED options to so the the waitpid() call will also be awakened if the waited-for task is stopped as well. From Gregory Nutt. * NSH Builtins: apps/builtin: - apps/builtin/Makefile. This commit changes apps/builtin to search the registry recursively. By supporting directories, external projects can install the hooks into the registry and easily clean them up and reinstall if something needs to be updated. Based on an idea from Anthony Merlino. From Gregory Nutt. * Examples/Tests: apps/examples: - apps/examples/calib_udelay: Add tool for calibrating CONFIG_BOARD_LOOPSPERMSEC From Juha Niskanen. - apps/examples/dhtxx: Example for the DHTxx sensor. From Ouss4. - apps/examples/dsptest: Add unit test for NuttX DSP library From Mateusz Szafoni. - apps/examples/elf: CROMFS and ROMFS configuration currently only usable in FLAT build. Add configuration to use ELF objects on external media like SD card or USB drive instead. From Gregory Nutt. - apps/examples/elf: If the test ELF files are on media in removable media such as SD or USB FLASH, the wait until the media has been installed and initialized before starting the test. From Gregory Nutt. - apps/examples/fb: Adds example to test framebuffer overlay From Marco Krahl. - apps/examples/gps: Add GPS example using MINMEA lib From Alan Carvalho de Assis. - apps/examples/i2sloop: Add i2sloop application. This application can be used to test I2S loopback like: ' nsh> i2sloop &'. From Masayuki Ishikawa. - apps/examples/lvgldemo: Update LVGL to version 5.1.1 From Alan Carvalho de Assis. - apps/examples/module: Add support for CROMFS and for stripping symbols from ELF module binaries. From Gregory Nutt. - apps/examples/module: Add support for automounting removable media. This involves a wait for the block driver to become available before performing the mount. From Gregory Nutt. - apps/examples/module: When built in the PROTECTED or KERNEL modes, the symbol table is not built by the application. That is because the build will fail since the kernel module depends on internal OS symbols thar are not available to the application build. With this change the examples does not attempt to build the kernel symbol table in these modes. Instead it just copies the kernel module symbol table into the nuttx/pass1 directory where it can be build directly into the OS during pass2 of the build. From Gregory Nutt. - apps/examples/ostest: Add a small test for SIGSTOP, SIGCONT, and SIGKILL actions. From Gregory Nutt. - apps/examples/popen: Add a test of popen/pclose. From Gregory Nutt. - apps/examples/powerled: Add arch initialization. From Mateusz Szafoni. - apps/examples/tcpblaster: Add TCP performance measurement test. From Gregory Nutt. * System Utilities: apps/system - apps/system/cle: Usage improvements including command line history (taken from readline) and support for addition control characters. From mst. - apps/system/i2c: Adapt to rename I2C_M_RESTART->i2C_M_START. I2C_M_NOSTOP should be in flags of first message in every write-read and write-write message sequence. From Gregory Nutt. - apps/system/i2c: Allow registers besides 0x00 in the dev command. From Jakob Haufe. - apps/system/nsh: Add logic to automatically register an application symbol table as part of NSH initialization. From Masayuki Ishikawa. - apps/system/nsh: The symbol table name and size variable names can now be configured. From Gregory Nutt. - apps/system/nsh: Move apps/examples/nsh to apps/system/nsh. It has become so entrenched that it is hardly an example these days. May as well formalized it as a system task. From Gregory Nutt. - apps/system/nxplayer: Refactor nxplayer.c. Apply netlib_parsehttpurl() and remove unnecessary usleep(). From Masayuki Ishikawa. - apps/system/nxplayer: Release buffer before session and release semaphore in nxplayer_setvolume system/nxplayer/nxplayer.c: Remove & for apb->samp reference. It is already a pointer. From Xiang Xiao. - system/nxplayer/nxplayer.c: Add playraw command From ZhongAn. - apps/system/nxrecorder: Add nxrecorder application From ZhongAn. - apps/system/popen: Add an implementation of the standard popen() and pclose() OS interfaces. These are implemented as applications vs. part of the OS because they depend on NSH. Untested on initial commit. From Gregory Nutt. - apps/system/system and popen: Adapt so that these can be used in the KERNEL build mode. In this case, simply replace task_spawn() with posix_spawn(). This depends on the existence of some environment where /bin/sh exists and can be used to execute one NSH command. For the case of system(), this change was more complete because it previously used task_create(). Now it uses either task_spawn() or posix_spawn(), depending upon the configuration. From Gregory Nutt. - apps/system/taskset: Add taskset command for SMP systems. This command can be used to retrieve or set a process's CPU affinity. For example, nsh> taskset -p 4 pid 4's current affinity mask: 2 nsh> taskset -p 3 4 pid 4's current affinity mask: 3 nsh> taskset -p 1 busyloop & From Masayuki Ishikawa. - apps/system/zmodem: Support -p <path> for rz to change the folder for the received file. Switch debug output from printf to syslog. Send the next packet for ZME_ACK in ZMS_SENDING to avoid rz on the host side stuck make send work reliable even without hardware flow control. From Xiang Xiao. * Network Utilities: apps/netutils: - apps/netutils/dhcpc: Activates BINDTODEVICE if available. From Sebastien Lorquet. * Wireless Utilities: apps/wireless: - apps/wireless/i8sak: i8sak daemon now gets shutdown if not in use. Previously, once the i8sak daemon was started, by running any command, it would stay running. This means that if you want to use i8sak to setup your network, but then want exclusive access to the char device, or network device, you have to manually shutdown the i8sak daemon. Now the daemon stays active as long as required to finish any commands, or stays open if a new command keeps it on, but when all work is finished, it shuts down. From Anthony Merlino. * Filesystem Utilities: apps/fsutils: - mkfatfs: Clean up some name BS_ and MBR_ refer to the same record and should use the same naming (MBR_). From Gregory Nutt. - mkfatfs: Add definitions for the FAT boot record (FBR). From Gregory Nutt. - mksmartfs: Add a check to see if the SmartFS is already formatted. From Xiang Xiao. * Graphic Utilities: apps/graphics: - graphics/littlevg/: Update LVGL to version 5.1.1 From Alan Carvalho de Assis. * Test Utilities: apps/testing: - testing/unity: Add Unity - unit testing library from ThrowTheSwitch.org. From Mateusz Szafoni. 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: - Signals: Signal handlers maybe run with interrupts enabled or disabled, depending on how the task the received the signal was blocked. (i.e.: If sem_wait() is called, then we disable interrupts, then block the currently running task). This could be dangerous, because user code would be running with interrupts disabled. This change forces interrupts to be enabled in up_sigdeliver() before executing the signal handler calling up_irq_enable() explicitly. This is safe because, when we return to normal execution, interrupts will be restored to their previous state when the signal handler returns. From Gregory Nutt (Based on a recommendation by Mark Shulte). - Signals: Lock the scheduler while while killing the children so that we do not lose priority and let the task group continue to run in an indeterminate state. From Gregory Nutt. - Groups: Fix a deadlock when loading an ELF From Masayuki Ishikawa. - Groups: In some circumstances, group_killchildren() could have called pthread_cancel() to kill a task. Also, the behavior would not be as expected if a pthread had cancellation disabled. From Gregory Nutt. - Posix Message Queues: mq_notify() fix - only part of struct copied to internal structure. As source address the address of the struct member sigev_value was used, and it is not located the start of the struct. This leads to invalid data being copied to internal structure. Both source and destination should be of type struct sigevent* . From Simon Liedl. - vfork(): vfork operation needs to allocate and copy the task argument too. Also correction of the address correction cannot depend on the stack pointer since it is not available in all architectures. Rather calculate the offset from the stack allocation pointer From Xiang Xiao. - IRQ Dispatch: Ensure vector never points to NULL since interrupt may happen before irq_initialize() From Xiang Xiao. - Work Queue: workqueues don't need set global data to zero since .bss is cleared automatically. Removing this unnecessary initialization also avoids the loss the work items queued before initialization. From ligd. - Work Queue: Remove work queue polling delay to simplify the code logic and save the power. From xuanlin. - syslog: Fix syslog crash on 64bit simulation. From anchao. - Pipes: Write to a pipe when there are no readers from the pipe should return -EPIPE. From ligd. - System Calls: Fix 6th parameter type of posix_spawnp in syscall.csv From Masayuki Ishikawa. - System Calls: Remove unused SYS_nnetsocket from syscall.h. Because SYS_nnetsocket is not implemented so far, it should be removed so that SYS_prctl can work correctly. From Masayuki Ishikawa. - Binary Loader: Refactor binfmt_exec.c. This change also fixes an argv issue for CONFIG_SCHED_ONEXIT=n or CONFIG_SCHED_HAVE_PARENT=n From Masayuki Ishikawa. - Binary Loader: Re-architect the way that loadable ELF or NXFLAT modules are unloaded. Memory resources must be recovered when the task loaded into memory exits. The original implementation used the death-of-child SIGCHLD signal to perform the unload. There are several problems with this: It is overly complex, it requires that the parent task stay resident while the loaded task runs, and it has fatal logic flaws in the protected and kernel model builds because the user signal handler attempts to run in the kernel address space. This corrects the issue using a mindlessly simply BINFMT callback when the task exits. From Gregory Nutt. - ELF Binary Loader: Set priority level to default if parent has no priority. From anchao. * File System/Block and MTD Drivers: - Auto-mounter: Ignore return values from work_cancel(). From Gregory Nutt. - SmartFS: Fixed filesystem corruption when writing to small file after open(... O_APPEND). From Dmitriy Linikov. - SmartFS stat(): A previous change added support for checking if a descriptor is a socket in fstat().' but it changed sys/stat.h in way that breaks smartfs file-type stat flags. CROMFS is similarly broken, as tools/gencromfs.c was not updated to match the sys/stat.h changes. This commit fixes both issues. It probably is not a good idea to use NuttX sys/stat.h bit-field values directly in stored structure of filesystem. From Jussi Kivilinna. - HostFS: Update duplicated definitions in HOSTFS that must match NuttX values. From ligd. - HostFS: Ensure f_type is equal to HOSTFS_MAGIC. From Xiang Xiao. - ROMFS: Make romfs_devread32 more portable From anchao. - TmpFS: Correct logic in tmpfs_ioctl() that extracts the priv state structure from the file system structures. It was not getting the right value and causing mmap() to fail. Noted by Jesse. From Gregory Nutt. - ProcFS network statistics: Was not handling the output correct for the case of an IEEE 802.11 device. From Gregory Nutt. - ProcFS IRQs: Fix occasional computation error when fracpart >= 1000 From Xiang Xiao. * Networking/Network Drivers: - TAP/TUN: Fixed custom tun devname formatting. From Dmitriy Linikov. - Network Drivers: This change attempts remove some long standard confusion in naming and some actual problems that result from the naming confusion. The basic problem is the standard MTU does not include the size of the Ethernet header. For clarity, I changed the naming of most things called MTU to PKTSIZE. For example, CONFIG_NET_ETH_MTU is now CONFIG_NET_ETH_PKTSIZE. This makes the user interface a little hostile. People think of an MTU of 1500 bytes, but the corresponding packet is really 1514 bytes (including the 14 byte Ethernet header). A more friendly solution would configure the MTU (as before), but then derive the packet buffer size by adding the MAC header length. Instead, we define the packet buffer size then derive the MTU. The MTU is not common currency in networking. On the wire, the only real issue is the MSS which is derived from MTU by subtracting the IP header and TCP header sizes (for the case of TCP). Now it is derived for the PKTSIZE by subtracting the IP header, the TCP header, and the MAC header sizes. So we should be all good and without the recurring 14 byte error in MTU's and MSS's. From Gregory Nutt. - netdev: Fix.. Too many calls to net_unlock() From Gregory Nutt. - IPv6: There are many different checks for IPv6 multicast addresses. Most of the checks are different. RFC 3513 clearly specifies how to detect an IPv6 multicast address: they should begin with 0xffxx. I did not change some of the checks in ipv6_input.c, however. In that file, the comments indicate that the code should only pick of certain multicast address that begin with 0xff02. From Gregory Nutt. - ARP: Fix some backward logic in an if condition. From Gregory Nutt. - TCP Re-assembly: Rename CONFIG_TCP_REASSEMBLY to CONFIG_IPv4_REASSEMBLY. Add some fixes to get a clean compile with CONFIG_IPv4_REASSEMBLY enabled. There are several problems with the current implementation: It is untested (and depends on CONFIG_EXPERMIMENTAL). It uses some Ethernet specific definitions (and depends on CONFIG_NET_ETHERNET). There is only a single reassembly buffer. The last two issues prevent use of this feature in any context where IPv4 packets may be reassembled for multiple network devices concurrently). From Gregory Nutt. - TCP: Set the default TCP MSS to the value required by RFC 879 and never change it under any circumstance unless the remote host requests a larger MSS via an option the TCP header. From Gregory Nutt. - TCP: Fix a deadlock condition that can occur when (1) all network logic runs on a single work queue, (1) TCP write buffering is enabled, and (2) we run out of IOBs. In this case, the TCP write buffering logic was blocking on iob_alloc() with the network locked. Since the network was locked, the device driver polls that would provide take the write buffer data and release the IOBs could not execute. This fixes the problem by unlocking the network lock while waiting for the IOBs. From Gregory Nutt. - TCP: Remove g_netstats.tcp.syndrop++ from tcp_data_event() From Masayuki Ishikawa. - TCP Monitor: Fix net unlock issue when tcp close. This bug could leave the net locked. From zhangyuan7. - UDP: When sending a broadcast (or multicast) packet do not attempt to look up the device by the destination IP address. Rather, use the locally bound address for these cases to select the correct network device. From Gregory Nutt. - UDP: Restore some legacy behavior that was lost with the implementation of CONFIG_NET_UDP_BINDTODEVICE: If no device has a local address when the broadcast packet is sent and the UDP socket is not bound to a device, there select some arbitrary device. This is certainly lunacy in the case where there are multiple network devices registered because the wrong device will probably be returned. It works find, however, for the legacy case where only a single network device is registered. From Gregory Nutt. - UDP: Fix for network byte-order issue when checking if an address is a multicast address. From Jake Choy. - USRSOCK: Correct of semaphore usage issues. From Gregory Nutt. - USRSOCK: Fix re-definitions of struct iovec. From ligd. - ICMP/ICMPv6 Connection: Change the type of id in icmpv[6]_findconn to uint16_t From Xiang Xiao. - ICMP/ICMPv6: Fix failure to poll ICMP socket issue. From dongjianli. * Wireless/Wireless Drivers: - XBee: Fixes issue with timeouts. Timeouts were in ticks but should have been in ms. This caused false triggers of timeout causing redundant packets, etc. From Anthony Merlino. - BCM43xx: Add missing logic to the BCM43xx IEEE 802.11 driver to poll for more Tx data after the last transfer completes. From Gregory Nutt. - BCM43xx: Bring in some fixes from the 'Haywire' branch. From Ramtin Amin. * Common Drivers: - Audio: Fix compile error in i2schar.c (CONFIG_DEBUG_ASSERTIONS=y) From Masayuki Ishikawa. - Audio I2S: Fix bad NULL pointer check From Juha Niskanen. - Input: Fixed FT5x06 driver to correctly close (previously it unregistered interrupt handler during close). From Marcin Wyrwas. - MMC/SD: Fix an error that was causing SDIO multiple block transfers from achieving full performance. From Bob Feretich. - Sensors: Increases SPI frequency in MAX6675 from 400Khz to 4MHz. From Alan Carvalho de Assis. - Sensors: Remove comment references to touchscreens from ADXL345 driver. From Russ Webber. - Serial: Don't overwrite nwritten unconditionally on UART write failure. From Xiang Xiao. - Serial DMA: Move head/tail pointer reset to uart_recvchars_dma since dma may be still transferring in the background. From Xiang Xiao. - Serial DMA: In DMA mode, the use of uart_disablexinit() is insufficient to protect a critical section. enter/leave_critical_section() must be used in those cases if CONFIG_SERIAL_DMA=y From Xiang Xiao. - Serial DMA: Fix typo error in uart_recvchars_dma() From Xiang Xiao. - 16550 UART: u16550_txempty() should check UART_LSR_TEMT to avoid some data left in the transmit FIFO From Xiang Xiao. * ARMv7-A: - ARMv7-A (and i.MX6): Add support for per-CPU IRQ and FIQ interrupt stacks (bugfix). Add support so that up_assert will print the correct interrupt stack on an assertion (FIQ stack is still not printed). From Gregory Nutt. * ARMv7-R: - ARMv7-R: Fix some wrong configuration of program status register. PSR_E_BIT bit should be set for big endian system. PSR_A_BIT bis is set automatically as arm cortex-r4 reference manual 3.7.4. So we don't need to set this bit. From EunBong Song. - ARMv7-R: Fix some wrong MPU register definition. Change MPU_RBAR_ADDR_MASK and MPU_RACR_TEX_SHIFT mask as arm cortex-r4 reference manual. Region Base Address Register 0-4 bits are reserved. MPU Region Access control register type 3-5 bits. From EunBong Song. * ARMv7-M: - ARMv7-M, Cortex F7: Add a configuration to enable workaround for r0p1 Errata 837070: Increasing priority using write to BASEPRI does not take effect immediately. This update is required to be serialized to the instruction stream meaning that after this update completes, it takes effect immediately and no exceptions of lower priority than the new boosted priority can preempt execution. Because of this erratum, the priority boosting does not take place immediately, allowing the instruction after the MSR to be interrupted by an exception of lower priority than the new boosted priority. This effect is only limited to the next instruction. Subsequent instructions are guaranteed to see the new boosted priority. This was raised in Bitbucket issue 113 from Vadzim Dambrouski. From Gregory Nutt. - ARMv7-M: MPU: mpu_log2regionceil needs take into account the offset too From Xiang Xiao. - ARMv7-M MPU: The prototype of mpu_log2regionfloor() changed; an additional parameter was added. However, none of the calls to mpu_log2regionfloor() were updated to pass the new, additional parameter. From Gregory Nutt. * Infineon XMC4xxx Drivers: - XMC4 SPI: XMC4 SPI was working only for the first transfer From Alan Carvalho de Assis. * Microchip/Atmel SAMv7 Drivers: - SAMv7 MCAN: Correct an error in the BUS_OFF reporting. In case of BUS_OFF the old implementation was leading to a package storm. Now it reports the error condition BUS_OFF only once. From Frank Benkert. * NXP/Freescale LPC43xx Drivers: - LPC43xx CAN: Fix lpc43 CAN configuration. Configuration settings were used and documented in README.txt files, but never in any Kconfig file. From Gregory Nutt. - LPC43xx: Make WWDT usable again. LPC43xx WWDT driver was not updated when irq_dispatch grew an argument parameter. Also fixes two typos and a naming inconsistency (WWDT vs. WWDG). From Jakob Haufe. * NXP/Freescale Kinetis Drivers: - kinetis: USB0 fix interrupt storm on error. The ERROR bit of USBx_ISTAT needed to be cleared once an error occurs. From David Sidrane. - Kinetis: SDHC fix SDIO driver so that DMA works. There were 2 problems. The first was that the interrupt did test DINT and raise a completion events. But since DINT is just an indication of DMA completion, TC is a valid way to determine that the transfer is complete. The second problem is that Software Reset For DAT Line SDHC_SYSCTL[RSTD] clears the bits 24-0 in SDHC_PROTO this looses the wide bus setting DTW From David Sidrane. - Kinetis: (1) PIT add Lifetime and Chaining, (2) flexcan fix duplicate line and ordering, (3) kinetis_lowput.c LPUART data format with parity fix. The 9-bit data mode is typically used with parity to allow eight bits of data plus the parity, (4) lowputc LPUART_BAUD_INIT has to be defined. Build fails with test case enable LPUART0 and make UART1 console. If HAVE_LPUART_DEVICE is defined then LPUART_BAUD_INIT has to be defined even if the LPUART is not the console From David Sidrane. - Kinetis: I2C ensure timeout on bus error. The code had a dead wait on I2C_S_BUSY. Noise on the bus would cause the driver to hang. Add timeout on invalid states of I2C_S_BUSY to allow the upper layers do deal with restart or abort. From David Sidrane. * NXP i.MXRT Drivers: - i.MXRT Ethernet: I finally got the Ethernet CRC32 to work properly after the FAE pointed me in the right direction: (1) Added CRC32 functions for multicast address filtering, (2) Do not reset PHY settings when doing an ifup, (2) Use chip's unique id as the device MAC, and (4) Enable discard enet frames with errors at PHY layer. From Jake Choy. * On Semi LC823450 Boards: - LC823450-XGEVK: Fix parallel build on lc823450-xgevk. This change fixes an archive file (*.a) corruption by locking $(TOPDIR). Please note that locking the current directory is insufficient because some archive files such as libapps.a are specified with absolute path. From Masayuki Ishikawa. - LC823450-XGEVK: Change IOB related params for rndis. Since TCP flow control scheme was changed, HTTP audio streaming has not been working. These IOB params are not optimized but HTTP audio streaming now works. From Masayuki Ishikawa. * STMicro STM32: - STM32 F7: Fix compile error caused by intentional use of fall through From Daniel Agar. * STMicro STM32 Drivers: - STM32 F1-F4: Port Bob Feritich's change to STM32 F2 and F4 which appear to have identical SD support and I/O compensation requirements. - STM32 F1-F4, STM32 F7, and STM32 L4: The STM32 RTC driver was being selected by the global CONFIG_RTC option. That is in correct. For example, if you want to disabled the STM32 RTC and use an external RTC you cannot because the external RTC also depends on the global CONFIG_RTC. The solution is to add a new CONFIG_STM32xx_RTC configuration option the permits to you select or deselect the STM32 RTC but still be able to select the external RTC. From Gregory Nutt. - STM32 F3 I2C: Fix compile error with I2C reset. From Juha Niskanen. - STM32 F7 Serial: Fix ioctl TIOCSSINGLEWIRE The TRM notes that UE must be disabled in order to write HDSEL in USART_CR3. This was not being done, so calls to TIOCSSINGLEWIRE were silently failing. This change checks the state of UE in USART_CR1, clears the UE bit before writing HDSEL, then re-enables it if necessary. From Kurt Kiefer. - STM32 F7 DMA: DMA macros did not account for the increase from 8 to 16 DMA channels. From Gregory Nutt. - STM32 F7 I2C: I2C reset Configure I2C pins as GPIO output. Pins were reset to inputs in the deinit(). This resets them to outputs. From David Sidrane. - STM32 F7: All of the SDMMC pins were set to 50 MHz, but not the clock. This sets the clock to 50 MHz also. This combined with turning on I/O compensation makes intermittent failures go away. From Bob Feritich. - STM32 F7: Port Bob Feritich's change to SDMMC2 and to all other STM32 F7 architectures. Also add a configuration option to automatically enable I/O compensation. From Gregory Nutt. - STM32 F7 SDMMC: Fix data timeout errors with multi-block transfers. From Bob Feretich. - STM32 L4: Corrects some mistakes in pin definitions for the STM32 L4 family. According to datasheet of STM32L496xx, STM32L475xx and STM32L443XX the AF2 of PE14 is TIM1_BKIN2 not TIM2_BKIN. From Daniel Pereira Carvalho. - STM32 L4: Avoid using redundant CONFIG_STM32L4_STM32L4X2. This is almost always same as CONFIG_STM32L4_STM32L4X3. Avoid duplication to reduce macro clutter. This patch limits CONFIG_STM32L4_STM32L4X2 usage to dependency tracking and pinmap. Also enable ADC for CONFIG_STM32L4_STM32L4X5 (untested, but same RM). From Juha Niskanen. - STM32 H7 Serial: don't include stm32_dma.h From raiden00pl. * STMicro STM32 Boards: - STM32F4-Discovery: Fix pca9635pw LED driver compilation on STM32F4-Discovery. From Alan Carvalho de Assis. - STM32F4-Discovery: Krassimir Cheshmedzhiev claims that sys/types.h needs to be included in the RGB LED file to avoid undeclared 'OK' From Gregory Nutt. - STM32F4-Discovery: Missing EXTERN(_vectors) in linker script. From Gregory Nutt. - Nucleo-L422KC: Fix RAM size; STM31L4x2xx has only 64Kb of RAM. Remove references to I2C and SDIO: There is no I2C2 or SDIO on the STM32F4x2xx. From Daniel P. Carvalho. - Nucleo-L422KC: Fix stm32_userleds. After change LD2 to LD3 in board.h stm32_userleds.c was broken. From Daniel P. Carvalho. - Nucleo-L422KC: Fix TIMx clock configuration. Also removes definitions related to timers not available in the STM32L432KC. From Daniel Pereira Carvalho. - Nucleo-L452RE: Fix TIMx clock configuration. This is cloned from similar change to the Nucleo-L422KC. Also fixes DAC build failure. From Juha Niskanen. - B-L475E-IOT01A: Fix copy paste errors in names: stm32_bringup->stm32l4_bringup. Noted by Freemans Goden. From Gregory Nutt. - STM32VL-Discovery: Changed the status LED to be the green one as mentioned in the README file. Removed the global array for buttons and replace it with the only button. Improve defconfig for the nsh configuration. From Ouss4. * C Library/Header Files: - libc audio: Call nxsem_destroy in apb_free. From Xiang Xiao. - libc netdb: The 'port' argument to the static alloc_ai() function is always in network byte order. However, that static function was still calling HTONS() on the port, incorrectly converting it back to host byte order. From Gregory Nutt. - libc netdb: Fix a link error in lib_gethostbynamer.c with protected build. NOTE: g_lo_ipv4addr also exists in net/loopback/lo_globals.c which can be linked with kernel build only. From Masayuki Ishikawa. - libc unistd : Fix backward conditional logic in Kconfig. From Gregory Nutt. - include/nuttx/compiler.h: Fix warning: __cplusplus is not defined. Some gcc derived compiler do not define __cplusplus From Xiang Xiao. - include/nuttx/fs/binfs.h: Fix warning: Type defaults to 'int' in declaration of 'mountpt_operations' From Xiang Xiao. - include/nuttx/net/ethernet.h: Remove CONFIG_NET_ETHERNET guard From Xiang Xiao. - include/nuttx/semaphore.h: don't include nuttx/fs/fs.h. (1) Avoid nested loops if CONFIG_SIG_EVTHREAD enabled, (2) semaphore.h doesn't depends on fs.h. From Gregory Nutt. - include/crc64.h: Fix warning: integer constant is too large for its type From Xiang Xiao. - include/limits.h and include/sys/types.h: Fix warning about 'SIZE_MAX' redefined. include/nuttx/usb/audio.h: Fix warnings due to '-' used whete '_' intended. From Xiang Xiao. - include/spawn.h: Fix posix_spawnattr_destroy warning: 'the address of attr will always evaluate as true' From Xiang Xiao. - include/sys/types: Move wint_t and wctype_t from wchar.h to types.h. This change is compatible as before since wchar.h include types.h indirectly. This fixes a compilation error with newlib's math.h: 'unknown type name wint_t' From Xiang Xiao. - apps/include/netutils/netlib.h: Eliminate a warning about AF_UNSPEC and AF_INET not defined. From Gregory Nutt. * Build System: - Build System: Fix parallel build in making context. This change avoids running $(MKSYSCALL) and .context in parallel and ensures that tools/mksyscall is built before it is actually used. From Masayuki Ishikawa. - Kconfig files: Fix several errors noted by Alex Denisov in Bitbucket issue 115. From Gregory Nutt. - apps Build System: Fix an error when building apps/ without nuttx/, using only the NuttX export package and assuming that the nuttx/ directory in not even present. In this case, the problem fixed where the apps/Make.defs file was selecting tools from the /tools directory which does not exist because TOPDIR=apps/import. Instead, for this build case, I have not thought of any option but to duplicate scripts as necessary in the apps/tools directory. Also added a top-level target to compile the symbol table. Misc fixes: quoting in scripts, some errors in script syntax. From Gregory Nutt. - apps/Application.mk: If a loadable module is generated the we need to add logic to remove the loadable module in the 'make clean' logic. From Gregory Nutt. * Tools: - nuttx/tools/Makefile.unix: Was not cleaning up export directory if it was left from a failed export. From Gregory Nutt. - apps/tools: Fix an error in mksymtab.sh From Masayuki Ishikawa. * NSH Library: apps/nshlib: - apps/nshlib: Fix 'while' and 'until' loop condition The loop condition logic was inverted: 'while true; do echo "test"; done' would exit immediately, while using 'until' would stay in the loop. This is the opposite of how it is supposed to work. The reason is that 'state' was set wrong because 'whilematch' is a bool. From Beat Küng. - apps/nshlib: I was able to cause an assertion with some typos in testing the 'fi' command. Not an important thing, but this will protect against the assertion. From Gregory Nutt. - apps/nshlib: Increase the default configuration for the maximum number of command line arguments to 7 (CONFIG_NSH_MAXARGUMENTS). This is needed for 'mount' with the -o option. From Xiang Xiao. - apps/nshlib: Do not dereference NULL 'pstate' in nsh_console.c. From Juha Niskanen. * Examples/Tests: apps/examples: - apps/examples: Remove illegal calls into OS to initialize BINFMT support. This must be moved to the board initialization logic within the OS. From anchao. - apps/examples/nettest: Fix typo: NET_LOOPBACK -> CONFIG_NET_LOOPBACK nettest: Fix compilation error. Should enable NET_SETSOCKOPT for preventing compilation error. From EunBong Song. - apps/examples/ostest: Signal handling tests should use the same configurable stack size as used in other tests, not PTHREAD_STACK_DEFAULT. From Gregory Nutt. - apps/examples/ostest: Attempt to make the nested signal test compatible with the suspend/resume test. Some signals cannot be caught when the suspend/resume configuration is in place. From Gregory Nutt. - apps/examples/smps: Fixes in some printf and in Kconfig. From Mateusz Szafoni. * System Utilities: apps/system: - apps/system/cu: (1) Protect from possible re-definition of signal values, (2) Fix CU ctrl-C hand when remote core hang. From ligd. - apps/system/i2c: Fix a backward comparison in i2c_main.c. Noted by Jakob Haufe. From Gregory Nutt. - apps/system/nsh: Fix compile errors with CONFIG_EXAMPLES_NSH_SYMTAB=y. From Masayuki Ishikawa. - apps/system/ping and ping6: Send ID and seqno in network byte order. From Xiang Xiao. - apps/system/ping and ping6: Change dependency in ping and ping6 Kconfig. These may be implemented in users sockets and, hence, may need to be available even if ICMP and ICMPv6 sockets are not support. From Xiang Xiao. - apps/system/system: Add 'const' to make function prototype compatible with OpenGroup.org requirement From Xiang Xiao. - apps/system/zmodem: Fix error "sz_main.o: No such file or directory" From Xiang Xiao. * Network Utilities: apps/netutils: - apps/netutils/ftpc: Fix handling of url-encoded strings From Dmitriy Linikov. - apps/netutils/ping: Remove unsupported ping. netutils/ping is not supported anymore. It's better to remove this folder for preventing confusing. ping is supported by system/ping. From EunBong Song. * Wireless Utilities: apps/wireless: - apps/wireless/wapi: Remove dependency on CONFIG_EXPERIMENTAL from Kconfig From Gregory Nutt. * GPS Utilities: apps/gpsutils: - apps/gpsutils/minmea: Include wchar.h in minmea.c file to fix wint_t error From Alan Carvalho de Assis. * Interpreters: apps/interpreters: - Remove apps/interpreters/micropthon. There are several reasons for this. (1) the current version 1.3.8 is very old and no one is supporting it. (2) the port only includes the core micropython logic and none of the Python libraries. As such it is useless in any real application. (3) There have recently been compile failures reported. It looks like this is due to changes in newlib based toolchains that now bring in incompatible newlib header files. See issue 104 at https://bitbucket.org/nuttx/nuttx/issues/104/build-micropython-138-error. With no one dedicated to the support of micropython, it can no longer be carried in the NuttX apps/ repository. From Gregory Nutt.