Nie jesteś zalogowany.
Jeśli nie posiadasz konta, zarejestruj je już teraz! Pozwoli Ci ono w pełni korzystać z naszego serwisu. Spamerom dziękujemy!

Ogłoszenie

Prosimy o pomoc dla małej Julki — przekaż 1% podatku na Fundacji Dzieciom zdazyć z Pomocą.
Więcej informacji na dug.net.pl/pomagamy/.

#1  2013-04-14 21:42:48

  pimowo - Użytkownik

pimowo
Użytkownik
Zarejestrowany: 2013-02-24

Nasłuch ttyS0

Witam,

Panowie, jak zrobić w Debianie taki myk, aby system non stop nasłuchiwał port /dev/ttyS0 i jeżeli coś przyjdzie to z automatu zapisze wszystko w /home/user/plik.txt

Offline

 

#2  2013-04-15 12:50:43

  andreq - Członek DUG

andreq
Członek DUG
Skąd: Nisko
Zarejestrowany: 2005-01-11

Re: Nasłuch ttyS0

Dodajesz danego użytkownika do grupy dialout

Kod:

usermod -aG dialout user

Kod:

$ cat /dev/ttyS0 >  /home/user/plik.txt

Może być przydatne zapoznanie się z "przekierowaniem wyjścia" w

Kod:

man bash

oraz pomoc do polecenia tee:

Kod:

man tee

Napisz czemu ma to służyć, bo bezpośredni odczyt z portu szeregowego i zapis wszystkich danych do pliku nie jest specjalnie dobrym pomysłem.

Offline

 

#3  2013-04-15 20:01:24

  pimowo - Użytkownik

pimowo
Użytkownik
Zarejestrowany: 2013-02-24

Re: Nasłuch ttyS0

Mam kartę przekaźników i chciałbym zrobić tak, że po naciśnięciu klawisza przełącza mi przekaźnik i wysyła jednocześnie jakąś tam komendę. Jeżeli już komputer (który "słucha") otrzyma tą komendę to uruchomi skrypt-ogólnie to ma być część czegoś większego.

W google znalazłem coś takiego:

Kod:

stty 9600 -parenb cs8 -cstopb | cat /dev/ttyS0 > /home/user/plik.txt

Ale nie do końca rozumiem tego polecenia i jak je wykorzystać.

Jeżeli uruchomię to polecenie w terminalu i wyślę z karty "Sw1" to w pliku otrzymuję "Sw1" i jakieś kwadraciki, jeżeli otworzę plik w LibreOffice Writer to mam "Sw1 ##"
Czy wysyłając coś z karty muszę wysłać jakieś dodatkowe znaki czy coś?


Danych ogólnie będzie mało.

Ostatnio edytowany przez pimowo (2013-04-15 21:20:58)

Offline

 

#4  2013-04-17 21:29:02

  pimowo - Użytkownik

pimowo
Użytkownik
Zarejestrowany: 2013-02-24

Re: Nasłuch ttyS0

Ma ktoś jakiś pomysł jak to mądrze rozwiązać? :)

Offline

 

#5  2013-04-18 14:58:10

  bercik - Moderator Mamut

bercik
Moderator Mamut
Skąd: Warszawa
Zarejestrowany: 2006-09-23
Serwis

Re: Nasłuch ttyS0

zobacz hexedytorem jakie wartości numeryczne odpowiadają tym kwadracikom ... często w transmisjach sieciowych (także na porcie szeregowym) używany jest wraz z znakiem nowej linii znak powrotu karetki ... poza tym skoro dostajesz numer switcha to w czym przeszkadzają te dodatkowe znaki?


"Wszyscy wiedzą, że czegoś zrobić nie można. Ale przypadkowo znajduje się jakiś nieuk, który tego nie wie. I on właśnie robi odkrycie." (A.Einstein)

Offline

 

#6  2013-04-21 13:14:37

  pimowo - Użytkownik

pimowo
Użytkownik
Zarejestrowany: 2013-02-24

Re: Nasłuch ttyS0

[quote=bercik]zobacz hexedytorem jakie wartości numeryczne odpowiadają tym kwadracikom ... często w transmisjach sieciowych (także na porcie szeregowym) używany jest wraz z znakiem nowej linii znak powrotu karetki ... poza tym skoro dostajesz numer switcha to w czym przeszkadzają te dodatkowe znaki?[/quote]
W sumie to mi to nie przeszkadza, byłem ciekawy dlaczego tak się dzieje.
Otwierając plik.txt w programie GHex otrzymuję ".. Sw1 ." "0A 0A 20 53 77 31 20 0A"

A jak to zrobić, aby Debian cały czas w tle "słuchał" co się dzieje na ttyS0 i jeżeli coś przyjdzie to zapisze do plik.txt?

Offline

 

#7  2013-04-22 20:24:24

  andreq - Członek DUG

andreq
Członek DUG
Skąd: Nisko
Zarejestrowany: 2005-01-11

Re: Nasłuch ttyS0

Robisz aby np. to

Kod:

stty 9600 -parenb cs8 -cstopb | cat /dev/ttyS0 > /home/user/plik.txt &

