Forum: PC-Programmierung linux, ttyUSB*, C, tcflush - receive buffer löschen?


von tipper (Gast)


Lesenswert?

Vielleicht verstehe ich es miß:

tcflush(pd, TCIOFLUSH)sollte doch sämtliche Daten aus der Schnittstelle
löschen!?

Das Problem ist, das bei Programmstart Müll im Puffer der seriellen
Schnitstelle steht, den ich löschen möchte. Vielleicht könnte man das
einfach auslesen, aber das ist nicht besonders elegant, und außerdem
wird das Phänomen dadurch nicht erklärt.

Könnte es sein, daß der Treiber das nicht unterstützt? Ist ein Prolific
USB-serial Adapter..

von tipper (Gast)


Lesenswert?

Also nochmal ein Versuch, es etwas klarer zu formulieren:

Ich möchte eingegangene Daten von der seriellen Schnittstelle löschen,
bevor ich diese benutze. Sprich, die Daten, die vor Programmstart
gepuffert worden sind, sollen gelöscht werden, so daß ein unmittelbar
anschließendes read() kein Ergebnis hätte.
Das funktioniert bei mir leider nicht, anscheinend, weil ich die
Schnittstelle asynchron benutze.

Vor Programmstart müssten Daten im Puffer sein, die vom µC gesendet
worden sind.
Aber irgendwie werden sie nicht erkannt:
1
Opening port ... Ok!
2
3
flushing: 0
4
5
TX 3 bytes: 116 0 0
6
0 bytes in buffer
7
flushing: 0
8
9
0 bytes in buffer
10
11
Waiting for RX ... Received SIGIO signal.
12
20 bytes in buffer
13
14
RX 20 bytes: 2006-05-16 18:16:43 - 97 0 0 97 0 0 98 1 64 120 1 64 97 1
15
23 120 0 0 116 0 - a 0 - 00.000mm

Sondern anscheinend kann der Port nur nach dem Auftreten des SIGIO
Signals gelesen werden. Eigentlich hätten die drei gesendeten Bytes
empfangen werden sollen (funktioniert einwandfrei, wenn vorher nichts
im Buffer steht). Jedenfalls sind die unerwünschten Daten immer noch
da.
Hier mal die Initialisierung:
1
/* install the signal handler before making the device asynchronous
2
*/
3
  saio.sa_handler = signal_handler_IO;
4
5
  //saio.sa_mask = 0;
6
  saio.sa_flags = 0;
7
  saio.sa_restorer = NULL;
8
  sigaction(SIGIO,&saio,NULL);
9
10
  /* allow the process to receive SIGIO */
11
  fcntl(pd, F_SETOWN, getpid());
12
13
  /* Make the file descriptor asynchronous (the manual page says only
14
O_APPEND and O_NONBLOCK, will work with F_SETFL...)*/
15
  fcntl(pd, F_SETFL, FASYNC);
16
17
  /* set new port settings for canonical input processing */
18
  newtio.c_cflag = BAUDRATE | CS8 | CLOCAL | CREAD;
19
  newtio.c_iflag = IGNPAR;
20
  newtio.c_oflag = 0;
21
  newtio.c_lflag = 0;
22
  newtio.c_cc[VMIN]=3;
23
  newtio.c_cc[VTIME]=0;
24
  
25
  //printw("flushing: %d\n\n",tcflush(pd, TCIOFLUSH));
26
  printw("flushing: %d\n\n",ioctl( pd, TCFLSH, TCIOFLUSH ));
27
  
28
  //tcflush(pd, TCIFLUSH);
29
  tcsetattr(pd,TCSANOW,&newtio);

Würde mich über Hilfe freuen, alleine komme ich nicht mehr weiter. Ich
weiß nicht, wonach ich noch suchen soll.

Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.