NuttX-7.4
---------

The 104th release of NuttX, Version 7.4, was made on August 15, 2014,
and is available for download from the SourceForge website. Note
that release consists of two tarballs: nuttx-7.4.tar.gz and
apps-7.4.tar.gz. Both may be needed (see the top-level nuttx/README.txt
file for build information).

Additional new features and extended functionality:

* Core OS:

- Beginnings of a crypto/ subsystem from Max Neklyudov
- Tickless operation: NuttX now supports a mode with no periodic
timer interrupts. Rather, timed events are handle via an interval
timer. This (1) lowers the rate of interrupt processing to timer
events, (2) gives much high timing resolution, and (3) allows lower
power modes of operation where the CPU is not constantly being
interrupted by the timer.
- Restructured the OS files under sched/ to better support the already
modular nature of the RTOS.

* Networking

- Substantial directory and header file reorganization and renaming to
make the NuttX networking implementation more modular.
- Add network device ioctl to access PHY registers. From Daniel Lazlo
Sitzer

* Binary Loader:

- Various changes associated with symbol tables from Pelle Windestam.

* Graphics:

- colorcmp(): New utility to compare two colors.
- The initial background color is now configurable. Includes logic to
eliminates multiple background updates to get the right color.
- Minor configuration changes to handle mouse X/Y and touchscreen
X/Y differently.

* File System/Block Drivers:

- SmartFS: Increase some variables from uint16_t to uint32_t to handle
larger device sizes. From Ken Pettit.
- Add configurable AES encryption support to the block-to-character
(BCH) driver. This allows any block device to be accessed as an
encrypted character device. From Max Nekludov
- Add an MTD layer that will add read-ahead or write buffering to any
MTD driver (incomplete).
- Automounter: Add support for an auto-mounter that will automatically
mount and unmount a file system a media is inserted and removed

* Audio/Audio Drivers

- WM8904 audio CODEC driver.
- PCM .WAV file decoder. Fast forward implemented with sub-sampling
(currently no rewind support).
- Add a NULL audio device that can be used to simply unit-level testing
of audio decoders.
- Audio subsystem now supports interfaces for fast-forward and rewind
needed by CMediaPlayer; add hooks for equalizer settings needed by
the WM8904 CODEC.

* Other Common Drivers:

- MTD: Extend erase block size to 18-bits in order (decrease block
size to 14-bits) to handle parts with large erase blocks. From Kosma
Moczek
- maxTouch: Add support for the Atmel maXTouch touchscreen controller.

* Host Simulation:

- Provides the timers needed to support the Tickless mode of operation.

* Atmel SAM4C:

- Add SAM4CM IPC register header file. From Max Neklyudov
- Various fixes PMC and clock configuration for the SAM4CM port from
Max Neklyudov

* Atmel SAM4E/4S Drivers:

- SAM4 AES driver. Contributed by Max Neklyudov

* Atmel SAMA5:

- Add logic to redirect all SAMA5D4 interrupts to the AIC
- Add a configuration option to reserve DRAM for a framebuffer when
executing out of DRAM. This optional was available before when
executing out of NOR, but needs to work a little differently in
this case.
- Add SAMA5 slow (32.768KHz) clock support.
- Add support for the ARM L2CC-PL310 L2 cache. The system runs with
L2CC cache enabled but there is some issues still with the LCD DMA;
I suspect that the memory timing configuration for L2CC needs to
be tuned.
- Provides the timers needed to support the Tickless mode of operation.

* Atmel SAMA5 Drivers:

- XDMAC-based HSCMI driver for the SAMA5D4
- Adapt the SAMA5D3 LCDC driver to work with the SAMA5D4 which has
no hardware cursor.
- PIO: Add a new interface sam_pio_forceclk() that can be used to
force PIO clocking on. I am afraid I was too conservative with
PIO clocking in the initial design; this is the price.
- TWI: Now supports the up_i2creset() method.
- TWI: Use sam_pio_forceclk() so that we can read the current state
of an open-drain output in the TWI reset logic.
- SSC: SCC Frame Synch Delay and Start Delay are now configurable.
- PCK: Add the slow clock and the main clocks as options for the
PCK configuration.
- Timer/Counter: Can now handle non-constant BOARD_MCK_FREQUENCY. Also
now supports methods to attach client interrupt handlers
- One shot and free-running timers. These are wrappers around the low
level timer/counter logic to provide one-shot and free-running
timers. These were developed to support the Tickless operation, but
can be used for any purpose.

