Zur Übersicht - INFO - Neueste 50 Beiträge - Neuer Beitrag - Suchen - FAQ - Zum CC1-Forum - Zum CC-Pro-Forum

Wichtig: Bevor Du wegen einem Problem mit der CC2 postest, stelle sicher, daß Du
die neueste OS-Version, die neuseste Compiler-DLL und die neuesten Modulversionen benutzt!
Beachte, daß sich auf der CD zur CC2-Unit/Station auch jetzt noch die ältesten Dateien befinden!
Es gelten folgende Anleitung und Regeln: Regeln CC2Net.de-Forum
Zurück zum Artikel  (Blaue Felder sind Pflichtfelder)


Name:   UserID: 
 E-Mail:
Kategorie
Betreff
Homepage:
Link-Titel:
Link-URL:
Cookie für Name, UserID, E-Mail, Homepage-URL setzen
(Erspart die Neueingabe bei Beiträgen und Antworten)
(Zum Löschen des Cookies hier klicken)
Ich nutze:
C-Control II Unit
C164CI-Controllerboard
C-Control II Station
CCRP5 mit CC2-Unit (Conrad Roboter)
CC2-Application-Board
CC2-StarterBoard
CC2-ReglerBoard
eigenes Board
original OS     OSOPT_V2     OSOPT V3.0 OSOPT V3.1

Kommentar:
Einfügen von HTML im Kommentar:

Link einfügen: <a href="LINKURL" target="_blank">LINKTITEL</a>
Bild einfügen: <img src="BILDURL">
Text formatieren: <b>fetter Text</b>  <i>kursiver Text</i> <u>unterstrichener Text</u>
Kombinationen sind auch möglich z.B.: <b><i>fetter & kursiver Text</i></b>
C2 Quellcode formatieren: <code>Quellcode</code>
ASM Quellcode formatieren: <asm>Quellcode</asm>
(Innerhalb eines Quellcodeabschnitts ist kein html möglich.)
Wichtig: Bitte mache Zeilenumbrüche, bevor Du am rechten Rand des Eingabefeldes ankommst !  

