4304 lines
190 KiB
Plaintext
4304 lines
190 KiB
Plaintext
|
//**********************************************************************
|
|||
|
//* ProgrammierAblaufBeschreibungsDatei PABD
|
|||
|
//* f<>r Flash-Prozess mit
|
|||
|
//* Muster SteuerGer<65>teBeschreibungsDatei SGBD
|
|||
|
//**********************************************************************
|
|||
|
//* History:
|
|||
|
//* 16.02.2001 rd V1.00 Freigabe der Muster PABD
|
|||
|
//* 03.04.2001 rd V1.01 TesterPresent, DNMT, ENMT Handling erweitert
|
|||
|
//* V1.01 TesterPresentHandlingSwitch neu dazu
|
|||
|
//* V1.01 Bei Wiederaufsetzen TransferExit mit Datenanzahl=0
|
|||
|
//* 21.05.2001 rd V1.02 WiederaufsetzenSwitch neu dazu
|
|||
|
//* 11.07.2001 rd V2.00 Ben<65>tigt mindestens WinKfp Version 2.0
|
|||
|
//* V2.00 Neue Programmierstati in FlashStatusLesen
|
|||
|
//* V2.00 Funktion SetEcuAdr neu dazu
|
|||
|
//* V2.00 <20>berarbeitung AIF lesen
|
|||
|
//* V2.00 <20>berarbeitung Datenreferenz lesen
|
|||
|
//* V2.00 Loeschzeit jetzt Wordparameter
|
|||
|
//* 03.12.2001 rj V2.10 Erweiterung um neue Prozessortypen
|
|||
|
//* Neuer Name von 00flash auf 01flash
|
|||
|
//* 18.03.2002 rj V2.11 Setzen der globalen Variable SIMULATION:
|
|||
|
//* ALt: SIMULATION = TRUE
|
|||
|
//* Neu: SIMULATION = FALSE
|
|||
|
//* 15.05.2002 Mw V3.00 Auswerten der 17-stelligen Fahrgestellnummer bei AIF_LESEN
|
|||
|
//* V3.00 Aufruf von SG_PHYS_HWNR_LESEN f<>r die Anzeige der physik. Hardwarenummer
|
|||
|
//* V3.00 Aufruf von SG_INNENTEMP_LESEN f<>r die Anzeige der SG-Innentemperatur
|
|||
|
//* V3.00 Erweiterung der Adressraums auf 4 Adressbytes
|
|||
|
//* 13.06.2002 Pf V3.01 Fehlerbehebung FLASH_BLOCK_LAENGE_GESAMT => Unsigned Int
|
|||
|
//* V3.01 Fehlerbehebung FLASH_SCHREIBEN_ANZAHL => Unsigned Int
|
|||
|
//* 08.08.2002 Pf V4.00 # Deaktivierung/Aktivierung des FZGBusses w<>hrend der Flashprogrammierung
|
|||
|
//* # Polling Verfahren w<>hrend des RESETs am Ende der Flashprogrammierung Prozess
|
|||
|
//* Funktion : "STEUERGERAETE_RESET
|
|||
|
//* # Prozessor Typ : entweder "Standard" oder "HC12DG128""
|
|||
|
//* # Wiederaufsetzen in der "Programmieren" Funktion
|
|||
|
//* Wenn 1 Fehler auftritt, flashen 2 Datenbl<62>cke zur<75>ck
|
|||
|
//* 27.08.2002 Pf V4.01 # Boot Sektor Update : BSUTime in der PAF File gelesen. Wenn nicht vorhanden,
|
|||
|
//* ist die Null Werte g<>ltig
|
|||
|
//* 12.11.2002 Pf V4.02 # AuffuellenSwitch: Auffuellung von Datenbloecke bis zu Maximal Block Laenge (MXBL)
|
|||
|
//* Betroffen ist die Funktion CDHGetApiJobByteData()
|
|||
|
//* 27.11.2002 Pf V4.03 # Daten Laenge Buffer beim "Flash_Loeschen" automatsich auffuellen
|
|||
|
//*
|
|||
|
//* 27.11.2002 Pf V4.04 # ENMT nach dem RESET am Ende der Programmierung nach dem Polling Verfahren geschoben
|
|||
|
//* 28.11.2002 Pf V4.05 # Polling Verfahren am Ende der Programmierung (nach dem RESET Aufruf) geloescht
|
|||
|
//* # Maximal Anzahl von Wiederaufsetzen ist parametrierbar
|
|||
|
//* 29.11.2002 Pf V4.06 # ENMT und DNMT wie in der 03Flash.ips implementiert
|
|||
|
//* # TesterPresentHandling DNMTTimerZeit = 10000 msec
|
|||
|
//* # 2 Wiederaufsetzen Verfahren sind // implementiert:
|
|||
|
//* WiederaufsetzenSwitch: nur den letzen Telegramm wird gesendet
|
|||
|
//* => NICHT MIT NEUEN Standard Core zu verwenden
|
|||
|
//* WiederaufsetzenSwitchBlock: die 2 letzten fehlerfreien Datenbloecken
|
|||
|
//* werden wiederholt
|
|||
|
//* 05.12.2002 Pf V4.07 # "SgInnenTemperaturLesen" und "SgPhysHwNrLesen" Parameter werden in dem anzupassenden
|
|||
|
//* Teil verschoben (vor "Ab hier darf....!!!")
|
|||
|
//* 19.02.2003 Pf V4.08 # Neue Implementierung der "TesterPresentHandling" Funktion
|
|||
|
//* # Auffuellung: Ber<65>cksichtigung der L<>nge des Puffers "Buffer": von BufferSize nach MaxData
|
|||
|
//* # Funktion TesterPresentHandling: - Nachdem die Busse geweckt wurden, warten 2000 mSek.
|
|||
|
//* # damit diese auch wach sind
|
|||
|
//* # - Neue Werte f<>r TesterPresentTimerZeit = 8000
|
|||
|
//* 21.02.2003 Pf V5.00 # Optimierung des Wiederaufsetzen- Verfahrens. Ab dieser Version wird nur ein Backup- Puffer
|
|||
|
//* # kopiert und seine Reihenfolge wird mit einem boolean Flag (BufferErst_X) markiert.
|
|||
|
//*
|
|||
|
//* 05.09.2003 KuS V6.00 # <20>nderungen:
|
|||
|
//* # -Baudratenumschaltung
|
|||
|
//* # -SG Status nach Abbruch der Programmierung
|
|||
|
//* # -Dynamische MXBL
|
|||
|
//* # -XXL-Telegramme
|
|||
|
//* # -Neue Parameter
|
|||
|
//* # -Debug-Ausgaben ge<67>ndert
|
|||
|
//* # -Abbruch bei Programmierung NOK
|
|||
|
//* # -Neue Implementierung Download-Teil mit verbessertem Wiederaufsetzen
|
|||
|
//*
|
|||
|
//* 02.03.2005 MK V6.10 # Berechnungsfehler behoben bei: AddWordToDWord, SubWordFromDWord
|
|||
|
//* # TesterPresentHandling: keine ApiFehler-Pr<50>fung mehr, konnte zu COAPI_ECU_TIMEOUT f<>hren
|
|||
|
//* # FlashSchreiben: Pr<50>fung auf i.O. (0x01) statt auf n.i.O. (0x02); 0x00 wurde als i.O. interpretiert
|
|||
|
//* # cabiexit: im Fehlerfall zuerst Bus wecken, dann Kommunikation zu SG pr<70>fen; keine Fehlerauswertung
|
|||
|
//* # Allgemeiner Fehler COAPI_ECU_TIMEOUT durch eigene Fehlercodes ersetzt
|
|||
|
//* # erweiterte Fehlercodes abh<62>ngig Flashzustand und Fehlerursache generieren
|
|||
|
//* # nach einem ENMT 6 sec warten, bis SG's wieder hochgefahren und kommunikationsf<73>hig sind
|
|||
|
//*
|
|||
|
//* 29.04.2005 MK V6.11 # BMW-Standard f<>r Low-Level-Retry eingesetzt, Defaultwert f<>r Sendeintervall
|
|||
|
//* # einmalige Ermittlung des Programmierzuganges (OPPS-MOST) f<>r LLR- und MXBL-Einstellung
|
|||
|
//* # Korrektur Busruhe: Timer initialisieren jetzt vor DNMT
|
|||
|
//* # cabiexit: 2 Min bei Abbruch warten
|
|||
|
//* # bei Abbruch vor Flashstate 2 (Programmierung) warten
|
|||
|
//* # erweiterte Fehlercodes auch bei FlashL<68>schen & TransferData
|
|||
|
//*
|
|||
|
//* 07.06.2005 MK V6.12 # neu: Fehlercodes 70x4/70x5, wenn nicht OPPS-MOST-Zugang benutzt wird
|
|||
|
//* # neu: Fehlercode COAPI_ADDRESS_CALC_ERROR bei Adressberechnungsfehler statt COAPI_DEBUG_INFO
|
|||
|
//* # Debugausgabe um OPPS/MOST-Einstellungen erweitert
|
|||
|
//*
|
|||
|
//* 21.07.2005 MH V6.13 # neu: eigene Funktion PruefeSignatur
|
|||
|
//* # neu: TesterPresent k<>nnen auch w<>hrend Signaturpr<70>fung gesendet werden
|
|||
|
//*
|
|||
|
//* 17.12.2004 KuS V7.00 # <20>nderungen:
|
|||
|
//* # -<2D>nderung auf CoAPI Kopierfunktionen. Erfordert CoAPI Version 3.6.0
|
|||
|
//* # -TesterPresent verl<72>ngert <20>ber kompletten ECU Programming Mode Zeitraum
|
|||
|
//* # -TesterPresent im WAS Ablauf
|
|||
|
//* # -WAS als Standard aktiviert
|
|||
|
//* # -Baudratenumschaltung entfernt
|
|||
|
//*
|
|||
|
//* 28.09.2005 MH V8.00 # 6.13 mit 7.00 zusammengef<65>hrt
|
|||
|
//* # neu: Einstellung DIREKT_MOST_PROG f<>r Ger<65>te die direkt auf MOST programmierbar sind
|
|||
|
//* # neu: Einstellung BUSRUHE_START_PUNKT und BUSRUHE_ENDE_PUNKT
|
|||
|
//* # zur Wahl des Start- und Endzeitpunkt der Busruhe
|
|||
|
//* # TesterPresentHandling Ueberarbeitet
|
|||
|
//* # Authentisieren und Flash-Loeschen angepasst um TesterPresents senden zu k<>nnen
|
|||
|
//* # neu: Vor Wiederaufsetzen wird Programmierstatus Lesen gepollt (f<>r maximal ca. 10 Sekunden)
|
|||
|
//* # um Komunikation mit SG wiederherzustellen
|
|||
|
//*
|
|||
|
//* 04.11.2005 MH V8.01 # Korrektur des Wiederaufsetzenablaufs
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
|
|||
|
|
|||
|
// Version, Verantwortung, Steuerger<65>tedaten
|
|||
|
string ModulName = "08FLASH";
|
|||
|
string Revision = "8.01";
|
|||
|
string Author = "ESG EE-21 Maximilian Heller,ESG GmbH EE-21 Sven Kurzeder,ESG GmbH EE-21 Michael Knoebl,BMW EE-21 Stefan Jurchen";
|
|||
|
string Comment = "Serienstand";
|
|||
|
string SGFamilie = "CHAMG1";
|
|||
|
|
|||
|
|
|||
|
int SG_MAXANZAHL_AIF = 0x02;
|
|||
|
// Anzahl der im SG gespeicherten Anwender-Info-Felder, Werte kleiner 0x02 nicht zulaessig.
|
|||
|
|
|||
|
int LL_INTERVAL = 5;
|
|||
|
// Zeitlicher Abstand mit dem LL-Telegramme gesendet werden. Default: 5 [ms]
|
|||
|
|
|||
|
int SG_GROESSE_AIF = 0x12;
|
|||
|
// Groesse eines Anwender-Info-Feld, default = 0x12.
|
|||
|
// 0x12 18dez - Kleines AIF
|
|||
|
// 0x33 51dez - Groesse AIF
|
|||
|
// 0x40 64dez - Groesses AIF (Power PC)
|
|||
|
|
|||
|
int SG_ENDEKENNUNG_AIF = 0x01;
|
|||
|
// Kennzeichnung des letzten Anwender-Info-Feld, default = 0x01.
|
|||
|
// 0xFE Letztes AIF nicht ueberschreibbar
|
|||
|
// 0x01 Letztes AIF ist ueberschreibbar
|
|||
|
|
|||
|
string SG_AUTHENTISIERUNG = "Asymetrisch";
|
|||
|
// Authentisierungsart des Steuergeraets, default = "Asymetrisch".
|
|||
|
// Simple
|
|||
|
// Symetrisch
|
|||
|
// Asymetrisch
|
|||
|
// Keine
|
|||
|
|
|||
|
string BUSRUHE_START_PUNKT = "StartDiagnose";
|
|||
|
// zur Wahl des Start- und Endzeitpunkt der Busruhe
|
|||
|
// StartDiagnose vor erstem Start-Diagnose
|
|||
|
// FlashLoeschen vor erstem Flash-Loeschen
|
|||
|
// DatenDownload vor erstem Daten-Schreiben
|
|||
|
|
|||
|
string BUSRUHE_ENDE_PUNKT = "DownloadEnde";
|
|||
|
// zur Wahl des Start- und Endzeitpunkt der Busruhe
|
|||
|
// DownloadEnde nach letztem Daten-Schreiben
|
|||
|
// SignaturPruefen nach letztem Signatur-Pruefen
|
|||
|
// DiagnoseEnde nach letztem Diagnose-Ende
|
|||
|
// Reset nach letztem Reset
|
|||
|
|
|||
|
bool ProgrammUndDaten = TRUE;
|
|||
|
// Programmierung von Programm und/oder Daten. Default = FALSE.
|
|||
|
// TRUE wenn Programme und Daten
|
|||
|
// FALSE wenn nur Programm
|
|||
|
|
|||
|
string ProzessorTyp = "Standard";
|
|||
|
// Definiert den im Steuergeraet verwendeten Prozessortyp.
|
|||
|
// Standard
|
|||
|
// HC12D128 Auswirkung : RequestDownload bei 0x004000, 0x0080000, 0x00C000
|
|||
|
|
|||
|
bool AuffuellenSwitch = FALSE;
|
|||
|
// Aktiviert/Deaktiviert das Auffuellen der Telegramme bis zur MXBL vor der Uebertragung. Default = FALSE.
|
|||
|
// TRUE Datenblock zum Flashen wird bis zur MXBL aufgefuellt
|
|||
|
// FALSE Auffuellung Verfahren wird ausgeschaltet
|
|||
|
|
|||
|
bool SgInnenTemperaturLesen = FALSE;
|
|||
|
// Definiert ob das Steuergeraet ein Auslesen der Innentemperatur unterstuetzt oder nicht.
|
|||
|
// TRUE Das Steuergeraet unterstuetzt die Ausgabe der Innentemperatur
|
|||
|
// FALSE Das Steuergeraet unterstuetzt n i c h t die Ausgabe der Innentemperatur
|
|||
|
|
|||
|
bool SgPhysHwNrLesen = FALSE;
|
|||
|
// Definiert ob das Steuergeraet ein Auslesen der pysikalischen Hardwarenummer unterstuetzt oder nicht.
|
|||
|
// TRUE Unterstuetzt
|
|||
|
// FALSE Nicht unterstuetzt
|
|||
|
|
|||
|
bool WiederaufsetzenSwitch = FALSE;
|
|||
|
// Altes Wiederaufsetzen Verfahren, wo nur das letzte Telegramm wiederholt wird.
|
|||
|
// TRUE Es wird im Kommunikationsfehlerfall bei Transfer Data wiederaufgesetzt
|
|||
|
// FALSE Es wird im Kommunikationsfehlerfall bei Transfer Data nicht wiederaufgesetzt
|
|||
|
|
|||
|
bool WiederaufsetzenBlockSwitch = FALSE;
|
|||
|
// Neues Wiederaufsetzen Verfahren, wo die beiden letzten fehlerfreien Telegramme wiederholt werden. Default = TRUE.
|
|||
|
// TRUE Es wird im Kommunikationsfehlerfall bei Transfer Data wiederaufgesetzt
|
|||
|
// FALSE Es wird im Kommunikationsfehlerfall bei Transfer Data nicht wiederaufgesetzt
|
|||
|
|
|||
|
int WartenNachECUProgrammMode = 0;
|
|||
|
// Wartezeit nach Umschalten in den Programmiermodus in Sekunden.
|
|||
|
|
|||
|
bool TesterPresentHandlingSwitch = TRUE;
|
|||
|
// Aktiviert/Deaktiviert das Senden von DNMT - TesterPresent - ENMT
|
|||
|
// TRUE Es wird DNMT, TesterPresent, ENMT gesendet
|
|||
|
// FALSE Es wird kein DNMT, TesterPresent, ENMT gesendet
|
|||
|
|
|||
|
bool DebugSwitch = FALSE;
|
|||
|
// Aktiviert/Deaktiviert das Schreiben von Debug-Informationen in die error.log Datei.
|
|||
|
// TRUE Es werden Debuginformationen in error.log geschrieben
|
|||
|
// FALSE Es werden keine Debuginformationen in error.log geschrieben
|
|||
|
|
|||
|
bool DynamischeMXBL = FALSE;
|
|||
|
// Aktiviert/Deaktiviert die MXBL Anpassung vor jedem Datenblock. Default = FALSE.
|
|||
|
// TRUE Die MXBL wird nach jeden RequestDownload angepasst
|
|||
|
// FALSE Es findet keine Anpassung der MXBL statt
|
|||
|
|
|||
|
bool TestSchluesselAuthentisierung = FALSE;
|
|||
|
// Aktiviert/Deaktiviert die automatische Teschluesselauthentisierung.
|
|||
|
// TRUE Bei einer fehlerhaften Authentisierung mit scharfen Schluessel wird eine Authentisierung mit einem Testschluessel versucht
|
|||
|
// FALSE Kein Versuch einer Authentisierung mit einem Testschluessel nach einer fehlerhaften Authentisierung mit einem scharfen Schluessel
|
|||
|
|
|||
|
bool DIREKT_MOST_PROG = TRUE;
|
|||
|
// Einstellung DIREKT_MOST_PROG fuer Geraete die direkt auf MOST programmierbar sind .
|
|||
|
// TRUE Aktiviert SG kann direkt ber den MOST-Bus programmiert werden
|
|||
|
// FALSE Deaktiviert SG kann nicht direkt ber den MOST-Bus programmiert werden
|
|||
|
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//* *
|
|||
|
//* A b h i e r d a r f n i c h t s *
|
|||
|
//* *
|
|||
|
//* g e <20> n d e r t w e r d e n ! ! ! *
|
|||
|
//* *
|
|||
|
//**********************************************************************
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//* *
|
|||
|
//* Anfang des Codes *
|
|||
|
//* *
|
|||
|
//**********************************************************************
|
|||
|
|
|||
|
#include "cabi.h"
|
|||
|
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//* G l o b a l e V a r i a b l e n *
|
|||
|
//**********************************************************************
|
|||
|
|
|||
|
bool TesterPresentHandlingFlag = FALSE;
|
|||
|
bool ProgSuccess = TRUE;
|
|||
|
bool OppsAccess = FALSE;
|
|||
|
bool OppsMostAccess = FALSE;
|
|||
|
int FlashState = 0;
|
|||
|
int BusruheStartState = 5;
|
|||
|
int BusruheEndeState = 5;
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//* F e h l e r n u m m e r n *
|
|||
|
//**********************************************************************
|
|||
|
|
|||
|
int COAPI_ECU_PROG_STATUS_ERROR = 2080; // Programmierstatus fehlerhaft
|
|||
|
int COAPI_ECU_AUTHENTICATION_ERROR = 2081; // Authentisierung fehlerhaft
|
|||
|
int COAPI_ECU_FLASH_ERASE_ERROR = 2082; // Flash l<>schen fehlerhaft
|
|||
|
int COAPI_ECU_FLASH_REQUEST_DOWNLOAD_ERROR = 2083; // Flash Download vorbereiten fehlerhaft
|
|||
|
int COAPI_ECU_FLASH_DOWNLOAD_ERROR = 2084; // Flash Download fehlerhaft
|
|||
|
int COAPI_ECU_FLASH_TRANSFER_EXIT_ERROR = 2085; // Flash Download abschliessen fehlerhaft
|
|||
|
int COAPI_ECU_SIGNATUR_ERROR = 2086; // Signaturpruefung fehlerhaft
|
|||
|
int COAPI_ECU_READ_AIF = 2087; // AIF lesen fehlerhaft
|
|||
|
int COAPI_ECU_WRITE_AIF = 2088; // AIF schreiben fehlerhaft
|
|||
|
int COAPI_ECU_PROGRAMMING_MODE_ERROR = 2089; // Programmiermode umschalten fehlerhaft
|
|||
|
int COAPI_ECU_AUTHENTICATION_FORMAT_ERROR = 2090; // Authentisierung Formatfehler
|
|||
|
int COAPI_ECU_DATA_REFERENZ_ERROR = 2091; // Datenreferenz fehlerhaft
|
|||
|
int COAPI_ADDRESS_CALC_ERROR = 2098; // Fehler bei Adressberechnung
|
|||
|
int COAPI_PROCESSOR_TYPE_ERROR = 2099; // Prozessortyp fehlerhaft
|
|||
|
|
|||
|
int COAPI_EDIABAS_ERROR_MATRIX = 7000; // bis 7099 belegt
|
|||
|
|
|||
|
int COAPI_ECU_IDENT_ERROR = 7210; // SG: Ident lesen
|
|||
|
int COAPI_ECU_HWREF_ERROR = 7211; // SG: HW-Referenz lesen
|
|||
|
int COAPI_ECU_ZIF_ERROR = 7212; // SG: ZIF lesen
|
|||
|
int COAPI_ECU_ZIFBACKUP_ERROR = 7213; // SG: ZIF-Backup lesen
|
|||
|
int COAPI_ECU_RESET_ERROR = 7214; // SG: Reset ausf<73>hren
|
|||
|
int COAPI_ECU_TIMES_ERROR = 7215; // SG: Zeiten lesen
|
|||
|
int COAPI_ECU_MXBL_ERROR = 7216; // SG: MaxBlockl<6B>nge
|
|||
|
int COAPI_ECU_SERIAL_ERROR = 7217; // SG: Seriennummer lesen
|
|||
|
int COAPI_ECU_RANDOM_ERROR = 7218; // SG: Zufallszahl lesen
|
|||
|
int COAPI_ECU_STOPDIAG_ERROR = 7219; // SG: Stop Diagnose
|
|||
|
int COAPI_ECU_PHYHWNR_ERROR = 7220; // SG: Physikalische HW-Nummer lesen
|
|||
|
int COAPI_ECU_INNENTEMP_ERROR = 7221; // SG: Innentemperatur lesen
|
|||
|
|
|||
|
int COAPI_SGBD_FLASHPARAM_ERROR = 7228; // P-SGBD: Flashparameter setzen
|
|||
|
int COAPI_SGBD_DIAGPROT_ERROR = 7229; // P-SGBD: Diagnoseprotokoll setzen
|
|||
|
|
|||
|
int COAPI_OPPS_STATUS_ERROR = 7400; // OPPS: OPPS Version bzw. Zugang ermitteln
|
|||
|
|
|||
|
int COAPI_DEBUG_INFO = 9000; // Debuginformation in error.log
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//* F u n k t i o n e n *
|
|||
|
//**********************************************************************
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : OutputDebugString
|
|||
|
//*
|
|||
|
//* Funktion : Debugausgabe in Datei error.log
|
|||
|
//*
|
|||
|
//* Parameter : LineNr - ZeilenNr im PABD-File
|
|||
|
//* Info - Auszugebender Text
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 19.10.2000 rd V0.01 Ersterstellung
|
|||
|
//* 16.02.2001 rd V1.00 Freigabe
|
|||
|
//**********************************************************************
|
|||
|
OutputDebugString(in: int LineNr, in: string Info)
|
|||
|
{
|
|||
|
string temp;
|
|||
|
|
|||
|
if (DebugSwitch == TRUE)
|
|||
|
{
|
|||
|
temp = Info;
|
|||
|
CDHSetError (COAPI_DEBUG_INFO, "Debug-Info", temp, LineNr, "");
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : OutputDebugInt
|
|||
|
//*
|
|||
|
//* Funktion : Debugausgabe in Datei error.log
|
|||
|
//*
|
|||
|
//* Parameter : LineNr - ZeilenNr im PABD-File
|
|||
|
//* Info - Auszugebender Text
|
|||
|
//* Wert - Auszugebende Zahl
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 19.10.2000 rd V0.01 Ersterstellung
|
|||
|
//* 16.02.2001 rd V1.00 Freigabe
|
|||
|
//**********************************************************************
|
|||
|
OutputDebugInt(in: int LineNr, in: string Info, in: int Wert)
|
|||
|
{
|
|||
|
string temp;
|
|||
|
|
|||
|
if (DebugSwitch == TRUE)
|
|||
|
{
|
|||
|
inttostring(Wert, temp);
|
|||
|
temp = Info + ": " + temp;
|
|||
|
OutputDebugString(LineNr, temp);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : OutputDebugBool
|
|||
|
//*
|
|||
|
//* Funktion : Debugausgabe in Datei error.log
|
|||
|
//*
|
|||
|
//* Parameter : LineNr - ZeilenNr im PABD-File
|
|||
|
//* Info - Auszugebender Text
|
|||
|
//* Wert - Auszugebender Bool-Wert
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 19.10.2000 rd V0.01 Ersterstellung
|
|||
|
//* 16.02.2001 rd V1.00 Freigabe
|
|||
|
//**********************************************************************
|
|||
|
OutputDebugBool(in: int LineNr, in: string Info, in: bool Wert)
|
|||
|
{
|
|||
|
string temp;
|
|||
|
|
|||
|
if (DebugSwitch == TRUE)
|
|||
|
{
|
|||
|
if (Wert == TRUE)
|
|||
|
{
|
|||
|
temp = Info + ": TRUE";
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
temp = Info + ": FALSE";
|
|||
|
}
|
|||
|
OutputDebugString(LineNr, temp);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : hexstring
|
|||
|
//*
|
|||
|
//* Funktion : Erzeugt einen 2-stelligen Hexstring
|
|||
|
//*
|
|||
|
//* Parameter : IntWert - Zahl
|
|||
|
//*
|
|||
|
//* Rueckgabe : StrWert - 2-stelliger Hexstring
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 19.10.2000 rd V0.01 Ersterstellung
|
|||
|
//* 16.02.2001 rd V1.00 Freigabe
|
|||
|
//**********************************************************************
|
|||
|
hexstring(in: int IntWert, inout: string StrWert)
|
|||
|
{
|
|||
|
int Low, High;
|
|||
|
|
|||
|
StrWert="??";
|
|||
|
|
|||
|
Low = IntWert / 16;
|
|||
|
Low = Low * 16;
|
|||
|
Low = IntWert - Low;
|
|||
|
|
|||
|
High = IntWert / 256;
|
|||
|
High = High * 256;
|
|||
|
High = IntWert - High;
|
|||
|
High = High / 16;
|
|||
|
|
|||
|
if (Low == 0) StrWert = "0";
|
|||
|
else if (Low == 1) StrWert = "1";
|
|||
|
else if (Low == 2) StrWert = "2";
|
|||
|
else if (Low == 3) StrWert = "3";
|
|||
|
else if (Low == 4) StrWert = "4";
|
|||
|
else if (Low == 5) StrWert = "5";
|
|||
|
else if (Low == 6) StrWert = "6";
|
|||
|
else if (Low == 7) StrWert = "7";
|
|||
|
else if (Low == 8) StrWert = "8";
|
|||
|
else if (Low == 9) StrWert = "9";
|
|||
|
else if (Low == 10) StrWert = "A";
|
|||
|
else if (Low == 11) StrWert = "B";
|
|||
|
else if (Low == 12) StrWert = "C";
|
|||
|
else if (Low == 13) StrWert = "D";
|
|||
|
else if (Low == 14) StrWert = "E";
|
|||
|
else if (Low == 15) StrWert = "F";
|
|||
|
|
|||
|
if (High == 0) StrWert = "0" + StrWert;
|
|||
|
else if (High == 1) StrWert = "1" + StrWert;
|
|||
|
else if (High == 2) StrWert = "2" + StrWert;
|
|||
|
else if (High == 3) StrWert = "3" + StrWert;
|
|||
|
else if (High == 4) StrWert = "4" + StrWert;
|
|||
|
else if (High == 5) StrWert = "5" + StrWert;
|
|||
|
else if (High == 6) StrWert = "6" + StrWert;
|
|||
|
else if (High == 7) StrWert = "7" + StrWert;
|
|||
|
else if (High == 8) StrWert = "8" + StrWert;
|
|||
|
else if (High == 9) StrWert = "9" + StrWert;
|
|||
|
else if (High == 10) StrWert = "A" + StrWert;
|
|||
|
else if (High == 11) StrWert = "B" + StrWert;
|
|||
|
else if (High == 12) StrWert = "C" + StrWert;
|
|||
|
else if (High == 13) StrWert = "D" + StrWert;
|
|||
|
else if (High == 14) StrWert = "E" + StrWert;
|
|||
|
else if (High == 15) StrWert = "F" + StrWert;
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : TestCDHFehler
|
|||
|
//*
|
|||
|
//* Funktion : Ueberpruefen, ob ein CDH-Fehler aufgetreten ist
|
|||
|
//* und wenn ja: Setzen der ReturnWerte und Ausstieg
|
|||
|
//*
|
|||
|
//* Parameter : FStatus - Returnwert dieser Funktion
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 19.10.2000 rd V0.01 Ersterstellung
|
|||
|
//* 16.02.2001 rd V1.00 Freigabe
|
|||
|
//**********************************************************************
|
|||
|
TestCDHFehler(in: int FStatus)
|
|||
|
{
|
|||
|
if (FStatus != 0)
|
|||
|
{
|
|||
|
CDHSetReturnVal(FStatus);
|
|||
|
exit();
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : SetCDHFehler
|
|||
|
//*
|
|||
|
//* Funktion : Setzen der ReturnWerte
|
|||
|
//*
|
|||
|
//* Parameter : CStatus - FehlerNr
|
|||
|
//* ProcName - Name der aufrufenden PABD-Funktion
|
|||
|
//* LineNr - ZeilenNr im PABD-File
|
|||
|
//* Info - SgbdName + EDIABAS-Job
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 19.10.2000 rd V0.01 Ersterstellung
|
|||
|
//* 16.02.2001 rd V1.00 Freigabe
|
|||
|
//**********************************************************************
|
|||
|
SetCDHFehler(in: int CStatus, in: string ProcName,
|
|||
|
in: int LineNr, in: string Info )
|
|||
|
{
|
|||
|
CDHSetError(CStatus, ModulName, ProcName, LineNr, Info);
|
|||
|
CDHSetReturnVal(CStatus);
|
|||
|
exit();
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : SetFlashState
|
|||
|
//*
|
|||
|
//* Funktion : Setzen des Flash-Zustandes
|
|||
|
//*
|
|||
|
//* Parameter : State - Zustand
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 02.03.2005 MK V6.10 Ersterstellung
|
|||
|
//**********************************************************************
|
|||
|
SetFlashState(in: int State)
|
|||
|
{
|
|||
|
int Status;
|
|||
|
|
|||
|
CDHSetCabdWordPar("FLASH_STATE", State, Status);
|
|||
|
FlashState = State;
|
|||
|
|
|||
|
OutputDebugInt( 545, "===> Wechsel zu FlashState", State);
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : GetFlashState
|
|||
|
//*
|
|||
|
//* Funktion : Wiederherstellen des Flash-Zustandes
|
|||
|
//*
|
|||
|
//* Parameter : -
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 02.03.2005 MK V6.10 Ersterstellung
|
|||
|
//**********************************************************************
|
|||
|
GetFlashState()
|
|||
|
{
|
|||
|
int Status;
|
|||
|
|
|||
|
CDHGetCabdWordPar("FLASH_STATE", FlashState, Status);
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : TestApiFehler
|
|||
|
//*
|
|||
|
//* Funktion : Ueberpruefen, ob bei ApiJob ein Fehler aufgetreten ist
|
|||
|
//* und wenn ja: Setzen der ReturnWerte und Ausstieg
|
|||
|
//*
|
|||
|
//* Parameter : CStatus - FehlerNr bei Fehler
|
|||
|
//* ProcName - Name der aufrufenden PABD-Funktion
|
|||
|
//* LineNr - ZeilenNr im PABD-File
|
|||
|
//* Info - SgbdName + EDIABAS-Job
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 19.10.2000 rd V0.01 Ersterstellung
|
|||
|
//* 16.02.2001 rd V1.00 Freigabe
|
|||
|
//* 02.03.2005 MK V6.10 erweiterte Fehlercodes abh<62>ngig Flashzustand und Fehlerursache generieren
|
|||
|
//**********************************************************************
|
|||
|
TestApiFehler(in: int CStatus, in: string ProcName,
|
|||
|
in: int LineNr, in: string Info )
|
|||
|
{
|
|||
|
bool rc;
|
|||
|
string ApiStatusText;
|
|||
|
string SgbdName;
|
|||
|
int ErrCode, iTmp;
|
|||
|
string strTmp, strTmp2;
|
|||
|
|
|||
|
// existiert JOB_STATUS bzw. hat SG geantwortet ?
|
|||
|
apiResultText(rc, ApiStatusText, "JOB_STATUS", 1, "");
|
|||
|
if(rc == TRUE)
|
|||
|
{
|
|||
|
// JA: Ergebnis nicht OKAY ?
|
|||
|
if(ApiStatusText != "OKAY")
|
|||
|
{
|
|||
|
// Fehlertext und -code nach Vorgabe setzten
|
|||
|
CDHSetError(CStatus, ModulName, ProcName, LineNr, Info + ": " + ApiStatusText);
|
|||
|
CDHSetReturnVal(CStatus);
|
|||
|
exit();
|
|||
|
}
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
// NEIN: JOB_STATUS gibt's nicht !
|
|||
|
// -> neue Fehlercodes generieren (Kommunikationsfehler)
|
|||
|
|
|||
|
// EDIABAS-Fehler auslesen
|
|||
|
apiErrorText(ApiStatusText);
|
|||
|
apiErrorCode(ErrCode);
|
|||
|
|
|||
|
// IFH-0009: keine Antwort vom SG ?
|
|||
|
if(ErrCode == 19)
|
|||
|
{
|
|||
|
|
|||
|
// Name der Flash-SGBD besorgen, damit Jobs daraus verwendet werden k<>nnen
|
|||
|
CDHGetSgbdName(SgbdName, iTmp);
|
|||
|
|
|||
|
// SG-Adresse zwischenspeichern
|
|||
|
CDHapiJob(SgbdName, "FLASH_PARAMETER_LESEN", "", "");
|
|||
|
CDHapiResultInt(iTmp, "SG_ADRESSE", 1);
|
|||
|
|
|||
|
if (DIREKT_MOST_PROG == TRUE)
|
|||
|
{
|
|||
|
// Kommunikation mit MOST-CAN-Gateway pr<70>fen
|
|||
|
CDHapiJob(SgbdName, "FLASH_PARAMETER_SETZEN", "0x62;2;18;1;simple", "");
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
// Kommunikation mit OBD-CAN-Gateway pr<70>fen
|
|||
|
CDHapiJob(SgbdName, "FLASH_PARAMETER_SETZEN", "0x00;2;18;1;simple", "");
|
|||
|
}
|
|||
|
|
|||
|
CDHapiJob(SgbdName, "IDENT", "", "");
|
|||
|
apiResultText(rc, strTmp, "JOB_STATUS", 1, "");
|
|||
|
if(rc == TRUE)
|
|||
|
ErrCode = 2; // 2: OPPS-(MOST)-Zugang; keine Antwort vom SG, GW i.O.
|
|||
|
else
|
|||
|
ErrCode = 3; // 3: OPPS-(MOST)-Zugang; keine Antwort vom SG und GW
|
|||
|
|
|||
|
// OPPS-(MOST)-Zugang pr<70>fen
|
|||
|
if(((DIREKT_MOST_PROG == TRUE ) && (OppsMostAccess == FALSE)) || // Kann MOST, wird aber nicht benutzt, oder
|
|||
|
((DIREKT_MOST_PROG == FALSE) && (OppsAccess == FALSE))) // kann kein MOST und es wird kein OPPS benutzt
|
|||
|
{
|
|||
|
ErrCode = ErrCode + 2; // 4 bzw. 5: kein OPPS-(MOST)-Zugang
|
|||
|
}
|
|||
|
|
|||
|
// urspr<70>ngliche Parameter wieder einstellen
|
|||
|
inttostring(iTmp, strTmp);
|
|||
|
inttostring(SG_MAXANZAHL_AIF, strTmp2);
|
|||
|
strTmp = strTmp + ";" + strTmp2;
|
|||
|
inttostring(SG_GROESSE_AIF, strTmp2);
|
|||
|
strTmp = strTmp + ";" + strTmp2;
|
|||
|
inttostring(SG_ENDEKENNUNG_AIF, strTmp2);
|
|||
|
strTmp = strTmp + ";" + strTmp2;
|
|||
|
strTmp = strTmp + ";" + SG_AUTHENTISIERUNG;
|
|||
|
CDHapiJob(SgbdName, "FLASH_PARAMETER_SETZEN", strTmp, "");
|
|||
|
}
|
|||
|
|
|||
|
// anderer IFH-Fehler ?
|
|||
|
else if((ErrCode >= 10) && (ErrCode <= 59))
|
|||
|
ErrCode = 6;
|
|||
|
|
|||
|
// NET-Fehler ?
|
|||
|
else if((ErrCode >= 150) && (ErrCode <= 199))
|
|||
|
ErrCode = 7;
|
|||
|
|
|||
|
// API-Fehler ?
|
|||
|
else if((ErrCode >= 120) && (ErrCode <= 149))
|
|||
|
ErrCode = 8;
|
|||
|
|
|||
|
// anderer EDIABAS-Fehler
|
|||
|
else
|
|||
|
ErrCode = 9;
|
|||
|
|
|||
|
// Fehlercode gem<65><6D> FlashState generieren und ausgeben
|
|||
|
GetFlashState();
|
|||
|
ErrCode = COAPI_EDIABAS_ERROR_MATRIX + (FlashState * 10) + ErrCode;
|
|||
|
CDHSetError(ErrCode, ModulName, ProcName, LineNr, Info + ": " + ApiStatusText);
|
|||
|
CDHSetReturnVal(ErrCode);
|
|||
|
// Programmierung noch nicht mal begonnen ?
|
|||
|
if(FlashState < 2) {
|
|||
|
if (DIREKT_MOST_PROG == TRUE) {
|
|||
|
CDHDelay(60*1000); // dann 1 Min warten
|
|||
|
} else {
|
|||
|
CDHDelay(20*1000); // dann 20 Sec warten
|
|||
|
}
|
|||
|
}
|
|||
|
exit();
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : TestApiFehlerNoExit
|
|||
|
//*
|
|||
|
//* Funktion : Ueberpruefen, ob bei ApiJob ein Fehler aufgetreten ist
|
|||
|
//* und wenn ja: Setzen der ReturnWerte, aber kein Ausstieg
|
|||
|
//* auch nicht bei Kommunikationsfehler
|
|||
|
//*
|
|||
|
//* Parameter : CStatus - FehlerNr bei Fehler
|
|||
|
//* ProcName - Name der aufrufenden PABD-Funktion
|
|||
|
//* LineNr - ZeilenNr im PABD-File
|
|||
|
//* Info - SgbdName + EDIABAS-Job
|
|||
|
//*
|
|||
|
//* Rueckgabe : RetVal : kein Fehler 0, sonst CStatus
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 19.10.2000 rd V0.01 Ersterstellung
|
|||
|
//* 25.01.2001 rd V0.05 CDHapiResultText ersetzt durch apiResultText
|
|||
|
//* 16.02.2001 rd V1.00 Freigabe
|
|||
|
//**********************************************************************
|
|||
|
TestApiFehlerNoExit(in: int CStatus, in: string ProcName,
|
|||
|
in: int LineNr, in: string Info, out: int RetVal)
|
|||
|
{
|
|||
|
bool rc;
|
|||
|
string ApiStatusText;
|
|||
|
|
|||
|
// R<>ckgabewert vorbelegen: JOB war i.O.
|
|||
|
RetVal = 0;
|
|||
|
|
|||
|
// existiert JOB_STATUS bzw. hat SG geantwortet ?
|
|||
|
apiResultText(rc, ApiStatusText, "JOB_STATUS", 1, "");
|
|||
|
if(rc == TRUE)
|
|||
|
{
|
|||
|
// JA: Ergebnis nicht OKAY ?
|
|||
|
if(ApiStatusText != "OKAY")
|
|||
|
{
|
|||
|
// Fehlertext und -code nach Vorgabe setzten
|
|||
|
CDHSetError(CStatus, ModulName, ProcName, LineNr, Info + ": " + ApiStatusText);
|
|||
|
CDHSetReturnVal(CStatus);
|
|||
|
RetVal = CStatus;
|
|||
|
}
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
// NEIN: JOB_STATUS gibt's nicht !
|
|||
|
// EDIABAS-Fehler auslesen
|
|||
|
apiErrorText(ApiStatusText);
|
|||
|
|
|||
|
// EDIABAS-Fehlertext und Fehlercode setzten
|
|||
|
CDHSetError(CStatus, ModulName, ProcName, LineNr, Info + ": " + ApiStatusText);
|
|||
|
CDHSetReturnVal(CStatus);
|
|||
|
RetVal = CStatus;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : CheckForOppsAccess
|
|||
|
//*
|
|||
|
//* Funktion : Ermittelt, ob ein OPPS Most-Zugang zum Flashen verwendet
|
|||
|
//* wird und setzt die globalen Variablen "OppsMostAccess"
|
|||
|
//* und "OppsAccess" entsprechend
|
|||
|
//*
|
|||
|
//* Parameter : ProcName - Name der aufrufenden PABD-Funktion
|
|||
|
//* SgbdName - SGBD
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 29.04.2005 MK V6.11 Ersterstellung
|
|||
|
//**********************************************************************
|
|||
|
CheckForOppsAccess(in: string ProcName, in: string SgbdName)
|
|||
|
{
|
|||
|
string Stat_Typ;
|
|||
|
string Stat_Interface;
|
|||
|
int Stat_Version;
|
|||
|
|
|||
|
// Initialisierung: Programmierung nicht <20>ber OPPS-Zugang oder OPPS-MOST-Zugang
|
|||
|
OppsAccess = FALSE;
|
|||
|
OppsMostAccess = FALSE;
|
|||
|
|
|||
|
if (DIREKT_MOST_PROG == TRUE)
|
|||
|
{
|
|||
|
// Interfacetyp und Interfaceversion ermitteln
|
|||
|
CDHapiJob("OPPS", "STATUS_TYP_VER", "", "");
|
|||
|
TestApiFehler(COAPI_OPPS_STATUS_ERROR, ProcName, 788, "OPPS, STATUS_TYP_VER");
|
|||
|
CDHapiResultText(Stat_Typ, "STAT_TYP", 1, "");
|
|||
|
OutputDebugString( 790, "Interface-Typ : " + Stat_Typ);
|
|||
|
CDHapiResultInt(Stat_Version, "STAT_VERSION", 1);
|
|||
|
OutputDebugInt( 792, "Interface-Version ", Stat_Version);
|
|||
|
|
|||
|
// OPPS verf<72>gbar ?
|
|||
|
if(Stat_Typ == "OPPS")
|
|||
|
{
|
|||
|
// Programmierung <20>ber OPPS
|
|||
|
OppsAccess = TRUE;
|
|||
|
|
|||
|
// ab Version 4.12?
|
|||
|
if(Stat_Version >= 412)
|
|||
|
{
|
|||
|
|
|||
|
// OPPS-Zugang ermitteln
|
|||
|
CDHapiJob("OPPS", "STATUS_ROUTER", "", "");
|
|||
|
TestApiFehler(COAPI_OPPS_STATUS_ERROR, ProcName, 806, "OPPS, STATUS_ROUTER");
|
|||
|
CDHapiResultText(Stat_Interface, "STAT_INTERFACE", 1, "");
|
|||
|
OutputDebugString( 808, "Interface-Zugang : " + Stat_Interface);
|
|||
|
if(Stat_Interface == "MOST")
|
|||
|
{
|
|||
|
// Programmierung <20>ber OPPS-MOST-Zugang
|
|||
|
OppsMostAccess = TRUE;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
// Interfacetyp ermitteln
|
|||
|
CDHapiJob(SgbdName, "INTERFACETYPE", "", "");
|
|||
|
TestApiFehler(COAPI_OPPS_STATUS_ERROR, ProcName, 821, SgbdName + ", INTERFACETYPE");
|
|||
|
CDHapiResultText(Stat_Typ, "INTERFACE_TYP", 1, "");
|
|||
|
OutputDebugString( 823, "Interface-Typ : " + Stat_Typ);
|
|||
|
|
|||
|
// OPPS verf<72>gbar ?
|
|||
|
if(Stat_Typ == "OPPS")
|
|||
|
{
|
|||
|
// Programmierung <20>ber OPPS
|
|||
|
OppsAccess = TRUE;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : SetOppsMostParams
|
|||
|
//*
|
|||
|
//* Funktion : Setzt die BMW-Standard OPPS Most-Zugangs-Parameter
|
|||
|
//* und das Low-Level-Intervall entsprechend der Einstellung
|
|||
|
//* LL_INTERVAL.
|
|||
|
//*
|
|||
|
//* Parameter : -
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 29.04.2005 MK V6.11 Ersterstellung
|
|||
|
//**********************************************************************
|
|||
|
SetOppsMostParams()
|
|||
|
{
|
|||
|
string Temp;
|
|||
|
|
|||
|
// OPPS: BMW-Standard Low-Level-Retry Werte einstellen
|
|||
|
// 27: 27 x 0,363 ms -> 9,801 ms Wartezeit f<>r Wiederholung nach n.i.O.-Fall
|
|||
|
// 20: max. 20 Wiederholungen
|
|||
|
CDHapiJob("OPPS", "STEUERN_MOSTCTRL_LLRETRY", "27;20", "");
|
|||
|
|
|||
|
// OPPS: minimale Telegrammzwischenzeit f<>r MOST-Kontrollkanal einstellen
|
|||
|
inttostring(LL_INTERVAL, Temp);
|
|||
|
CDHapiJob("OPPS", "STEUERN_MOSTCTRL_LLINTERVALL", Temp, "");
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : ResetOppsMostParams
|
|||
|
//*
|
|||
|
//* Funktion : Setzt die OPPS Most-Zugangs-Parameter wieder zur<75>ck.
|
|||
|
//*
|
|||
|
//* Parameter : -
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 29.04.2005 MK V6.11 Ersterstellung
|
|||
|
//**********************************************************************
|
|||
|
ResetOppsMostParams()
|
|||
|
{
|
|||
|
// OPPS: Defaultwert (5 ms) f<>r minimale Telegrammzwischenzeit einstellen
|
|||
|
CDHapiJob("OPPS", "STEUERN_MOSTCTRL_LLINTERVALL", "5", "");
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : StopTesterPresentHandling
|
|||
|
//*
|
|||
|
//* Funktion : Fahrzeugbus wieder wecken.
|
|||
|
//*
|
|||
|
//* Parameter : ProcName - Name der aufrufenden PABD-Funktion
|
|||
|
//* SgbdName - SGBD
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 28.09.2005 MH V8.00 Ersterstellung
|
|||
|
//**********************************************************************
|
|||
|
StopTesterPresentHandling(in: string ProcName, in: string SgbdName)
|
|||
|
{
|
|||
|
int DNMTTimerNr = 1;
|
|||
|
int TesterPresentTimerNr = 2;
|
|||
|
int Status;
|
|||
|
|
|||
|
// ENMT nur senden von gerade TesterPresentHandling aktiv ist
|
|||
|
if (TesterPresentHandlingFlag != FALSE)
|
|||
|
{
|
|||
|
// Fahrzeugbusse wieder wecken und Timer loeschen
|
|||
|
TesterPresentHandlingFlag = FALSE; // Deaktiviert
|
|||
|
|
|||
|
// OutputDebugString( 911, "--> Enable Normal Message Transmission");
|
|||
|
CDHapiJob(SgbdName, "NORMALER_DATENVERKEHR", "JA;NEIN;JA", "");
|
|||
|
// TestApiFehler(COAPI_ECU_TIMEOUT, ProcName, 913, SgbdName + ", NORMALER_DATENVERKEHR (JA;NEIN;JA)");
|
|||
|
settimer(DNMTTimerNr, 0);
|
|||
|
settimer(TesterPresentTimerNr, 0);
|
|||
|
// warten, bis alle Steuerger<65>te wieder hochgefahren und diagnosef<65>hig sind
|
|||
|
// lt. LH mu<6D> dies nach sp<73>testens 5 sec geschehen sein
|
|||
|
// -> 6 sec mit Reserve
|
|||
|
CDHDelay(6000);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : TesterPresentHandling
|
|||
|
//*
|
|||
|
//* Funktion : Fahrzeugbus einschlafen lassen,
|
|||
|
//* Tester Present senden,
|
|||
|
//* ggf. Fahrzeugbus wieder wecken.
|
|||
|
//*
|
|||
|
//* Parameter : ProcName - Name der aufrufenden PABD-Funktion
|
|||
|
//* SgbdName - SGBD
|
|||
|
//* Force_Sending - Senden von TP erzwingen (wenn in der Busruhe),
|
|||
|
//* auch wenn noch nicht TesterPresentTimerZeit vergangen ist
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 29.01.2001 rd V0.01 Ersterstellung
|
|||
|
//* 16.02.2001 rd V1.00 Freigabe
|
|||
|
//* 30.03.2001 rd V1.01 TesterPresentHandlingSwitch neu dazu
|
|||
|
//* 19.02.2003 sj V4.08 - TesterPresentTimerZeit = 8000
|
|||
|
//* - "settimer" wird vor dem "NORMALER_DATENVERKEHR" Job Aufruf
|
|||
|
//* aufgerufen und nicht mehr nachher
|
|||
|
//* 04.08.2003 KuS V6.00 <20>nderung f<>r Baudratenumschaltung. Neuer Parameter DiagProt
|
|||
|
//* 02.03.2005 MK V6.10 keine ApiFehler-Pr<50>fung mehr, konnte zu COAPI_ECU_TIMEOUT f<>hren
|
|||
|
//* nach einem ENMT 6 sec warten, bis SG's wieder hochgefahren und kommunikationsf<73>hig sind
|
|||
|
//* Korrektur Busruhe: Timer initialisieren jetzt vor DNMT
|
|||
|
//* 21.07.2005 MH V6.13 neu: Force_Sending zum Erzwingen des Sendens eines TP
|
|||
|
//* 18.10.2004 KuS V7.00 Parameter DiagProt entfernt
|
|||
|
//* TesterPresentTimerZeit = 7750 gesetzt
|
|||
|
//* 28.09.2005 MH V8.00 <20>berarbeitung:
|
|||
|
//* - Senden von ENMT/TP/DNMT in Abh<62>ngigkeit von den globalen Variablen
|
|||
|
//* BusruheStartState, BusruheEndeState und FlashState
|
|||
|
//* - Parameter Ein entfernt
|
|||
|
//* - Parameter Force_Sending hinzugef<65>gt
|
|||
|
//**********************************************************************
|
|||
|
TesterPresentHandling(in: string ProcName, in: string SgbdName, in: bool Force_Sending)
|
|||
|
{
|
|||
|
int DNMTTimerNr = 1;
|
|||
|
int DNMTTimerZeit= 10000; // Zeit in ms
|
|||
|
int TesterPresentTimerNr = 2;
|
|||
|
int TesterPresentTimerZeit= 7750; // Zeit in ms
|
|||
|
bool DNMTTimerAbgelaufen;
|
|||
|
bool TesterPresentTimerAbgelaufen;
|
|||
|
int Status;
|
|||
|
|
|||
|
if (TesterPresentHandlingSwitch == TRUE)
|
|||
|
{
|
|||
|
// W<>hrend der FlashStates zw. BusruheStartState und BusruheEndeState DNMT/TP senden
|
|||
|
if ((FlashState >= BusruheStartState) && (FlashState <= BusruheEndeState))
|
|||
|
{
|
|||
|
TesterPresentHandlingFlag = TRUE; // Aktiviert
|
|||
|
testtimer(DNMTTimerNr, DNMTTimerAbgelaufen);
|
|||
|
if (DNMTTimerAbgelaufen == TRUE)
|
|||
|
{
|
|||
|
// Fahrzeugbusse einschlafen lassen und Timer aufziehen
|
|||
|
// OutputDebugString( 979, "--> Disable Normal Message Transmission");
|
|||
|
settimer(DNMTTimerNr, DNMTTimerZeit);
|
|||
|
settimer(TesterPresentTimerNr, TesterPresentTimerZeit);
|
|||
|
CDHapiJob(SgbdName, "NORMALER_DATENVERKEHR", "NEIN;NEIN;JA", "");
|
|||
|
// TestApiFehler(COAPI_ECU_TIMEOUT, ProcName, 983, SgbdName + ", NORMALER_DATENVERKEHR (NEIN;NEIN;JA)");
|
|||
|
CDHapiJob(SgbdName, "NORMALER_DATENVERKEHR", "JA;NEIN;NEIN", "");
|
|||
|
// TestApiFehler(COAPI_ECU_TIMEOUT, ProcName, 985, SgbdName + ", NORMALER_DATENVERKEHR (JA;NEIN;NEIN)");
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
testtimer(TesterPresentTimerNr, TesterPresentTimerAbgelaufen);
|
|||
|
if ((TesterPresentTimerAbgelaufen == TRUE) || (Force_Sending == TRUE))
|
|||
|
{
|
|||
|
// TesterPresent absetzen und Timer wieder aufziehen
|
|||
|
// OutputDebugString( 993, "--> Tester Present");
|
|||
|
settimer(DNMTTimerNr, DNMTTimerZeit);
|
|||
|
settimer(TesterPresentTimerNr, TesterPresentTimerZeit);
|
|||
|
CDHapiJob(SgbdName, "DIAGNOSE_AUFRECHT", "NEIN;JA", "");
|
|||
|
// TestApiFehler(COAPI_ECU_TIMEOUT, ProcName, 997, SgbdName + ", DIAGNOSE_AUFRECHT (NEIN;JA)");
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
// wenn nicht mehr in einem Busruhe-FlashState, aber noch Busruhe aktiv, dann jetzt ENMT senden!
|
|||
|
StopTesterPresentHandling(ProcName, SgbdName);
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : Jobs
|
|||
|
//*
|
|||
|
//* Funktion : Ausgabe der unterstuetzten Jobs
|
|||
|
//*
|
|||
|
//* Parameter : -
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 19.10.2000 rd V0.01 Ersterstellung
|
|||
|
//* 16.02.2001 rd V1.00 Freigabe
|
|||
|
//**********************************************************************
|
|||
|
Jobs()
|
|||
|
{
|
|||
|
string ProcName = "Jobs";
|
|||
|
int Status;
|
|||
|
|
|||
|
OutputDebugString( 1029, ProcName);
|
|||
|
CDHSetCabdPar("JOB[1]", "JOB_ERMITTELN", Status);
|
|||
|
CDHSetCabdPar("JOB[2]", "INFO", Status);
|
|||
|
CDHSetCabdPar("JOB[3]", "SG_IDENT_LESEN", Status);
|
|||
|
CDHSetCabdPar("JOB[4]", "SG_AIF_LESEN", Status);
|
|||
|
CDHSetCabdPar("JOB[5]", "SG_AIF_SCHREIBEN", Status);
|
|||
|
CDHSetCabdPar("JOB[6]", "SG_STATUS_LESEN", Status);
|
|||
|
CDHSetCabdPar("JOB[7]", "SG_PROGRAMMIEREN", Status);
|
|||
|
CDHSetCabdPar("JOB[8]", "FEHLER_LOESCHEN", Status);
|
|||
|
CDHSetCabdPar("JOB[9]", "DATEN_REFERENZ", Status);
|
|||
|
CDHSetCabdPar("JOB[10]", "HW_REFERENZ", Status);
|
|||
|
CDHSetCabdPar("JOB[11]", "ZIF", Status);
|
|||
|
CDHSetCabdPar("JOB[12]", "ZIF_BACKUP", Status);
|
|||
|
CDHSetCabdPar("JOB[13]", "U_PROG_LESEN", Status);
|
|||
|
CDHSetCabdPar("JOB[14]", "GET_DIAG_PROT", Status);
|
|||
|
CDHSetCabdPar("JOB[15]", "SET_DIAG_PROT", Status);
|
|||
|
CDHSetCabdPar("JOB[16]", "SET_ECU_ADDRESS", Status);
|
|||
|
CDHSetCabdPar("JOB[17]", "SG_INNENTEMP_LESEN", Status);
|
|||
|
CDHSetCabdPar("JOB[18]", "SG_PHYS_HWNR_LESEN", Status);
|
|||
|
CDHSetCabdPar("JOB_ANZAHL", "18", Status);
|
|||
|
CDHTestError(Status);
|
|||
|
CDHSetReturnVal(Status);
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : UProgLesen
|
|||
|
//*
|
|||
|
//* Funktion : Dummy Job Programmierspannung auslesen
|
|||
|
//*
|
|||
|
//* Parameter : -
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 19.10.2000 rd V0.01 Ersterstellung
|
|||
|
//* 16.02.2001 rd V1.00 Freigabe
|
|||
|
//**********************************************************************
|
|||
|
UProgLesen()
|
|||
|
{
|
|||
|
string ProcName = "UProgLesen";
|
|||
|
int Status;
|
|||
|
|
|||
|
OutputDebugString( 1073, ProcName);
|
|||
|
CDHSetCabdPar("U_PROG", "0.0V", Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHSetReturnVal(Status);
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : GetDiagProt
|
|||
|
//*
|
|||
|
//* Funktion : Diagnoseprotokolle des SG lesen
|
|||
|
//*
|
|||
|
//* Parameter : -
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 19.10.2000 rd V0.01 Ersterstellung
|
|||
|
//* 16.02.2001 rd V1.00 Freigabe
|
|||
|
//**********************************************************************
|
|||
|
GetDiagProt()
|
|||
|
{
|
|||
|
string ProcName = "GetDiagProt";
|
|||
|
int Status;
|
|||
|
string SgbdName;
|
|||
|
string StringResult;
|
|||
|
int ProtAnzahl;
|
|||
|
int i;
|
|||
|
string ResultName;
|
|||
|
|
|||
|
OutputDebugString( 1104, ProcName);
|
|||
|
CDHapiInit(); // CDH-Initialisierung
|
|||
|
CDHGetSgbdName(SgbdName, Status); // SGBD-Name aus SGET
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
CDHapiJob(SgbdName, "DIAGNOSEPROTOKOLL_LESEN", "", "");
|
|||
|
TestApiFehler(COAPI_SGBD_DIAGPROT_ERROR, ProcName, 1110, SgbdName + ", DIAGNOSEPROTOKOLL_LESEN");
|
|||
|
|
|||
|
CDHapiResultInt(ProtAnzahl, "DIAG_PROT_ANZAHL", 1);
|
|||
|
CDHSetCabdWordPar("DIAG_PROT_ANZAHL", ProtAnzahl, Status);
|
|||
|
OutputDebugInt( 1114, "ProtAnzahl ", ProtAnzahl);
|
|||
|
|
|||
|
i=0;
|
|||
|
while(i < ProtAnzahl )
|
|||
|
{
|
|||
|
i = i + 1;
|
|||
|
inttostring(i,ResultName);
|
|||
|
ResultName="DIAG_PROT_NR" + ResultName;
|
|||
|
|
|||
|
CDHapiResultText(StringResult, ResultName, 1, "");
|
|||
|
CDHSetCabdPar(ResultName, StringResult, Status);
|
|||
|
OutputDebugString( 1125, ResultName+" : "+StringResult);
|
|||
|
}
|
|||
|
|
|||
|
CDHTestError(Status);
|
|||
|
CDHSetReturnVal(Status);
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : SetDiagProt
|
|||
|
//*
|
|||
|
//* Funktion : Diagnoseprotokoll setzen
|
|||
|
//*
|
|||
|
//* Parameter : -
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 19.10.2000 rd V0.01 Ersterstellung
|
|||
|
//* 16.02.2001 rd V1.00 Freigabe
|
|||
|
//**********************************************************************
|
|||
|
SetDiagProt()
|
|||
|
{
|
|||
|
string ProcName = "SetDiagProt";
|
|||
|
int Status;
|
|||
|
string SgbdName;
|
|||
|
string DiagProt;
|
|||
|
|
|||
|
OutputDebugString( 1154, ProcName);
|
|||
|
CDHapiInit(); // CDH-Initialisierung
|
|||
|
CDHGetSgbdName(SgbdName, Status); // SGBD-Name aus SGET
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
CDHGetCabdPar("DIAG_PROT", DiagProt, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
CDHapiJob(SgbdName, "DIAGNOSEPROTOKOLL_SETZEN", DiagProt, "");
|
|||
|
TestApiFehler(COAPI_SGBD_DIAGPROT_ERROR, ProcName, 1163, SgbdName + ", DIAGNOSEPROTOKOLL_SETZEN (" + DiagProt + ")");
|
|||
|
OutputDebugString( 1164, "DiagProt : " + DiagProt);
|
|||
|
|
|||
|
CDHTestError(Status);
|
|||
|
CDHSetReturnVal(Status);
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : SetEcuAdr
|
|||
|
//*
|
|||
|
//* Funktion : Diagnoseadresse setzen
|
|||
|
//*
|
|||
|
//* Parameter : -
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 03.07.2001 rd V2.00 Ersterstellung
|
|||
|
//* 02.03.2005 MK V6.10 <20>nderungen f<>r erweiterte Fehlercodes
|
|||
|
//**********************************************************************
|
|||
|
SetEcuAdr()
|
|||
|
{
|
|||
|
string ProcName = "SetEcuAdr";
|
|||
|
int Status;
|
|||
|
string SgbdName;
|
|||
|
string EcuAdr;
|
|||
|
string StringArgument;
|
|||
|
string Temp;
|
|||
|
|
|||
|
SetFlashState(0);
|
|||
|
|
|||
|
OutputDebugString( 1196, ProcName);
|
|||
|
CDHapiInit(); // CDH-Initialisierung
|
|||
|
CDHGetSgbdName(SgbdName, Status); // SGBD-Name aus SGET
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
CDHGetCabdPar("ECU_ADDRESS", EcuAdr, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
OutputDebugString( 1203, "EcuAdr : 0x"+EcuAdr);
|
|||
|
|
|||
|
StringArgument="0x" + EcuAdr;
|
|||
|
inttostring(SG_MAXANZAHL_AIF, Temp);
|
|||
|
StringArgument= StringArgument + ";" + Temp;
|
|||
|
inttostring(SG_GROESSE_AIF, Temp);
|
|||
|
StringArgument= StringArgument + ";" + Temp;
|
|||
|
inttostring(SG_ENDEKENNUNG_AIF, Temp);
|
|||
|
StringArgument= StringArgument + ";" + Temp;
|
|||
|
StringArgument= StringArgument + ";" + SG_AUTHENTISIERUNG;
|
|||
|
|
|||
|
CDHapiJob(SgbdName, "FLASH_PARAMETER_SETZEN", StringArgument, "");
|
|||
|
TestApiFehler(COAPI_SGBD_FLASHPARAM_ERROR, ProcName, 1215, SgbdName + ", FLASH_PARAMETER_SETZEN (" + StringArgument + ")");
|
|||
|
CDHTestError(Status);
|
|||
|
CDHSetReturnVal(Status);
|
|||
|
|
|||
|
SetFlashState(1);
|
|||
|
|
|||
|
CheckForOppsAccess(ProcName, SgbdName); // Programmierzugang ermitteln (f<>r erweiterte Fehlercodes)
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : VersionInfo
|
|||
|
//*
|
|||
|
//* Funktion : Ausgabe der PABD-VersionInfo
|
|||
|
//*
|
|||
|
//* Parameter : -
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 19.10.2000 rd V0.01 Ersterstellung
|
|||
|
//* 16.02.2001 rd V1.00 Freigabe
|
|||
|
//**********************************************************************
|
|||
|
VersionInfo()
|
|||
|
{
|
|||
|
string ProcName = "VersionInfo";
|
|||
|
int Status;
|
|||
|
|
|||
|
OutputDebugString( 1244, ProcName);
|
|||
|
CDHSetCabdPar("REVISION", Revision, Status);
|
|||
|
CDHSetCabdPar("AUTHOR", Author, Status);
|
|||
|
CDHSetCabdPar("COMMENT", Comment, Status);
|
|||
|
CDHTestError(Status);
|
|||
|
CDHSetReturnVal(Status);
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : Ident
|
|||
|
//*
|
|||
|
//* Funktion : ID-Daten des SG lesen
|
|||
|
//*
|
|||
|
//* Parameter : -
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 19.10.2000 rd V0.01 Ersterstellung
|
|||
|
//* 16.02.2001 rd V1.00 Freigabe
|
|||
|
//* 02.03.2005 MK V6.10 SetFlashState hinzugef<65>gt f<>r erweiterte Fehlercodes
|
|||
|
//**********************************************************************
|
|||
|
Ident()
|
|||
|
{
|
|||
|
string ProcName = "Ident";
|
|||
|
int Status;
|
|||
|
string SgbdName;
|
|||
|
string StringResult;
|
|||
|
int IntResult;
|
|||
|
|
|||
|
OutputDebugString( 1276, ProcName);
|
|||
|
CDHapiInit(); // CDH-Initialisierung
|
|||
|
CDHGetSgbdName(SgbdName, Status); // SGBD-Name aus SGET
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
CDHapiJob(SgbdName, "IDENT", "", "");
|
|||
|
TestApiFehler(COAPI_ECU_IDENT_ERROR, ProcName, 1282, SgbdName + ", IDENT");
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "ID_BMW_NR", 1, "");
|
|||
|
CDHSetCabdPar ("ID_BMW_NR", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "ID_HW_NR", 1, "");
|
|||
|
CDHSetCabdPar ("ID_HW_NR", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "ID_DIAG_INDEX", 1, "");
|
|||
|
CDHSetCabdPar ("ID_DIAG_INDEX", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "ID_COD_INDEX", 1, "");
|
|||
|
CDHSetCabdPar ("ID_COD_INDEX", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "ID_VAR_INDEX", 1, "");
|
|||
|
CDHSetCabdPar ("ID_VAR_INDEX", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "ID_DATUM", 1, "");
|
|||
|
CDHSetCabdPar ("ID_DATUM", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "ID_LIEF_NR", 1, "");
|
|||
|
CDHSetCabdPar ("ID_LIEF_NR", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "ID_LIEF_TEXT", 1, "");
|
|||
|
CDHSetCabdPar ("ID_LIEF_TEXT", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "ID_SW_NR_MCV", 1, "");
|
|||
|
CDHSetCabdPar ("ID_SW_NR_MCV", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "ID_SW_NR_FSV", 1, "");
|
|||
|
CDHSetCabdPar ("ID_SW_NR_FSV", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "ID_SW_NR_OSV", 1, "");
|
|||
|
CDHSetCabdPar ("ID_SW_NR_OSV", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "ID_SW_NR_RES", 1, "");
|
|||
|
CDHSetCabdPar ("ID_SW_NR_RES", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultInt (IntResult, "ID_DATUM_TAG", 1);
|
|||
|
CDHSetCabdWordPar("ID_DATUM_TAG", IntResult, Status);
|
|||
|
|
|||
|
CDHapiResultInt (IntResult, "ID_DATUM_MONAT", 1);
|
|||
|
CDHSetCabdWordPar("ID_DATUM_MONAT", IntResult, Status);
|
|||
|
|
|||
|
CDHapiResultInt (IntResult, "ID_DATUM_JAHR", 1);
|
|||
|
CDHSetCabdWordPar("ID_DATUM_JAHR", IntResult, Status);
|
|||
|
|
|||
|
CDHSetCabdPar ("ID_PROD_NR", "000000000", Status);
|
|||
|
|
|||
|
CDHTestError(Status);
|
|||
|
CDHSetReturnVal(Status);
|
|||
|
|
|||
|
SetFlashState(2);
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : FehlerLoeschen
|
|||
|
//*
|
|||
|
//* Funktion : Fehlerspeicher loeschen
|
|||
|
//*
|
|||
|
//* Parameter : -
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 19.10.2000 rd V0.01 Ersterstellung
|
|||
|
//* 16.02.2001 rd V1.00 Freigabe
|
|||
|
//**********************************************************************
|
|||
|
FehlerLoeschen()
|
|||
|
{
|
|||
|
string ProcName = "FehlerLoeschen";
|
|||
|
int Status;
|
|||
|
string SgbdName;
|
|||
|
string StringResult;
|
|||
|
int IntResult;
|
|||
|
|
|||
|
OutputDebugString( 1360, ProcName);
|
|||
|
CDHapiInit(); // CDH-Initialisierung
|
|||
|
CDHGetSgbdName(SgbdName, Status); // SGBD-Name aus SGET
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
CDHapiJob(SgbdName, "FS_LOESCHEN", "", "");
|
|||
|
TestApiFehler(COAPI_ECU_DELETE_DTC_ERROR, ProcName, 1366, SgbdName + ", FS_LOESCHEN");
|
|||
|
|
|||
|
CDHTestError(Status);
|
|||
|
CDHSetReturnVal(Status);
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : AifLesen
|
|||
|
//*
|
|||
|
//* Funktion : erste freie AIF-Adresse und Anzahl freie AIF-Eintraege
|
|||
|
//* des SGs sowie alle Daten des aktuellen Aifs
|
|||
|
//*
|
|||
|
//* Parameter : -
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 19.10.2000 rd V0.01 Ersterstellung
|
|||
|
//* 16.02.2001 rd V1.00 Freigabe
|
|||
|
//* 03.07.2001 rd V2.00 <20>berarbeitung f<>r Letztes AIF ist <20>berschreibbar
|
|||
|
//**********************************************************************
|
|||
|
AifLesen()
|
|||
|
{
|
|||
|
string ProcName = "AifLesen";
|
|||
|
int Status;
|
|||
|
string SgbdName;
|
|||
|
string AifNr;
|
|||
|
string StringResult;
|
|||
|
int IntResult;
|
|||
|
int AifAnzFrei;
|
|||
|
|
|||
|
OutputDebugString( 1399, ProcName);
|
|||
|
CDHapiInit(); // CDH-Initialisierung
|
|||
|
CDHGetSgbdName(SgbdName, Status); // SGBD-Name aus SGET
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
CDHGetCabdPar ("AIF_NUMMER", AifNr, Status);
|
|||
|
TestCDHFehler (Status);
|
|||
|
|
|||
|
CDHapiJob(SgbdName, "AIF_LESEN", AifNr, "");
|
|||
|
TestApiFehler(COAPI_ECU_READ_AIF, ProcName, 1408, SgbdName + ", AIF_LESEN");
|
|||
|
|
|||
|
CDHapiResultInt (IntResult, "AIF_GROESSE", 1);
|
|||
|
CDHSetCabdWordPar("AIF_GROESSE", IntResult, Status);
|
|||
|
|
|||
|
CDHapiResultInt (IntResult, "AIF_ADRESSE_LOW", 1);
|
|||
|
CDHSetCabdWordPar("AIF_ADRESSE_LOW", IntResult, Status);
|
|||
|
|
|||
|
CDHapiResultInt (IntResult, "AIF_ADRESSE_HIGH", 1);
|
|||
|
CDHSetCabdWordPar("AIF_ADRESSE_HIGH", IntResult, Status);
|
|||
|
|
|||
|
CDHapiResultInt (AifAnzFrei, "AIF_ANZ_FREI", 1);
|
|||
|
// Letztes AIF ist <20>berschreibbar
|
|||
|
if ((SG_ENDEKENNUNG_AIF == 0x01) && (AifAnzFrei == 1) && (AifNr != "0"))
|
|||
|
{
|
|||
|
inttostring(SG_MAXANZAHL_AIF, StringResult);
|
|||
|
if (StringResult == AifNr)
|
|||
|
AifAnzFrei=0;
|
|||
|
}
|
|||
|
CDHSetCabdWordPar("AIF_ANZ_FREI", AifAnzFrei, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "AIF_FG_NR_LANG", 1, "");
|
|||
|
CDHSetCabdPar ("AIF_FG_NR", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "AIF_DATUM", 1, "");
|
|||
|
CDHSetCabdPar ("AIF_DATUM", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "AIF_SW_NR", 1, "");
|
|||
|
CDHSetCabdPar ("AIF_SW_NR", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "AIF_BEHOERDEN_NR", 1, "");
|
|||
|
CDHSetCabdPar ("AIF_BEHOERDEN_NR", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "AIF_ZB_NR", 1, "");
|
|||
|
CDHSetCabdPar ("AIF_ZB_NR", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "AIF_SERIEN_NR", 1, "");
|
|||
|
CDHSetCabdPar ("AIF_SERIEN_NR", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "AIF_HAENDLER_NR", 1, "");
|
|||
|
CDHSetCabdPar ("AIF_HAENDLER_NR", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "AIF_KM", 1, "");
|
|||
|
CDHSetCabdPar ("AIF_KM", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "AIF_PROG_NR", 1, "");
|
|||
|
CDHSetCabdPar ("AIF_PROG_NR", StringResult, Status);
|
|||
|
|
|||
|
CDHTestError(Status);
|
|||
|
CDHSetReturnVal(Status);
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : HwReferenzLesen
|
|||
|
//*
|
|||
|
//* Funktion : HW-Referenz lesen
|
|||
|
//*
|
|||
|
//* Parameter : -
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 19.10.2000 rd V0.01 Ersterstellung
|
|||
|
//* 16.02.2001 rd V1.00 Freigabe
|
|||
|
//* 02.03.2005 MK V6.10 Allgemeiner Fehler COAPI_ECU_TIMEOUT durch eigene Fehlercodes ersetzt
|
|||
|
//**********************************************************************
|
|||
|
HwReferenzLesen()
|
|||
|
{
|
|||
|
string ProcName = "HwReferenzLesen";
|
|||
|
int Status;
|
|||
|
string SgbdName;
|
|||
|
string StringResult;
|
|||
|
int IntResult;
|
|||
|
|
|||
|
OutputDebugString( 1484, ProcName);
|
|||
|
CDHapiInit(); // CDH-Initialisierung
|
|||
|
CDHGetSgbdName(SgbdName, Status); // SGBD-Name aus SGET
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
CDHapiJob(SgbdName, "HARDWARE_REFERENZ_LESEN", "", "");
|
|||
|
TestApiFehler(COAPI_ECU_HWREF_ERROR, ProcName, 1490, SgbdName + ", HARDWARE_REFERENZ_LESEN");
|
|||
|
|
|||
|
CDHapiResultInt (IntResult, "HW_REF_STATUS", 1);
|
|||
|
CDHSetCabdWordPar("HW_REF_STATUS", IntResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "HW_REF_SG_KENNUNG", 1, "");
|
|||
|
CDHSetCabdPar ("HW_REF_SG_KENNUNG", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "HW_REF_PROJEKT", 1, "");
|
|||
|
CDHSetCabdPar ("HW_REF_PROJEKT", StringResult, Status);
|
|||
|
|
|||
|
CDHTestError(Status);
|
|||
|
CDHSetReturnVal(Status);
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : DatenReferenzLesen
|
|||
|
//*
|
|||
|
//* Funktion : Daten-Referenz lesen
|
|||
|
//*
|
|||
|
//* Parameter : -
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 19.10.2000 rd V0.01 Ersterstellung
|
|||
|
//* 16.02.2001 rd V1.00 Freigabe
|
|||
|
//* 03.07.2001 rd V2.00 <20>berarbeitung ERROR_NO_DREF
|
|||
|
//**********************************************************************
|
|||
|
DatenReferenzLesen()
|
|||
|
{
|
|||
|
string ProcName = "DatenReferenzLesen";
|
|||
|
int Status;
|
|||
|
string SgbdName;
|
|||
|
string StringResult;
|
|||
|
int IntResult;
|
|||
|
bool rc;
|
|||
|
|
|||
|
OutputDebugString( 1530, ProcName);
|
|||
|
CDHapiInit(); // CDH-Initialisierung
|
|||
|
CDHGetSgbdName(SgbdName, Status); // SGBD-Name aus SGET
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
CDHapiJob(SgbdName, "DATEN_REFERENZ_LESEN", "", "");
|
|||
|
apiResultText (rc, StringResult, "JOB_STATUS", 1, "");
|
|||
|
if (rc==TRUE)
|
|||
|
{
|
|||
|
if (StringResult == "OKAY")
|
|||
|
{
|
|||
|
CDHapiResultInt (IntResult, "DATEN_REF_STATUS", 1);
|
|||
|
CDHSetCabdWordPar("DATEN_REF_STATUS", IntResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "DATEN_REF_SG_KENNUNG", 1, "");
|
|||
|
CDHSetCabdPar ("DATEN_REF_SG_KENNUNG", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "DATEN_REF_PROJEKT", 1, "");
|
|||
|
CDHSetCabdPar ("DATEN_REF_PROJEKT", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "DATEN_REF_PROGRAMM_STAND", 1, "");
|
|||
|
CDHSetCabdPar ("DATEN_REF_PROGRAMM_STAND", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "DATEN_REF_DATENSATZ", 1, "");
|
|||
|
CDHSetCabdPar ("DATEN_REF_DATENSATZ", StringResult, Status);
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
if (StringResult == "ERROR_NO_DREF")
|
|||
|
{
|
|||
|
CDHSetCabdWordPar("DATEN_REF_STATUS", 0, Status);
|
|||
|
CDHSetCabdPar ("DATEN_REF_SG_KENNUNG", "-", Status);
|
|||
|
CDHSetCabdPar ("DATEN_REF_PROJEKT", "-", Status);
|
|||
|
CDHSetCabdPar ("DATEN_REF_PROGRAMM_STAND", "-", Status);
|
|||
|
CDHSetCabdPar ("DATEN_REF_DATENSATZ", "-", Status);
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
TestApiFehler(COAPI_ECU_DATA_REFERENZ_ERROR, ProcName, 1568, SgbdName + ", DATEN_REFERENZ_LESEN");
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
TestApiFehler(COAPI_ECU_DATA_REFERENZ_ERROR, ProcName, 1574, SgbdName + ", DATEN_REFERENZ_LESEN");
|
|||
|
}
|
|||
|
|
|||
|
CDHTestError(Status);
|
|||
|
CDHSetReturnVal(Status);
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : ZifLesen
|
|||
|
//*
|
|||
|
//* Funktion : ZIF lesen
|
|||
|
//*
|
|||
|
//* Parameter : -
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 19.10.2000 rd V0.01 Ersterstellung
|
|||
|
//* 16.02.2001 rd V1.00 Freigabe
|
|||
|
//* 02.03.2005 MK V6.10 Allgemeiner Fehler COAPI_ECU_TIMEOUT durch eigene Fehlercodes ersetzt
|
|||
|
//**********************************************************************
|
|||
|
ZifLesen()
|
|||
|
{
|
|||
|
string ProcName = "ZifLesen";
|
|||
|
int Status;
|
|||
|
string SgbdName;
|
|||
|
string StringResult;
|
|||
|
int IntResult;
|
|||
|
|
|||
|
OutputDebugString( 1605, ProcName);
|
|||
|
CDHapiInit(); // CDH-Initialisierung
|
|||
|
CDHGetSgbdName(SgbdName, Status); // SGBD-Name aus SGET
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
CDHapiJob(SgbdName, "ZIF_LESEN", "", "");
|
|||
|
TestApiFehler(COAPI_ECU_ZIF_ERROR, ProcName, 1611, SgbdName + ", ZIF_LESEN");
|
|||
|
|
|||
|
CDHapiResultInt (IntResult, "ZIF_STATUS", 1);
|
|||
|
CDHSetCabdWordPar("ZIF_STATUS", IntResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "ZIF_SG_KENNUNG", 1, "");
|
|||
|
CDHSetCabdPar ("ZIF_SG_KENNUNG", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "ZIF_PROJEKT", 1, "");
|
|||
|
CDHSetCabdPar ("ZIF_PROJEKT", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "ZIF_PROGRAMM_STAND", 1, "");
|
|||
|
CDHSetCabdPar ("ZIF_PROGRAMM_STAND", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "ZIF_BMW_HW", 1, "");
|
|||
|
CDHSetCabdPar ("ZIF_BMW_HW", StringResult, Status);
|
|||
|
|
|||
|
CDHSetCabdPar ("ZIF_BMW_PST", "", Status); // ???
|
|||
|
|
|||
|
CDHTestError(Status);
|
|||
|
CDHSetReturnVal(Status);
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : ZifBackupLesen
|
|||
|
//*
|
|||
|
//* Funktion : ZIF-Backup lesen
|
|||
|
//*
|
|||
|
//* Parameter : -
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 19.10.2000 rd V0.01 Ersterstellung
|
|||
|
//* 16.02.2001 rd V1.00 Freigabe
|
|||
|
//* 02.03.2005 MK V6.10 Allgemeiner Fehler COAPI_ECU_TIMEOUT durch eigene Fehlercodes ersetzt
|
|||
|
//**********************************************************************
|
|||
|
ZifBackupLesen()
|
|||
|
{
|
|||
|
string ProcName = "ZifBackupLesen";
|
|||
|
int Status;
|
|||
|
string SgbdName;
|
|||
|
string StringResult;
|
|||
|
int IntResult;
|
|||
|
|
|||
|
OutputDebugString( 1658, ProcName);
|
|||
|
CDHapiInit(); // CDH-Initialisierung
|
|||
|
CDHGetSgbdName(SgbdName, Status); // SGBD-Name aus SGET
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
CDHapiJob(SgbdName, "ZIF_BACKUP_LESEN", "", "");
|
|||
|
TestApiFehler(COAPI_ECU_ZIFBACKUP_ERROR, ProcName, 1664, SgbdName + ", ZIF_BACKUP_LESEN");
|
|||
|
|
|||
|
CDHapiResultInt (IntResult, "ZIF_BACKUP_STATUS", 1);
|
|||
|
CDHSetCabdWordPar("ZIF_BACKUP_STATUS", IntResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "ZIF_BACKUP_SG_KENNUNG", 1, "");
|
|||
|
CDHSetCabdPar ("ZIF_BACKUP_SG_KENNUNG", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "ZIF_BACKUP_PROJEKT", 1, "");
|
|||
|
CDHSetCabdPar ("ZIF_BACKUP_PROJEKT", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "ZIF_BACKUP_PROGRAMM_STAND", 1, "");
|
|||
|
CDHSetCabdPar ("ZIF_BACKUP_PROGRAMM_STAND", StringResult, Status);
|
|||
|
|
|||
|
CDHapiResultText (StringResult, "ZIF_BACKUP_BMW_HW", 1, "");
|
|||
|
CDHSetCabdPar ("ZIF_BACKUP_BMW_HW", StringResult, Status);
|
|||
|
|
|||
|
CDHSetCabdPar ("ZIF_BACKUP_BMW_PST", "", Status); // ???
|
|||
|
|
|||
|
CDHTestError(Status);
|
|||
|
CDHSetReturnVal(Status);
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : AifSchreiben
|
|||
|
//*
|
|||
|
//* Funktion : Dummy Job Aif schreiben
|
|||
|
//*
|
|||
|
//* Parameter : -
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 19.10.2000 rd V0.01 Ersterstellung
|
|||
|
//* 16.02.2001 rd V1.00 Freigabe
|
|||
|
//**********************************************************************
|
|||
|
AifSchreiben()
|
|||
|
{
|
|||
|
string ProcName = "AifSchreiben";
|
|||
|
int Status=0;
|
|||
|
|
|||
|
OutputDebugString( 1707, ProcName);
|
|||
|
OutputDebugString( 1708, "Dummy Job Aif schreiben");
|
|||
|
CDHTestError(Status);
|
|||
|
CDHSetReturnVal(Status);
|
|||
|
}
|
|||
|
|
|||
|
//*************************************************************
|
|||
|
//*
|
|||
|
//* Name : Innentemp
|
|||
|
//*
|
|||
|
//* Funktion : Innentemperatur des SG auslesen
|
|||
|
//*
|
|||
|
//* Parameter : -
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//*************************************************************
|
|||
|
//* History :
|
|||
|
//* 16.07.2001 SK V1.00 Freigabe
|
|||
|
//* 16.05.2002 Softing Mw Ausgabe ist konfigurierbar
|
|||
|
//* 02.03.2005 MK V6.10 Allgemeiner Fehler COAPI_ECU_TIMEOUT durch eigene Fehlercodes ersetzt
|
|||
|
//*************************************************************
|
|||
|
Innentemp()
|
|||
|
{
|
|||
|
string ProcName = "Innentemp";
|
|||
|
string SgbdName;
|
|||
|
string Innentemperatur;
|
|||
|
string Innentemp_einh;
|
|||
|
int Status;
|
|||
|
|
|||
|
if (SgInnenTemperaturLesen == TRUE)
|
|||
|
{
|
|||
|
OutputDebugString( 1739, ProcName);
|
|||
|
CDHapiInit(); // CDH-Initialisierung
|
|||
|
CDHGetSgbdName(SgbdName, Status); // SGBD-Name aus SGET
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
CDHapiJob(SgbdName, "INNENTEMP_LESEN", "", ""); //Innentemperatur aus SG lesen
|
|||
|
TestApiFehler(COAPI_ECU_INNENTEMP_ERROR, ProcName, 1745, SgbdName + ", INNENTEMP_LESEN");
|
|||
|
|
|||
|
CDHapiResultText (Innentemperatur, "SG_INNENTEMP", 1, "");
|
|||
|
CDHSetCabdPar ("SG_INNENTEMP", Innentemperatur, Status);
|
|||
|
|
|||
|
CDHapiResultText (Innentemp_einh, "SG_INNENTEMP_EINH", 1, "");
|
|||
|
CDHSetCabdPar ("SG_INNENTEMP_EINH", Innentemp_einh, Status);
|
|||
|
|
|||
|
CDHTestError(Status);
|
|||
|
CDHSetReturnVal(Status);
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
Status = COAPI_CABD_PAR_ERROR;
|
|||
|
TestCDHFehler(Status);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
//*************************************************************
|
|||
|
//*
|
|||
|
//* Name : PhysHwNrLesen
|
|||
|
//*
|
|||
|
//* Funktion : Physikalische Hardwarenummer des SG auslesen
|
|||
|
//*
|
|||
|
//* Parameter : -
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//*************************************************************
|
|||
|
//* History :
|
|||
|
//* 26.11.2001 Softing Mw Mustererstellung
|
|||
|
//* 17.05.2002 Softing Mw Ausgabe ist konfigurierbar
|
|||
|
//* 02.03.2005 MK V6.10 Allgemeiner Fehler COAPI_ECU_TIMEOUT durch eigene Fehlercodes ersetzt
|
|||
|
//*************************************************************
|
|||
|
PhysHwNrLesen()
|
|||
|
{
|
|||
|
string ProcName = "PhysHwNrLesen";
|
|||
|
string SgbdName;
|
|||
|
string PhysHwNummer;
|
|||
|
int Status;
|
|||
|
|
|||
|
if (SgPhysHwNrLesen == TRUE)
|
|||
|
{
|
|||
|
OutputDebugString( 1788, ProcName);
|
|||
|
CDHapiInit(); // CDH-Initialisierung
|
|||
|
CDHGetSgbdName(SgbdName, Status); // SGBD-Name aus SGET
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
CDHapiJob(SgbdName, "PHYSIKALISCHE_HW_NR_LESEN", "", ""); //Physikalische Hardwarenummer aus SG lesen
|
|||
|
TestApiFehler(COAPI_ECU_PHYHWNR_ERROR, ProcName, 1794, SgbdName + ", PHYSIKALISCHE_HW_NR_LESEN");
|
|||
|
|
|||
|
CDHapiResultText (PhysHwNummer, "PHYSIKALISCHE_HW_NR", 1, "");
|
|||
|
CDHSetCabdPar ("PHYSIKALISCHE_HW_NR", PhysHwNummer, Status);
|
|||
|
|
|||
|
CDHTestError(Status);
|
|||
|
CDHSetReturnVal(Status);
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
Status = COAPI_CABD_PAR_ERROR;
|
|||
|
TestCDHFehler(Status);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
//*************************************************************
|
|||
|
//*
|
|||
|
//* Name : FlashSchreiben
|
|||
|
//*
|
|||
|
//* Funktion : Daten in Buffer an SG senden
|
|||
|
//*
|
|||
|
//* Parameter : SgbdName - Name der verwendeten SGBD
|
|||
|
//* Buffer - Binaerpuffer mit Daten
|
|||
|
//* BufferSize - Groesse des Binaerpuffers Buffer
|
|||
|
//* RequestDownloadBuffer - Binaerpuffer mit Startadresse und Laenge des aktuellen Datenblocks
|
|||
|
//* NoExit - TRUE wenn kein Abbruch im Fehlerfall von FLASH_SCHREIBEN erfolgen soll, FALSE andererseits
|
|||
|
//*
|
|||
|
//* Rueckgabe : RetVal - Status von FLASH_SCHREIBEN
|
|||
|
//*
|
|||
|
//*************************************************************
|
|||
|
//* History :
|
|||
|
//* 24.06.2003 V1.00 KuS Ersterstellung
|
|||
|
//* 02.03.2005 V6.10 MK <20>berarbeitung der Fehlerabfrage
|
|||
|
//*************************************************************
|
|||
|
FlashSchreiben(in: string SgbdName,
|
|||
|
in: int Buffer,
|
|||
|
in: int BufferSize,
|
|||
|
in: int RequestDownloadBuffer,
|
|||
|
in: bool NoExit,
|
|||
|
out: int RetVal)
|
|||
|
{
|
|||
|
string ProcName = "FlashSchreiben";
|
|||
|
int Status = 0;
|
|||
|
int SgStatus = 1; // Block i.O.
|
|||
|
|
|||
|
RetVal = 0;
|
|||
|
CDHapiJobData(SgbdName, "FLASH_SCHREIBEN_XXL", Buffer, BufferSize, "");
|
|||
|
|
|||
|
// MK: wenn bei der <20>bertragung ohne Wiederaufsetzen ein Fehler passiert,
|
|||
|
// dann sofort mit den neuen Fehlercodes abbrechen.
|
|||
|
// Deshalb: "TestApiFehlerNoExit" nur, wenn Wiederaufsetzen in PABD eingeschalten ist
|
|||
|
if ((NoExit == TRUE) && ((WiederaufsetzenBlockSwitch == TRUE) || (WiederaufsetzenSwitch == TRUE)))
|
|||
|
// <20>bertragung mit Wiederaufsetzen
|
|||
|
TestApiFehlerNoExit(COAPI_ECU_FLASH_DOWNLOAD_ERROR, ProcName, 1847, SgbdName + ", FLASH_SCHREIBEN (...)", Status);
|
|||
|
else
|
|||
|
// <20>bertragung ohne Wiederaufsetzen oder beim Wiederaufsetzen (1 bis 3 Bl<42>cke)
|
|||
|
TestApiFehler(COAPI_ECU_FLASH_DOWNLOAD_ERROR, ProcName, 1850, SgbdName + ", FLASH_SCHREIBEN (...)");
|
|||
|
|
|||
|
if (Status == 0) // Kann nur abgefragt werden wenn Status gleich Null ist.
|
|||
|
CDHapiResultInt(SgStatus, "FLASH_SCHREIBEN_STATUS", 1);
|
|||
|
|
|||
|
if (SgStatus != 1)
|
|||
|
{
|
|||
|
// SG meldet Programmierung NOK --> Programmierung mit TransferExit abschliesen und beenden.
|
|||
|
CDHapiJobData(SgbdName, "FLASH_SCHREIBEN_ENDE", RequestDownloadBuffer, 21, "");
|
|||
|
// MK: urspr<70>nglichen Fehler nicht verschleiern
|
|||
|
// TestApiFehler(COAPI_ECU_FLASH_TRANSFER_EXIT_ERROR, ProcName, 1860, SgbdName + ", WAS - FLASH_SCHREIBEN_ENDE Datenbloecke(...)");
|
|||
|
// Fehler eintragen und dann abbrechen
|
|||
|
SetCDHFehler(COAPI_ECU_FLASH_DOWNLOAD_ERROR, ProcName, 1862, "SG meldet Programmierung NOK. Abbruch!!");
|
|||
|
}
|
|||
|
|
|||
|
RetVal = Status;
|
|||
|
}
|
|||
|
|
|||
|
//*************************************************************
|
|||
|
//*
|
|||
|
//* Name : AddWordToDWord
|
|||
|
//*
|
|||
|
//* Funktion : Word zu Double Word addieren
|
|||
|
//*
|
|||
|
//* Parameter : LowByte - Low-Byte Teil des DWord
|
|||
|
//* MidLowByte - MidLow-Byte Teil des DWord
|
|||
|
//* MidHighByte - MidHigh-Byte Teil des DWord
|
|||
|
//* HighByte - High-Byte Teil des DWord
|
|||
|
//* AddWord - Word das addiert werden soll
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//*************************************************************
|
|||
|
//* History :
|
|||
|
//* 03.07.2003 V1.00 KuS Ersterstellung
|
|||
|
//* 02.03.2005 MK V6.10 Berechnungsfehler behoben
|
|||
|
//*************************************************************
|
|||
|
AddWordToDWord(inout: int LowByte,
|
|||
|
inout: int MidLowByte,
|
|||
|
inout: int MidHighByte,
|
|||
|
inout: int HighByte,
|
|||
|
in: int AddWord)
|
|||
|
{
|
|||
|
int NextByte = 0;
|
|||
|
|
|||
|
LowByte = LowByte + AddWord;
|
|||
|
// Uebertrag auf MidLow
|
|||
|
if (LowByte > 0xFF)
|
|||
|
{
|
|||
|
NextByte = LowByte / 256;
|
|||
|
MidLowByte = MidLowByte + NextByte;
|
|||
|
LowByte = LowByte - (NextByte * 256);
|
|||
|
}
|
|||
|
// Uebertrag auf MidHigh
|
|||
|
if (MidLowByte > 0xFF)
|
|||
|
{
|
|||
|
NextByte = MidLowByte / 256;
|
|||
|
MidHighByte = MidHighByte + NextByte;
|
|||
|
MidLowByte = MidLowByte - (NextByte * 256);
|
|||
|
}
|
|||
|
// Uebertrag auf High
|
|||
|
if (MidHighByte > 0xFF)
|
|||
|
{
|
|||
|
NextByte = MidHighByte / 256;
|
|||
|
HighByte = HighByte + NextByte;
|
|||
|
MidHighByte = MidHighByte - (NextByte * 256);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
//*************************************************************
|
|||
|
//*
|
|||
|
//* Name : AddDWordToDWord
|
|||
|
//*
|
|||
|
//* Funktion : Double Word zu Double Word addieren
|
|||
|
//*
|
|||
|
//* Parameter : LowByte - Low-Byte Teil des DWord
|
|||
|
//* MidLowByte - MidLow-Byte Teil des DWord
|
|||
|
//* MidHighByte - MidHigh-Byte Teil des DWord
|
|||
|
//* HighByte - High-Byte Teil des DWord
|
|||
|
//* AddLowByte - Low-Byte Teil des DWord
|
|||
|
//* AddMidLowByte - MidLow-Byte Teil des DWord
|
|||
|
//* AddMidHighByte - MidHigh-Byte Teil des DWord
|
|||
|
//* AddHighByte - High-Byte Teil des DWord
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//*************************************************************
|
|||
|
//* History :
|
|||
|
//* 16.07.2003 V6.00 KuS Ersterstellung
|
|||
|
//*************************************************************
|
|||
|
AddDWordToDWord(inout: int LowByte,
|
|||
|
inout: int MidLowByte,
|
|||
|
inout: int MidHighByte,
|
|||
|
inout: int HighByte,
|
|||
|
in: int AddLowByte,
|
|||
|
in: int AddMidLowByte,
|
|||
|
in: int AddMidHighByte,
|
|||
|
in: int AddHighByte)
|
|||
|
{
|
|||
|
LowByte = LowByte + AddLowByte;
|
|||
|
if (LowByte > 0xFF)
|
|||
|
{
|
|||
|
MidLowByte = MidLowByte + 1; // Uebertrag nach MidLow
|
|||
|
LowByte = LowByte - 0x100;
|
|||
|
}
|
|||
|
if (MidLowByte > 0xFF)
|
|||
|
{
|
|||
|
MidHighByte = MidHighByte + 1;// Uebertrag nach MidHigh
|
|||
|
MidLowByte = MidLowByte - 0x100;
|
|||
|
}
|
|||
|
if (MidHighByte > 0xFF)
|
|||
|
{
|
|||
|
HighByte = HighByte + 1; // Uebertrag nach High
|
|||
|
MidHighByte = MidHighByte - 0x100;
|
|||
|
}
|
|||
|
MidLowByte = MidLowByte + AddMidLowByte;
|
|||
|
if (MidLowByte > 0xFF)
|
|||
|
{
|
|||
|
MidHighByte = MidHighByte + 1;// Uebertrag nach MidHigh
|
|||
|
MidLowByte = MidLowByte - 0x100;
|
|||
|
}
|
|||
|
if (MidHighByte > 0xFF)
|
|||
|
{
|
|||
|
HighByte = HighByte + 1; // Uebertrag nach High
|
|||
|
MidHighByte = MidHighByte - 0x100;
|
|||
|
}
|
|||
|
MidHighByte = MidHighByte + AddMidHighByte;
|
|||
|
if (MidHighByte > 0xFF)
|
|||
|
{
|
|||
|
HighByte = HighByte + 1; // Uebertrag nach High
|
|||
|
MidHighByte = MidHighByte - 0x100;
|
|||
|
}
|
|||
|
HighByte = HighByte + AddHighByte;
|
|||
|
}
|
|||
|
|
|||
|
//*************************************************************
|
|||
|
//*
|
|||
|
//* Name : SubDWordFromDWord
|
|||
|
//*
|
|||
|
//* Funktion : Double Word von Double Word subtrahieren
|
|||
|
//*
|
|||
|
//* Parameter : LowByte - Low-Byte Teil des DWord
|
|||
|
//* MidLowByte - MidLow-Byte Teil des DWord
|
|||
|
//* MidHighByte - MidHigh-Byte Teil des DWord
|
|||
|
//* HighByte - High-Byte Teil des DWord
|
|||
|
//* AddLowByte - Low-Byte Teil des DWord
|
|||
|
//* AddMidLowByte - MidLow-Byte Teil des DWord
|
|||
|
//* AddMidHighByte - MidHigh-Byte Teil des DWord
|
|||
|
//* AddHighByte - High-Byte Teil des DWord
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//*************************************************************
|
|||
|
//* History :
|
|||
|
//* 16.07.2003 V6.00 KuS Ersterstellung
|
|||
|
//*************************************************************
|
|||
|
SubDWordFromDWord(inout: int LowByte,
|
|||
|
inout: int MidLowByte,
|
|||
|
inout: int MidHighByte,
|
|||
|
inout: int HighByte,
|
|||
|
in: int SubLowByte,
|
|||
|
in: int SubMidLowByte,
|
|||
|
in: int SubMidHighByte,
|
|||
|
in: int SubHighByte)
|
|||
|
{
|
|||
|
LowByte = LowByte - SubLowByte;
|
|||
|
if (LowByte < 0)
|
|||
|
{
|
|||
|
LowByte = LowByte + 0x100;
|
|||
|
MidLowByte = MidLowByte - 1;
|
|||
|
}
|
|||
|
if (MidLowByte < 0)
|
|||
|
{
|
|||
|
MidLowByte = MidLowByte + 0x100;
|
|||
|
MidHighByte = MidHighByte - 1;
|
|||
|
}
|
|||
|
if (MidHighByte < 0)
|
|||
|
{
|
|||
|
MidHighByte = MidHighByte + 0x100;
|
|||
|
HighByte = HighByte - 1;
|
|||
|
}
|
|||
|
MidLowByte = MidLowByte - SubMidLowByte;
|
|||
|
if (MidLowByte < 0)
|
|||
|
{
|
|||
|
MidLowByte = MidLowByte + 0x100;
|
|||
|
MidHighByte = MidHighByte - 1;
|
|||
|
}
|
|||
|
if (MidHighByte < 0)
|
|||
|
{
|
|||
|
MidHighByte = MidHighByte + 0x100;
|
|||
|
HighByte = HighByte - 1;
|
|||
|
}
|
|||
|
MidHighByte = MidHighByte - SubMidHighByte;
|
|||
|
if (MidHighByte < 0)
|
|||
|
{
|
|||
|
MidHighByte = MidHighByte + 0x100;
|
|||
|
HighByte = HighByte - 1;
|
|||
|
}
|
|||
|
HighByte = HighByte - SubHighByte;
|
|||
|
}
|
|||
|
|
|||
|
//*************************************************************
|
|||
|
//*
|
|||
|
//* Name : BufferAuffuellen
|
|||
|
//*
|
|||
|
//* Funktion : Buffer mit 0xFF bis MXBL auffuellen
|
|||
|
//*
|
|||
|
//* Parameter : Buffer - Binaerpuffer mit Daten
|
|||
|
//* BufferSize - Groesse des Binaerpuffers Buffer
|
|||
|
//* MaxData - MXBL des SG
|
|||
|
//*
|
|||
|
//* Rueckgabe :
|
|||
|
//*
|
|||
|
//*************************************************************
|
|||
|
//* History :
|
|||
|
//* 07.07.2003 V6.00 KuS Ersterstellung
|
|||
|
//*************************************************************
|
|||
|
BufferAuffuellen(in: int Buffer,
|
|||
|
in: int BufferSize,
|
|||
|
in: int MaxData)
|
|||
|
{
|
|||
|
string ProcName = "BufferAuffuellen";
|
|||
|
int Status = 0;
|
|||
|
int Byte = 0xFF;
|
|||
|
int Position = 0;
|
|||
|
int MaxDataHighByte = 0;
|
|||
|
int MaxDataLowByte = 0;
|
|||
|
|
|||
|
// OutputDebugInt( 2078, "Auffuellen des Buffer mit BufferSize = ",BufferSize);
|
|||
|
Position = BufferSize - 1; // Um das alte letzte Byte zu <20>berschreiben: ETX=0x03h
|
|||
|
while (Position <= MaxData + 21 - 1) // 20 von Info Bytes(Adresse,...)
|
|||
|
{ // Letztes Byte ist fuer ETX = 03h
|
|||
|
CDHBinBufWriteByte(Buffer, Byte, Position, Status);
|
|||
|
Position = Position + 1;
|
|||
|
BufferSize = BufferSize + 1;
|
|||
|
}
|
|||
|
CDHBinBufWriteByte(Buffer, 0x03, Position, Status); //Letzte Byte ist immer ETX = 03h
|
|||
|
BufferSize = BufferSize + 1;
|
|||
|
|
|||
|
if (MaxData > 0xFF)
|
|||
|
{
|
|||
|
MaxDataHighByte = (MaxData / 256);
|
|||
|
MaxDataLowByte = (MaxData - (MaxDataHighByte * 256));
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
MaxDataHighByte = 0x00;
|
|||
|
MaxDataLowByte = MaxData;
|
|||
|
}
|
|||
|
|
|||
|
CDHBinBufWriteByte(Buffer, MaxDataLowByte, 13, Status); // Anzahl Bytedaten LowByte
|
|||
|
CDHBinBufWriteByte(Buffer, MaxDataHighByte, 14, Status); // Anzahl Bytedaten HighByte
|
|||
|
|
|||
|
CDHBinBufWriteByte(Buffer, MaxDataLowByte, 15, Status); // Anzahl Wortdaten LowByte
|
|||
|
CDHBinBufWriteByte(Buffer, MaxDataHighByte, 16, Status); // Anzahl Wortdaten HighByte
|
|||
|
}
|
|||
|
|
|||
|
//*************************************************************
|
|||
|
//*
|
|||
|
//* Name : SubWordFromDWord
|
|||
|
//*
|
|||
|
//* Funktion : Word von Double Word subtrahieren
|
|||
|
//*
|
|||
|
//* Parameter : LowByte - Low-Byte Teil des DWord
|
|||
|
//* MidLowByte - MidLow-Byte Teil des DWord
|
|||
|
//* MidHighByte - MidHigh-Byte Teil des DWord
|
|||
|
//* HighByte - High-Byte Teil des DWord
|
|||
|
//* SubWord - Word das subtrahiert werden soll
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//*************************************************************
|
|||
|
//* History :
|
|||
|
//* 03.07.2003 KuS V6.00 Ersterstellung
|
|||
|
//* 02.03.2005 MK V6.10 Berechnungsfehler behoben
|
|||
|
//* 07.06.2005 MK V6.12 neu: Fehlercode COAPI_ADDRESS_CALC_ERROR
|
|||
|
//*************************************************************
|
|||
|
SubWordFromDWord(inout: int LowByte,
|
|||
|
inout: int MidLowByte,
|
|||
|
inout: int MidHighByte,
|
|||
|
inout: int HighByte,
|
|||
|
in: int SubWord)
|
|||
|
{
|
|||
|
int SubWordHigh;
|
|||
|
int SubWordMidHigh;
|
|||
|
int SubWordMidLow;
|
|||
|
int SubWordLow;
|
|||
|
|
|||
|
SubWordHigh = 0;
|
|||
|
SubWordMidHigh = 0;
|
|||
|
SubWordMidLow = SubWord / 256;
|
|||
|
SubWordLow = SubWord - (SubWordMidLow * 0x100);
|
|||
|
|
|||
|
if (LowByte < SubWordLow)
|
|||
|
{
|
|||
|
LowByte = (LowByte - SubWordLow) + 0x100;
|
|||
|
SubWordMidLow = SubWordMidLow + 1;
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
LowByte = LowByte - SubWordLow;
|
|||
|
}
|
|||
|
|
|||
|
if (MidLowByte < SubWordMidLow)
|
|||
|
{
|
|||
|
MidLowByte = (MidLowByte - SubWordMidLow) + 0x100;
|
|||
|
SubWordMidHigh = SubWordMidHigh + 1;
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
MidLowByte = MidLowByte - SubWordMidLow;
|
|||
|
}
|
|||
|
|
|||
|
if (MidHighByte < SubWordMidHigh)
|
|||
|
{
|
|||
|
MidHighByte = (MidHighByte - SubWordMidHigh) + 0x100;
|
|||
|
SubWordHigh = SubWordHigh + 1;
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
MidHighByte = MidHighByte - SubWordMidHigh;
|
|||
|
}
|
|||
|
|
|||
|
if (HighByte < SubWordHigh)
|
|||
|
{
|
|||
|
SetCDHFehler(COAPI_ADDRESS_CALC_ERROR, "SubWordFromDWord", 0, "Fehler bei Adressberechnung");
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
HighByte = HighByte - SubWordHigh;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
//*************************************************************
|
|||
|
//*
|
|||
|
//* Name : WASBufferKopieren
|
|||
|
//*
|
|||
|
//* Funktion : Buffer in einen der WASBackup Buffer kopieren
|
|||
|
//*
|
|||
|
//* Parameter : Buffer - Binaerpuffer mit Daten
|
|||
|
//* BufferSize - Groesse des Binaerpuffers Buffer
|
|||
|
//* WASBuffer - WAS Puffer zum Speichern der Daten
|
|||
|
//* WASBufferSize - Groesse des Binaerpuffers WASBuffer
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//*************************************************************
|
|||
|
//* History :
|
|||
|
//* 14.07.2003 V6.00 KuS Ersterstellung
|
|||
|
//*************************************************************
|
|||
|
WASBufferKopieren(in: int Buffer,
|
|||
|
in: int BufferSize,
|
|||
|
inout: int WASBuffer,
|
|||
|
inout: int WASBufferSize)
|
|||
|
{
|
|||
|
int Status = 0;
|
|||
|
int Position = 0;
|
|||
|
int Byte = 0;
|
|||
|
|
|||
|
if (WASBufferSize != BufferSize) // Neu Erzeugen des Puffers. Sonst Fehler beim WAS eines kleineren Blocks als MXBL
|
|||
|
{
|
|||
|
CDHBinBufDelete(WASBuffer,Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufCreate(WASBuffer,Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
}
|
|||
|
|
|||
|
// Coapi-Funktion benutzen
|
|||
|
CDHBinBufCopy(Buffer, WASBuffer, 0, 0, BufferSize, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
WASBufferSize = BufferSize;
|
|||
|
}
|
|||
|
|
|||
|
//*************************************************************
|
|||
|
//*
|
|||
|
//* Name : FlashSchreibenEnde
|
|||
|
//*
|
|||
|
//* Funktion : SGBG Job FLASH_SCHREIBEN_ENDE ausf<73>hren
|
|||
|
//*
|
|||
|
//* Parameter : SgbdName - Name der verwendeten SGBD
|
|||
|
//* RequestDownloadBuffer - Binaerpuffer mit Startadresse und L<>nge
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//*************************************************************
|
|||
|
//* History :
|
|||
|
//* 16.07.2003 V6.00 KuS Ersterstellung
|
|||
|
//*************************************************************
|
|||
|
FlashSchreibenEnde(in: string SgbdName,
|
|||
|
in: int RequestDownloadBuffer)
|
|||
|
{
|
|||
|
string ProcName = "FlashSchreibenEnde";
|
|||
|
|
|||
|
CDHapiJobData(SgbdName, "FLASH_SCHREIBEN_ENDE", RequestDownloadBuffer, 21, "");
|
|||
|
TestApiFehler(COAPI_ECU_FLASH_TRANSFER_EXIT_ERROR, ProcName, 2245, SgbdName + ", FLASH_SCHREIBEN_ENDE (...)");
|
|||
|
}
|
|||
|
|
|||
|
//*************************************************************
|
|||
|
//*
|
|||
|
//* Name : FlashSchreibenAdresse
|
|||
|
//*
|
|||
|
//* Funktion : SGBG Job FLASH_SCHREIBEN_ADRESSE ausf<73>hren
|
|||
|
//*
|
|||
|
//* Parameter : SgbdName - Name der verwendeten SGBD
|
|||
|
//* RequestDownloadBuffer - Binaerpuffer mit Startadresse und L<>nge
|
|||
|
//* DynMaxData - Angepassste MXBL (FLASH_SCHREIBEN_ADRESSE)
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//*************************************************************
|
|||
|
//* History :
|
|||
|
//* 16.07.2003 V6.00 KuS Ersterstellung
|
|||
|
//*************************************************************
|
|||
|
FlashSchreibenAdresse(in: string SgbdName,
|
|||
|
in: int RequestDownloadBuffer,
|
|||
|
inout: int DynMaxData)
|
|||
|
{
|
|||
|
string ProcName = "FlashSchreibenAdresse";
|
|||
|
|
|||
|
CDHapiJobData(SgbdName, "FLASH_SCHREIBEN_ADRESSE", RequestDownloadBuffer, 21, "");
|
|||
|
TestApiFehler(COAPI_ECU_FLASH_REQUEST_DOWNLOAD_ERROR, ProcName, 2271, SgbdName + ", FLASH_SCHREIBEN_ADRESSE (...)");
|
|||
|
|
|||
|
// Dynamische MXBL Behandlung
|
|||
|
if (DynamischeMXBL == TRUE)
|
|||
|
{
|
|||
|
CDHapiResultInt(DynMaxData, "FLASH_BLOCKLAENGE_DATEN", 1);
|
|||
|
DynMaxData = DynMaxData - 1; // Das Service Id (SID) muss abgezogen werden
|
|||
|
OutputDebugInt( 2278, "DynMaxData ", DynMaxData);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
//*************************************************************
|
|||
|
//*
|
|||
|
//* Name : VorbereitenRDBuffer
|
|||
|
//*
|
|||
|
//* Funktion : Setzen der Werte im RequestDownloadBuffer
|
|||
|
//*
|
|||
|
//* Parameter : StartAdrLow - Low Byte der Startadresse
|
|||
|
//* StartAdrMidLow - MidLow Byte der Startadresse
|
|||
|
//* StartAdrMidHigh - MidHigh Byte der Startadresse
|
|||
|
//* StartAdrHigh - High Byte der Startadresse
|
|||
|
//* DataBlockLengthLow - Low Byte der Datenblocklaenge
|
|||
|
//* DataBlockLengthMidLow - MidLow Byte der Datenblocklaenge
|
|||
|
//* DataBlockLengthMidHigh - MidHigh Byte der Datenblocklaenge
|
|||
|
//* DataBlockLengthHigh - High Byte der Datenblocklaenge
|
|||
|
//* RequestDownloadBuffer - Binaerpuffer mit Startadresse und L<>nge
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//*************************************************************
|
|||
|
//* History :
|
|||
|
//* 16.07.2003 V6.00 KuS Ersterstellung
|
|||
|
//*************************************************************
|
|||
|
VorbereitenRDBuffer(in: int StartAdrLow,
|
|||
|
in: int StartAdrMidLow,
|
|||
|
in: int StartAdrMidHigh,
|
|||
|
in: int StartAdrHigh,
|
|||
|
in: int DataBlockLengthLow,
|
|||
|
in: int DataBlockLengthMidLow,
|
|||
|
in: int DataBlockLengthMidHigh,
|
|||
|
in: int DataBlockLengthHigh,
|
|||
|
inout: int RequestDownloadBuffer)
|
|||
|
{
|
|||
|
int Status = 0;
|
|||
|
|
|||
|
// Startadresse fuer Telegramm setzen
|
|||
|
CDHBinBufWriteByte(RequestDownloadBuffer, StartAdrLow, 17, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufWriteByte(RequestDownloadBuffer, StartAdrMidLow, 18, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufWriteByte(RequestDownloadBuffer, StartAdrMidHigh, 19, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufWriteByte(RequestDownloadBuffer, StartAdrHigh , 20, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
// Laenge des Datenblocks fuer Telegramm setzen
|
|||
|
CDHBinBufWriteByte(RequestDownloadBuffer, DataBlockLengthLow, 13, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufWriteByte(RequestDownloadBuffer, DataBlockLengthMidLow, 14, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufWriteByte(RequestDownloadBuffer, DataBlockLengthMidHigh, 15, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufWriteByte(RequestDownloadBuffer, DataBlockLengthHigh, 16, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
}
|
|||
|
|
|||
|
//*************************************************************
|
|||
|
//*
|
|||
|
//* Name : Delay
|
|||
|
//*
|
|||
|
//* Funktion : Warten (ggf. mit TP Handling)
|
|||
|
//*
|
|||
|
//* Parameter : SgbdName - Name der verwendeten SGBD
|
|||
|
//* DelayTime - Wartezeit in MSekunden
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//*************************************************************
|
|||
|
//* History :
|
|||
|
//* 14.06.2003 V6.00 KuS Ersterstellung
|
|||
|
//* 28.09.2005 V8.00 MH <20>nderung des TP Handling
|
|||
|
//* Umbenennung in "Delay"
|
|||
|
//*************************************************************
|
|||
|
Delay(in: string SgbdName, in : int DelayTime)
|
|||
|
{
|
|||
|
string ProcName = "Delay";
|
|||
|
int DelayTimeCounter = 0;
|
|||
|
|
|||
|
while (DelayTimeCounter < DelayTime)
|
|||
|
{
|
|||
|
CDHDelay(500);
|
|||
|
// ACHTUNG: Wenn ein TP gesendet wird, verz<72>gert das den Vorgang um das busabh<62>ngige Telegramm-Timeout!
|
|||
|
TesterPresentHandling(ProcName, SgbdName, FALSE);
|
|||
|
DelayTimeCounter = DelayTimeCounter + 500;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
//*************************************************************
|
|||
|
//*
|
|||
|
//* Name : SGReset
|
|||
|
//*
|
|||
|
//* Funktion : SGBG Job STEUERGERAETE_RESET ausf<73>hren
|
|||
|
//*
|
|||
|
//* Parameter : SgbdName - Name der verwendeten SGBD
|
|||
|
//* ResetZeit - ResetZeit des SG
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//*************************************************************
|
|||
|
//* History :
|
|||
|
//* 12.08.2003 V6.00 KuS Ersterstellung
|
|||
|
//* 28.09.2005 V8.00 MH Parameter TP entfernt
|
|||
|
//*************************************************************
|
|||
|
SGReset(in: string SgbdName, in: int ResetZeit)
|
|||
|
{
|
|||
|
string ProcName = "SGReset";
|
|||
|
|
|||
|
OutputDebugString( 2388, "Reset");
|
|||
|
CDHapiJob(SgbdName, "STEUERGERAETE_RESET", "", "");
|
|||
|
TestApiFehler(COAPI_ECU_RESET_ERROR, ProcName, 2390, SgbdName + ", STEUERGERAETE_RESET");
|
|||
|
if (ResetZeit > 0)
|
|||
|
{
|
|||
|
Delay(SgbdName, ResetZeit * 1000 + 500);
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
Delay(SgbdName, 500);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
//*************************************************************
|
|||
|
//*
|
|||
|
//* Name : PruefeSignatur
|
|||
|
//*
|
|||
|
//* Funktion : SignaturPr<50>fung f<>r angegebenen Bereich durchf<68>hren
|
|||
|
//*
|
|||
|
//* Parameter : SgbdName - Name der verwendeten SGBD
|
|||
|
//* SignaturBereich - "Programm" oder "Daten"
|
|||
|
//* SignaturTestZeit - SignaturTestZeit des SG
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//*************************************************************
|
|||
|
//* History :
|
|||
|
//* 21.07.2005 V6.13 MH Ersterstellung
|
|||
|
//*************************************************************
|
|||
|
PruefeSignatur(in: string SgbdName, in: string SignaturBereich, in: int SignaturTestZeit)
|
|||
|
{
|
|||
|
string ProcName = "PruefeSignatur";
|
|||
|
|
|||
|
bool rc;
|
|||
|
string ApiStatusText;
|
|||
|
|
|||
|
bool RoutineNotCompleteErhalten = FALSE;
|
|||
|
bool OkayErhalten = FALSE;
|
|||
|
|
|||
|
bool SignaturTestZeitAbgelaufen;
|
|||
|
int PollingWarteZeit = 1000;
|
|||
|
int TPfaelligCounter = 0;
|
|||
|
|
|||
|
// Sende erzwungenes TP (damit, wenn RespPend auf Signaturpr<70>fung kommt, kein Timeout entsteht)
|
|||
|
TesterPresentHandling(ProcName, SgbdName, TRUE);
|
|||
|
|
|||
|
settimer(3, (SignaturTestZeit * 1000) + 1000); // SignaturTestZeit + 1 Sekunde zus<75>tzlich
|
|||
|
testtimer(3, SignaturTestZeitAbgelaufen);
|
|||
|
|
|||
|
// Polling solange kein Okay erhalten und die Signaturpr<70>fungszeit nicht vergangen ist
|
|||
|
while ((OkayErhalten == FALSE) && (SignaturTestZeitAbgelaufen == FALSE))
|
|||
|
{
|
|||
|
|
|||
|
CDHapiJob (SgbdName, "NG_SIGNATUR_PRUEFEN", SignaturBereich, "");
|
|||
|
// existiert JOB_STATUS bzw. hat SG geantwortet ?
|
|||
|
apiResultText(rc, ApiStatusText, "JOB_STATUS", 1, "");
|
|||
|
if(rc == TRUE) // Ergebnis erhalten?
|
|||
|
{
|
|||
|
if(ApiStatusText == "OKAY")
|
|||
|
{
|
|||
|
// Siganturpr<70>fung erfolgreich beendet
|
|||
|
OutputDebugString( 2449, "Siganturpruefung erfolgreich beendet");
|
|||
|
OkayErhalten = TRUE;
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
if (ApiStatusText == "ROUTINE_NOT_COMPLETE")
|
|||
|
{
|
|||
|
if (RoutineNotCompleteErhalten == FALSE)
|
|||
|
{
|
|||
|
// Ein RoutineNotComplete erhalten
|
|||
|
OutputDebugString( 2459, "Ein RoutineNotComplete bei Siganturpruefung erhalten");
|
|||
|
RoutineNotCompleteErhalten = TRUE;
|
|||
|
|
|||
|
}
|
|||
|
// else
|
|||
|
// {
|
|||
|
//
|
|||
|
// OutputDebugString( 2466, "Wiederholtes RoutineNotComplete bei Authentisierung erhalten");
|
|||
|
// // kein Abbruch bei wiederholtem RoutineNotComplete
|
|||
|
// // TestApiFehler(COAPI_ECU_AUTHENTICATION_ERROR, ProcName, 2468, SgbdName + ", NG_AUTHENTISIERUNG_START (...)");
|
|||
|
// }
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
if (ApiStatusText == "NO_RESPONSE")
|
|||
|
{
|
|||
|
if (RoutineNotCompleteErhalten == FALSE)
|
|||
|
{
|
|||
|
// Auf ersten Job weder ein RoutineNotComplete noch eine andere Antwort erhalten
|
|||
|
OutputDebugString( 2478, "Auf ersten Job bei Siganturpruefung weder ein RoutineNotComplete noch eine andere Antwort erhalten");
|
|||
|
TestApiFehler(COAPI_ECU_SIGNATUR_ERROR, ProcName, 2479, SgbdName + ", NG_SIGNATUR_PRUEFEN (" + SignaturBereich + ")");
|
|||
|
|
|||
|
}
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
// Fehler im Ablauf, bei etwas anderem als "NO_RESPONSE" (&& "ROUTINE_NOT_COMPLETE")
|
|||
|
// if (ApiStatusText == "ERROR_SG_RESPONSE")
|
|||
|
// OutputDebugString( 2487, "Bei Authentisierung keine brauchbare Antwort vom SG erhalten");
|
|||
|
// else if (ApiStatusText == "ERROR_ERROR_AUTHENTICATION")
|
|||
|
// OutputDebugString( 2489, "Bei Authentisierung negative Antwort vom SG erhalten");
|
|||
|
// else
|
|||
|
// OutputDebugString( 2491, "Bei Authentisierung unbekannten JOB_STATUS erhalten");
|
|||
|
// Entsprechende Fehlerbehandlung einleiten
|
|||
|
TestApiFehler(COAPI_ECU_SIGNATUR_ERROR, ProcName, 2493, SgbdName + ", NG_SIGNATUR_PRUEFEN (" + SignaturBereich + ")");
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
TPfaelligCounter = TPfaelligCounter + 1;
|
|||
|
if (TPfaelligCounter == 3) {
|
|||
|
TesterPresentHandling(ProcName, SgbdName, TRUE);
|
|||
|
TPfaelligCounter = 0;
|
|||
|
// // Verz<72>gerung vom Bus einberechnen
|
|||
|
// if (DIREKT_MOST_PROG == TRUE)
|
|||
|
// PollingWarteZeit = PollingWarteZeit - 400;
|
|||
|
// else
|
|||
|
// PollingWarteZeit = PollingWarteZeit - 800;
|
|||
|
}
|
|||
|
|
|||
|
// PollingWarteZeit warten
|
|||
|
CDHDelay(PollingWarteZeit);
|
|||
|
PollingWarteZeit = 1000;
|
|||
|
|
|||
|
} // end of else of if(ApiStatusText == "OKAY")
|
|||
|
}
|
|||
|
else
|
|||
|
{ // kein Ergebnis erhalten
|
|||
|
|
|||
|
// Fehler im Aufruf der Signaturpr<70>fung
|
|||
|
OutputDebugString( 2518, "Fehler im Aufruf der Signaturpruefung");
|
|||
|
// Entsprechende Fehlerbehandlung einleiten
|
|||
|
TestApiFehler(COAPI_ECU_SIGNATUR_ERROR, ProcName, 2520, SgbdName + ", NG_SIGNATUR_PRUEFEN (" + SignaturBereich + ")");
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
testtimer(3, SignaturTestZeitAbgelaufen);
|
|||
|
|
|||
|
} // end of while ((OkayErhalten == FALSE) && (SignaturTestZeitAbgelaufen == FALSE))
|
|||
|
|
|||
|
if (OkayErhalten == FALSE)
|
|||
|
{
|
|||
|
OutputDebugString( 2530, "Ueberschreitung der Siganturpruefungszeit");
|
|||
|
// <20>berschreitung der Siganturpr<70>fungszeit also entsprechende Fehlerbehandlung einleiten
|
|||
|
TestApiFehler(COAPI_ECU_SIGNATUR_ERROR, ProcName, 2532, SgbdName + ", NG_SIGNATUR_PRUEFEN (" + SignaturBereich + ")");
|
|||
|
// Fehlertext und -code nach Vorgabe setzten
|
|||
|
// CDHSetError(COAPI_ECU_SIGNATUR_ERROR, ModulName, ProcName, 0, SgbdName + ", NG_SIGNATUR_PRUEFEN (" + SignaturBereich + "): " + ApiStatusText);
|
|||
|
// CDHSetReturnVal(COAPI_ECU_SIGNATUR_ERROR);
|
|||
|
// exit();
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
//*************************************************************
|
|||
|
//*
|
|||
|
//* Name : LoescheFlash
|
|||
|
//*
|
|||
|
//* Funktion : Loeschen des angegebenen Speicherbereichs
|
|||
|
//*
|
|||
|
//* Parameter : SgbdName - Name der verwendeten SGBD
|
|||
|
//* Buffer - BinBuffer mit Beschreibung des Speicherbereichs
|
|||
|
//* BufferSize - Groesse des BinBuffers
|
|||
|
//* LoeschZeit - LoeschZeit des SG
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//*************************************************************
|
|||
|
//* History :
|
|||
|
//* 28.09.2005 V8.00 MH Ersterstellung
|
|||
|
//*************************************************************
|
|||
|
LoescheFlash(in: string SgbdName, in: int Buffer, in: int BufferSize, in: int LoeschZeit)
|
|||
|
{
|
|||
|
string ProcName = "LoescheFlash";
|
|||
|
|
|||
|
bool rc;
|
|||
|
string ApiStatusText;
|
|||
|
|
|||
|
bool RoutineNotCompleteErhalten = FALSE;
|
|||
|
bool OkayErhalten = FALSE;
|
|||
|
|
|||
|
bool LoeschZeitAbgelaufen;
|
|||
|
int PollingWarteZeit = 2000;
|
|||
|
int TPfaelligCounter = 0;
|
|||
|
|
|||
|
// Sende erzwungenes TP (damit, wenn RespPend auf Flashl<68>schen kommt, kein Timeout entsteht)
|
|||
|
TesterPresentHandling(ProcName, SgbdName, TRUE);
|
|||
|
|
|||
|
settimer(3, (LoeschZeit * 1000) + 1000); // LoeschZeit + 1 Sekunde zus<75>tzlich
|
|||
|
testtimer(3, LoeschZeitAbgelaufen);
|
|||
|
|
|||
|
// Polling solange kein Okay erhalten und die FlashLoeschzeit nicht vergangen ist
|
|||
|
while ((OkayErhalten == FALSE) && (LoeschZeitAbgelaufen == FALSE))
|
|||
|
{
|
|||
|
CDHapiJobData (SgbdName, "NG_FLASH_LOESCHEN", Buffer, BufferSize, "");
|
|||
|
// existiert JOB_STATUS bzw. hat SG geantwortet ?
|
|||
|
apiResultText(rc, ApiStatusText, "JOB_STATUS", 1, "");
|
|||
|
if(rc == TRUE) // Ergebnis erhalten?
|
|||
|
{
|
|||
|
if(ApiStatusText == "OKAY")
|
|||
|
{
|
|||
|
// FlashLoeschen erfolgreich beendet
|
|||
|
OutputDebugString( 2588, "FlashLoeschen erfolgreich beendet");
|
|||
|
OkayErhalten = TRUE;
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
if (ApiStatusText == "ROUTINE_NOT_COMPLETE")
|
|||
|
{
|
|||
|
if (RoutineNotCompleteErhalten == FALSE)
|
|||
|
{
|
|||
|
// Ein RoutineNotComplete erhalten
|
|||
|
OutputDebugString( 2598, "Ein RoutineNotComplete bei FlashLoeschen erhalten");
|
|||
|
RoutineNotCompleteErhalten = TRUE;
|
|||
|
|
|||
|
}
|
|||
|
// else
|
|||
|
// {
|
|||
|
//
|
|||
|
// OutputDebugString( 2605, "Wiederholtes RoutineNotComplete bei Authentisierung erhalten");
|
|||
|
// // kein Abbruch bei wiederholtem RoutineNotComplete
|
|||
|
// // TestApiFehler(COAPI_ECU_AUTHENTICATION_ERROR, ProcName, 2607, SgbdName + ", NG_AUTHENTISIERUNG_START (...)");
|
|||
|
// }
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
if (ApiStatusText == "NO_RESPONSE")
|
|||
|
{
|
|||
|
if (RoutineNotCompleteErhalten == FALSE)
|
|||
|
{
|
|||
|
// Auf ersten Job weder ein RoutineNotComplete noch eine andere Antwort erhalten
|
|||
|
OutputDebugString( 2617, "Auf ersten Job bei FlashLoeschen weder ein RoutineNotComplete noch eine andere Antwort erhalten");
|
|||
|
TestApiFehler(COAPI_ECU_FLASH_ERASE_ERROR, ProcName, 2618, SgbdName + ", NG_FLASH_LOESCHEN (...)");
|
|||
|
}
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
// Fehler im Ablauf, bei etwas anderem als "NO_RESPONSE" (&& "ROUTINE_NOT_COMPLETE")
|
|||
|
// if (ApiStatusText == "ERROR_SG_RESPONSE")
|
|||
|
// OutputDebugString( 2625, "Bei Authentisierung keine brauchbare Antwort vom SG erhalten");
|
|||
|
// else if (ApiStatusText == "ERROR_ERROR_AUTHENTICATION")
|
|||
|
// OutputDebugString( 2627, "Bei Authentisierung negative Antwort vom SG erhalten");
|
|||
|
// else
|
|||
|
// OutputDebugString( 2629, "Bei Authentisierung unbekannten JOB_STATUS erhalten");
|
|||
|
// Entsprechende Fehlerbehandlung einleiten
|
|||
|
TestApiFehler(COAPI_ECU_FLASH_ERASE_ERROR, ProcName, 2631, SgbdName + ", NG_FLASH_LOESCHEN (...)");
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
TPfaelligCounter = TPfaelligCounter + 1;
|
|||
|
if (TPfaelligCounter == 3) {
|
|||
|
TesterPresentHandling(ProcName, SgbdName, TRUE);
|
|||
|
TPfaelligCounter = 0;
|
|||
|
// // Verz<72>gerung vom Bus einberechnen
|
|||
|
// if (DIREKT_MOST_PROG == TRUE)
|
|||
|
// PollingWarteZeit = PollingWarteZeit - 400;
|
|||
|
// else
|
|||
|
// PollingWarteZeit = PollingWarteZeit - 800;
|
|||
|
}
|
|||
|
|
|||
|
// PollingWarteZeit warten
|
|||
|
CDHDelay(PollingWarteZeit);
|
|||
|
PollingWarteZeit = 1000;
|
|||
|
|
|||
|
} // end of else of if(ApiStatusText == "OKAY")
|
|||
|
|
|||
|
} else { // kein Ergebnis erhalten
|
|||
|
|
|||
|
// Fehler im Aufruf des FlashLoeschens
|
|||
|
OutputDebugString( 2655, "Fehler im Aufruf des FlashLoeschens");
|
|||
|
// Entsprechende Fehlerbehandlung einleiten
|
|||
|
TestApiFehler(COAPI_ECU_FLASH_ERASE_ERROR, ProcName, 2657, SgbdName + ", NG_FLASH_LOESCHEN (...)");
|
|||
|
}
|
|||
|
|
|||
|
testtimer(3, LoeschZeitAbgelaufen);
|
|||
|
|
|||
|
} // end of while ((OkayErhalten == FALSE) && (LoeschZeitAbgelaufen == FALSE))
|
|||
|
|
|||
|
if (OkayErhalten == FALSE)
|
|||
|
{
|
|||
|
OutputDebugString( 2666, "Ueberschreitung der FlashLoeschzeit");
|
|||
|
// <20>berschreitung der FlashLoeschzeit also entsprechende Fehlerbehandlung einleiten
|
|||
|
TestApiFehler(COAPI_ECU_FLASH_ERASE_ERROR, ProcName, 2668, SgbdName + ", NG_FLASH_LOESCHEN (...)");
|
|||
|
// Fehlertext und -code nach Vorgabe setzten
|
|||
|
// CDHSetError(COAPI_ECU_FLASH_ERASE_ERROR, ModulName, ProcName, 0, SgbdName + ", NG_FLASH_LOESCHEN (...): " + ApiStatusText);
|
|||
|
// CDHSetReturnVal(COAPI_ECU_FLASH_ERASE_ERROR);
|
|||
|
// exit();
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
//*************************************************************
|
|||
|
//*
|
|||
|
//* Name : Authentisierung
|
|||
|
//*
|
|||
|
//* Funktion : Authentisierung
|
|||
|
//*
|
|||
|
//* Parameter : SgbdName - Name der verwendeten SGBD
|
|||
|
//* AuthentisierungZeit - Authentisierungszeit des SG
|
|||
|
//* TestKey - Testschluesselauthentisierung
|
|||
|
//* NoExit - kein Abbruch nach negativer Resp auf Authentisierung
|
|||
|
//* RetVal
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//*************************************************************
|
|||
|
//* History :
|
|||
|
//* 18.10.2004 V6.00 KuS Ersterstellung
|
|||
|
//* 28.09.2005 V8.00 MH Polling mit TesterPresent bei Freischalten implementiert
|
|||
|
//*************************************************************
|
|||
|
Authentisierung(in: string SgbdName, in : int AuthentisierungZeit,
|
|||
|
in: bool TestKey, in : bool NoExit, out: int RetVal)
|
|||
|
{
|
|||
|
string ProcName = "Authentisierung";
|
|||
|
string AUTHENTISIERUNGS_LEVEL = "3";
|
|||
|
int AuthentisierungZufallsZahl;
|
|||
|
string AuthentisierungArt;
|
|||
|
int AuthentisierungSchluessel;
|
|||
|
int AuthentisierungSchluesselLaenge;
|
|||
|
int AuthentisierungBuffer;
|
|||
|
string Key;
|
|||
|
string UserIdSGBD;
|
|||
|
string UserId;
|
|||
|
string SgSerienNr;
|
|||
|
|
|||
|
bool rc;
|
|||
|
string ApiStatusText;
|
|||
|
|
|||
|
bool RoutineNotCompleteErhalten = FALSE;
|
|||
|
bool AntwortErhalten = FALSE;
|
|||
|
|
|||
|
bool AuthentisierungZeitAbgelaufen;
|
|||
|
int PollingWarteZeit = 2000;
|
|||
|
int TPfaelligCounter = 0;
|
|||
|
|
|||
|
int Status = 0;
|
|||
|
int STATUS_NO_ERROR = 0;
|
|||
|
int STATUS_ERROR = -1;
|
|||
|
|
|||
|
CDHapiJob(SgbdName, "SERIENNUMMER_LESEN", "", "");
|
|||
|
TestApiFehler(COAPI_ECU_TIMEOUT, ProcName, 2726, SgbdName + ", SERIENNUMMER_LESEN");
|
|||
|
CDHapiResultText(SgSerienNr, "SERIENNUMMER", 1, "");
|
|||
|
// nur die Zeichen 5-8 + terminierungs-Null benutzen
|
|||
|
midstr(SgSerienNr,SgSerienNr,5,5);
|
|||
|
OutputDebugString( 2730, "SgSerienNr : "+SgSerienNr);
|
|||
|
|
|||
|
// Zufallszahlen holen
|
|||
|
CDHAuthGetRandom(UserId,UserIdSGBD);
|
|||
|
|
|||
|
TesterPresentHandling(ProcName, SgbdName, FALSE);
|
|||
|
|
|||
|
CDHapiJob(SgbdName, "AUTHENTISIERUNG_ZUFALLSZAHL_LESEN", AUTHENTISIERUNGS_LEVEL+";"+UserIdSGBD, "");
|
|||
|
TestApiFehler(COAPI_ECU_TIMEOUT, ProcName, 2738, SgbdName + ", AUTHENTISIERUNG_ZUFALLSZAHL_LESEN (3;"+UserIdSGBD+")");
|
|||
|
|
|||
|
// Erzeugen Buffer fuer Authentisierungs Zufallszahl
|
|||
|
CDHBinBufCreate(AuthentisierungZufallsZahl,Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
CDHapiResultBinary(AuthentisierungZufallsZahl, "ZUFALLSZAHL", 1, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
CDHapiResultText(AuthentisierungArt, "AUTHENTISIERUNG", 1,"");
|
|||
|
OutputDebugString( 2748, "Authentisierungsart : "+AuthentisierungArt);
|
|||
|
|
|||
|
// Schluessel auswaehlen
|
|||
|
if (TRUE == TestKey)
|
|||
|
{
|
|||
|
// Testschluessel verwenden
|
|||
|
Key="??";
|
|||
|
if (AuthentisierungArt=="Asymetrisch")
|
|||
|
Key="T_SMA";
|
|||
|
if (AuthentisierungArt=="Symetrisch")
|
|||
|
Key="T_SMB";
|
|||
|
if (AuthentisierungArt=="Simple")
|
|||
|
Key="T_SMC";
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
// SGFamilie verwenden
|
|||
|
Key = SGFamilie;
|
|||
|
}
|
|||
|
OutputDebugString( 2767, "Key : " + Key);
|
|||
|
|
|||
|
// Erzeugen Buffer fuer Authentisierungs Schl<68>ssel
|
|||
|
CDHBinBufCreate(AuthentisierungSchluessel,Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
CDHCallAuthenticate(Key, UserId, SgSerienNr,
|
|||
|
AuthentisierungArt,
|
|||
|
AuthentisierungZufallsZahl,
|
|||
|
AUTHENTISIERUNGS_LEVEL,
|
|||
|
AuthentisierungSchluessel,
|
|||
|
AuthentisierungSchluesselLaenge,
|
|||
|
Status);
|
|||
|
|
|||
|
if (Status != STATUS_NO_ERROR)
|
|||
|
TestCDHFehler(COAPI_ECU_AUTHENTICATION_FORMAT_ERROR);
|
|||
|
|
|||
|
OutputDebugInt( 2784, "Schluessellaenge ",AuthentisierungSchluesselLaenge);
|
|||
|
|
|||
|
// Erzeugen Buffer fuer Authentisierungs Buffer
|
|||
|
CDHBinBufCreate(AuthentisierungBuffer,Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufWriteByte(AuthentisierungBuffer, 1, 0, Status);
|
|||
|
CDHBinBufWriteByte(AuthentisierungBuffer, AuthentisierungZeit, 4, Status);
|
|||
|
CDHBinBufWriteByte(AuthentisierungBuffer, AuthentisierungSchluesselLaenge, 13, Status);
|
|||
|
CDHBinBufWriteByte(AuthentisierungBuffer, 0, 14, Status);
|
|||
|
|
|||
|
CDHBinBufWriteByte(AuthentisierungBuffer, 3, 21 + AuthentisierungSchluesselLaenge, Status); // ETX setzen (03h)
|
|||
|
|
|||
|
// AuthentisierungSchluessel nach AuthentisierungBuffer kopieren
|
|||
|
CDHBinBufCopy(AuthentisierungSchluessel, AuthentisierungBuffer, 0, 21, AuthentisierungSchluesselLaenge, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
// ------------------------------------------------------
|
|||
|
// Polling mit TP
|
|||
|
|
|||
|
// Sende erzwungenes TP (damit, wenn RespPend auf Freischalten kommt, kein Timeout entsteht)
|
|||
|
TesterPresentHandling(ProcName, SgbdName, TRUE);
|
|||
|
|
|||
|
settimer(3, (AuthentisierungZeit * 1000) + 1000); // AuthentisierungsZeit + 1 Sekunde zus<75>tzlich
|
|||
|
testtimer(3, AuthentisierungZeitAbgelaufen);
|
|||
|
|
|||
|
// Polling solange kein Okay erhalten und die Authentisierungszeit nicht vergangen ist
|
|||
|
while ((AntwortErhalten == FALSE) && (AuthentisierungZeitAbgelaufen == FALSE))
|
|||
|
{
|
|||
|
CDHapiJobData (SgbdName, "NG_AUTHENTISIERUNG_START", AuthentisierungBuffer, 21+AuthentisierungSchluesselLaenge, "");
|
|||
|
// existiert JOB_STATUS bzw. hat SG geantwortet ?
|
|||
|
apiResultText(rc, ApiStatusText, "JOB_STATUS", 1, "");
|
|||
|
if(rc == TRUE) // Ergebnis erhalten?
|
|||
|
{
|
|||
|
if(ApiStatusText == "OKAY")
|
|||
|
{
|
|||
|
// Authentisieren erfolgreich beendet
|
|||
|
OutputDebugString( 2820, "Authentisierung erfolgreich beendet");
|
|||
|
AntwortErhalten = TRUE;
|
|||
|
|
|||
|
}
|
|||
|
else if ((ApiStatusText == "ERROR_ERROR_AUTHENTICATION") && (NoExit == TRUE))
|
|||
|
{
|
|||
|
|
|||
|
// Authentisieren erfolglos beendet, aber es soll nicht abgebrochen werden
|
|||
|
OutputDebugString( 2828, "Authentisierung erfolglos beendet, aber es soll nicht abgebrochen werden");
|
|||
|
AntwortErhalten = TRUE;
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
if (ApiStatusText == "ROUTINE_NOT_COMPLETE")
|
|||
|
{
|
|||
|
if (RoutineNotCompleteErhalten == FALSE)
|
|||
|
{
|
|||
|
// Ein RoutineNotComplete erhalten
|
|||
|
OutputDebugString( 2838, "Ein RoutineNotComplete bei Authentisierung erhalten");
|
|||
|
RoutineNotCompleteErhalten = TRUE;
|
|||
|
}
|
|||
|
// else
|
|||
|
// {
|
|||
|
//
|
|||
|
// OutputDebugString( 2844, "Wiederholtes RoutineNotComplete bei Authentisierung erhalten");
|
|||
|
// // kein Abbruch bei wiederholtem RoutineNotComplete
|
|||
|
// // TestApiFehler(COAPI_ECU_AUTHENTICATION_ERROR, ProcName, 2846, SgbdName + ", NG_AUTHENTISIERUNG_START (...)");
|
|||
|
// }
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
if (ApiStatusText == "NO_RESPONSE")
|
|||
|
{
|
|||
|
if (RoutineNotCompleteErhalten == FALSE)
|
|||
|
{
|
|||
|
// Auf ersten Job weder ein RoutineNotComplete noch eine andere Antwort erhalten
|
|||
|
OutputDebugString( 2856, "Auf ersten Job bei Authentisierung weder ein RoutineNotComplete noch eine andere Antwort erhalten");
|
|||
|
TestApiFehler(COAPI_ECU_AUTHENTICATION_ERROR, ProcName, 2857, SgbdName + ", NG_AUTHENTISIERUNG_START (...)");
|
|||
|
}
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
// Fehler im Ablauf, bei etwas anderem als "NO_RESPONSE" (&& "ROUTINE_NOT_COMPLETE")
|
|||
|
// if (ApiStatusText == "ERROR_SG_RESPONSE")
|
|||
|
// OutputDebugString( 2864, "Bei Authentisierung keine brauchbare Antwort vom SG erhalten");
|
|||
|
// else if (ApiStatusText == "ERROR_ERROR_AUTHENTICATION")
|
|||
|
// OutputDebugString( 2866, "Bei Authentisierung negative Antwort vom SG erhalten");
|
|||
|
// else
|
|||
|
// OutputDebugString( 2868, "Bei Authentisierung unbekannten JOB_STATUS erhalten");
|
|||
|
// Entsprechende Fehlerbehandlung einleiten
|
|||
|
TestApiFehler(COAPI_ECU_AUTHENTICATION_ERROR, ProcName, 2870, SgbdName + ", NG_AUTHENTISIERUNG_START (...)");
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
TPfaelligCounter = TPfaelligCounter + 1;
|
|||
|
if (TPfaelligCounter == 3) {
|
|||
|
TesterPresentHandling(ProcName, SgbdName, TRUE);
|
|||
|
TPfaelligCounter = 0;
|
|||
|
// // Verz<72>gerung vom Bus einberechnen
|
|||
|
// if (DIREKT_MOST_PROG == TRUE)
|
|||
|
// PollingWarteZeit = PollingWarteZeit - 400;
|
|||
|
// else
|
|||
|
// PollingWarteZeit = PollingWarteZeit - 800;
|
|||
|
}
|
|||
|
|
|||
|
// PollingWarteZeit warten
|
|||
|
CDHDelay(PollingWarteZeit);
|
|||
|
PollingWarteZeit = 1000;
|
|||
|
|
|||
|
} // end of else of if((ApiStatusText == "ERROR_ERROR_AUTHENTICATION") && (NoExit == TRUE))
|
|||
|
}
|
|||
|
else
|
|||
|
{ // kein Ergebnis erhalten
|
|||
|
|
|||
|
// Fehler im Aufruf der Authentisierung
|
|||
|
OutputDebugString( 2895, "Fehler im Aufruf der Authentisierung");
|
|||
|
// Entsprechende Fehlerbehandlung einleiten
|
|||
|
TestApiFehler(COAPI_ECU_AUTHENTICATION_ERROR, ProcName, 2897, SgbdName + ", NG_AUTHENTISIERUNG_START (...)");
|
|||
|
}
|
|||
|
|
|||
|
testtimer(3, AuthentisierungZeitAbgelaufen);
|
|||
|
|
|||
|
} // end of while ((AntwortErhalten == FALSE) && (AuthentisierungZeitAbgelaufen == FALSE))
|
|||
|
|
|||
|
if (AntwortErhalten == FALSE) // ACHUTNG: Keine Antwort f<>hrt auch bei (NoExit == FALSE) zum Abbruch!
|
|||
|
{
|
|||
|
OutputDebugString( 2906, "Ueberschreitung der AuthentisierungZeit");
|
|||
|
// <20>berschreitung der AuthentisierungZeit, also entsprechende Fehlerbehandlung einleiten
|
|||
|
TestApiFehler(COAPI_ECU_AUTHENTICATION_ERROR, ProcName, 2908, SgbdName + ", NG_AUTHENTISIERUNG_START (...)");
|
|||
|
// Fehlertext und -code nach Vorgabe setzten
|
|||
|
// CDHSetError(COAPI_ECU_AUTHENTICATION_ERROR, ModulName, ProcName, 0, SgbdName + ", NG_AUTHENTISIERUNG_START (...): " + ApiStatusText);
|
|||
|
// CDHSetReturnVal(COAPI_ECU_AUTHENTICATION_ERROR);
|
|||
|
// exit();
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
TestApiFehlerNoExit(COAPI_ECU_AUTHENTICATION_ERROR, ProcName, 2916, SgbdName + ", AUTHENTISIERUNG_START ( SG-Schluessel ...)", Status);
|
|||
|
}
|
|||
|
|
|||
|
//------------------------------------------------------
|
|||
|
|
|||
|
RetVal = Status;
|
|||
|
|
|||
|
// L<>schen Buffer fuer Authentisierungs Buffer
|
|||
|
CDHBinBufDelete(AuthentisierungBuffer,Status);
|
|||
|
// L<>schen Buffer fuer Authentisierungs Zufallszahl
|
|||
|
CDHBinBufDelete(AuthentisierungZufallsZahl,Status);
|
|||
|
// L<>schen Buffer fuer Authentisierungs Schl<68>ssel
|
|||
|
CDHBinBufDelete(AuthentisierungSchluessel,Status);
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : Programmieren
|
|||
|
//*
|
|||
|
//* Funktion : Programmieren des SG
|
|||
|
//*
|
|||
|
//* Parameter : -
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 19.10.2000 rd V0.01 Ersterstellung
|
|||
|
//* 16.02.2001 rd V1.00 Freigabe
|
|||
|
//* 05.09.2003 KuS V6.00 <20>nderungen 06Flash
|
|||
|
//**********************************************************************
|
|||
|
Programmieren()
|
|||
|
{
|
|||
|
string ProcName = "Programmieren";
|
|||
|
int Status;
|
|||
|
string SgbdName; // Name der verwendeten SGBD die fuer alle Jobs verwendet wird
|
|||
|
|
|||
|
int Index; // Schleiferzaehler Variable
|
|||
|
int IntWert; // Tempor<6F>rer Speicherplatz fuer Byte-Werte
|
|||
|
string StrWert; // Tempor<6F>rer Speicherplatz fuer String-Werte
|
|||
|
string Text; // Tempor<6F>rer Speicherplatz fuer Debug-Texte
|
|||
|
|
|||
|
int Buffer; // Binaerpuffer zur Aufnahme der Programmierdaten
|
|||
|
int StartAdrBuffer; // Binaerpuffer zur Aufnahme der Startadressen der Datenbloecke
|
|||
|
int BlockLengthBuffer;
|
|||
|
int RequestDownloadBuffer;
|
|||
|
|
|||
|
int MaxData;
|
|||
|
int DynMaxData;
|
|||
|
int BufferSize;
|
|||
|
int NrOfData;
|
|||
|
|
|||
|
int ZwischenBuffer;
|
|||
|
int ZwischenBufferSize;
|
|||
|
int ZwischenBufferNrOfData;
|
|||
|
|
|||
|
int BlockCounter;
|
|||
|
bool BlockSchreibenFlag;
|
|||
|
bool FreibrennBlockFlag;
|
|||
|
int AdrSprungFlag;
|
|||
|
bool FreibrennBlockSchreiben = FALSE;
|
|||
|
|
|||
|
int AktuellAdrLow, AktuellAdrMidLow, AktuellAdrMidHigh, AktuellAdrHigh;
|
|||
|
int StartAdrLow, StartAdrMidLow, StartAdrMidHigh, StartAdrHigh;
|
|||
|
int NextAdrLow, NextAdrMidLow, NextAdrMidHigh, NextAdrHigh;
|
|||
|
int DataLengthLow, DataLengthMidLow, DataLengthMidHigh, DataLengthHigh;
|
|||
|
int DataBlockLengthLow, DataBlockLengthMidLow, DataBlockLengthMidHigh, DataBlockLengthHigh;
|
|||
|
int EndDataBlockLengthLow, EndDataBlockLengthMidLow, EndDataBlockLengthMidHigh, EndDataBlockLengthHigh;
|
|||
|
|
|||
|
int LoeschZeit;
|
|||
|
int SignaturTestZeit;
|
|||
|
int ResetZeit;
|
|||
|
int AuthentisierungZeit;
|
|||
|
|
|||
|
int SgStatus;
|
|||
|
|
|||
|
int PROG_WITH_AIF;
|
|||
|
int AifGroesse;
|
|||
|
string AifDaten;
|
|||
|
int AifDatenLen;
|
|||
|
string StringArgument;
|
|||
|
|
|||
|
int BSUTime; // Boot Sektor Update
|
|||
|
|
|||
|
int DataBlockLoopCounter; // Zaehler <20>eber alle Datenblocke
|
|||
|
bool BlockEnd; // Flag fuer die Kennzeichnung eines erkannten Datenblockendes
|
|||
|
int NextByte; // F<>r Implementierung MaxData > 255
|
|||
|
|
|||
|
// OPPS XXL
|
|||
|
int MXBL_STANDARD = 254;
|
|||
|
int MXBL_MOST_XXL = 1002;
|
|||
|
|
|||
|
// WAS Variablen
|
|||
|
int WASBuffer_A_Handle, WASBuffer_B_Handle; // Handle der Buffer fuer WAS
|
|||
|
int WASBuffer_1_Size, WASBuffer_2_Size; // Groe<6F>e der WAS Buffer
|
|||
|
int WASBuffer_1_Pointer, WASBuffer_2_Pointer; // Zeiger auf die WAS Buffer
|
|||
|
int WASBuffer_1_Size_Pointer, WASBuffer_2_Size_Pointer; // Groe<6F>e der WAS Buffer die durch Zeiger bestimmt sind
|
|||
|
bool WASSwitch; // Flag zur Auswahl des richtigen WAS Buffer
|
|||
|
int DEFAULT_BUFFER_SIZE = 22; // Anzahl der in den Bin<69>rpuffern zus<75>tzlich enthaltenen Daten
|
|||
|
int WASOffset; // Anzahl an Bytes die bei einem WAS zur<75>ckgegangen wird.
|
|||
|
// Anzahl der Daten die bei einem WAS von der WAS Startadresse im Datenblock verbleiben
|
|||
|
int RemainingDataBlockLengthLow, RemainingDataBlockLengthMidLow, RemainingDataBlockLengthMidHigh, RemainingDataBlockLengthHigh;
|
|||
|
// Anzahl der Daten die im Datenblock erfolgreich <20>bertragen wurden und bei einem WAS nicht wiederholt werden
|
|||
|
int WrittenDataBlockLengthLow, WrittenDataBlockLengthMidLow, WrittenDataBlockLengthMidHigh, WrittenDataBlockLengthHigh;
|
|||
|
// Startadresse fuer WAS
|
|||
|
int WASStartAdrLow, WASStartAdrMidLow, WASStartAdrMidHigh, WASStartAdrHigh;
|
|||
|
|
|||
|
// Schleifenvariablen f<>r wiederholtes PrgStatus_lesen vor WAS
|
|||
|
int WASPrgStatusLesenWiederholung;
|
|||
|
bool WASPrgStatusLesenErfolgreich;
|
|||
|
string WASPrgStatusLesenApiStatusText;
|
|||
|
|
|||
|
//############################################################################################################
|
|||
|
// (1) Initialisierung
|
|||
|
//############################################################################################################
|
|||
|
|
|||
|
SetFlashState(2);
|
|||
|
|
|||
|
|
|||
|
ProgSuccess = FALSE;
|
|||
|
|
|||
|
OutputDebugString( 3037, ProcName);
|
|||
|
CDHapiInit(); // CDH-Initialisierung
|
|||
|
CDHGetSgbdName(SgbdName,Status); // SGBD-Name aus SGET
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
// Erzeugen der dynamischen Puffer
|
|||
|
CDHBinBufCreate(StartAdrBuffer, Status); // Erzeugen des StartAdressDaten-Buffers
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufCreate(BlockLengthBuffer, Status); // Erzeugen des LaengenDaten-Buffers
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufCreate(Buffer, Status); // Erzeugen des Flashdaten-Buffers
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufCreate(ZwischenBuffer, Status); // Erzeugen des Flashdaten-ZwischenBuffers
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
// Programmierzugang ermitteln und ggf. SG-spezifische OPPS-MOST-Parameter setzen
|
|||
|
CheckForOppsAccess(ProcName, SgbdName);
|
|||
|
if(OppsMostAccess == TRUE)
|
|||
|
SetOppsMostParams();
|
|||
|
|
|||
|
// Busruhe Start und Ende festlegen
|
|||
|
if (BUSRUHE_START_PUNKT == "StartDiagnose")
|
|||
|
BusruheStartState = 3;
|
|||
|
else if (BUSRUHE_START_PUNKT == "FlashLoeschen")
|
|||
|
BusruheStartState = 4;
|
|||
|
else if (BUSRUHE_START_PUNKT == "DatenDownload")
|
|||
|
BusruheStartState = 5;
|
|||
|
else
|
|||
|
OutputDebugString( 3065, "BUSRUHE_START_PUNKT hat ung<6E>ltigen Wert \'"+BUSRUHE_START_PUNKT+"\'; Default-Wert wird verwendet!");
|
|||
|
|
|||
|
if (BUSRUHE_ENDE_PUNKT == "DownloadEnde")
|
|||
|
BusruheEndeState = 5;
|
|||
|
else if (BUSRUHE_ENDE_PUNKT == "SignaturPruefen")
|
|||
|
BusruheEndeState = 6;
|
|||
|
else if (BUSRUHE_ENDE_PUNKT == "DiagnoseEnde")
|
|||
|
BusruheEndeState = 8;
|
|||
|
else if (BUSRUHE_ENDE_PUNKT == "Reset")
|
|||
|
BusruheEndeState = 9;
|
|||
|
else
|
|||
|
OutputDebugString( 3076, "BUSRUHE_ENDE_PUNKT hat ung<6E>ltigen Wert \'"+BUSRUHE_ENDE_PUNKT+"\'; Default-Wert wird verwendet!");
|
|||
|
|
|||
|
|
|||
|
|
|||
|
//############################################################################################################
|
|||
|
// (2) Ausgeben von PADB und SGBD Informationen
|
|||
|
//############################################################################################################
|
|||
|
|
|||
|
if (DebugSwitch == TRUE)
|
|||
|
{
|
|||
|
// SGBD Informationen ausgeben
|
|||
|
OutputDebugString( 3087, "SGBD-Name : " + SgbdName);
|
|||
|
CDHapiJob(SgbdName, "INFO", "", "");
|
|||
|
CDHapiResultText(StrWert , "ORIGIN", 1, "");
|
|||
|
OutputDebugString( 3090, "SGBD-Origin : " + StrWert);
|
|||
|
CDHapiResultText(StrWert , "REVISION", 1, "");
|
|||
|
OutputDebugString( 3092, "SGBD-Revision : " + StrWert);
|
|||
|
CDHapiResultText(StrWert , "PACKAGE", 1, "");
|
|||
|
OutputDebugString( 3094, "SGBD-Package : " + StrWert);
|
|||
|
|
|||
|
// PABD Informationen ausgeben
|
|||
|
OutputDebugString( 3097, "PABD-Modulname : " + ModulName);
|
|||
|
OutputDebugString( 3098, "PABD-Revision : " + Revision);
|
|||
|
OutputDebugString( 3099, "PABD-Author : " + Author);
|
|||
|
OutputDebugString( 3100, "PABD-Comment : " + Comment);
|
|||
|
|
|||
|
// PABD Einstellungen ausgeben
|
|||
|
OutputDebugString( 3103, "PABD-SGFamilie : " + SGFamilie);
|
|||
|
OutputDebugInt ( 3104, "PABD-SG_MAXANZAHL_AIF " , SG_MAXANZAHL_AIF);
|
|||
|
OutputDebugInt ( 3105, "PABD-SG_GROESSE_AIF " , SG_GROESSE_AIF);
|
|||
|
OutputDebugInt ( 3106, "PABD-SG_ENDEKENNUNG_AIF " , SG_ENDEKENNUNG_AIF);
|
|||
|
OutputDebugString( 3107, "PABD-SG_AUTHENTISIERUNG : " + SG_AUTHENTISIERUNG);
|
|||
|
OutputDebugBool ( 3108, "PABD-ProgrammUndDaten : " , ProgrammUndDaten);
|
|||
|
OutputDebugString( 3109, "PABD-ProzessorTyp : " + ProzessorTyp);
|
|||
|
OutputDebugBool ( 3110, "PABD-AuffuellenSwitch : " , AuffuellenSwitch);
|
|||
|
OutputDebugBool ( 3111, "PABD-DynamischeMXBL : " , DynamischeMXBL);
|
|||
|
OutputDebugBool ( 3112, "PABD-WiederaufsetzenBlockSwitch : " , WiederaufsetzenBlockSwitch);
|
|||
|
OutputDebugInt ( 3113, "PABD-WartenNachECUProgrammMode " , WartenNachECUProgrammMode);
|
|||
|
OutputDebugBool ( 3114, "PABD-TestSchluesselAuthentisierung: " , TestSchluesselAuthentisierung);
|
|||
|
OutputDebugBool ( 3115, "PABD-WiederaufsetzenSwitch : " , WiederaufsetzenSwitch);
|
|||
|
OutputDebugBool ( 3116, "PABD-SgInnenTemperaturLesen : " , SgInnenTemperaturLesen);
|
|||
|
OutputDebugBool ( 3117, "PABD-SgPhysHwNrLesen : " , SgPhysHwNrLesen);
|
|||
|
OutputDebugBool ( 3118, "PABD-TesterPresentHandlingSwitch : " , TesterPresentHandlingSwitch);
|
|||
|
OutputDebugBool ( 3119, "PABD-DebugSwitch : " , DebugSwitch);
|
|||
|
OutputDebugBool ( 3120, "PABD-DIREKT_MOST_PROG : " , DIREKT_MOST_PROG);
|
|||
|
OutputDebugString( 3121, "PABD-BUSRUHE_START_PUNKT : " + BUSRUHE_START_PUNKT);
|
|||
|
OutputDebugString( 3122, "PABD-BUSRUHE_ENDE_PUNKT : " + BUSRUHE_ENDE_PUNKT);
|
|||
|
OutputDebugInt ( 3123, "MOST: min. Telegrammzwischenzeit " , LL_INTERVAL);
|
|||
|
OutputDebugBool ( 3124, "OPPS: benutzt : " , OppsAccess);
|
|||
|
OutputDebugBool ( 3125, "OPPS: MOST-Zugang benutzt : " , OppsMostAccess);
|
|||
|
}
|
|||
|
|
|||
|
//############################################################################################################
|
|||
|
// (3) Flash Zeiten aus SG auslesen
|
|||
|
//############################################################################################################
|
|||
|
|
|||
|
CDHapiJob(SgbdName, "FLASH_ZEITEN_LESEN", "", "");
|
|||
|
TestApiFehler(COAPI_ECU_TIMES_ERROR, ProcName, 3133, SgbdName + ", FLASH_ZEITEN_LESEN");
|
|||
|
|
|||
|
CDHapiResultInt(LoeschZeit, "FLASH_LOESCHZEIT", 1);
|
|||
|
CDHapiResultInt(SignaturTestZeit, "FLASH_SIGNATURTESTZEIT", 1);
|
|||
|
CDHapiResultInt(ResetZeit, "FLASH_RESETZEIT", 1);
|
|||
|
CDHapiResultInt(AuthentisierungZeit, "FLASH_AUTHENTISIERZEIT", 1);
|
|||
|
|
|||
|
OutputDebugInt( 3140, "LoeschZeit ", LoeschZeit);
|
|||
|
OutputDebugInt( 3141, "SignaturTestZeit ", SignaturTestZeit);
|
|||
|
OutputDebugInt( 3142, "ResetZeit ", ResetZeit);
|
|||
|
OutputDebugInt( 3143, "AuthentisierungZeit", AuthentisierungZeit);
|
|||
|
|
|||
|
|
|||
|
//############################################################################################################
|
|||
|
// (4) Programmierstatus abfragen
|
|||
|
//############################################################################################################
|
|||
|
|
|||
|
CDHapiJob(SgbdName, "FLASH_PROGRAMMIER_STATUS_LESEN", "", "FLASH_PROGRAMMIER_STATUS");
|
|||
|
// MK: Fehlerhandling <20>berarbeitet
|
|||
|
TestApiFehler(COAPI_ECU_PROG_STATUS_ERROR, ProcName, 3152, SgbdName + ", FLASH_PROGRAMMIER_STATUS_LESEN");
|
|||
|
|
|||
|
CDHapiResultInt(SgStatus, "FLASH_PROGRAMMIER_STATUS", 1);
|
|||
|
OutputDebugInt( 3155, "ProgrammierStatus vor der Programmierung ", SgStatus);
|
|||
|
// ProgStatus auswerten
|
|||
|
if ((SgStatus >= 0x10) && (SgStatus <= 0x7F))
|
|||
|
{
|
|||
|
SetCDHFehler(COAPI_ECU_PROG_STATUS_ERROR, ProcName, 3159, SgbdName + ", FLASH_PROGRAMMIER_STATUS_LESEN");
|
|||
|
}
|
|||
|
if (SgStatus >= 0x80)
|
|||
|
SgStatus = 0x01; // F<>r Zulieferer reserviert - Interpretation wie 0x01
|
|||
|
if ((SgStatus != 0x01) && (SgStatus != 0x00) && (SgStatus != 0x0F))
|
|||
|
{
|
|||
|
// STEUERGERAET ist im Boot-Modus
|
|||
|
// Reset der Statemachine
|
|||
|
SGReset(SgbdName, ResetZeit);
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
//############################################################################################################
|
|||
|
// (5) Blockl<6B>nge lesen
|
|||
|
//############################################################################################################
|
|||
|
|
|||
|
CDHapiJob(SgbdName, "FLASH_BLOCKLAENGE_LESEN", "", "FLASH_BLOCKLAENGE_GESAMT");
|
|||
|
TestApiFehler(COAPI_ECU_MXBL_ERROR, ProcName, 3176, SgbdName + ", FLASH_BLOCKLAENGE_LESEN");
|
|||
|
CDHapiResultInt(MaxData, "FLASH_BLOCKLAENGE_GESAMT", 1 );
|
|||
|
|
|||
|
if(MaxData < 0)
|
|||
|
MaxData = MaxData + 65536; // MaxData > 0x8000
|
|||
|
|
|||
|
MaxData = MaxData - 1; // Service ID wird nicht gezaehlt
|
|||
|
|
|||
|
// MK: OppsMostAccess verwendet
|
|||
|
if(MaxData > MXBL_STANDARD) // MXBL > 0x00FF
|
|||
|
{
|
|||
|
if(OppsMostAccess == TRUE)
|
|||
|
{
|
|||
|
if(MaxData > MXBL_MOST_XXL)
|
|||
|
{
|
|||
|
MaxData = MXBL_MOST_XXL;
|
|||
|
}
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
MaxData = MXBL_STANDARD; // Programmierung nicht <20>ber OPPS-MOST-Zugang
|
|||
|
}
|
|||
|
}
|
|||
|
OutputDebugInt( 3199, "MXBL ",MaxData);
|
|||
|
|
|||
|
|
|||
|
SetFlashState(3);
|
|||
|
|
|||
|
//############################################################################################################
|
|||
|
// (6) Block-Informationen berechnen
|
|||
|
//############################################################################################################
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
// Laenge & Anfangsadressen der Datenbloecke ohne Adressenluecken ermitteln
|
|||
|
// Start
|
|||
|
//**********************************************************************
|
|||
|
// ersten Datenblock holen
|
|||
|
CDHGetApiJobByteData(MaxData, Buffer, BufferSize, NrOfData, Status);
|
|||
|
|
|||
|
if (NrOfData == 0)
|
|||
|
{
|
|||
|
Status = COAPI_READ_INPUT_FILE_ERROR;
|
|||
|
}
|
|||
|
|
|||
|
BlockCounter = 0;
|
|||
|
BlockSchreibenFlag = TRUE;
|
|||
|
|
|||
|
DataBlockLengthLow = 0;
|
|||
|
DataBlockLengthMidLow = 0;
|
|||
|
DataBlockLengthMidHigh = 0;
|
|||
|
DataBlockLengthHigh = 0;
|
|||
|
|
|||
|
DataLengthLow = 0;
|
|||
|
DataLengthMidLow = 0;
|
|||
|
DataLengthMidHigh = 0;
|
|||
|
DataLengthHigh = 0;
|
|||
|
|
|||
|
while (NrOfData > 0)
|
|||
|
{
|
|||
|
// Startadresse bestimmen
|
|||
|
CDHBinBufReadByte(Buffer, AktuellAdrLow, 17, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufReadByte(Buffer, AktuellAdrMidLow, 18, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufReadByte(Buffer, AktuellAdrMidHigh, 19, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufReadByte(Buffer, AktuellAdrHigh, 20, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
StartAdrLow = AktuellAdrLow;
|
|||
|
StartAdrMidLow = AktuellAdrMidLow;
|
|||
|
StartAdrMidHigh = AktuellAdrMidHigh;
|
|||
|
StartAdrHigh = AktuellAdrHigh;
|
|||
|
|
|||
|
NextAdrLow = AktuellAdrLow; // fuer Erkennung auf Datenblockende
|
|||
|
NextAdrMidLow = AktuellAdrMidLow;
|
|||
|
NextAdrMidHigh = AktuellAdrMidHigh;
|
|||
|
NextAdrHigh = AktuellAdrHigh;
|
|||
|
|
|||
|
// Laenge des Datenblocks feststellen
|
|||
|
AdrSprungFlag = 0;
|
|||
|
FreibrennBlockFlag = FALSE;
|
|||
|
while (AdrSprungFlag != 1)
|
|||
|
{
|
|||
|
// Naechste Adresse Berechnen
|
|||
|
AddWordToDWord(NextAdrLow, NextAdrMidLow, NextAdrMidHigh, NextAdrHigh, NrOfData);
|
|||
|
|
|||
|
// Laenge des Datenblocks
|
|||
|
AddWordToDWord(DataBlockLengthLow, DataBlockLengthMidLow, DataBlockLengthMidHigh, DataBlockLengthHigh, NrOfData);
|
|||
|
|
|||
|
// Naechsten Datenblock lesen
|
|||
|
CDHGetApiJobByteData (MaxData, Buffer, BufferSize, NrOfData, Status); // Daten holen
|
|||
|
TestCDHFehler (Status);
|
|||
|
|
|||
|
CDHBinBufReadByte(Buffer,AktuellAdrLow, 17, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufReadByte(Buffer,AktuellAdrMidLow, 18, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufReadByte(Buffer,AktuellAdrMidHigh, 19, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufReadByte(Buffer,AktuellAdrHigh, 20, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
// Ueberpruefung auf Adressluecke
|
|||
|
if ((NextAdrLow == AktuellAdrLow) && // keine Luecke
|
|||
|
(NextAdrMidLow == AktuellAdrMidLow) && // keine Luecke
|
|||
|
(NextAdrMidHigh == AktuellAdrMidHigh) && // keine Luecke
|
|||
|
(NextAdrHigh == AktuellAdrHigh)) // keine Luecke
|
|||
|
{
|
|||
|
AdrSprungFlag = 0; // keine Luecke
|
|||
|
|
|||
|
// Sonderbehandlung Segmentwechsel
|
|||
|
if (ProzessorTyp == "HC12DG128")
|
|||
|
{
|
|||
|
if ((NextAdrLow == 0x00) &&
|
|||
|
((NextAdrMidLow == 0x40) || (NextAdrMidLow == 0x80) || (NextAdrMidLow == 0xC0)) &&
|
|||
|
(NextAdrMidHigh == 0x00) &&
|
|||
|
(NextAdrHigh == 0x00))
|
|||
|
{
|
|||
|
hexstring(NextAdrMidLow, StrWert);
|
|||
|
OutputDebugString( 3296, "Segmentwechsel bei 00:" + StrWert + ":00");
|
|||
|
AdrSprungFlag = 1; // Segmentwechsel
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
if ((StartAdrLow == AktuellAdrLow) && // Freibrennblock
|
|||
|
(StartAdrMidLow == AktuellAdrMidLow) && // fuer Flash
|
|||
|
(StartAdrMidHigh == AktuellAdrMidHigh) && // (Lauter 0xFF)
|
|||
|
(StartAdrHigh == AktuellAdrHigh))
|
|||
|
{
|
|||
|
AdrSprungFlag = 1; // Freibrennblock erkannt
|
|||
|
FreibrennBlockFlag = TRUE;
|
|||
|
if (FreibrennBlockSchreiben == TRUE)
|
|||
|
{
|
|||
|
BlockSchreibenFlag = TRUE;
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
BlockSchreibenFlag = FALSE;
|
|||
|
}
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
AdrSprungFlag = 1; // echte Adressluecke
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
if (NrOfData==0)
|
|||
|
{
|
|||
|
AdrSprungFlag = 1; // Datenende
|
|||
|
}
|
|||
|
|
|||
|
} // end of while (AdrSprungFlag != 1)
|
|||
|
|
|||
|
// Startadressen im Buffer merken
|
|||
|
CDHBinBufWriteByte(StartAdrBuffer,StartAdrLow, (4*BlockCounter), Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufWriteByte(StartAdrBuffer,StartAdrMidLow, (4*BlockCounter)+1, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufWriteByte(StartAdrBuffer,StartAdrMidHigh, (4*BlockCounter)+2, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufWriteByte(StartAdrBuffer,StartAdrHigh, (4*BlockCounter)+3, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
// Datenlaenge im Buffer merken
|
|||
|
CDHBinBufWriteByte(BlockLengthBuffer,DataBlockLengthLow, (4*BlockCounter), Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufWriteByte(BlockLengthBuffer,DataBlockLengthMidLow, (4*BlockCounter)+1, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufWriteByte(BlockLengthBuffer,DataBlockLengthMidHigh, (4*BlockCounter)+2, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufWriteByte(BlockLengthBuffer,DataBlockLengthHigh, (4*BlockCounter)+3, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
// Gesamtl<74>nge errechnen
|
|||
|
if (FreibrennBlockFlag == FALSE)
|
|||
|
{
|
|||
|
AddDWordToDWord(DataLengthLow, DataLengthMidLow, DataLengthMidHigh, DataLengthHigh,
|
|||
|
DataBlockLengthLow, DataBlockLengthMidLow, DataBlockLengthMidHigh, DataBlockLengthHigh);
|
|||
|
}
|
|||
|
|
|||
|
DataBlockLengthLow = 0;
|
|||
|
DataBlockLengthMidLow = 0;
|
|||
|
DataBlockLengthMidHigh = 0;
|
|||
|
DataBlockLengthHigh = 0;
|
|||
|
|
|||
|
BlockCounter = BlockCounter + 1;
|
|||
|
|
|||
|
} // end of while (NrOfData > 0)
|
|||
|
|
|||
|
// DebugOutput aller gefundenen Datenbloecke und deren Adressen
|
|||
|
if (DebugSwitch == TRUE)
|
|||
|
{
|
|||
|
OutputDebugInt( 3371, "Anzahl Datenbloecke", BlockCounter);
|
|||
|
Index = 0;
|
|||
|
while (Index < BlockCounter)
|
|||
|
{
|
|||
|
inttostring(Index, StrWert);
|
|||
|
Text="Block(" + StrWert + ") Startadressse = ";
|
|||
|
CDHBinBufReadByte(StartAdrBuffer, IntWert, (4*Index)+3, Status);
|
|||
|
hexstring(IntWert, StrWert);
|
|||
|
Text = Text + StrWert + ":";
|
|||
|
|
|||
|
CDHBinBufReadByte(StartAdrBuffer, IntWert, (4*Index)+2, Status);
|
|||
|
hexstring(IntWert, StrWert);
|
|||
|
Text = Text + StrWert + ":";
|
|||
|
|
|||
|
CDHBinBufReadByte(StartAdrBuffer, IntWert, (4*Index)+1, Status);
|
|||
|
hexstring(IntWert, StrWert);
|
|||
|
Text = Text + StrWert + ":";
|
|||
|
|
|||
|
CDHBinBufReadByte(StartAdrBuffer, IntWert, (4*Index), Status);
|
|||
|
hexstring(IntWert, StrWert);
|
|||
|
Text = Text + StrWert + " Anzahl Bytes = ";
|
|||
|
|
|||
|
CDHBinBufReadByte(BlockLengthBuffer, IntWert, (4*Index)+3, Status);
|
|||
|
hexstring(IntWert, StrWert);
|
|||
|
Text = Text + StrWert + ":";
|
|||
|
|
|||
|
CDHBinBufReadByte(BlockLengthBuffer, IntWert, (4*Index)+2, Status);
|
|||
|
hexstring(IntWert, StrWert);
|
|||
|
Text = Text + StrWert + ":";
|
|||
|
|
|||
|
CDHBinBufReadByte(BlockLengthBuffer, IntWert, (4*Index)+1, Status);
|
|||
|
hexstring(IntWert, StrWert);
|
|||
|
Text = Text + StrWert + ":";
|
|||
|
|
|||
|
CDHBinBufReadByte(BlockLengthBuffer, IntWert, (4*Index), Status);
|
|||
|
hexstring(IntWert, StrWert);
|
|||
|
Text = Text + StrWert;
|
|||
|
|
|||
|
OutputDebugString( 3409, Text);
|
|||
|
Index = Index + 1;
|
|||
|
}
|
|||
|
Text = "Gesamtanzahl Bytes= ";
|
|||
|
hexstring(DataLengthHigh, StrWert);
|
|||
|
Text = Text + StrWert + ":";
|
|||
|
hexstring(DataLengthMidHigh, StrWert);
|
|||
|
Text = Text + StrWert + ":";
|
|||
|
hexstring(DataLengthMidLow, StrWert);
|
|||
|
Text = Text + StrWert + ":";
|
|||
|
hexstring(DataLengthLow, StrWert);
|
|||
|
Text = Text + StrWert;
|
|||
|
OutputDebugString( 3421, Text);
|
|||
|
}
|
|||
|
|
|||
|
TestCDHFehler(Status);
|
|||
|
//**********************************************************************
|
|||
|
// Ende
|
|||
|
// Laenge & Anfangsadressen der Datenbloecke ohne Adressenluecken ermitteln
|
|||
|
//**********************************************************************
|
|||
|
|
|||
|
|
|||
|
//############################################################################################################
|
|||
|
// (7) StartDiagonsticSession und Authentisierung
|
|||
|
//############################################################################################################
|
|||
|
|
|||
|
TesterPresentHandling(ProcName, SgbdName, FALSE);
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
// StartDiagonsticSession wird vor der Authentisierung durchgefuehrt.
|
|||
|
// Bei positive Response muss sie nicht mehr durchgefuehrt werden,
|
|||
|
// bei negative Response wird die Authentisierung aufgerufen
|
|||
|
// mit nachfolgendem StartDiagonsticSession
|
|||
|
//**********************************************************************
|
|||
|
|
|||
|
CDHapiJob(SgbdName, "DIAGNOSE_MODE", "ECUPM", "");
|
|||
|
TestApiFehlerNoExit(COAPI_ECU_PROGRAMMING_MODE_ERROR, ProcName, 3445, SgbdName + ", DIAGNOSE_MODE (ECUPM)", Status);
|
|||
|
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
// Status von StartDiagonsticSession auswerten
|
|||
|
//**********************************************************************
|
|||
|
if (Status != 0)
|
|||
|
{
|
|||
|
//**********************************************************************
|
|||
|
// Authentisierung
|
|||
|
// Start
|
|||
|
//**********************************************************************
|
|||
|
|
|||
|
TesterPresentHandling(ProcName, SgbdName, FALSE);
|
|||
|
|
|||
|
Status = 0;
|
|||
|
// Authentisierung mit scharfen Schluessel und keinem Fehlerabbruch bei Authentisierungsfehler wenn TestschluesselAuthentisierung aktiviert
|
|||
|
Authentisierung(SgbdName, AuthentisierungZeit, FALSE, TestSchluesselAuthentisierung, Status);
|
|||
|
if ((Status != 0) && (TRUE == TestSchluesselAuthentisierung))
|
|||
|
{
|
|||
|
TesterPresentHandling(ProcName, SgbdName, FALSE);
|
|||
|
|
|||
|
// Authentisierung mit Test-Schluessel und Fehlerabbruch bei Authentisierungsfehler
|
|||
|
Authentisierung(SgbdName, AuthentisierungZeit, TRUE, FALSE, Status);
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
// Ende
|
|||
|
// Authentisierung
|
|||
|
//**********************************************************************
|
|||
|
|
|||
|
TesterPresentHandling(ProcName, SgbdName, FALSE);
|
|||
|
|
|||
|
CDHapiJob(SgbdName, "DIAGNOSE_MODE", "ECUPM", "");
|
|||
|
TestApiFehler(COAPI_ECU_PROGRAMMING_MODE_ERROR, ProcName, 3479, SgbdName + ", DIAGNOSE_MODE (ECUPM)");
|
|||
|
}
|
|||
|
|
|||
|
if (WartenNachECUProgrammMode > 0)
|
|||
|
{
|
|||
|
Delay(SgbdName, WartenNachECUProgrammMode * 1000 + 500);
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
if (ResetZeit > 0)
|
|||
|
{
|
|||
|
Delay(SgbdName, ResetZeit * 1000 + 500);
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
Delay(SgbdName, 500);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
//############################################################################################################
|
|||
|
// (8) Daten schreiben vorbereiten und Flash l<>schen
|
|||
|
//############################################################################################################
|
|||
|
|
|||
|
// ersten Datenblock holen
|
|||
|
CDHGetApiJobByteData (MaxData, Buffer, BufferSize, NrOfData, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
SetFlashState(4);
|
|||
|
|
|||
|
TesterPresentHandling(ProcName, SgbdName, FALSE);
|
|||
|
|
|||
|
//Auffuellen mit 0xFF bis MaxData (Laenge)
|
|||
|
if (AuffuellenSwitch == TRUE)
|
|||
|
{
|
|||
|
if (NrOfData < MaxData)
|
|||
|
{
|
|||
|
BufferAuffuellen(Buffer, BufferSize, MaxData);
|
|||
|
}
|
|||
|
}
|
|||
|
//Ende von auffuellen mit 0xFF bis MaxData (Laenge)
|
|||
|
|
|||
|
// Flash-Speicher im SG loeschen
|
|||
|
if (LoeschZeit < 256)
|
|||
|
{
|
|||
|
CDHBinBufWriteByte(Buffer, LoeschZeit, 4, Status);
|
|||
|
CDHBinBufWriteWord(Buffer, 0, 5, Status);
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
CDHBinBufWriteByte(Buffer, 0, 4, Status);
|
|||
|
CDHBinBufWriteWord(Buffer, LoeschZeit, 5, Status);
|
|||
|
}
|
|||
|
|
|||
|
CDHBinBufWriteByte(Buffer, DataLengthLow, 13, Status); // Low
|
|||
|
CDHBinBufWriteByte(Buffer, DataLengthMidLow, 14, Status); // MidLow
|
|||
|
CDHBinBufWriteByte(Buffer, DataLengthMidHigh, 15, Status); // MidHigh
|
|||
|
CDHBinBufWriteByte(Buffer, DataLengthHigh, 16, Status); // High
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
// Flash l<>schen
|
|||
|
LoescheFlash(SgbdName, Buffer, BufferSize, LoeschZeit);
|
|||
|
|
|||
|
|
|||
|
SetFlashState(5);
|
|||
|
|
|||
|
//############################################################################################################
|
|||
|
// (9) Daten schreiben
|
|||
|
//############################################################################################################
|
|||
|
|
|||
|
TesterPresentHandling(ProcName, SgbdName, FALSE);
|
|||
|
|
|||
|
OutputDebugBool( 3550, "### 1. Datenblock schreiben: ", BlockSchreibenFlag);
|
|||
|
|
|||
|
// Erzeugen des RequestDownload-Buffers
|
|||
|
CDHBinBufCreate(RequestDownloadBuffer, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufWriteByte(RequestDownloadBuffer, 0x01, 0, Status); // Datentyp Daten setzen
|
|||
|
CDHBinBufWriteByte(RequestDownloadBuffer, 0x03, 21, Status); // ETX setzen
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
DataBlockLoopCounter = 0;
|
|||
|
|
|||
|
CDHBinBufCreate(WASBuffer_A_Handle, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufCreate(WASBuffer_B_Handle, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
while (DataBlockLoopCounter < BlockCounter) // solange nicht alle datenbloecke geschrieben sind
|
|||
|
{
|
|||
|
OutputDebugInt( 3568, "### Datenblock schreiben ", DataBlockLoopCounter);
|
|||
|
|
|||
|
WASSwitch = FALSE;
|
|||
|
WASBuffer_1_Size = DEFAULT_BUFFER_SIZE;
|
|||
|
WASBuffer_2_Size = DEFAULT_BUFFER_SIZE;
|
|||
|
WASBuffer_1_Size_Pointer = DEFAULT_BUFFER_SIZE;
|
|||
|
WASBuffer_2_Size_Pointer = DEFAULT_BUFFER_SIZE;
|
|||
|
|
|||
|
// Startadresse des Datenblocks aus StartAdrBuffer holen
|
|||
|
CDHBinBufReadByte(StartAdrBuffer, StartAdrLow, (4 * DataBlockLoopCounter), Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufReadByte(StartAdrBuffer, StartAdrMidLow, (4 * DataBlockLoopCounter) + 1, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufReadByte(StartAdrBuffer, StartAdrMidHigh, (4 * DataBlockLoopCounter) + 2, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufReadByte(StartAdrBuffer, StartAdrHigh, (4 * DataBlockLoopCounter) + 3, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
// Laenge des Datenblocks aus BlockLengthBuffer holen
|
|||
|
CDHBinBufReadByte(BlockLengthBuffer, DataBlockLengthLow, (4 * DataBlockLoopCounter), Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufReadByte(BlockLengthBuffer, DataBlockLengthMidLow, (4 * DataBlockLoopCounter) + 1, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufReadByte(BlockLengthBuffer, DataBlockLengthMidHigh, (4 * DataBlockLoopCounter) + 2, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
CDHBinBufReadByte(BlockLengthBuffer, DataBlockLengthHigh, (4 * DataBlockLoopCounter) + 3, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
// Den RequestDownloadBuffer mit gelesenen Werten vorbereiten
|
|||
|
VorbereitenRDBuffer(StartAdrLow, StartAdrMidLow, StartAdrMidHigh, StartAdrHigh,
|
|||
|
DataBlockLengthLow, DataBlockLengthMidLow, DataBlockLengthMidHigh, DataBlockLengthHigh,
|
|||
|
RequestDownloadBuffer);
|
|||
|
|
|||
|
// Download anfordern
|
|||
|
if (FALSE != BlockSchreibenFlag)
|
|||
|
FlashSchreibenAdresse(SgbdName, RequestDownloadBuffer, MaxData);
|
|||
|
|
|||
|
// Wg. mgl. RespPend. bei DownloadStart
|
|||
|
TesterPresentHandling(ProcName, SgbdName, FALSE);
|
|||
|
|
|||
|
// Variablen r<>cksetzen
|
|||
|
EndDataBlockLengthLow = 0; // fuer Erkennung auf Datenblockende
|
|||
|
EndDataBlockLengthMidLow = 0;
|
|||
|
EndDataBlockLengthMidHigh = 0;
|
|||
|
EndDataBlockLengthHigh = 0;
|
|||
|
|
|||
|
BlockEnd = FALSE;
|
|||
|
|
|||
|
// wenn der erste block nicht geschrieben wird, aber gr<67><72>er als MaxData ist.
|
|||
|
// muss CDHGetApiJobBateData mehrmal aufgerufen werden und die bereits in buffer vorliegenden daten m<>ssen fuer
|
|||
|
// die erkenung des blockendes beruecksichtigt werden.
|
|||
|
if (FALSE == BlockSchreibenFlag)
|
|||
|
{
|
|||
|
AddWordToDWord(EndDataBlockLengthLow, EndDataBlockLengthMidLow, EndDataBlockLengthMidHigh, EndDataBlockLengthHigh, NrOfData);
|
|||
|
if ((DataBlockLengthLow == EndDataBlockLengthLow ) &&
|
|||
|
(DataBlockLengthMidLow == EndDataBlockLengthMidLow ) &&
|
|||
|
(DataBlockLengthMidHigh == EndDataBlockLengthMidHigh ) &&
|
|||
|
(DataBlockLengthHigh == EndDataBlockLengthHigh))
|
|||
|
{
|
|||
|
BlockEnd = TRUE;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
// Flash Block schreiben
|
|||
|
//**********************************************************************
|
|||
|
while (FALSE == BlockEnd)
|
|||
|
{ // solange kein datenblockende erreicht ist
|
|||
|
|
|||
|
TesterPresentHandling(ProcName, SgbdName, FALSE);
|
|||
|
|
|||
|
CDHGetApiJobByteData (MaxData, Buffer, BufferSize, NrOfData, Status); // Daten aus PAF Datei holen
|
|||
|
|
|||
|
// pr<70>fen auf datenblockende
|
|||
|
AddWordToDWord(EndDataBlockLengthLow, EndDataBlockLengthMidLow, EndDataBlockLengthMidHigh, EndDataBlockLengthHigh, NrOfData);
|
|||
|
if ((DataBlockLengthLow == EndDataBlockLengthLow ) &&
|
|||
|
(DataBlockLengthMidLow == EndDataBlockLengthMidLow ) &&
|
|||
|
(DataBlockLengthMidHigh == EndDataBlockLengthMidHigh ) &&
|
|||
|
(DataBlockLengthHigh == EndDataBlockLengthHigh))
|
|||
|
{
|
|||
|
OutputDebugString( 3648, "### BlockEnd = TRUE");
|
|||
|
BlockEnd = TRUE;
|
|||
|
}
|
|||
|
|
|||
|
// nicht maxdata erhalten und es gibt noch weitere daten --> buffer auff<66>llen
|
|||
|
while ((NrOfData < MaxData) && (FALSE == BlockEnd) && (TRUE == BlockSchreibenFlag))
|
|||
|
{
|
|||
|
OutputDebugString( 3655, "### Buffer aufuellen");
|
|||
|
|
|||
|
CDHGetApiJobByteData(MaxData - NrOfData, ZwischenBuffer, ZwischenBufferSize, ZwischenBufferNrOfData, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
// Daten umkopieren
|
|||
|
CDHBinBufCopy(ZwischenBuffer, Buffer, 21, NrOfData + 21, ZwischenBufferNrOfData, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
NextByte = (NrOfData + ZwischenBufferNrOfData) / 256;
|
|||
|
|
|||
|
CDHBinBufWriteByte(Buffer, NextByte, 14, Status); // L<>nge setzen
|
|||
|
CDHBinBufWriteByte(Buffer, (NrOfData + ZwischenBufferNrOfData) - (NextByte * 256), 13, Status); // L<>nge setzen
|
|||
|
|
|||
|
CDHBinBufWriteByte(Buffer, 3, NrOfData + ZwischenBufferNrOfData + 21, Status); // ETX setzen (03h)
|
|||
|
|
|||
|
NrOfData = NrOfData + ZwischenBufferNrOfData;
|
|||
|
BufferSize = BufferSize + ZwischenBufferNrOfData;
|
|||
|
|
|||
|
// erneutes pr<70>fen auf datenblockende
|
|||
|
AddWordToDWord(EndDataBlockLengthLow, EndDataBlockLengthMidLow, EndDataBlockLengthMidHigh, EndDataBlockLengthHigh, ZwischenBufferNrOfData);
|
|||
|
|
|||
|
if ((DataBlockLengthLow == EndDataBlockLengthLow ) &&
|
|||
|
(DataBlockLengthMidLow == EndDataBlockLengthMidLow ) &&
|
|||
|
(DataBlockLengthMidHigh == EndDataBlockLengthMidHigh ) &&
|
|||
|
(DataBlockLengthHigh == EndDataBlockLengthHigh))
|
|||
|
{
|
|||
|
OutputDebugString( 3682, "### BlockEnd = TRUE");
|
|||
|
BlockEnd = TRUE;
|
|||
|
}
|
|||
|
} // Ende von: if ( (NrOfData < MaxData) && (FALSE == BlockEnd) )
|
|||
|
|
|||
|
TesterPresentHandling(ProcName, SgbdName, FALSE);
|
|||
|
|
|||
|
// Auffuellen wenn der Buffer nicht MXBL hat.
|
|||
|
if (AuffuellenSwitch == TRUE)
|
|||
|
{
|
|||
|
if (NrOfData < MaxData)
|
|||
|
{
|
|||
|
BufferAuffuellen(Buffer, BufferSize, MaxData);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
Status = 0;
|
|||
|
// Daten an das SG senden
|
|||
|
if (FALSE != BlockSchreibenFlag)
|
|||
|
FlashSchreiben(SgbdName, Buffer, BufferSize, RequestDownloadBuffer, TRUE, Status);
|
|||
|
|
|||
|
if (Status != 0 && (TRUE == WiederaufsetzenBlockSwitch || TRUE == WiederaufsetzenSwitch))
|
|||
|
{
|
|||
|
// WAS
|
|||
|
// Fehler aufgetreten, WAS initiieren
|
|||
|
|
|||
|
OutputDebugString( 3708, "*** WAS WAS WAS WAS WAS ***");
|
|||
|
|
|||
|
// ======================================================
|
|||
|
// MH 17.8.05: vor Wiederaufsetzen PrgStatus lesen,
|
|||
|
// im 2 sec Abstand max. 5 mal wiederholen (bei CAN jeweils inkl. 800 ms = max. 14 sec)
|
|||
|
// (falls ein verlorengegangenes RespPend des SG noch aussteht, o.<2E>.)
|
|||
|
//
|
|||
|
// Variablen:
|
|||
|
// int WASPrgStatusLesenWiederholung;
|
|||
|
// bool WASPrgStatusLesenErfolgreich;
|
|||
|
// string WASPrgStatusLesenApiStatusText;
|
|||
|
|
|||
|
WASPrgStatusLesenWiederholung = 5;
|
|||
|
WASPrgStatusLesenErfolgreich = FALSE;
|
|||
|
|
|||
|
OutputDebugString( 3723, "PrgStatus lesen");
|
|||
|
apiJob(SgbdName, "FLASH_PROGRAMMIER_STATUS_LESEN", "", "");
|
|||
|
apiResultText(WASPrgStatusLesenErfolgreich, WASPrgStatusLesenApiStatusText, "JOB_STATUS", 1, "");
|
|||
|
while ((WASPrgStatusLesenWiederholung>0) && (WASPrgStatusLesenErfolgreich == FALSE))
|
|||
|
{
|
|||
|
// 2 Sekunden warten
|
|||
|
Delay(SgbdName, 2000);
|
|||
|
|
|||
|
OutputDebugString( 3731, "PrgStatus lesen");
|
|||
|
apiJob(SgbdName, "FLASH_PROGRAMMIER_STATUS_LESEN", "", "");
|
|||
|
apiResultText(WASPrgStatusLesenErfolgreich, WASPrgStatusLesenApiStatusText, "JOB_STATUS", 1, "");
|
|||
|
// Ungeachtet der Antwort fortsetzen
|
|||
|
WASPrgStatusLesenWiederholung = WASPrgStatusLesenWiederholung - 1;
|
|||
|
}
|
|||
|
|
|||
|
//------------------------------------------------------
|
|||
|
|
|||
|
// Flash schreiben abschliessen
|
|||
|
FlashSchreibenEnde(SgbdName, RequestDownloadBuffer);
|
|||
|
|
|||
|
// WAS Adresse berechnen
|
|||
|
// Anzahl der bereits geschriebenen Daten neu berechnen (2 Bloecke zurueck bereits miteingerechnet)
|
|||
|
WrittenDataBlockLengthLow = EndDataBlockLengthLow;
|
|||
|
WrittenDataBlockLengthMidLow = EndDataBlockLengthMidLow;
|
|||
|
WrittenDataBlockLengthMidHigh = EndDataBlockLengthMidHigh;
|
|||
|
WrittenDataBlockLengthHigh = EndDataBlockLengthHigh;
|
|||
|
if (TRUE == WiederaufsetzenBlockSwitch)
|
|||
|
WASOffset = NrOfData + (WASBuffer_1_Size - DEFAULT_BUFFER_SIZE) + (WASBuffer_2_Size - DEFAULT_BUFFER_SIZE);
|
|||
|
else
|
|||
|
WASOffset = NrOfData;
|
|||
|
SubWordFromDWord(WrittenDataBlockLengthLow,
|
|||
|
WrittenDataBlockLengthMidLow,
|
|||
|
WrittenDataBlockLengthMidHigh,
|
|||
|
WrittenDataBlockLengthHigh,
|
|||
|
WASOffset);
|
|||
|
|
|||
|
// Startadresse fuer WAS berechnen
|
|||
|
WASStartAdrLow = StartAdrLow;
|
|||
|
WASStartAdrMidLow = StartAdrMidLow;
|
|||
|
WASStartAdrMidHigh = StartAdrMidHigh;
|
|||
|
WASStartAdrHigh = StartAdrHigh;
|
|||
|
AddDWordToDWord(WASStartAdrLow,
|
|||
|
WASStartAdrMidLow,
|
|||
|
WASStartAdrMidHigh,
|
|||
|
WASStartAdrHigh,
|
|||
|
WrittenDataBlockLengthLow,
|
|||
|
WrittenDataBlockLengthMidLow,
|
|||
|
WrittenDataBlockLengthMidHigh,
|
|||
|
WrittenDataBlockLengthHigh);
|
|||
|
|
|||
|
// Verbleibende Blocklaenge berechnen
|
|||
|
RemainingDataBlockLengthLow = DataBlockLengthLow;
|
|||
|
RemainingDataBlockLengthMidLow = DataBlockLengthMidLow;
|
|||
|
RemainingDataBlockLengthMidHigh = DataBlockLengthMidHigh;
|
|||
|
RemainingDataBlockLengthHigh = DataBlockLengthHigh;
|
|||
|
SubDWordFromDWord(RemainingDataBlockLengthLow,
|
|||
|
RemainingDataBlockLengthMidLow,
|
|||
|
RemainingDataBlockLengthMidHigh,
|
|||
|
RemainingDataBlockLengthHigh,
|
|||
|
WrittenDataBlockLengthLow,
|
|||
|
WrittenDataBlockLengthMidLow,
|
|||
|
WrittenDataBlockLengthMidHigh,
|
|||
|
WrittenDataBlockLengthHigh);
|
|||
|
|
|||
|
//RequestDownloadBuffer mit berechneten Adressen vorbereiten
|
|||
|
VorbereitenRDBuffer(WASStartAdrLow, WASStartAdrMidLow, WASStartAdrMidHigh, WASStartAdrHigh,
|
|||
|
RemainingDataBlockLengthLow, RemainingDataBlockLengthMidLow,
|
|||
|
RemainingDataBlockLengthMidHigh, RemainingDataBlockLengthHigh,
|
|||
|
RequestDownloadBuffer);
|
|||
|
|
|||
|
// Flash schreiben Adressse
|
|||
|
FlashSchreibenAdresse(SgbdName, RequestDownloadBuffer, MaxData);
|
|||
|
|
|||
|
// wg. mgl. RespPend. bei Download
|
|||
|
TesterPresentHandling(ProcName, SgbdName, FALSE);
|
|||
|
|
|||
|
// Buffer_1 schreiben
|
|||
|
if ((WASBuffer_1_Size_Pointer - DEFAULT_BUFFER_SIZE) > 0 && TRUE == WiederaufsetzenBlockSwitch)
|
|||
|
{
|
|||
|
OutputDebugString( 3802, "*** WAS: WASBuffer_1 schreiben ***");
|
|||
|
FlashSchreiben(SgbdName, WASBuffer_1_Pointer, WASBuffer_1_Size_Pointer, RequestDownloadBuffer, FALSE, Status);
|
|||
|
}
|
|||
|
|
|||
|
// Buffer_2 schreiben
|
|||
|
if ((WASBuffer_2_Size_Pointer - DEFAULT_BUFFER_SIZE) > 0 && TRUE == WiederaufsetzenBlockSwitch)
|
|||
|
{
|
|||
|
OutputDebugString( 3809, "*** WAS: WASBuffer_2 schreiben ***");
|
|||
|
FlashSchreiben(SgbdName, WASBuffer_2_Pointer, WASBuffer_2_Size_Pointer, RequestDownloadBuffer, FALSE, Status);
|
|||
|
}
|
|||
|
|
|||
|
// Buffer schreiben
|
|||
|
OutputDebugString( 3814, "*** WAS: Buffer schreiben ***");
|
|||
|
FlashSchreiben(SgbdName, Buffer, BufferSize, RequestDownloadBuffer, FALSE, Status);
|
|||
|
|
|||
|
TesterPresentHandling(ProcName, SgbdName, FALSE);
|
|||
|
|
|||
|
} // Ende von: if (Status != 0)
|
|||
|
else if (Status != 0)
|
|||
|
{
|
|||
|
// Fehler bei der <20>bertragung und kein WAS aktiviert --> Abbruch!
|
|||
|
SetCDHFehler(Status, ProcName, 3823, SgbdName + ", FLASH_SCHREIBEN (...)");
|
|||
|
}
|
|||
|
|
|||
|
if ((TRUE == WiederaufsetzenBlockSwitch) && (TRUE == BlockSchreibenFlag))
|
|||
|
{
|
|||
|
// Buffer fuer WAS speichern
|
|||
|
if (FALSE == WASSwitch)
|
|||
|
{
|
|||
|
WASBufferKopieren(Buffer, BufferSize, WASBuffer_A_Handle, WASBuffer_1_Size);
|
|||
|
WASSwitch = TRUE;
|
|||
|
WASBuffer_1_Pointer = WASBuffer_B_Handle;
|
|||
|
WASBuffer_2_Pointer = WASBuffer_A_Handle;
|
|||
|
WASBuffer_1_Size_Pointer = WASBuffer_2_Size;
|
|||
|
WASBuffer_2_Size_Pointer = WASBuffer_1_Size;
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
WASBufferKopieren(Buffer, BufferSize, WASBuffer_B_Handle, WASBuffer_2_Size);
|
|||
|
WASSwitch = FALSE;
|
|||
|
WASBuffer_1_Pointer = WASBuffer_A_Handle;
|
|||
|
WASBuffer_2_Pointer = WASBuffer_B_Handle;
|
|||
|
WASBuffer_1_Size_Pointer = WASBuffer_1_Size;
|
|||
|
WASBuffer_2_Size_Pointer = WASBuffer_2_Size;
|
|||
|
}
|
|||
|
}
|
|||
|
} // Ende von: while (FALSE == BlockEnd)
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
// Flash Schreiben abschliessen
|
|||
|
//**********************************************************************
|
|||
|
if (FALSE != BlockSchreibenFlag)
|
|||
|
FlashSchreibenEnde(SgbdName, RequestDownloadBuffer);
|
|||
|
|
|||
|
DataBlockLoopCounter = DataBlockLoopCounter + 1;
|
|||
|
BlockSchreibenFlag = TRUE;
|
|||
|
|
|||
|
} // Ende von: while (DataBlockLoopCounter < BlockCounter)
|
|||
|
|
|||
|
// Sch<63>nheitskorrektur, KEINE FUNKTION
|
|||
|
CDHGetApiJobByteData(MaxData, Buffer, BufferSize, NrOfData, Status);
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
// Ende - Datenbloecke schreiben
|
|||
|
//**********************************************************************
|
|||
|
|
|||
|
|
|||
|
SetFlashState(6);
|
|||
|
|
|||
|
//############################################################################################################
|
|||
|
// (10) Signaturpr<70>fung
|
|||
|
//############################################################################################################
|
|||
|
|
|||
|
// ggf. Fahrzeugbusse wieder wecken, Timer loeschen
|
|||
|
TesterPresentHandling(ProcName, SgbdName, FALSE);
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
// Programmierstatus abfragen fuer Signaturpruefung
|
|||
|
//**********************************************************************
|
|||
|
CDHapiJob (SgbdName, "FLASH_PROGRAMMIER_STATUS_LESEN", "", "FLASH_PROGRAMMIER_STATUS");
|
|||
|
TestApiFehler(COAPI_ECU_PROG_STATUS_ERROR, ProcName, 3882, SgbdName + ", FLASH_PROGRAMMIER_STATUS_LESEN");
|
|||
|
CDHapiResultInt(SgStatus, "FLASH_PROGRAMMIER_STATUS", 1);
|
|||
|
OutputDebugInt( 3884, "ProgrammierStatus nach der Programmierung ", SgStatus);
|
|||
|
// Programmierstatus auswerten
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
// Signaturpruefung
|
|||
|
//**********************************************************************
|
|||
|
if (SgStatus == 0x06) // Signaturpruefung DAF nicht durchgefuehrt
|
|||
|
{
|
|||
|
PruefeSignatur(SgbdName, "Daten", SignaturTestZeit);
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
if ((SgStatus == 0x05) || // Signaturpruefung PAF nicht durchgefuehrt
|
|||
|
((SgStatus == 0x0C) && (ProgrammUndDaten == FALSE)))
|
|||
|
{
|
|||
|
PruefeSignatur(SgbdName, "Programm", SignaturTestZeit);
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
// Programmierstatus nach Download nicht plausibel
|
|||
|
SetCDHFehler(COAPI_ECU_PROG_STATUS_ERROR, ProcName, 3904, SgbdName + ", FLASH_PROGRAMMIER_STATUS_LESEN, Programmierstatus nicht plausibel");
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
SetFlashState(7);
|
|||
|
|
|||
|
//############################################################################################################
|
|||
|
// (11) AIF schreiben
|
|||
|
//############################################################################################################
|
|||
|
|
|||
|
// ggf. Fahrzeugbusse wieder wecken, Timer loeschen
|
|||
|
TesterPresentHandling(ProcName, SgbdName, FALSE);
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
// Programmierstatus abfragen
|
|||
|
//**********************************************************************
|
|||
|
CDHapiJob(SgbdName, "FLASH_PROGRAMMIER_STATUS_LESEN", "", "FLASH_PROGRAMMIER_STATUS");
|
|||
|
TestApiFehler(COAPI_ECU_PROG_STATUS_ERROR, ProcName, 3922, SgbdName + ", FLASH_PROGRAMMIER_STATUS_LESEN");
|
|||
|
CDHapiResultInt(SgStatus, "FLASH_PROGRAMMIER_STATUS", 1);
|
|||
|
OutputDebugInt( 3924, "ProgrammierStatus nach der Signaturpruefung ", SgStatus);
|
|||
|
// Programmierstatus auswerten
|
|||
|
|
|||
|
|
|||
|
SetFlashState(8);
|
|||
|
|
|||
|
// ggf. Fahrzeugbusse wieder wecken, Timer loeschen
|
|||
|
TesterPresentHandling(ProcName, SgbdName, FALSE);
|
|||
|
|
|||
|
if ((SgStatus == 0x01) || // Normalbetrieb
|
|||
|
((SgStatus == 0x0C) && (ProgrammUndDaten == FALSE)))
|
|||
|
{
|
|||
|
CDHGetCabdWordPar("PROG_WITH_AIF" , PROG_WITH_AIF, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
OutputDebugInt( 3938, "AIF schreiben aktiviert ",PROG_WITH_AIF);
|
|||
|
|
|||
|
if ( PROG_WITH_AIF == 1 )
|
|||
|
{
|
|||
|
//**********************************************************************
|
|||
|
// AIF schreiben
|
|||
|
//**********************************************************************
|
|||
|
CDHGetCabdPar("AIF_FG_NR", AifDaten, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
StringArgument = AifDaten;
|
|||
|
CDHGetCabdPar("AIF_DATUM", AifDaten, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
StringArgument = StringArgument + ";" + AifDaten;
|
|||
|
CDHGetCabdPar("AIF_ZB_NR", AifDaten, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
StringArgument = StringArgument + ";" + AifDaten;
|
|||
|
|
|||
|
CDHGetCabdWordPar("AIF_GROESSE", AifGroesse, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
OutputDebugInt( 3957, "AifGroesse ",AifGroesse);
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
// Daten f<>r grosses AIF
|
|||
|
// 0x12 18 dez kleines AIF
|
|||
|
// 0x33 51 dez grosses AIF
|
|||
|
// 0x40 64 dez grosses AIF ( gilt nur fuer Power-Pc )
|
|||
|
// sonst Nicht zulaessig
|
|||
|
//**********************************************************************
|
|||
|
if ((AifGroesse == 0x40) || (AifGroesse == 0x33))
|
|||
|
{
|
|||
|
CDHGetCabdPar("AIF_SW_NR", AifDaten, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
StringArgument = StringArgument + ";" + AifDaten;
|
|||
|
CDHGetCabdPar("AIF_BEHOERDEN_NR", AifDaten, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
StringArgument = StringArgument + ";" + AifDaten;
|
|||
|
CDHGetCabdPar("AIF_HAENDLER_NR", AifDaten, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
// 6 Byte BCD
|
|||
|
AifDaten = "000000" + AifDaten;
|
|||
|
strlen(AifDatenLen, AifDaten);
|
|||
|
midstr(AifDaten, AifDaten, AifDatenLen - 6, 6);
|
|||
|
StringArgument = StringArgument + ";" + AifDaten;
|
|||
|
CDHGetCabdPar("AIF_SERIEN_NR", AifDaten, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
// 5 Byte ASCII
|
|||
|
AifDaten = " " + AifDaten;
|
|||
|
strlen(AifDatenLen, AifDaten);
|
|||
|
midstr(AifDaten, AifDaten,AifDatenLen - 5, 5);
|
|||
|
StringArgument = StringArgument + ";" + AifDaten;
|
|||
|
CDHGetCabdPar("AIF_KM", AifDaten, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
StringArgument = StringArgument + ";" + AifDaten;
|
|||
|
CDHGetCabdPar("AIF_PROG_NR", AifDaten, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
// 12 Byte ASCII
|
|||
|
AifDaten = " " + AifDaten;
|
|||
|
strlen(AifDatenLen, AifDaten);
|
|||
|
midstr(AifDaten, AifDaten, AifDatenLen - 12, 12);
|
|||
|
StringArgument = StringArgument + ";" + AifDaten;
|
|||
|
}
|
|||
|
OutputDebugString( 3999, "Aif Argument : " + StringArgument);
|
|||
|
CDHapiJob(SgbdName, "AIF_SCHREIBEN", StringArgument, "");
|
|||
|
TestApiFehler(COAPI_ECU_WRITE_AIF, ProcName, 4001, SgbdName + ", AIF_SCHREIBEN (" + StringArgument + ")");
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
//############################################################################################################
|
|||
|
// (12) Programmierung beenden
|
|||
|
//############################################################################################################
|
|||
|
|
|||
|
TesterPresentHandling(ProcName, SgbdName, FALSE);
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
// DIAGNOSE_ENDE
|
|||
|
//**********************************************************************
|
|||
|
CDHapiJob(SgbdName, "DIAGNOSE_ENDE", "", "");
|
|||
|
TestApiFehler(COAPI_ECU_STOPDIAG_ERROR, ProcName, 4015, SgbdName + ", DIAGNOSE_ENDE");
|
|||
|
|
|||
|
SetFlashState(9);
|
|||
|
|
|||
|
// ggf. Fahrzeugbusse wieder wecken, Timer loeschen
|
|||
|
TesterPresentHandling(ProcName, SgbdName, FALSE);
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
// STEUERGERAETE_RESET
|
|||
|
//**********************************************************************
|
|||
|
// Boot Sektor Update
|
|||
|
CDHGetCabdWordPar("BSUTIME", BSUTime, Status);
|
|||
|
OutputDebugInt( 4027, "BSUTime ", BSUTime);
|
|||
|
ResetZeit = ResetZeit + BSUTime;
|
|||
|
|
|||
|
OutputDebugInt( 4030, "ResetZeit mit BSUTime ", ResetZeit);
|
|||
|
SGReset(SgbdName, ResetZeit);
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
// Programmierstatus abfragen
|
|||
|
//**********************************************************************
|
|||
|
CDHapiJob (SgbdName, "FLASH_PROGRAMMIER_STATUS_LESEN", "", "FLASH_PROGRAMMIER_STATUS");
|
|||
|
TestApiFehler(COAPI_ECU_PROG_STATUS_ERROR, ProcName, 4037, SgbdName + ", FLASH_PROGRAMMIER_STATUS_LESEN");
|
|||
|
CDHapiResultInt(SgStatus, "FLASH_PROGRAMMIER_STATUS", 1);
|
|||
|
OutputDebugInt( 4039, "ProgrammierStatus nach RESET ",SgStatus);
|
|||
|
|
|||
|
// Programmierstatus auswerten
|
|||
|
if ((SgStatus != 1) && ((SgStatus != 0x0C) || (BSUTime == 0)))
|
|||
|
{
|
|||
|
SetCDHFehler(COAPI_ECU_PROG_STATUS_ERROR, ProcName, 4044, SgbdName + ", FLASH_PROGRAMMIER_STATUS_LESEN");
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
// Fahrzeugbusse sicher wieder wecken, Timer loeschen
|
|||
|
StopTesterPresentHandling(ProcName, SgbdName);
|
|||
|
|
|||
|
CDHTestError(Status);
|
|||
|
CDHSetReturnVal(0);
|
|||
|
|
|||
|
OutputDebugString( 4054, "Programmierung erfolgreich beendet");
|
|||
|
ProgSuccess = TRUE;
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : FlashStatusLesen
|
|||
|
//*
|
|||
|
//* Funktion : Status des SG und Festlegung der Programmierung:
|
|||
|
//* Programm-, Datenprogrammierung, Reihenfolge
|
|||
|
//*
|
|||
|
//* Parameter : HWNR_IS_NEW ( != 0 bedeutet neue HwNr -> Programmprog.)
|
|||
|
//* (soll nur Status gelesen werden auf 0 setzen)
|
|||
|
//*
|
|||
|
//* Rueckgabe : PRG_TYP (1 Daten, 2 Programm, 3 Programm + Daten),
|
|||
|
//* PRG_ORDER (1 Daten zuerst, 2 Programm zuerst)
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 19.10.2000 rd V0.01 Ersterstellung
|
|||
|
//* 16.02.2001 rd V1.00 Freigabe
|
|||
|
//* 03.07.2001 rd V2.00 Neue Programmierstati
|
|||
|
//**********************************************************************
|
|||
|
FlashStatusLesen()
|
|||
|
{
|
|||
|
string ProcName = "FlashStatusLesen";
|
|||
|
int Status;
|
|||
|
string SgbdName;
|
|||
|
string StringResult;
|
|||
|
int IntResult;
|
|||
|
|
|||
|
int SgStatus;
|
|||
|
int IsNewHwNr;
|
|||
|
int ProgTyp = 0;
|
|||
|
int ProgOrder = 0;
|
|||
|
|
|||
|
OutputDebugString( 4090, ProcName);
|
|||
|
CDHapiInit(); // CDH-Initialisierung
|
|||
|
CDHGetSgbdName(SgbdName, Status); // SGBD-Name aus SGET
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
CDHGetCabdWordPar("HWNR_IS_NEW", IsNewHwNr, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
OutputDebugInt( 4097, "IsNewHwNr ",IsNewHwNr);
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
// Programmierstatus abfragen
|
|||
|
//**********************************************************************
|
|||
|
CDHapiJob(SgbdName, "FLASH_PROGRAMMIER_STATUS_LESEN", "", "FLASH_PROGRAMMIER_STATUS");
|
|||
|
TestApiFehler(COAPI_ECU_PROG_STATUS_ERROR, ProcName, 4103, SgbdName + ", FLASH_PROGRAMMIER_STATUS_LESEN");
|
|||
|
CDHapiResultInt(SgStatus, "FLASH_PROGRAMMIER_STATUS", 1);
|
|||
|
OutputDebugInt( 4105, "ProgrammierStatus ",SgStatus);
|
|||
|
if (SgStatus >= 0x80) SgStatus = 0x01; // F<>r Zulieferer reserviert - Interpretation wie 0x01
|
|||
|
|
|||
|
CDHSetCabdWordPar("SG_STATUS", SgStatus, Status);
|
|||
|
CDHTestError(Status);
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
// Festlegung Programm-, Datenprogrammierung, Reihenfolge
|
|||
|
//**********************************************************************
|
|||
|
|
|||
|
if ( ProgrammUndDaten == TRUE )
|
|||
|
{
|
|||
|
if( SgStatus == 0x05 || // Signaturpruefung PAF nicht durchgefuehrt
|
|||
|
SgStatus == 0x07 || // Programmprogrammiersitzung aktiv
|
|||
|
SgStatus == 0x0A || // Programmreferenzeintrag fehlerhaft
|
|||
|
SgStatus == 0x0B || // Referenzierungsfehler Hardware -> Programm
|
|||
|
SgStatus == 0x0C ) // Programm nicht vollstaendig
|
|||
|
{
|
|||
|
ProgTyp = 3; // Programm + Daten
|
|||
|
ProgOrder = 2; // Programm zuerst
|
|||
|
}
|
|||
|
|
|||
|
if( SgStatus == 0x00 || // Anlieferzustand
|
|||
|
SgStatus == 0x06 || // Signaturpruefung DAF nicht durchgefuehrt
|
|||
|
SgStatus == 0x08 || // Datenprogrammiersitzung aktiv
|
|||
|
SgStatus == 0x0D || // Datenreferenzeintrag fehlerhaft
|
|||
|
SgStatus == 0x0F ) // Daten nicht vollstaendig
|
|||
|
{
|
|||
|
if( IsNewHwNr != 0 )
|
|||
|
{
|
|||
|
ProgTyp = 3; // Programm + Daten
|
|||
|
ProgOrder = 1; // Daten zuerst
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
ProgTyp = 1; // nur Daten
|
|||
|
ProgOrder = 1; // Daten zuerst
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
if( SgStatus == 0x01 || // Normalbetrieb
|
|||
|
SgStatus == 0x0E ) // Referenzierungsfehler Programm -> Daten
|
|||
|
{
|
|||
|
if( IsNewHwNr != 0 )
|
|||
|
{
|
|||
|
ProgTyp = 3; // Programm + Daten
|
|||
|
ProgOrder = 2; // Programm zuerst
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
ProgTyp = 1; // nur Daten
|
|||
|
ProgOrder = 1; // Daten zuerst
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
ProgTyp = 2; // nur Programm
|
|||
|
ProgOrder = 2; // Programm zuerst
|
|||
|
}
|
|||
|
|
|||
|
CDHSetCabdWordPar("PROG_TYP", ProgTyp, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
OutputDebugInt( 4168, "ProgTyp ", ProgTyp);
|
|||
|
|
|||
|
CDHSetCabdWordPar("PROG_ORDER", ProgOrder, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
OutputDebugInt( 4172, "ProgOrder ", ProgOrder);
|
|||
|
|
|||
|
if ((ProgTyp == 0) || (ProgOrder == 0))
|
|||
|
{
|
|||
|
Status = COAPI_ECU_PROG_STATUS_ERROR;
|
|||
|
SetCDHFehler(Status, ProcName, 4177, "PROG_TYP, PROG_ORDER ung<6E>ltig");
|
|||
|
}
|
|||
|
|
|||
|
CDHTestError(Status);
|
|||
|
CDHSetReturnVal(Status);
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : cabimain
|
|||
|
//*
|
|||
|
//* Funktion : Hauptfunktion des Scripts
|
|||
|
//*
|
|||
|
//* Parameter : -
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 19.10.2000 rd V0.01 Ersterstellung
|
|||
|
//* 16.02.2001 rd V1.00 Freigabe
|
|||
|
//* 03.12.2001 rj V2.10 Erweiterung um neue Prozessortypen
|
|||
|
//* 08.08.2002 pf V3.00 Nur 2 Moeglichkeiten als ProzessorTyp
|
|||
|
//**********************************************************************
|
|||
|
cabimain()
|
|||
|
{
|
|||
|
string ProcName = "cabimain";
|
|||
|
string JobName;
|
|||
|
int Status = 0;
|
|||
|
|
|||
|
// Test ob Prozessortyp erlaubt
|
|||
|
if ((ProzessorTyp != "Standard") && (ProzessorTyp != "HC12DG128"))
|
|||
|
{
|
|||
|
Status = COAPI_PROCESSOR_TYPE_ERROR;
|
|||
|
SetCDHFehler(Status, ProcName, 4211, "ProzessorTyp = " + ProzessorTyp);
|
|||
|
}
|
|||
|
|
|||
|
ModulName = SGFamilie; // Vorbelegung ModulName mit SgFamilie
|
|||
|
|
|||
|
OutputDebugString( 4216, ProcName);
|
|||
|
CDHGetCabdPar("JOBNAME", JobName, Status);
|
|||
|
TestCDHFehler(Status);
|
|||
|
|
|||
|
if ( JobName == "JOB_ERMITTELN" ) Jobs();
|
|||
|
else if ( JobName == "INFO" ) VersionInfo();
|
|||
|
else if ( JobName == "SG_IDENT_LESEN" ) Ident();
|
|||
|
else if ( JobName == "SG_AIF_LESEN" ) AifLesen();
|
|||
|
else if ( JobName == "SG_AIF_SCHREIBEN" ) AifSchreiben();
|
|||
|
else if ( JobName == "SG_STATUS_LESEN" ) FlashStatusLesen();
|
|||
|
else if ( JobName == "SG_PROGRAMMIEREN" ) Programmieren();
|
|||
|
else if ( JobName == "FEHLER_LOESCHEN" ) FehlerLoeschen();
|
|||
|
else if ( JobName == "DATEN_REFERENZ" ) DatenReferenzLesen();
|
|||
|
else if ( JobName == "HW_REFERENZ" ) HwReferenzLesen();
|
|||
|
else if ( JobName == "ZIF" ) ZifLesen();
|
|||
|
else if ( JobName == "ZIF_BACKUP" ) ZifBackupLesen();
|
|||
|
else if ( JobName == "U_PROG_LESEN" ) UProgLesen();
|
|||
|
else if ( JobName == "GET_DIAG_PROT" ) GetDiagProt();
|
|||
|
else if ( JobName == "SET_DIAG_PROT" ) SetDiagProt();
|
|||
|
else if ( JobName == "SET_ECU_ADDRESS" ) SetEcuAdr();
|
|||
|
else if ( JobName == "SG_INNENTEMP_LESEN" ) Innentemp();
|
|||
|
else if ( JobName == "SG_PHYS_HWNR_LESEN" ) PhysHwNrLesen();
|
|||
|
else
|
|||
|
{
|
|||
|
Status = COAPI_CABD_PAR_ERROR;
|
|||
|
SetCDHFehler(Status, ProcName, 4241, "JobName = " + JobName);
|
|||
|
}
|
|||
|
CDHSetReturnVal(Status);
|
|||
|
exit();
|
|||
|
}
|
|||
|
|
|||
|
//**********************************************************************
|
|||
|
//*
|
|||
|
//* Name : cabiexit
|
|||
|
//*
|
|||
|
//* Funktion : Exit-Funktion des Scripts
|
|||
|
//*
|
|||
|
//* Parameter : -
|
|||
|
//*
|
|||
|
//* Rueckgabe : -
|
|||
|
//*
|
|||
|
//**********************************************************************
|
|||
|
//* History :
|
|||
|
//* 19.10.2000 rd V0.01 Ersterstellung
|
|||
|
//* 16.02.2001 rd V1.00 Freigabe
|
|||
|
//* 02.03.2005 MK V6.10 <20>berarbeitung der Fehlerbehandlung
|
|||
|
//**********************************************************************
|
|||
|
cabiexit()
|
|||
|
{
|
|||
|
string ProcName = "cabiexit";
|
|||
|
string SgbdName;
|
|||
|
int Status = 0;
|
|||
|
int i = 0;
|
|||
|
string DiagProt = "NO_DIAG_PROT_SET";
|
|||
|
|
|||
|
|
|||
|
// bei OPPS-MOST-Zugang wieder Default OPPS-Senderate einstellen
|
|||
|
if (OppsMostAccess == TRUE)
|
|||
|
ResetOppsMostParams();
|
|||
|
|
|||
|
OutputDebugString( 4276, ProcName);
|
|||
|
if (ProgSuccess == FALSE)
|
|||
|
{
|
|||
|
//******************************************************************************
|
|||
|
// hier keine Fehlerauswertung mehr, da Abbruchgrund sonst verschleiert wird !!!
|
|||
|
//******************************************************************************
|
|||
|
CDHGetSgbdName (SgbdName, Status); // SGBD-Name aus SGET
|
|||
|
if (TesterPresentHandlingFlag == TRUE)
|
|||
|
{
|
|||
|
//**********************************************************************
|
|||
|
// Fahrzeugbusse wieder wecken
|
|||
|
// Timer loeschen
|
|||
|
// Tritt nur bei abgebrochener Programmierung auf
|
|||
|
//**********************************************************************
|
|||
|
StopTesterPresentHandling(ProcName, SgbdName);
|
|||
|
}
|
|||
|
|
|||
|
// nach Abbruch nocheinmal Kommunikation zum SG pr<70>fen
|
|||
|
CDHapiJob (SgbdName, "FLASH_BLOCKLAENGE_LESEN", "", "FLASH_BLOCKLAENGE_GESAMT");
|
|||
|
CDHapiJob (SgbdName, "FLASH_PROGRAMMIER_STATUS_LESEN", "", "FLASH_PROGRAMMIER_STATUS");
|
|||
|
|
|||
|
if (DIREKT_MOST_PROG == TRUE)
|
|||
|
{
|
|||
|
// Nach einem Abbruch lieber mochmal 2 min warten, bevor n<>chster Versuch gestartet wird
|
|||
|
CDHDelay(120*1000);
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
// Nach einem Abbruch lieber mochmal 20 sec warten, bevor n<>chster Versuch gestartet wird
|
|||
|
CDHDelay(20*1000);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
// L<>schen der dynamischen Buffer
|
|||
|
Status = 0;
|
|||
|
i = 0;
|
|||
|
while(Status == 0)
|
|||
|
{
|
|||
|
CDHBinBufDelete(i, Status);
|
|||
|
i = i + 1;
|
|||
|
}
|
|||
|
CDHapiEnd();
|
|||
|
}
|
|||
|
|
|||
|
// -- EOF --
|
|||
|
//*
|
|||
|
// -- EOF --
|