Hi
I have developed an application in which four tasks are running one by one(thanks to the scheduler!).
Now the customer is asking me to write the same application using multiple threads.
So basically, my dought is, how can we implement multithreading using MQX RTOS??. Is there any example available of the multithreading is done using the MQX RTOS??
Any help will be really appreciated!!
Regards,
Omkar DIxit
I definitely agree with @myke_predko MQX is not the best option here. We are using it and it is cumbersome and not that straightforward. Also, If you get stuck then good luck because support is not good.
I would also recommend FreeRTOS. It is very easy to use and there are a lot of resources for learning. Additionally, if you are using MCUXpresso, the very examples NXP includes are based on FreeRTOS and you can jumpstart from there.
And if you get stuck with FreeRTOS you can ask anywhere, not only NXP forum and you'll get an answer and help much faster. Whereas with MXQ you are stuck with the little help you can get only here in the NXP forum.
Currently the recommended RTOS from NXP side is FreeRTOS. MQX RTOS is a third party OS from Embedded Access. http://embedded-access.com/
Hi Omkar DIxit:
The default MQX scheduling policy is FIFO, with FIFO scheduling, the tasks runs next is the highest-priority tasks that has been waiting the longest time.
Maybe the multi-threading you mentioned the Roubin robin , with Round Robin scheduling, tasks of the same priority can share the processor in a time-equitable manner.
you need to set the MQX_TIME_SLICE_TASK attribute in the task's template.
The task's time slice is determined by the value of the template's DEFAULT_TIME_SLICE.
Regards
Daniel
Can I ask why you're looking at MQX? It is a fine RTOS (that I used in a fairly major product) but there are licensing costs associated with it which may be an okay thing but what I find is that when a company starts doing that, support becomes something you have to pay for as the company wants to consult on application development. You can get more information here: Embedded Access
Would you consider FreeRTOS? Examples are available for the K70 as part of the SDK and there's a lot more support available as well as there are no licensing costs.
I'm sure @mjbcswitzerland would introduce you to utasker and give you a helping hand to start off. It's licenced software, but has great support.
Based on your questions, I think you're looking a tough learning curve and you should consider how you are going to get help to get started as well as get help for architecting your application.
myke
Before also someone suggested me to use uTASK os instead of MQX, I tried the same but I found it a bit difficult(maybe was wrong!) as compared to MQX.
When I moved to the MQX RTOS 4.1, I found so many documents about the same which made my work easy. Whenever I got confused, I followed the documents provided in the MQX RTOS.
But, if I get time in the future I will definitely like to work on uTASK os.
Regards,
Omkar Dixit
Hi @omkardixit
[EDIT: I realized that I didn't list what I consider to be the most important feature of an RTOS]
What is your experience level with working with RTOSes? I'm asking because I would be hesitant to consider MQX as a starting point or as the RTOS for a new product.
It's not that it isn't a good quality product but with it's change in licensing (around five years ago) to a pay licensing model on line support by other users has dried up. I still support products written with MQX so these comments are not coming from a position of ignorance. I'm surprised that the documentation is still there, I guess that's a residual of NXP (Freescale actually) actively promoting their products with MQX from 10 years ago. My biggest concern with MQX is that there aren't examples with NXP's SDK and when I worked with it, I had to write/support drivers (that are freely available in the SDK) by hand which ended up being a lot more work. There are KSDK (Freescale's "Kinetis SDK") MQX code and examples available but KSDK is no longer actively supported.
To net it out, I would consider MQX to be a suboptimal RTOS for learning and/or creating new applications.
To be honest, there is very little difference in the different RTOSes available for Kinetis (or really any MCU). In all of them provide a level of basic functionality with standard resources and while there are differences in performance/overhead/code size they all require the same thought processes.
When you're selecting an RTOS, I would consider the three four most important criteria to be:
Let me know if you want to talk more about this.
myke