CR300 Series OS 6
Updated: 09-08-2017

  1. (URGENT) An issue was found in the previous operating systems that could cause the datalogger to become unresponsive in some systems after 50 days. This operating system resolves that issue. It is highly recommended that all CR300s and CR310s be upgraded to this operating system.
  2. (WARNING) Upgrading the Operating System could reset all CR300 settings back to factory defaults. Sending this Operating System remotely can be done but is not recommended. To restore settings after the update, it is recommended that a backup be made of the current datalogger settings or take programmatic measures to ensure your settings can be restored. This can be done using Device Configuration Utility’s (DevConfig) backup utility or the CRBasic instruction SetSetting()Watch the Video Tutorial: Sending an OS to a Local Datalogger.
  3. Added GPS() instruction.
  4. Added AM25T() instruction.
  5. Added PreserveVariables() instruction.
  6. Added SMSRecv() instruction (for use with the CR3X0-CELL200 and CR3X0-CELL210 only).
  7. Added SMSSend() instruction (for use with the CR3X0-CELL200 and CR3X0-CELL210 only).
  8. Added support for the CR3X0-CELL200 and CR3X0-CELL210 embedded cellular modems.
  9. Added RNDIS support which allows Ethernet over the USB port.
  10. Fixed an internal system timer rollover issue that could cause tasks to sleep indefinitely resulting in communications loss and/or a watchdog.
  11. Communications are now paused until the radio (407,422, etc.) has initialized.
  12. Added the ability to create WireShark PCAP files that can be used for Ethernet tracing and troubleshooting.
  13. Added the ability to update the datalogger operating system, internal webpages, and program to the datalogger using a single xxx.WEB.OBJ.GZ file.
  14. Added background task queue checking.
  15. Boot-up table verification buffer updated (requires less memory).
  16. Combined communications and IP to share the same pool memory.
  17. Various memory optimizations have been made to improve variable and table space.
  18. Updated default program checking to include "default.cr300" on the CSI drive.
  19. Fixed a USB issue that could cause USB transmit to fail.
  20. Fixed an error in the USB driver that caused USB communications to fail.
  21. Fixed a wakeup from sleep issue that could cause RS-232 transmit to fail.
  22. Fixed a memory issue related to configuration of C1 and C2 ports.
  23. Updated default program checking. If default.cr300 has a compile error, the datalogger does not continually restart.
  24. Fixed an issue that caused hidden files to lockup the datalogger.
  25. Fixed an issue in memrealloc that could cause a hard fault due to a memory read beyond the memory boundary.
  26. Fixed an ABS function when using doubles.
  27. Fixed the EXP function when using doubles.
  28. Fixed an issue when storing tables with records greater than 4K.
  29. Fixed an issue in the IP task that did not allow the CR310 to sleep when the Ethernet was disabled or powered down.
  30. Fixed an issue that could cause memory corruption in the IP stack.
  31. Fixed a memory corruption issue with the IP stack buffers.
  32. Fixed a continuous restart issue related to file streaming.
  33. Fixed an issue where the PakBus TCP Client setting was not able to connect to large port numbers.
  34. Fixed a wait communications issue that could cause PPP dial to fail.
  35. Fixed a TLS server memory allocation issue that could cause the logger to continually restart.
  36. Fixed an issue when using EmailRelay() to send emails to multiple email accounts.
  37. Fixed an HTTP chunking issue when using EmailRelay() with table streaming.
  38. Updated IP stack advertised MTU to 1430 bytes. This resolves an issue with EmailRelay() when used with a datalogger connected to an RV50 cellular modem.
  39. Lowered TCP maximum segment size. Fixes issue with RV50 modems and EmailRelay().
  40. Fixed an issue that caused the chunk size to be incorrect when using EmailRelay().
  41. Streaming pointers for EmailSend(), FTPClient(), HTTPPost(), HTTPPut() are now preserved across power cycles. (A lithium battery is required.)
  42. Fixed a continuous restart issue related to file streaming.
  43. Fixed a memory buffer size issue that caused HTTPPut() to fail.
  44. Fixed an issue when using FTPClient() and TLS in slow sequences that caused the datalogger to continually restart.
  45. Updated CRBasic compile to allocate an additional TLS buffer when using FTPClient().
  46. Fixed a TLS memory free issue that could cause FTPS to fail.
  47. Added low-level file creation retries for HTTP/FTP.
  48. Updated the HTTP server to look for files on the CPU drive first.
  49. Updated the HTTP server to first look for "CPU:index.html" before trying "CSI:index.html".
  50. Updated the "Forbidden" HTTP message for internal web pages.
  51. Fixed an issue that caused web sockets to fail to update after bootup.
  52. Fixed an issue that caused XMLParse() to fail when XMLContent was a file name.
  53. Fixed a TCP/IP buffer overrun issue with the DHCP server.
  54. Fixed an issue that caused PPPClose to not allow the datalogger to sleep.
  55. Fixed an issue that caused duplicate sniff output when sniffing over a TCP/IP connection.
  56. Updated the default domain name to be "linktodevice.com".
  57. Fixed a PakBus/TCP Clients issue when using a large port number that caused datalogger to not make the TCP/IP connection.
  58. Fixed an issue that caused ModbusMaster() to always reopen the port. This caused issues when using a non-default serial format.
  59. Updated ModbusSlave() to show a compiler error if the baud rate is incorrect.
  60. Fixed an issue that caused the MODBUS flag to not be set when the port was already opened.
  61. Fixed Tablefile() record pointers incorrect after power cycle.
  62. Fixed an issue that could cause an IP Trace to be enabled while tracing another port.
  63. Updated terminal command web update to retry if the first network fails.
  64. Fixed an issue with SetSettings(Settings.RadioEnable).
  65. Fixed an issue that caused a continual restart when using SetSetting("EthernetEnable" . . .).
  66. CRBasic SetSetting "USBconfig" added.
  67. Fixed issues with SetSetting "BaudrateRS232", "BaudrateCOM1", "BeaconRS232", "BeaconCOM1", "BeaconCOMRF", "VerifyRS232", "VerifyCOM1" and "VerifyCOMRF".
  68. Updated Settings.RadioRSSI to return a negative value.
  69. Updated SetSetting() parameter FieldName to support variables or expressions.
  70. Fixed an issue with SDI12SensorResponse giving +9999999 for NAN instead of -9999999.
  71. Fixed the SDI12Recorder() instruction array bounds checking.
  72. Updated port/channelcompiler error to give the port/channel name instead of the number.
  73. Fixed an issue with GoesTable() not addressing the transmitter prior to sending data.
  74. Added support for Sprintf() 'Y' SDI-12 formatting.
  75. Fixed Sprintf() so %% in the format string generates a % character.
  76. Added a PulseCount() - PConfig compiler check.
  77. Fixed an issue that could cause a PakBus timer to request a disconnect when using the watch command (W) in the terminal.
  78. Fixed an issue that caused the compiler to crash with variable names > 39 characters.
  79. Fixed an issue that caused GetDataRecord() timestamp to be incorrect.
  80. Fixed an issue that caused PakBus communications to fail if Modbus was enabled on the same port.
  81. Fixed MuxSelect() to allow VX1 and VX2 as the clock and reset ports.
  82. Fixed an issue that caused SerialBrk() to not send the break.
  83. Updated digital I/O pin hardware initialization.
  84. Fixed an issue that caused CRBasic long variable = NAN to fail.
  85. Updated SlowSequence task priorities.
  86. Updated FileControl() to allow file delete if "run now program flag" is set and the program is not running.
  87. Fixed an issue when storing tables with greater rhan 4k record size.
  88. Updated low-level serial open to skip hardware/DMA initialization if port is already open with same options.
  89. Fixed ABS() negative to positive error.
  90. Fixed a ABS() issue when using doubles.
  91. Updated math "^"(pwr) function to return results consistent with other dataloggers.
  92. Fixed an issue when using SerialOpen() for ports ComC1_Rx,ComC2_Rx,ComC1_Tx, ComC2_Tx. Format was set incorrectly.
  93. Fixed Terminal CSI Security Code issue.
  94. Added clock calibration option to calibrate the clock using P_SW port.
  95. Added support for VX1 and VX2 to PortSet().
  96. Fixed an issue that caused the menu to be truncated when displaying the terminal menu.
  97. Fixed an issue that caused invalid differential measurements if a port was configured as an input.
  98. Fixed an issue that could cause CurrentSE() to measure before the hardware was fully ready.
  99. Fixed a record find issue that caused GoesTable() buffer to not output all data.
  100. Low-temperature clock calibration added.
  101. Updated Startup timing to use a hardware timer.
  102. Fixed GoesTable()/GoesField() instructions.
  103. Fixed setting values in ConstTable. The flag that told the search code that this was not a final storage table was being cleared.
  104. Fixed an issue in SerialClose() that caused the port to not shut down in the correct sequence.
  105. CRBasic SerialIn() updated. If the timeout = 0 and the termination character/string is < 0 or a NULL string, then it will record any characters in its buffer and then exit.
  106. Fixed a SlowSequece task start priority issue that could cause slow sequences without scans to run at a higher priority.
  107. SerialOpen(), SerialIn(), SerialOut(), SerialClose() updated to support ComC1_Tx, ComC1_Rx,ComC2_Tx,ComC2_Rx. Example: SerialOpen (ComC1_Tx,115200,0,0,500)
  108. Fixed an issue that caused sniff RX packets to be duplicated.
  109. Updated PWM port checking. Allows PWM on same port and fixed the reported channel.
  110. GoesTable() and GoesField() adjusted so slashes are present only when the record has not yet been recorded.
  111. Adjusted GoesTable() syntax when decimating.
  112. Fixed GOES pseudo binary message so it will now not include any spaces or carriage returns.
  113. Fixed setting a Boolean in a constant table.
  114. Power-up flag is now restored when a lithium battery failure occurs.
  115. Fixed an issue that could cause the datalogger to continually reboot if a compile error occurred with a line greater than 512 bytes.
  116. Fixed a serial flash write issue with tables larger than 4K.
  117. Fixed a table memory buffer issue.
  118. Changed LithiumBattery text to "OK, ON POWER UP".
  119. Fixed a PakBus issue that caused a watchdog when a link timed out.
  120. Updated Goes instructions.
  121. PakBusClock() changed so PakBusAddr parameter can be variable.
  122. PakBus 30 minute close file timeout not active if called from the program.
  123. Fixed an issue where, if writing to a special field (TIMESTAMP, RECORD, etc.) of a structure, the table semaphore was not released.
  124. Removed various compile errors with GetDataRecord() and AcceptDataRecord() when referencing a data table not matching the scan interval, which will allow the data table's DataInterval() declaration to match the remote DataInterval() declaration.
  125. Fixed terminal command "C".
  126. Fixed an issue with MODBUS that caused the RxParse task to drop to a lower priority.
  127. Fixed an issue that could cause PeriodAvg() to reset the datalogger.
  128. Fixed a PeriodAvg() timer rollover issue.
  129. PeriodAvg() - removed cycle restriction of 200 cycles.
  130. Updated GOES to prevent pc-compiler crash.
  131. Fixed an issue that could cause a serial flash error at address 217088 when settings are set to defaults.
  132. Fixed the DataTableInfo record number from incrementing on every poll.
  133. Fixed a NAN issue when using reps with measurements. If one channel is NAN the sequential channels will NAN as well.
  134. Removed a 16K task allocation.
  135. Fixed an issue with channel port configuration checking when using reps.
  136. Fixed an issue that could cause the RunProgram task to lock up if the same table is called from both the SlowSequence and scan.
  137. Fixed an issue that caused unclean frame size to not be calculated correctly.
  138. Fixed a COM1 open issue that could cause the COM1 task to not start. (Occurred when a SerialClose() and SerialOpen() were called without a delay in-between them.)