> Hallo, > leider bin ich auch and der seriellen Kommunikation gescheitert. > Bei 9600 Baud funktioniert das Programm einwandfrei. > Bei 19200 Baud fehlt im Empfangsbuffer des CC2 sporadisch das letzte Byte. > Die Datenlänge beträgt maximal 134 Byte. RTS/CTS Handshake ist aktiviert. > Ich habe einen serielle Protokollanalysator in die Leitung gehängt. > Die Daten werden vollständig gesendet. Das CC2 ändert nicht den Pegel an der CTS Leitung. > Da der Empfangspuffer größer als 134 Byte ist, besteht dazu wohl auch kein Grund. > Hat jemand eine Idee? > > Hier nun der Code: > <code> > // Programmierung 24C16 > //-------------------------- > byte EEDataWrite[0x800]; > byte EEDataRead[0x800]; > int Error; > byte HWcombuf[255]; > byte RXDbuf[255]; > byte TXDbuf[255]; > byte TXDdata[255]; > byte command; > byte HeaderCS; > byte DataCS; > byte Datalen; > byte TXDdatalen; > byte CFG_bck12; > byte CFG_bck34; > int CFG_end_address; > byte CFG_init_value; > long CFG_checksum; > byte CFG_status; > > > //----------- > thread main > //----------- > { int i; > byte cs; > byte cmd_reset; > CFG_bck12 = 0; > CFG_bck34 = 0; > CFG_end_address = 0; > CFG_init_value = 0; > CFG_checksum = 0; > CFG_status= 0; > hwcom.init (); // Init > hwcom.setspeed(hwcom.SPEED_19200); // Baudrate setzen > hwcom.set_S0CON (hwcom.set8N1); // 8Bit, no parity, 1 stop bit > hwcom.setbuf(HWcombuf,255); // standard buffer hat nur 64 byte > lcd.init(); > lcd.clear(); > //lcd.goto(0, 0); > //lcd.print("WAITING"); > wait lcd.ready(); > do // endlosschleife > { > Error = 0; > cmd_reset = 0; > command = 0; > DataCS = 0; > Datalen = 0; > TXDdatalen = 0; > hwcom.flush(); //Buffer löschen; > wait hwcom.rxd(); // Wartet auf Daten. Gibt -1 zurück, sobald Daten im Puffer > i = hwcom.receive (RXDbuf, 4, 25); // die ersten 4 byte einlesen > if i != 4 Error = 0x90; > if Error == 0 > { > HeaderCS = RXDbuf[0] + RXDbuf[2] + RXDbuf[3]; > if HeaderCS != RXDbuf[1] Error = 0x81; > if Error == 0 > { > command = RXDbuf[0]; > DataCS = RXDbuf[2]; > Datalen = RXDbuf[3]; > if Datalen > 0 > { > i = hwcom.receive (RXDbuf, Datalen, Datalen + Datalen + 50); > if i != Datalen > { > Error = 0x85; > mem.copypos(TXDdata,0,RXDbuf,0,i); > TXDdatalen = i; > } > if Error == 0 > { > cs = 0; > for i = 0 ... (Datalen - 1) cs = cs + RXDbuf[i]; > if DataCS != cs Error = 0x82; > } > } > } > if Error == 0 > { > if (command > 0) and (command < 0xF) > { > if (command == 1) Software_Version(); > if (command == 2) Error = 0x83; // change Baudrate > if (command == 3) cmd_reset = -1; > if (command == 4) Config_Write(); > if (command == 5) Config_Read(0); > if (command == 6) Error = 0x83; > if (command == 7) Parameter_Tester2Buf(); > if (command == 8) Error = 0x83; > if (command == 9) Error = 0x83; > if (command == 0xA) Error = 0x83; > if (command == 0xB) Error = 0x83; > if (command == 0xC) Error = 0x83; > if (command == 0xD) Error = 0x83; > if (command == 0xE) Config_Read(-1); > } > else > { > Error = 0x83; > } > } > } > if Error != 0 > { > TXDQuittung(Error); > } > else > { > TXDQuittung(command); > } > } > while cmd_reset == 0; > quit -1; > } //main > </code> > > Hier noch ein Beispiel für eine fehlerhafte Datenübertragung aus Sicht des PC: > TX:07 D3 4A 82 06 00 00 01 02 03 04 05 06 07 00 68 > 00 12 34 56 0E 04 09 17 12 13 14 15 16 17 18 19 > FF 01 1C 1D 1E 1F 20 21 22 23 24 25 26 27 28 29 > 2A 2B 2C 2D 2E 2F 30 31 32 33 34 35 36 37 38 39 > 3A 3B 3C 3D 3E 3F 40 41 42 43 44 45 46 47 48 49 > 4A 4B 4C 4D 4E 4F 50 51 52 53 54 55 56 57 58 59 > 5A 5B 5C 5D 5E 5F 60 61 62 63 64 65 66 67 68 69 > 6A 6B 6C 6D 6E 6F 70 71 72 73 74 75 76 77 78 79 > 7A 7B 7C 7D 7E 7F > RX:85 D1 CB 81 06 00 00 01 02 03 04 05 06 07 00 68 > 00 12 34 56 0E 04 09 17 12 13 14 15 16 17 18 19 > FF 01 1C 1D 1E 1F 20 21 22 23 24 25 26 27 28 29 > 2A 2B 2C 2D 2E 2F 30 31 32 33 34 35 36 37 38 39 > 3A 3B 3C 3D 3E 3F 40 41 42 43 44 45 46 47 48 49 > 4A 4B 4C 4D 4E 4F 50 51 52 53 54 55 56 57 58 59 > 5A 5B 5C 5D 5E 5F 60 61 62 63 64 65 66 67 68 69 > 6A 6B 6C 6D 6E 6F 70 71 72 73 74 75 76 77 78 79 > 7A 7B 7C 7D 7E > > Gruss Detlef
Dateianhang: (.gif, .png., .jpg, .zip, .rar)
max. 256kB
max. 256kB