Sebastian BiaĹy
Guest
Sun May 29, 2016 8:56 pm
Cześć.
Problem: w pewnym cpu został mi 1 pin. Chce podpiąc wyświetlacz i
klawiaturę, odległość naście cm, prędkość znikoma.
Wstawiam więc drugi cpu.
Cpu1 to avr, cpu2 może być byleczym.
Teraz: cpu1 jest *bardzo* zajęty. Gdzieś koło 90% mocy w przerwaniach,
dwa timery wolne. W głownej pętli programu mam chwilę (nierównomierne)
na obsługę czegoś, co jakieś 1000-3000 cykli 20MHz. Cpu2 od wyświetlacza
(2x16) i klawiatury nie ma nic do roboty.
No i teraz się zastanawiam, czy jest jakiś pomysł na komunikację po 1
drucie w *dwie* strony:
a) nie obciąza cpu sztucznymi pętlami opóźniającymi
b) nie wymaga szybkiego poolingu na liniach
c) może korzystać z hardware cpu, prawie wszystko wolne (pwm, timery,
uart itd)
d) da radę wysłać jakieś 100 bajtów / sek i odebrać 10 bajtów sek
(jakość obsługi).
Oczywiście od razu nasuwa sie 1-wire, ale powtarzam: nie mam cpu dla
siebie. Przyszedł mi do głowy pomysł aby sterować szerokością impulsu
1-wire za pomocą wolnego PWM. Gorzej z czytaniem, choć może dałbym radę
trafiać jako tako z czytaniem pomiędzy przerwaniami. Oczywiscie to może
być "moje" 1-wire i np. mogę je znacząco spowolnić. Moge też popędzić
cpu1 większym zegarem ale to ostateczność.
Zanim zaczne kombinować z 1wire - czy zna ktoś inny protokół 1-drutowy?
Od biedy mogę podpiąć wspólny XTAL do obu jesli coś to da.
Nie, nie zmienię avr-a cpu1 na coś innego. Nie ma nic innego w tym
zastosowaniu (szybki cykl zegarowy, 5V) co miało by ekonomiczny sens.
Jakub Rakus
Guest
Sun May 29, 2016 9:10 pm
W dniu 29.05.2016 o 22:56, Sebastian Biały pisze:
Quote:
c) może korzystać z hardware cpu, prawie wszystko wolne (pwm, timery,
uart itd)
No to może jednak UART? Pod warunkiem, że możesz tak go poustawiać żeby
jeden pin był na przemian nadajnikiem i odbiornikiem.
--
Pozdrawiam
Jakub Rakus
Guest
Mon May 30, 2016 1:41 am
Sebastian Bia?y <heby@poczta.onet.pl> wrote:
Quote:
Cze??.
Problem: w pewnym cpu zosta? mi 1 pin. Chce podpi?c wy?wietlacz i
klawiatur?, odleg?o?? na?cie cm, pr?dko?? znikoma.
Wstawiam wi?c drugi cpu.
Cpu1 to avr, cpu2 mo?e by? byleczym.
Teraz: cpu1 jest *bardzo* zaj?ty. Gdzie? ko?o 90% mocy w przerwaniach,
dwa timery wolne. W g?ownej p?tli programu mam chwil? (nier?wnomierne)
na obs?ug? czego?, co jakie? 1000-3000 cykli 20MHz. Cpu2 od wy?wietlacza
(2x16) i klawiatury nie ma nic do roboty.
No i teraz si? zastanawiam, czy jest jaki? pomys? na komunikacj? po 1
drucie w *dwie* strony:
a) nie obci?za cpu sztucznymi p?tlami op??niaj?cymi
b) nie wymaga szybkiego poolingu na liniach
c) mo?e korzysta? z hardware cpu, prawie wszystko wolne (pwm, timery,
uart itd)
d) da rad? wys?a? jakie? 100 bajt?w / sek i odebra? 10 bajt?w sek
(jako?? obs?ugi).
Oczywi?cie od razu nasuwa sie 1-wire, ale powtarzam: nie mam cpu dla
siebie.
Oczywistym rozwiazaniem jest UART w half-duplex. 1-wire to nie jest
dobry pomysl, bo przy ustalonej szybkosci transmisji wymaga duzo
lepszej rozdzielczosci czasowej niz UART. Niekture procesory
(np. STM32) maja UART sprzetowo wspierajacy half-duplex,
w AVR nie zauwazylem takiej mozliwosci... Programowo UART
mozna zrobic z timera kosztem jednego przerwania na bit.
Tzn. uzywasz timer do pomiaru czasu miedzy zboczami
przy odbiorze, przy nadawianiu machasz GPIO z przerwania
timera. 1200 bitow na sekunde powinno Ci wystarczyc, wiec
jak zniesiesz dodatkowe 1200 przerwan to bedzie OK.
Mozesz uzyc tez kombinowane rozwiazanie: sprzetowy UART
do odbioru, softwarowy (na tej samej linii) do nadawania.
Jeszcze jeden pomysl: sporo CPU ma UART-y ktore moga
odbierac np. 5MHz. Wiec z AVR mozesz nadawac z duza
szybkoscia, tak ze bajt zajmie powiedzmy 2us. Na tyle
pewnie mozesz zablokowac przerwania.
--
Waldek Hebisch
jacek pozniak
Guest
Mon May 30, 2016 6:19 am
Sebastian Biały wrote:
Quote:
Cześć.
Problem: w pewnym cpu został mi 1 pin. Chce podpiąc wyświetlacz i
klawiaturę, odległość naście cm, prędkość znikoma.
Wstawiam więc drugi cpu.
Cpu1 to avr, cpu2 może być byleczym.
Teraz: cpu1 jest *bardzo* zajęty. Gdzieś koło 90% mocy w przerwaniach,
dwa timery wolne. W głownej pętli programu mam chwilę (nierównomierne)
na obsługę czegoś, co jakieś 1000-3000 cykli 20MHz. Cpu2 od wyświetlacza
(2x16) i klawiatury nie ma nic do roboty.
No i teraz się zastanawiam, czy jest jakiś pomysł na komunikację po 1
drucie w *dwie* strony:
a) nie obciąza cpu sztucznymi pętlami opóźniającymi
b) nie wymaga szybkiego poolingu na liniach
c) może korzystać z hardware cpu, prawie wszystko wolne (pwm, timery,
uart itd)
d) da radę wysłać jakieś 100 bajtów / sek i odebrać 10 bajtów sek
(jakość obsługi).
Zaemuluj UARTA programowo w głównej pętli (oczywiście nieblokująco).
Synchronizację (zegar) wyznaczaj przez wolny timer.
W najgorszym przypadku główna pętla jest wołana co 1,5ms więc odebrać 10
znaków/s powinno się dać bez problemu, nie wiem tylko czy wyślesz tak
100bajtów/sec (chociaż jeśli cpu2 będzie dość mądre to może da radę
odebrać).
jp
Piotr GaĹka
Guest
Mon May 30, 2016 8:09 am
Użytkownik "Sebastian Biały" <heby@poczta.onet.pl> napisał w wiadomości
news:nifl22$9um$1@node2.news.atman.pl...
Quote:
Cześć.
Problem: w pewnym cpu został mi 1 pin. Chce podpiąc wyświetlacz i
klawiaturę, odległość naście cm, prędkość znikoma.
Wstawiam więc drugi cpu.
Cpu1 to avr, cpu2 może być byleczym.
Teraz: cpu1 jest *bardzo* zajęty. Gdzieś koło 90% mocy w przerwaniach, dwa
timery wolne. W głownej pętli programu mam chwilę (nierównomierne) na
obsługę czegoś, co jakieś 1000-3000 cykli 20MHz. Cpu2 od wyświetlacza
(2x16) i klawiatury nie ma nic do roboty.
No i teraz się zastanawiam, czy jest jakiś pomysł na komunikację po 1
drucie w *dwie* strony:
a) nie obciąza cpu sztucznymi pętlami opóźniającymi
b) nie wymaga szybkiego poolingu na liniach
c) może korzystać z hardware cpu, prawie wszystko wolne (pwm, timery, uart
itd)
d) da radę wysłać jakieś 100 bajtów / sek i odebrać 10 bajtów sek (jakość
obsługi).
Oczywiście od razu nasuwa sie 1-wire, ale powtarzam: nie mam cpu dla
siebie. Przyszedł mi do głowy pomysł aby sterować szerokością impulsu
1-wire za pomocą wolnego PWM. Gorzej z czytaniem, choć może dałbym radę
trafiać jako tako z czytaniem pomiędzy przerwaniami. Oczywiscie to może
być "moje" 1-wire i np. mogę je znacząco spowolnić. Moge też popędzić cpu1
większym zegarem ale to ostateczność.
Zanim zaczne kombinować z 1wire - czy zna ktoś inny protokół 1-drutowy? Od
biedy mogę podpiąć wspólny XTAL do obu jesli coś to da.
Nie, nie zmienię avr-a cpu1 na coś innego. Nie ma nic innego w tym
zastosowaniu (szybki cykl zegarowy, 5V) co miało by ekonomiczny sens.
Podwieszone OC - każdy może wymusić 0.
Jeden cały czas taktuje linię - impulsy 0 krótsze od odstępów.
Czasy dobrane tak, aby obserwujący linię nie przegapił impulsu.
Jak chce coś nadać to zaczyna od dłuższego impulsu = bit startu itd.
Jak drugi chce nadać to robi to przedłużając obserwowany impuls = bit
startu.
P.G.
Czarek GrÄ
dys
Guest
Mon May 30, 2016 10:12 am
W dniu 29.05.2016 o 22:56, Sebastian Biały pisze:
Quote:
Cześć.
Problem: w pewnym cpu został mi 1 pin. Chce podpiąc wyświetlacz i
klawiaturę, odległość naście cm, prędkość znikoma.
Może się przyda, wprawdzie potrzebujesz w 2 strony, ale może
uda się ten pomysł rozwinąć.
https://developer.mbed.org/cookbook/1-wire-shifting-2x16-LCD
--
Cezary Grądys
czarekgr@wa.onet.pl
AlexY
Guest
Mon May 30, 2016 1:07 pm
Czarek Grądys pisze:
Quote:
W dniu 29.05.2016 o 22:56, Sebastian Biały pisze:
Cześć.
Problem: w pewnym cpu został mi 1 pin. Chce podpiąc wyświetlacz i
klawiaturę, odległość naście cm, prędkość znikoma.
Może się przyda, wprawdzie potrzebujesz w 2 strony, ale może
uda się ten pomysł rozwinąć.
https://developer.mbed.org/cookbook/1-wire-shifting-2x16-LCD
Genialne w swojej prostocie, dodane do przydasiów, dzięki.
--
AlexY
http://faq.enter.net.pl/simple-polish.html
http://www.pg.gda.pl/~agatek/netq.html
Marek
Guest
Mon May 30, 2016 1:18 pm
On Sun, 29 May 2016 22:56:33 +0200, Sebastian
Biały<heby@poczta.onet.pl> wrote:
Quote:
No i teraz się zastanawiam, czy jest jakiś pomysł na komunikację po
1
drucie w *dwie* strony:
A PJON rozważałeś? Taka alternatywa do 1W:
http://hackaday.com/2016/03/31/pjon-fancy-one-wire-arduino-communications-protocol-for-home-automation/
--
Marek
Jakub Rakus
Guest
Mon May 30, 2016 4:31 pm
W dniu 29.05.2016 o 22:56, Sebastian Biały pisze:
Quote:
Cześć.
Problem: w pewnym cpu został mi 1 pin. Chce podpiąc wyświetlacz i
klawiaturę, odległość naście cm, prędkość znikoma.
Takie coś znalazłem:
http://nerdralph.blogspot.com/2014/01/avr-half-duplex-software-uart.html
--
Pozdrawiam
Jakub Rakus