Offline
Edison Member
Karma: 26
Posts: 1339
You do some programming to solve a problem, and some to solve it in a particular language. (CC2)
|
 |
« Reply #255 on: October 28, 2012, 06:48:42 pm » |
Ops... "Ready", come scordarsi di te ? 
|
|
|
|
|
Logged
|
|
|
|
|
Offline
Sr. Member
Karma: 6
Posts: 462
|
 |
« Reply #256 on: October 29, 2012, 11:47:35 am » |
|
|
|
|
|
Logged
|
|
|
|
|
Cagliari
Online
Faraday Member
Karma: 51
Posts: 3194
|
 |
« Reply #257 on: November 08, 2012, 12:12:54 pm » |
|
|
|
|
|
Logged
|
|
|
|
|
Forum Moderator
Italy
Online
Brattain Member
Karma: 226
Posts: 17003
Don't know what I do
|
 |
« Reply #258 on: November 08, 2012, 12:20:41 pm » |
No, non l'avevo vista. Non sono iscritto alle mailing-list. Se hai modo di rispondere, fagli presente che esiste già uno schedulatore 
|
|
|
|
|
Logged
|
|
|
|
|
|
|
Forum Moderator
Italy
Online
Brattain Member
Karma: 226
Posts: 17003
Don't know what I do
|
 |
« Reply #260 on: November 08, 2012, 12:29:21 pm » |
Lo sai che in questi giorni stavo pensando proprio a modificare il timer che sugli Atmega ed Attiny gestisce millis per integrare il leOS lì, in modo da non consumare timer extra né interferire con altre librerie? 
|
|
|
|
|
Logged
|
|
|
|
|
0
Offline
Full Member
Karma: 0
Posts: 111
Arduino rocks
|
 |
« Reply #261 on: November 08, 2012, 12:49:23 pm » |
È una buona idea far fare tutto il lavoro a delle funzioni richiamate con leOS e lasciare il loop() vuoto se non serve eseguire in continuazione il codice o è meglio lasciare la parte principale in loop() e mettere un delay alla fine?
|
|
|
|
|
Logged
|
|
|
|
|
0
Offline
Faraday Member
Karma: 18
Posts: 4051
Arduino rocks
|
 |
« Reply #262 on: November 08, 2012, 03:59:49 pm » |
il famoso Delay2, di cui rivendico la paternita' dell'idea, sara' la funzione piu' importante di Arduino cioe' se ti serve un delay bloccante userai delay() se ti serve uno non bloccante useray delay2() senza dover mettere in campo millis ed i suoi giri contorti (per un non programmatore)
a proposito Leo, complimenti per il lavoro pubblicato sull'overflow di millis, potresti chiedere di modificare il blinkwithoutdelay aggiungendo la tua idea per superare i famosi 50giorni sarebbe comunque molto bello avere il tuo nome in uno sketch che viene inserito ufficialmente negli esempi dell'IDE
p.s. ma oltre all'articlo sul tuo blog c'e' hai aperto anche una discussione sul forum ?
|
|
|
|
|
Logged
|
|
|
|
|
Forum Moderator
Italy
Online
Brattain Member
Karma: 226
Posts: 17003
Don't know what I do
|
 |
« Reply #263 on: November 08, 2012, 04:06:52 pm » |
È una buona idea far fare tutto il lavoro a delle funzioni richiamate con leOS e lasciare il loop() vuoto se non serve eseguire in continuazione il codice o è meglio lasciare la parte principale in loop() e mettere un delay alla fine?
I task dovrebbero essere compiti semplici, che occupano poco tempo CPU, in modo da non rallentare l'esecuzione delle altre funzioni basate su interrupt. Se il tuo caso ricade in questo esempio, puoi anche inserire tutto in task e lasciare il loop vuoto. Se hai un compito che invece è molto gravoso, conviene inserirlo nel loop (e qui puoi rallentarne l'esecuzione con un delay).
|
|
|
|
|
Logged
|
|
|
|
|
Forum Moderator
Italy
Online
Brattain Member
Karma: 226
Posts: 17003
Don't know what I do
|
 |
