VS
Dear Friends ,
Today I'm working on IDE for Multipilot 2.0 . I found different kind of approach available For developing application on Arm Cortex A3 microcontroller.
Actually I'm studing this kind of platform :
Xduino , Maple IDE and CooCox IDE.
The first two ide are Clone of official Arduino project . This kind of ide use same Arduino Java ide and add support for gcc arm compiler instead of gcc . Normaly support usb uploading of firmware don' support jtag debugging. The Maple is better of xduino at the moment. The standard arm library is wrapped for using same arduino language sintax. Is not yet fully compatible with original arduino sintax.
The second one instead is a Eclipse ide , that include support for makefile automatic production , gcc compiler , linker, debugger and support Jtag interface for debug and upgrade firmware.
Support a lot of functionality of ARM micro , is available a micro operating systems that support task and preemptive multitasking.
Personally I prefer second kind of approach , more professional approach not for entry level programmer . The first kind of approach is very good for people that normaly use arduino for development of his application .
My idea at the moment is to support all kind of systems .. actualy the second kind of ide don't support the arduino .pde application ,but i think that is possible to develop a wrapper class and a mod for eclipse that support this kind of improvment.
What kind of approach do you prefer ?
Regards
Roberto
Replies
Today I testing Eclipse CDT IDE , import GCC make code for ARM Cortex A3 micro is simple.
When you import the make editing compile and debugging is very simple and powerfull. :)
This is my proosal .. I would work on VROS ...this is the White Paper
http://www.virtualrobotix.com/forum/topics/vros-01-white-paper?xg_s...
I'm yet start to work on it ..
Regards
Roberto
@Sthephen,
i check your link . I know Arduino approach is more simple as RTOS . I think that we need a mix between efficence of RTOS RT and Arduino like approach.
I think that a big difference is doing by C++ . With C++ the class could be more simple to read and write.
However in hardware-related programming, simple C is still de facto standard for good reason: C++ implies quite some (hidden) overhead. Although this is considered to be not a problem in systems with a modern microprocessor, it might still be an issue for microcontrollers.
Also, as opposed to C, C++ does some things "in the background", which is not obvious to the programmer (e.g. object constructor/destructor). This is not the case with C where you always have full control of what is going on (much like with assembler).
All this has been discussed a great length years ago e.g. in the Windows device driver community and I have not seen many drivers written in C++ in my life (and I have seen myriads).
Anyway, you actually *can* use C++ with FreeRTOS as Robert Bouwens already pointed out: https://sites.google.com/a/stf12.net/developer-sw-fw/cpp-demo
Having said all that, after all what a mini OS like FreeRTOS primarily does is just add timer-based features like timer callbacks and of course multitasking.
Stephan
Sorry to jump in here. May I suggest it is sometimes worth taking a look at what others do. The OpenPilot project has choosen FreeRTOS as a firmware framework and Qt as a ground control framework (http://www.openpilot.org/). They use the Qt Creator IDE. Qt is free for non-commercial projects (http://qt.nokia.com/).
FreeRTOS is a very robust real-time OS (http://www.freertos.org/). It is available in both a free and a commecrial version (as is the case with Qt, BTW).
Although OpenPilot actually uses these, I would have chosen them anyway.
Just my 2 cents.
Stephan
Another example completly opensource with Eclipse, GCC Compiler, OpenOCD e FreeRtos.
http://developers.stf12.net/eclipse-demo
Regards
Roberto
Last Update ...
I testing Keil IDE and XDuino project library ... First test and all work fine ... :)
Starting Xduino (v0.330000) example program...hello!! 1 2 3
The floating point number is 1234.567800
Xduino Lib v 0.33000 work fine on Ardupilot32 :) This is good news because Xduino is based on standard STM32 lib ...
https://sites.google.com/a/stf12.net/developer-sw-fw/cpp-demo
as an example