******************************** DuinOS v0.4 Alpha ******************************** Copyright (C) 2009 Multiplo http://multiplo.org http://robotgroup.com.ar Created by Julián U. da Silva Gillig. Based on the FreeRTOS v6.1.0 kernel (www.freertos.org). Please see the License section below. This is our only distribution of DuinOS, which includes the complete source code. The last version is always available from http://robotgroup.com.ar ******************************** License ******************************** The DuinOS kernel (cores\arduino.DuinOS) is under the same license as the FreeRTOS operating system (www.freertos.org) Please see the included FreeRTOS.license.txt file. We have used too, some files belonging to the AVR port of the FreeRTOS operating system, made by Micropendous (www.micropendous.org). As these files are modified FreeRTOS files, we understand they are under the same license as the FreeRTOS kernel. We are grateful to Opendous Inc. for their valuable contribution to the open source community. If there are some other files belonging to the Micropendous project, these may be under the following license: Copyright Under the Creative Commons Attribution License http://creativecommons.org/licenses/by/3.0/ By Opendous Inc. www.Micropendous.org October 04, 2009 Please visit www.micropendous.org if there is any doubt. NOTE: We strongly believe in peace, so we would not like to see our work in any non-civil or military project. But, due to the FreeRTOS's modified GPL license which we do have to maintain, this is only a recommendation and an expression of our wishes. ******************************** Installing DuinOS ******************************** 0. Close the Arduino IDE (all instances). 1. Copy the arduino.DuinOS folder to the \hardware\cores folder. 2. Rename your current \hardware\boards.txt file. 3. Copy the boards.txt deployed with DuinOS to the \hardware folder. 4. Rename your current \lib\keywords.txt file. 5. Copy the keywords.txt deployed with DuinOS to the \lib folder. 6. Start the Arduino IDE. 7. Please select any DuinOS board from the Tools->Board menu, like the "Arduino Duemilanove or Nano w/ ATmega328 + DuinOS". 8. Now, you can compile any standard project, but we suggest the \examples\MoreComplexBlinking deployed with DuinOS. ******************************** Uninstall ******************************** 0. Close the Arduino IDE (all instances). 1. If you have renamed the original boards.txt file, delete the current boards.txt file and rename the previous one (so it will be now your new boards.txt). 2. If you have renamed the original keywords.txt file, delete the current keywords.txt file and rename the previous one (so it will be now your new keywords.txt). 3. Delete the arduino.DuinOS folder from the \cores folder. 4. Now you can restart the Arduino IDE and keep working without DuinOS. ******************************** DISCLAIMER ******************************** THE SOFTWARE (AND ANY OTHER CONTENT) IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE MATERIALS ON THIS WEBSITE OR THE USE OR OTHER DEALINGS IN MATERIALS ON THIS WEBSITE. ******************************** History / Change log ******************************** * 0.1.0 Alpha / 2009.11.02 (Julián U. da Silva Gillig. - http://robotgroup.com.ar ) - First version released DuinOS v0.1 Alpha. - Arduino IDE updated to version 0017 ref - FreeRTOS updated to version 5.4.2 - Add example MoreComplexBlinking (Blinks two LEDs) * 0.2.0 Alpha / 2010.06.30 (Michael Grigorev aka CHERTS <sleuthhound@gmail.com>): - Arduino IDE updated to version 0018 - FreeRTOS updated to version 6.0.5 - Add new example MoreComplexBlinkingAndSound (Blinks two LEDs and play sound) * 0.3.0 Alpha / 2010.12.19 (Yannick LE NY <yleny@nospam@laposte.net>): - Arduino IDE updated to version 0021 - FreeRTOS updated to version 6.1.0 - add mprintf library - a thread safe printf called mprintf (Developped by Paula Keezer http://www.out--there.com/blog/mprintf-a-thread-safe-printf-mprintf-library/ ) - add cserial library - two c functions are required so that stdout can be initialized for the stdio library - This binds the printf function to the hardware serial port (Developped by Paula Keezer http://www.out--there.com/blog/mprintf-thread-safe-freertos-printf-part/ ) - add CPPLib library - add the new() and delete() operators, (with very common and well known iplementations) and the function that allows to have virtual pure destructors. (Developped by Julián U. da Silva Gillig. - http://robotgroup.com.ar ) - Because Serial Outpout doesn't work with DuinOS and AtMega 88, 88P, 168 and 168P, decrease TOTAL_HEAP_SIZE from 800 to 500 Reported by Chumbud Test Code : http://www.arduino.cc/cgi-bin/yabb2/YaBB.pl?num=1256745982/39#39 Workaround : http://www.arduino.cc/cgi-bin/yabb2/YaBB.pl?num=1256745982/46#46 - Add patched Servo lib (from Arduino IDE 0021) with Timer1 disabled because DuinOS uses the timer 1 for its kernel. Now should works only with AtMega 128, 1280, 1281, 2560, 2561, 32U4, AT90USB646, AT90USB1286 Need testing - add ServoTimer2 lib to replace Servo for AtMega 88,168,328,644 - use the 8 bits Timer2 to manage up to 8 servos ServoTimer2 lib website : http://code.google.com/p/tricopter/source/browse/trunk/arduino/#arduino%2Flibraries%2FServoTimer2 Need testing * 0.4.0 Alpha / 2012.01.08 (Eric Dillmann <eric.dillmann@nospam@gmail.com>) - Arduino IDE updated to version 1.0 - FreeRTOS updated to 7.1.0 - Use Timer0 for FreeRTOS - Remove Servo library (standard one should work) * 0.