« Reply #264 on: November 08, 2012, 04:09:02 pm » |
a proposito Leo, complimenti per il lavoro pubblicato sull'overflow di millis,
Grazie  potresti chiedere di modificare il blinkwithoutdelay aggiungendo la tua idea per superare i famosi 50giorni sarebbe comunque molto bello avere il tuo nome in uno sketch che viene inserito ufficialmente negli esempi dell'IDE
Non credo che lo faranno mai  p.s. ma oltre all'articlo sul tuo blog c'e' hai aperto anche una discussione sul forum ?
No.
|
|
|
|
|
Logged
|
|
|
|
|
Forum Moderator
Italy
Online
Brattain Member
Karma: 226
Posts: 17003
Don't know what I do
|
 |
« Reply #265 on: November 09, 2012, 12:32:18 pm » |
Oggi ho studiato un po' la cosa, ed è una funzione molto più complessa della mia. Essa sfrutta un modulo presente nel SAM3X, il SysTick, un contatore indipendente dai timer del micro a cui hanno agganciato un gestore di task. Ogni task ha un suo tempo computazionale, ed il tutto è gestito dallo scheduler proprio tramite i tick, anche il delay segue lo stesso principio: usano un task che genera i millis, che poi leggono per i ritardi. Insomma, una cosina più raffinata che ovviamente non è replicabile sui Mega perché appunto utilizzano dell'HW dedicato. PS: in teoria si potrebbe agganciare il leOS ad un INT esterno o ad un PCINT, ma in questo modo si perderebbe un pin.
|
|
|
|
|
Logged
|
|
|
|
|
Offline
Edison Member
Karma: 26
Posts: 1339
You do some programming to solve a problem, and some to solve it in a particular language. (CC2)
|
 |
« Reply #266 on: November 09, 2012, 03:13:46 pm » |
Mi sa che tra un po' per il DUE uscirà una sorta di ArduinOS ex-novo... 
|
|
|
|
|
Logged
|
|
|
|
|
Forum Moderator
Italy
Online
Brattain Member
Karma: 226
Posts: 17003
Don't know what I do
|
 |
« Reply #267 on: November 09, 2012, 04:54:21 pm » |
Mi sa che tra un po' per il DUE uscirà una sorta di ArduinOS ex-novo...  Non credo, penso che non sia questo il desiderio del team di Arduino. Loro sono per le cose semplici, ed un RTOS nel vero senso della parola non è una cosa tanto facile da gestire per un utente di medio livello. E poi non penso che passerà molto tempo prima che progetti quali FreeRTOS o ChibiOS siano resi compatibili con il SAM3X della DUE.
|
|
|
|
|
Logged
|
|
|
|
|
Offline
Edison Member
Karma: 26
Posts: 1339
You do some programming to solve a problem, and some to solve it in a particular language. (CC2)
|
 |
« Reply #268 on: November 09, 2012, 05:29:57 pm » |
In effetti la mia era più che altro una battuta. Penso che tu abbia ragione. non penso che passerà molto tempo prima che progetti quali FreeRTOS o ChibiOS siano resi compatibili con il SAM3X della DUE[/quote
Il Chibi l'avevo provato sulla 2009, mi è sembrato interessante anche se non ho approfondito. Credo che la DUE diventerà una piattaforma molto interessante per lo studio dei sistemi operativi grazie alla maggiore potenza della cpu.
|
|
|
|
|
Logged
|
|
|
|
|
Forum Moderator
Italy
Online
Brattain Member
Karma: 226
Posts: 17003
Don't know what I do
|
 |
« Reply #269 on: November 09, 2012, 05:34:55 pm » |
Il Chibi l'avevo provato sulla 2009, mi è sembrato interessante anche se non ho approfondito. Credo che la DUE diventerà una piattaforma molto interessante per lo studio dei sistemi operativi grazie alla maggiore potenza della cpu.
Il problema della DUE è che non è abbastanza potente per poter farci girare un vero SO, e gli RTOS embedded girano tranquillamente anche su chippini insignificanti come i Tiny con 2 kB di Flash, vedi il FemtoOS. Insomma, nulla di nuovo.
|
|
|
|
|
Logged
|
|
|
|
|
|