* Atmel SAMA5 Board Support:

- Add a boot loader that runs from ISRAM and loads an Intel HEX file
into DRAM.
- Add a configuration that will load a bootloader into AT25 Serial
FLASH
- SAMA5D4-EK NSH configuration supports many more features: RTC, HSCMI
card detection, maXTouch touchscreen, TM7000 LCD, the command line
media player (currently using the NULL audio device), automounter,
and others.
- SAMA5D4-EK: Add an NxWM configuration using the TM7000 LCD with
the maXTouch multi-touch touchscreen.
- SAMA5D4-EK NxWM: Uses new, larger icons in configuration instead of
scaling.
- SAMA5D4-EK NxWM: The NxPlayer and audio system are now enabled in
the default configuration (but currently using the NULL audio
device). The automounter is used to automatically mount media
on an SD card.
- SAMA5D3x-EK: Add a configuration to support the command line
NxPlayer and to verify the WM8904 CODEC driver.

* STMicro STM32:

- Add support for the STM32F103RC and RD. From Kosma Moczek
- Add a procfs entry to show the state of the CCM heap usage.
From Pelle Winderstam

* STMicro STM32 Drivers:

- Unconfigure GPIO pins when closing a serial port to prevent back
effects from back-powering on the TX pin. From Kosma Moczek

* NXP LPC17xx Drivers:

- ADC: Added burstmode ADC conversion mode, with CONFIG_ADC_BURSTMODE
option in Kconfig. From Max
- Ethernet: Added option to use the kernel worker thread to do most of
the workload with CONFIG_NET_WORKER_THREAD option in Kconfig. From Max
- Ethernet: Critical bugfix: From time to time (after some hours) the
Ethernet receiver would lose one receive interrupt and the IP stack
never recover because there is no receive watchdog as the transmit
watchdog. From Max

* NXP LPC17xx Boards:

- mbed: Port ADC, DAC, and PWM logic from the configs/zkit-arm-1769.
From Max
- mbed: Eliminated a problem with PHY DP83848C : it doesn't need a
specific initialization on mbed. From Max

* Library:

- Adds support for localtime. From Max Neklyudov

* Configuration/Build System:

- Make variable definitions 'static const' when possible to save RAM
usage. From Kosma Moczek

* Applications:

- system/mdio: New PHY tool from Daniel Lazlo Sizter.
- NSH: Networking logic modified to handler the case of SLIP
transport. From Max Neklyudov.
- NSH: Add a configuration to use a USB keyboard for the stdin
device.
- NSH: Software assigned MAC address is now configurable. From Lazlo.
- NSH: Also add an option to let platform-specific logic select the
MAC address.
- NSH: There is now a configuration option that will bring up the
network on an separate thread. Since the network bring-up is
asynchronous, there are no serial console start-up delays due
to the network negotiation time.
- NxPlayer: Changes to integrate with Ken's NxWM::CMediaPlayer.
- NxPlayer: Add interfaces for fast-forward and rewind needed by
CMediaPlayer; add interface for equalizer settings needed by the
WM8904.
- NxPlayer: Supports new way of identifying the end of the audio
stream (see the Audio section above).
- Sudoku: Add a sudoku game.

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):

* Graphics:

- NxConsole: Fix scrolling for the case of the framebuffer device. In
this case, the logic for clearing the vacated region at the bottom
was missing so garbage would scroll up from the last, uncleared
line.

* Networking:

- Important fix to the read-ahead buffer queue management: Consumed
bytes were being trimmed from the head of the queue, but the queue
head itself was not being updated. From Rony XLN.
- Fix an error in SLIP escaping. From Max Neklyudov

* Network Utilities:

- Fix an include file ordering problem when CONFIG_NET_STATISTICS=y.
- Move statistics from uip.h to new netstats.h to remove a circular
inclusion problem
- Various fixes for networking and tiny webserver from Max
- webclient: Fix to offset calculation from Rony Xln. Prevents 0x0a
at the beginning of lines.
- webserver: Fix some configuration usage issues. From Max.
- webserver: Missing logic to close sockets on loop termination.

* File System / Block Drivers:

- SmartFS: Fix for a bug that would show up if CONFIG_MTD_BYTE_WRITE
was not selected and the SMART sector size was larger than the MTD
device's block size (like it would be if using SMARTFS on larger
flash devices). From Ken Pettit.

* Audio:

