![]() |
Auslesen/Programmieren
Hallo
Ich muss bei einem FT232BM von FTDI unteranderem Daten programmieren und auslesen können. Dazu benutze ich Delphi... Beim Programmieren habe ich keine Probleme, aber dass auslesen ist etwas harziger... Mal den Code zum Programmieren: Die Daten zum Programmieren sind in einem Record.
Delphi-Quellcode:
Beim Auslesen habe ich das hier... aber es stürzt mir immer ab...
ftdata : Record
VendorID : word; ProductID : word; Manufacturer : PChar; ManufacturerID : PChar; Description : PChar; SerialNumber : PChar; MaxPower : word; PnP : Word; SelfPowered : Word; RemoteWakeup : Word; Rev4 : boolean; IsoIn : boolean; IsoOut : boolean; PullDownEnable : boolean; SerNumEnable : boolean; USBVersionEnable : boolean; USBVersion : Word; FT_EE_Program(Multi_Handle,@FtData);
Delphi-Quellcode:
Function ReadEE : FT_Result;
var ManufacturerBuf : string[8]; ManufacturerIDBuf : string[16]; DescriptionBuf : string[32]; SerialNumberBuf : String[16]; begin ManufacturerBuf := ftData.Manufacturer; ManufacturerIDBuf := ftData.ManufacturerID; DescriptionBuf := ftData.Description; SerialNumberBuf := ftData.SerialNumber; Result := FT_EE_Read(Multi_Handle,@FtData); if Result <> FT_OK then FT_Error_Report('FT_EE_Read',Result); end; Das blöde ist, dass die Beispiele in C-Sprache sind und ich nicht weiss ob ich sie richtig übertragen habe... Code zum Programmieren
Code:
Code zum Lesen
FT_PROGRAM_DATA (EEPROM Programming Interface)
typedef struct ft_program_data { WORD VendorId; // 0x0403 WORD ProductId; // 0x6001 char *Manufacturer; // "FTDI" char *ManufacturerId; // "FT" char *Description; // "USB HS Serial Converter" char *SerialNumber; // "FT000001" if fixed, or NULL WORD MaxPower; // 0 < MaxPower <= 500 WORD PnP; // 0 = disabled, 1 = enabled WORD SelfPowered; // 0 = bus powered, 1 = self powered WORD RemoteWakeup; // 0 = not capable, 1 = capable bool Rev4; // true if Rev4 chip, false otherwise bool IsoIn; // true if in endpoint is isochronous bool IsoOut; // true if out endpoint is isochronous bool PullDownEnable; // true if pull down enabled bool SerNumEnable; // true if serial number to be used bool USBVersionEnable; // true if chip uses USBVersion WORD USBVersion; // BCD (0x0200 => USB2) } FT_PROGRAM_DATA, *PFT_PROGRAM_DATA;
Code:
FT_PROGRAM_DATA ftData;char ManufacturerBuf[32];
char ManufacturerIdBuf[16]; char DescriptionBuf[64]; char SerialNumberBuf[16]; ftData.Manufacturer = ManufacturerBuf; ftData.ManufacturerId = ManufacturerIdBuf; ftData.Description = DescriptionBuf; ftData.SerialNumber = SerialNumberBuf; ftStatus = FT_EE_Read(ftHandle,&ftData); if (ftStatus == FT_OK) { // FT_EE_Read OK, data is available in ftData } else { // FT_EE_Read FAILED! } vielleicht bin ich hier auch total falsch... Aber bin trotzdem dankbar für jede Hilfe PEACE STW |
Re: Auslesen/Programmieren
Hi STW,
ich hab zwar keine Ahnung von FT232BM ?? Aufgefallen ist mir aber, daß die Deklarationen nicht ganz korrekt sind.
Delphi-Quellcode:
Vielleicht geht's so :?:
Function ReadEE : FT_Result;
var ManufacturerBuf : string[32]; ManufacturerIDBuf : string[16]; DescriptionBuf : string[64]; SerialNumberBuf : String[16]; myftData : ftData; begin ManufacturerBuf := myftData.Manufacturer; ManufacturerIDBuf := myftData.ManufacturerID; DescriptionBuf := myftData.Description; SerialNumberBuf := myftData.SerialNumber; Result := FT_EE_Read(Multi_Handle,@myFtData); if Result <> FT_OK then FT_Error_Report('FT_EE_Read',Result); end; |
Re: Auslesen/Programmieren
hy s14
hmmm...
Delphi-Quellcode:
die länge der Strings bestimme ich ja selbst...
ManufacturerBuf : string[32];
ManufacturerIDBuf : string[16]; DescriptionBuf : string[64]; SerialNumberBuf : String[16]; daher sollte es eigentlich unwichtig sein wie lang sie sind
Delphi-Quellcode:
das klappt gar nicht...
myftData : ftData;
Das ist ja das selbe wie ich habe, nur dass es nicht mehr ftData sonder myFtData heisst... PEACE STW |
Re: Auslesen/Programmieren
Die Stringlängen hab ich nur aus dem C-Source übernommen, es sollten halt so viele Fehlerquellen wie möglich ausgeschaltet werden.
In der Funktion greifst Du direkt auf den Typ zu, deshalb hab ich eine Variable dieses Typs verwendet, damit die Funktion "FT_EE_Read" die Daten in der Variablen ablegen kann. An welcher Stelle tritt eigentlich der Fehler genau auf und wie lautet die Fehlermeldung (GetLastError)? |
Re: Auslesen/Programmieren
naja die Meldung kommt:
Project EXProgrammer.exe raised exception class EAccessViolation with message 'Access violation at address 00402C43 in Module 'EXProgrammer.EXE'. Read of Address 00000000'. Process stopped. Use Step or Run to continue. und zwar nach der Zeile:
Delphi-Quellcode:
ManufacturerBuf := ftData.Manufacturer;
|
Re: Auslesen/Programmieren
Das sagt eindeutig aus, das der Variablen ftdata kein Speicher zugewiesen ist.
Es wird versucht etwas auszulesen was nicht da ist :-( Deshalb muss eben der Record ftData erst als Variable deklariert, dann mit Inhalt gefüllt werden. Woher kommen die Daten in der Funktion "ReadEE"?? |
Re: Auslesen/Programmieren
Die Werte von FtData sind in einem EEPROM gespeichert
Also wenn ich das Prog öffne, das EEPROM mit dem ftData programmiere und dann versuche auszulesen klappt es! Dann bekomme ich die 4 strings. Aber wenn ich das Prog öffne und dann gleich auslesen möchte kommt eben dieser Error... :wall: Die Daten müssen aber doch immer noch im EEPROM gespeichert sein... |
Re: Auslesen/Programmieren
Naja soweit kommst Du ja gar nicht.
Ich stochere hier ziemlich im Trüben :roll: Aber, was ist damit:
Delphi-Quellcode:
Function ReadEE : FT_Result;
var ManufacturerBuf : string[32]; ManufacturerIDBuf : string[16]; DescriptionBuf : string[64]; SerialNumberBuf : String[16]; myftData : ftData; begin Result := FT_EE_Read(Multi_Handle,@myFtData); if Result = FT_OK then begin ManufacturerBuf := myftData.Manufacturer; ManufacturerIDBuf := myftData.ManufacturerID; DescriptionBuf := myftData.Description; SerialNumberBuf := myftData.SerialNumber; // -- enthalten die Variablen jetzt die Werte?? end else FT_Error_Report('FT_EE_Read',Result); end; |
Re: Auslesen/Programmieren
Manche Dinge lasssen mir keine Ruhe :drunken:
Wir sind von unterschiedlichen Deklarationen ausgegangen:
Delphi-Quellcode:
und dann in einer Methode folgendes:
type
PFT_PROGRAM_DATA = ^FT_PROGRAM_DATA; FT_PROGRAM_DATA = packed record //(EEPROM Programming Interface) VendorID : word; ProductID : word; Manufacturer : PChar; ManufacturerID : PChar; Description : PChar; SerialNumber : PChar; MaxPower : word; PnP : Word; SelfPowered : Word; RemoteWakeup : Word; Rev4 : boolean; IsoIn : boolean; IsoOut : boolean; PullDownEnable : boolean; SerNumEnable : boolean; USBVersionEnable : boolean; USBVersion : Word; end;
Delphi-Quellcode:
Wie gesagt, ich kann es nicht testen. Sieht aber nicht schlecht aus :)
var
ftHandle : FT_HANDLE; ftData : FT_PROGRAM_DATA; ftstatus : FT_STATUS; begin ftStatus = FT_Open(0, @ftHandle); if ftStatus = FT_OK then begin ftstatus := FT_EE_Read(ftHandle, @ftData); if ftstatus FT_OK then begin // FT_EE_Read OK, data is available in ftData // in ftData müssten nun alle Daten enthalten sein !! end else FT_Error_Report('FT_EE_Read', ftstatus); end; Gruß aus dem verschneiten München |
Re: Auslesen/Programmieren
hmmm...
dass ganze ist wahrscheinlich ein bisschen verwirrend :? hab nun mal alles reingepackt was hierfür notwendig ist...
Delphi-Quellcode:
type
TFtData = Record VendorID : word; ProductID : word; Manufacturer : PChar; ManufacturerID : PChar; Description : PChar; SerialNumber : PChar; MaxPower : word; PnP : Word; SelfPowered : Word; RemoteWakeup : Word; Rev4 : boolean; IsoIn : boolean; IsoOut : boolean; PullDownEnable : boolean; SerNumEnable : boolean; USBVersionEnable : boolean; USBVersion : Word; end; var ftData : TFtData; implementation function FT_EE_Program(fthandle: DWord; FT_Data: Pointer) : FT_Result; stdcall ; External FT_DLL_Name name 'FT_EE_Program'; function FT_EE_Read(fthandle: DWord; FT_Data: Pointer) : FT_Result; stdcall ; External FT_DLL_Name name 'FT_EE_Read'; Function ReadEE : FT_Result; var ManufacturerBuf : string[32]; ManufacturerIDBuf : string[16]; DescriptionBuf : string[64]; SerialNumberBuf : string[16]; begin ManufacturerBuf := ftData.Manufacturer; ManufacturerIDBuf := ftData.ManufacturerID; DescriptionBuf := ftData.Description; SerialNumberBuf := ftData.SerialNumber; Result := FT_EE_Read(Multi_Handle,@FtData); if Result <> FT_OK then FT_Error_Report('FT_EE_Read',Result); end; Function ProgramEE : FT_Result; begin Result := FT_EE_Program(Multi_Handle,@FtData); if Result <> FT_OK then FT_Error_Report('FT_EE_Program',Result); end; die Functionen ReadEE und ProgramEE werden durch ButtonClicks aufgerufen... das komische ist, wenn ich
Delphi-Quellcode:
vollkommen weglasse, stürzt das Prog nicht mehr ab.
ManufacturerBuf := ftData.Manufacturer;
ManufacturerIDBuf := ftData.ManufacturerID; DescriptionBuf := ftData.Description; SerialNumberBuf := ftData.SerialNumber; Die anderen Werte werden alle angezeigt! ( Also boolean, word -werte vom record) ... |
Alle Zeitangaben in WEZ +1. Es ist jetzt 23:42 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz