English Version Spanish Version French Version

MIOS8 Change Log

Last Release: V1.9h @ 2014-12-19

  • V1.9h
    • Improved acceleration handling of rotary encoders in FAST mode

  • V1.9g
    • The encoder driver has been overworked based on proposals from Avogra.
      Now it can even handle excotic encoder types without changes in MIOS code. MIOS_ENC_MODE_DETENTED4 and MIOS_ENC_MODE_DETENTED5 have been added.
      MIOS_ENC_MODE_DETENTED4 should be used for the so called "cheap Panasonic encoders" which are available at www.pollin.de
      The performance of the encoder driver has been improved as well.
      The new method required a change of the MIOS_ENC_MODE_NON_DETENTED and MIOS_ENC_MODE_DETENTED* definitions, which unfortunately makes all previously released applications incompatible.
      Accordingly, all applications have been re-released. The new binaries can be downloaded from the MIOS download page.
    • in order to update MIOS, please download the <derivative>/midi/mios_v1_9g_<derivative>.hex file first, thereafter the .hex file of the application.

  • V1.9f
    • Timer0 now free as resource if the AIN driver is not enabled.
      A special interrupt hook is not provided, but this timer can be used for 16bit time measurements
    • AIN driver now working correctly on PIC18F4620/PIC18F4685
    • backup function now properly working for >32k flash devices like PIC18F4620 and PIC18F4685 (see also doc/mios_backup.txt)<(LI>
    • a new rotary encoder mode "MIOS_ENC_MODE_DETENTED3" is available, which works similar to MIOS_ENC_MODE_DETENTED2, but increments the value "during the click", and not "after the click"

  • V1.9e
    • priority of MIDI Rx Handler changed (now it has the highest priority)
    • MIOS_HLP_GetIndex_2bytes now takes the 64k boundary into account (only relevant for PIC18F4685 and PIC18F4682)
    • debouncing was skipped (or DIN toggles were ignored) if BSR was modified within the USER_SR_Service_Finish hook
    • download request for 64k BankSticks (24LC512) working now

  • V1.9d
    • support for PIC18F4685 and PIC18F4682
    • initialisation of 4bit CLCD overworked
    • 4bit CLCD selected by default for PIC18F4685 and PIC18F4682 to free the ECAN pins at RB2 and RB3
      Note that the D0-D3 pins of the CLCD should not be connected to the PIC in this case, but clamped to ground instead!
    • new Bootloader version V1.2b: support for the new PICs
      Output drivers of Port B are not enabled during the startup phase anymore.

  • V1.9c
    • Changed the way how MIOS debounces buttons. Before this change, the whole SRIO scan was skipped, with the result, that DOUT registers were not serviced as well. This led to the unwanted side effect, that LED matrices were flickering and rotary encoders with high resolutions were jumping.
      With this release, only DINs which are not assigned to encoders are debounced, and the SRIO scan is continued so that the DOUT registers are always updated
    • MIOS_MIDI_InterfaceSet/MIOS_MIDI: (E)USART baudrate only updated when value has changed to ensure, that the baudrate generator won't be reset - this was leading to invalid MIDI bytes on quick changes between an external MBHP_IIC and the internal MIDI port

  • V1.9b
      Changes are only relevant for PIC18F4620!
    • undone modification of MIOS_EEPROM_* due to compatibility issues with PIC18F452 based MIOS applications (they don't initialize EEADRH) EEADRH must now be incremented/set from the application if required.

  • V1.9
    • the bootloader location has been moved from 0x7c00-0x7fff to 0x0000-0x0400. This frees the upper 1k block for applications, and equates the memory allocation between PIC18F452, PIC18F4620 and future PIC devices.
    • the default font for graphical displays has been moved from 0x28fc to 0x7cfc
    • both changes ensure compatibility with all existing applications.
      Newer versions of applications like MIDIbox SID, MIDIbox SEQ, MIDIbox FM, MIDIbox64 and MIDIbox64E will allocate the upper 1k block very soon, they won't be compatible to MIOS V1.8 and lower anymore. Therefore an update to MIOS V1.9 is strongly recommended!
    • a new Bootloader has been released (V1.2)
    • an update package for MIOS V1.9 and Bootloader V1.2 is available under http://www.ucapps.de/mios/mios_update_v1_9.zip.
      It makes the update so comfortable and secure as possible
    • MIOS and Bootloader now support the MBHP_IIC_MIDI module as alternative MIDI Out port. The address of the module has to be specified in the ID header, byte 5
      Example: 0000000000100000 redirects all MIDI Out messages to the first MBHP_IIC_MIDI module.
      This is intended as workaround for the silicon bug of PIC devices like PIC18F4620 with chip revision A3 and A4
      see also this article
      Note that the ID header can be changed with the change_id application without using a PIC programmer.
    • the MIOS_MIDI_InterfaceSet function now allows to change the target interface of MIOS_MIDI_TxBufferPut on-the-fly
    • the MIOS_IIC_ByteSend function now returns the inverted ACK flag for easier usage under C
    • the MIOS function description has been enhanced by C declarations and examples -> cmios_fun.html
    • MIOS is not licensed under GPL anymore. It's still open source, but commercial use is not allowed without my permission.

  • V1.8
    • the interrupt handler now also saves FSR0L and FSR0H. This allows the use of C programs compiled with sdcc
    • a wrapper for the SDCC compiler is now available in a separate package. More informations can be found under http://www.ucapps.de/mios_c.html
    • the motorfader driver has been overworked. The new concept works with a "dynamic deadband" and a definable PWM which will be used once the fader reaches the target position.
      The details are described at http://www.ucapps.de/mbhp_mf.html
    • on a MIOS up- or download, the BankStick number is now selected with an address extension, which is part of the SysEx command
    • the "Brown Out Reset" (BOR) settings in the configuration sector are changed automatically when MIOS detects unproper settings - the appr. cell in this sector will be overwritten and the device will be reset.
      New Setting: Brown Out Reset at 4.5V
      This ensures that the PIC won't access devices during power-off which cannot operate at voltages < 4.5V (e.g. the BankStick, which could get an unintended write command)
    • support for PIC18F4620 (64k flash device)
      Unfortunately this derivative is currently not qualified for MIOS due to a silicon bug in the EUSART peripheral (rev3)

  • V1.7

      this version requires slight changes on the core module wiring to improve the performance of MIOS. See also this infopage.

    • DOUT signals are stable over the whole update cycle
    • BankStick (IIC) accesses don't block the interrupts anymore
    • the CPU load caused by the rotary encoder handler has been reduced to improve the realtime behaviour of MIOS

  • V1.6
    • MIOS_MIDI_TxBufferPut is an atomic operation now to prevent a malfunction which can happen when this function is executed at the same time where the Tx handler fetches new data from the buffer
    • MIOS_Timer_ReInit can be used to re-initialize the timer w/o a reset for smooth timer period changes
    • MIOS_BANKSTICK_ReadPage, MIOS_EEPROM_WritePage and MIOS_EEPROM_ReadPage are new functions for faster data transfers
    • new functions USER_LCD_Data, USER_LCD_Cmd, USER_LCD_SpecialCharInit for custom display drivers

  • V1.5b
    • Bugfix: due to an unprotected register the MIDI receiver forwarded the wrong byte to the MIDI Rx Buffer. This happened when a MIDI event had been received in Running Status mode and the application had overwritten IRQ_TMP1 within the USER_MIDI_NotifyRx hook. The MIDI receiver now uses an internal register
    • support for CLCDs with 4bit interface, see the functional description of MIOS_LCD_TypeSet

  • V1.5 - the first open source release
    • if MIOS_SRIO_TS_SensitivitySet is called with WREG == 0x00, the touch sensor Pin RD.4 (J14 of the core module) won't be driven by MIOS anymore and therefore is free for other purposes
    • the AIN handler has been optimized to a two-step state machine with a sample frequency of 200 uS
    • USER_MPROC_NotifyTimeout hang-up has been fixed
    • the internal registers have been rearranged for a better overview. Applications shouldn't be affected from these changes

  • V1.4b
    • LCD cursor mapping (MIOS_LCD_YAddressSet in conjunction with MIOS_LCD_CursorSet) didn't work correctly with 4-line displays (cursor pos >= 0x80 was forwarded to second display, although third and fourth lines was mapped to a position < 0x80)
    • USER_MPROC_NotifyReceivedEvent and USER_MPROC_NotifyFoundEvent: On 2-byte MIDI events (program change and channel pressure), the 2nd byte, stored in MIOS_PARAMETER2, is now also copied to the 3rd byte (MIOS_PARAMETER3) for an easier handling in some MIDIbox applications
    • new function MIOS_MF_TouchDetectionReset: it resets the software implemented touch detection so that the fader is repositioned regardless if it is currently manually moved or not
    • interrupts are not blocked during a BankStick write anymore to improve the realtime capability of MIOS and especially to avoid MIDI data loss during the write cycle

  • V1.4
    • the IIC functions are now open for public, they can be used to access any IIC compatible device via port J4 in parallel to the BankSticks. Example: see the lcd7_iic driver
    • there are two new hooks available which allow to monitor the incoming and outgoing MIDI traffic with zero latency: USER_MIDI_NotifyRx and USER_MIDI_NotifyTx.
    • The motorfader driver now works much better with panasonic faders. New recommended calibration values: Alps: 0x0e@8V, Panasonic: 0x0c@8V
    • automatic debouncing has been added to the SRIO driver which compensates temporal spikes caused by low-cost buttons. See also the detailed description of the MIOS_SRIO_DebounceSet function. Just add this function at the beginning of your application (below USER_Init) if required.
    • a new display type #6 has been added which redirects single characters and strings to the MIDI interface. The used protocol is documented in the http://www.ucapps.de/mios/mios_sysex_implementation.txt
    • a LCD message receiver has been added to the MIDI processor. Incoming characters will be print for 2 seconds on screen. Btw.: the same protocol will be supported by MBHP_TV in the next days
    • it's now possible to write directly into a BankStick via MIDI. This opens the possibility to embed the BankStick content into the application by locating the data to address range 0x400000-0x407fff (24LC256; 32k) resp. 0x400000-0x40ffff (24LC512; 64k). Also the upload to multiple BankSticks is supported with the BankStick select function
    • it's now possible to read directly from internal Flash/EEPROM and external BankStick via MIDI. This is a nice debugging help, but opens also the possibility to create backups and to copy (clone) the content of a BankStick

  • V1.3
    • it's now possible to integrate an own LCD driver which is not natively supported by MIOS. See also the docs under MBHP->LCD
    • up to 8 BankSticks can now be addressed over the same IIC bus by using the MIOS_BANKSTICK_CtrlSet function. Note that this feature doesn't work with the EEPROM M24256 from ST, but only with Microchip EEPROM 24LC256. See also the docs under MBHP->BankStick
    • the MIOS_HLP_Dec2BCD function can be used to convert a 16 bit decimal value to BCD (for example to send the digits of a decimal number over the MIDI interface or to display the numbers on a LED digit display)
    • MIOS_LCD_PrintBCD4 and MIOS_LCD_PrintBCD5 can be used to print 16 bit values in decimal form
    • the MIOS_MF_StartupSpeedSet allows to give the motorfaders a "kick" when they are starting to move (can be tried with the mf_calibration application. The MIDIbox LC application now includes a calibration menu)
    • the speed modes of the encoder driver have been rewritten, see the MIOS_ENC_SpeedSet description for further details. The "enc_speed_v1_3" application allows to test the various settings.

  • V1.2
    • MIOS_LCD_TypeSet offers additional parameters
    • the chip select lines of KS0108 or HD61202 based displays can now be inverted
    • additional GLCD driver for T6963c based displays. The performance of this display is very poor, it is not recommended for applications which have to react in realtime like the MIDIbox LC or any other "MIDI receiver"
    • the enable pins of character LCDs can now be changed during runtime. In this way it is possible to connect multiple LCDs to one core module, the maximum number of LCDs which can be handled by a application is now only limited by the number of free pins
    • fast write to BankStick and EEPROM w/o verify
    • page write to BankStick (64 bytes at once)
    • dynamic priority sampling for muxed pots (improved latency, known from MIDIbox Plus and MIDIbox64)

  • V1.1
    • some imperfections in the SRIO and MF handler have been fixed in this release.
    • MIOS_HLP_16bitAddSaturate: 16 bit addition with saturation. Usefull in conjunction with rotary encoders. Will be used by upcoming applications (MIDIbox HN already uses this function in hn_enc.inc)
    • support for detented encoders (see mios_tables.inc)
    • MIOS_DIN_PinAutoRepeatEnable, MIOS_DIN_PinAutoRepeatDisable, MIOS_DIN_PinAutoRepeatGet: an assignable autorepeat function for every button. Excellent for data entry.
    • MIOS_CLCD_SpecialCharInit, MIOS_CLCD_SpecialCharsInit: allows to initialize the 8 special characters of a LCD.
    • MIOS_LCD_YAddressSet: allows to enable a second character LCD

  • V1.0
    • initial version

Last update: 2024-05-08

Copyright 1998-2023, Thorsten Klose. All rights reserved.