uruchamiane było podczas startu systemu, tu masz wątek jak to zrobić: http://forum.dug.net.pl/viewtopic.php?id=5695 Zwróć uwagę na znak & kończący linię.

Offline

 

#8  2013-04-23 14:21:34

  bercik - Moderator Mamut

bercik
Moderator Mamut
Skąd: Warszawa
Zarejestrowany: 2006-09-23
Serwis

Re: Nasłuch ttyS0

czyli poza nowymi liniami i spacjami nic specjalnego tam nie ma ... więc nie powinno być kwadracików :-/


"Wszyscy wiedzą, że czegoś zrobić nie można. Ale przypadkowo znajduje się jakiś nieuk, który tego nie wie. I on właśnie robi odkrycie." (A.Einstein)

Offline

 

#9  2013-04-23 15:02:30

  andreq - Członek DUG

andreq
Członek DUG
Skąd: Nisko
Zarejestrowany: 2005-01-11

Re: Nasłuch ttyS0

@bercik

Ale on ustawa przez stty (opcja -parentb) generowanie bitu parzystości na wyjściu, stąd pewnie dodatkowe znaki, najlepiej jakby bezpośrednio czytał np. hexdump-em /dev/ttyS0

Tak nawiasem zapisywanie danych z portu szeregowego bezpośrednio do pliku a potem odczytywanie jego zawartości można o kant d... wytłuc, lepiej napisać własny program chociażby w pythonie lub nawet w C, jest sporo gotowych przykładów w sieci, tym bardziej, jak autor wątku napisał, że ma to być częścią czegoś większego

Offline

 

#10  2015-10-13 18:01:05

  pimowo - Użytkownik

pimowo
Użytkownik
Zarejestrowany: 2013-02-24

Re: Nasłuch ttyS0

Panowie, odgrzewam swojego starego kotleta...

Ostatnio mnie znów natchnęło aby wykonać nasłuch portu, ale tym razem /dev/ttyUSB0 :)

Kiedyś tak jak i teraz nie wiem jak sobie z tym poradzić :(
Napisałem sobie coś takiego:

Kod:

#!/bin/bash

PORT=/dev/ttyUSB0

while true; do

  read -n90 RESPONSE < $PORT &&

echo $RESPONSE
    if [ $RESPONSE = "S5551" ]
      then
      /gdzies/jakis/skrypt
    fi

done

Czyli w sieci pojawi się ciąg znaków "S5551" i wykona mi się skrypt. Tadam, wszystko działa :)
Niestety działa tylko w połowie jak bym tego chciał :(
Jak ten programik odczyta coś z sieci to już nic innego nie działa :(
W sumie chodzi mi o to jak zrobić "przezroczysty" nasłuch /dev/ttyUSB0?

Offline

 

Stopka forum

Powered by PunBB
© Copyright 2002–2005 Rickard Andersson
Nas ludzie lubią po prostu, a nie klikając w przyciski ;-)

[ Generated in 0.017 seconds, 11 queries executed ]

Informacje debugowania

Time (s) Query
0.00011 SET CHARSET latin2
0.00007 SET NAMES latin2
0.00128 SELECT u.*, g.*, o.logged FROM punbb_users AS u INNER JOIN punbb_groups AS g ON u.group_id=g.g_id LEFT JOIN punbb_online AS o ON o.ident='18.117.183.150' WHERE u.id=1
0.00127 REPLACE INTO punbb_online (user_id, ident, logged) VALUES(1, '18.117.183.150', 1713962761)
0.00097 SELECT * FROM punbb_online WHERE logged<1713962461
0.00128 SELECT topic_id FROM punbb_posts WHERE id=291674
0.00319 SELECT id FROM punbb_posts WHERE topic_id=23345 ORDER BY posted
0.00128 SELECT t.subject, t.closed, t.num_replies, t.sticky, f.id AS forum_id, f.forum_name, f.moderators, fp.post_replies, 0 FROM punbb_topics AS t INNER JOIN punbb_forums AS f ON f.id=t.forum_id LEFT JOIN punbb_forum_perms AS fp ON (fp.forum_id=f.id AND fp.group_id=3) WHERE (fp.read_forum IS NULL OR fp.read_forum=1) AND t.id=23345 AND t.moved_to IS NULL
0.00045 SELECT search_for, replace_with FROM punbb_censoring
0.00172 SELECT u.email, u.title, u.url, u.location, u.use_avatar, u.signature, u.email_setting, u.num_posts, u.registered, u.admin_note, p.id, p.poster AS username, p.poster_id, p.poster_ip, p.poster_email, p.message, p.hide_smilies, p.posted, p.edited, p.edited_by, g.g_id, g.g_user_title, o.user_id AS is_online FROM punbb_posts AS p INNER JOIN punbb_users AS u ON u.id=p.poster_id INNER JOIN punbb_groups AS g ON g.g_id=u.group_id LEFT JOIN punbb_online AS o ON (o.user_id=u.id AND o.user_id!=1 AND o.idle=0) WHERE p.topic_id=23345 ORDER BY p.id LIMIT 0,25
0.00213 UPDATE punbb_topics SET num_views=num_views+1 WHERE id=23345
Total query time: 0.01375 s