-
Data: 2016-05-30 01:41:27
Temat: Re: Jaki? pomys? na komunikacj? po 1 drucie bez obci?zania cpu?
Od: a...@m...uni.wroc.pl szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]Sebastian Bia?y <h...@p...onet.pl> wrote:
> 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
Następne wpisy z tego wątku
- 30.05.16 08:19 jacek pozniak
- 30.05.16 10:09 Piotr Gałka
- 30.05.16 12:12 Czarek Grądys
- 30.05.16 15:07 AlexY
- 30.05.16 15:18 Marek
- 30.05.16 18:31 Jakub Rakus
Najnowsze wątki z tej grupy
- Szok
- Dziwny schemat wzmacniacza m.cz.
- We Wrocławiu ruszyła Odra 5, pierwszy w Polsce komputer kwantowy z nadprzewodzącymi kubitami
- CGNAT i ewentualne problemy
- wzmacniacz mocy
- Linuks od wer. 6.15 przestanie wspierać procesory 486 i będzie wymagać min. Pentium
- Propagation velocity v/c dla kabli RF
- Jakie natynkowe podwójne gniazdo z bolcem (2P+PE)
- Czujnik nacisku
- Protoków komunikacyjny do urządzenia pomiarowego
- Hiszpania bez pradu
- amperomierz w plusie
- 3G-nadal działa
- Historia pewnego miernika kalibratora
- Ustym 4k Pro i wyświetlacz
Najnowsze wątki
- 2025-06-01 nie ustąpiła moturowi?
- 2025-05-31 Skoro jest tak dobrze i TANIO to dlaczego jeszcze nie jeździmy na takich akumulatorach?
- 2025-05-31 Warszawa => IT Data Analyst (obszar Power BI) <=
- 2025-05-31 Warszawa => IT Hardware Specialist - Wsparcie i Konfiguracja <=
- 2025-05-31 Środa Wielkopolska => Konsultant wewnętrzny SAP FI/CO <=
- 2025-05-31 Gdańsk => PHP Developer <=
- 2025-05-31 Lublin => Delphi Programmer <=
- 2025-05-31 co to za obcęgi? [OT]
- 2025-05-30 Rondo :)
- 2025-05-30 Warszawa => Senior Account Manager <=
- 2025-05-30 Warszawa => Senior C++ Developer (analiza numeryczna i modelowanie) <=
- 2025-05-30 Gdańsk => Team Lead Data Engineer (Snowflake) <=
- 2025-05-30 Warszawa => Team Lead Data Engineer (obszar Snowflake) <=
- 2025-05-30 Gdańsk => Programista Delphi <=
- 2025-05-30 Warszawa => Software Engineer .Net <=