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..
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
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.