- Change how the end of the audio stream is detected by the leaf audio
component. This used to be done by looking for the first partial
buffer. That does not work with the in-place sub-sampling performed
by the PCM decoder: That always reduces the size of the buffer so
that all buffers only partially filled by the time they get to the
leaf. Now, a flag is set in the audio buffer flags set to indicate
the final buffer in the stream.

* Common Drivers:

- RAMLOG putc() method needs to set the errno and return EOF on a
failure.
- Add missing configuration option to select the MAX11802 touchscreen
controller. From Petteri Aimonen

* Atmel SAMA5D3/4:

- Fix logic in conversion of physical and virtual DRAM addresses when
running out of DRAM. This is an important bug fix for the SAMA5D3
and 4 when running out of DRAM .
- Critical SAMA5D3 and 4 bug fix: PIO clocking must be enabled for
all input pins or else the value that is read never changes.

* Atmel SAMA5D3/4 Drivers:

- OHCI: Fix an error in a DEBUGASSERT statement. Caused an
assertion to fire inappropriately when a low- or full-speed device
was removed and CONFIG_DEBUG=y
- OHCI: Pointers to allocated port values were not being
nullified after being deallocated. This caused some assertions
to fire when debug was enabled
- SSC: Needs to account for data offset in audio buffer

* ARMv7-M:

- Correct the initial value of the BASEPRI register. This was
apparently never being initialized! From Max

* STMicro STM32 Drivers:

- I2C: Fix missing configuration of GPIO pins in I2C driver. Fix
from Alex D.
- STM32 OTGFS device: Various changes to try to reduce that amount of
time in interrupts handles and with interrupts disabled. From
Petteri Aimonen

* Atmel SAM3/4 Drivers:

- Ethernet: Wrong bits being cleared before OR-ing in new settings.
- Ethernet: Fix an error in the function that determines the number
of free TX descriptors. This is an important bugfix on busy
networks.
- I2C: Test for read or write operation was reversed. How could
this have worked before?

* Atmel SAM3/4 Boards:

- SAM4S Xplained-Pro: Correct description of LEDs and usage. From
Kosma Moczek

* Atmel SAMA5:

- PIO: Fix definitions that could disable PIO interrupt support if only
PIOE interrupts were enabled
- PIO: Macro SAM_PION_VBASE is not define-able for the SAMA5D4 and must
be replaced with a table lookup.
- PIO: Fix a typo in Schmitt trigger configuration; Configure pin as a
vanilla input first so that final pin configuration is more read-able
(i.e., easier to debug)
- PIO: Logic for Schmitt trigger selection backward
- SAMA5D4: Correct system timer frequency. Input clock is MCK/2, not MCK.

* Atmel SAMA5 Drivers:

- Ethernet: Wrong bits being cleared before OR-ing in new settings.
- Ethernet: Fix an error in the function that determines the number
of free TX descriptors. This is an important bugfix on busy
networks.
- HSMCI: The 8-byte SCR transfer was failing silently with the DMA
transfer, leaving the SD card in single bit mode. Fixed by adding
a non-DMA read transfer mode.
- HSMCI: Fix a problem on card insertion/removal callback handling.
Interrupts were being disable so that the callbacks occurred with
interrupts disabled. This resulted in loss of some interrupts and
some not-so-good behaviors. The solution is to perform all
callbacks on the work thread unconditionally

* Atmel SAMA5 Boards:

- PIO: Fix some cloned errors in SAM GPIO interrupt setup

* NXP LPC17xx Drivers:

- Ethernet: Comment out an assertion that is reported to fire
inappropriately. From Max

* Library:

- stdint.h: Correct naming of [U]INT_LEASTn_{MAX|MIN} and
[U]INT_FASTn{MAX|MIN}. From Kosma Moczek
- unistd.h: POSIX definitions should be defined to a value. rom Kosma
Moczek
- Fixes associated with rint() and related interfaces in the math
library.

* Configuration/Build System:

- NAME_MAX not available on SunOS; use FILENAME_MAX or MAXNAMELEN.
Noted by Douglas Beattie

* Applications:

- NSH: if # appears on line, need to comment ignore additional
commands on the line
- NxPlayer: Check for file read errors and end-of-file with zero
bytes read. Other error handling corrected as well.
- NxPlayer: NxPlayer needs to set curbyte field to zero before
enqueuing a buffer. Otherwise, it looks like beginning of the
buffer has already been consumed.