AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Sonstige Fragen zu Delphi Delphi Erkennungszeit von unlesbaren Bytes verkürzen?
Thema durchsuchen
Ansicht
Themen-Optionen

Erkennungszeit von unlesbaren Bytes verkürzen?

Ein Thema von Kernel32.DLL · begonnen am 20. Jun 2004 · letzter Beitrag vom 24. Jun 2004
Antwort Antwort
Seite 1 von 2  1 2      
Kernel32.DLL
(Gast)

n/a Beiträge
 
#1

Erkennungszeit von unlesbaren Bytes verkürzen?

  Alt 20. Jun 2004, 13:19
Tach alle zusammen,

Ich bräuchte da mal einen Wink mit dem Zaunpfahl...

Mein Problem ist, dass ich ein Programm schreibe, welches bei fehlerhaften Dateien (z.B. zerkratzte CD) im Gegensatz zum Windows Explorer den Kopiervorgang nicht sofort abbricht, sondern stur weiterkopiert und die unlesbaren Bytes einfach durch "0" ersetzt.

Soweit, so gut. In der Praxis funzt das auch relativ gut, bis auf die kleine, störende Eigenschaft, dass es ziemlich lange dauert, bis das Programm den Dateizeiger bei einem fehlerhaften Block um 2048 Bytes weitersetzt.

Kann man diese Zeit irgendwie reduzieren?

P.S.: Zum Auslesen benutze ich BlockRead/BlockWrite in einer Try-Except Konstruktion
  Mit Zitat antworten Zitat
Kernel32.DLL
(Gast)

n/a Beiträge
 
#2

Re: Erkennungszeit von unlesbaren Bytes verkürzen?

  Alt 21. Jun 2004, 20:12
Keiner eine Ahnung?
  Mit Zitat antworten Zitat
supermuckl

Registriert seit: 1. Feb 2003
1.340 Beiträge
 
FreePascal / Lazarus
 
#3

Re: Erkennungszeit von unlesbaren Bytes verkürzen?

  Alt 22. Jun 2004, 00:06
das geht wohl nur mit treibern ?!
bei clonecd oder dvd decrypter kann man auch über die fehler "hinweg fliegen" aber die dinger benutzen eigene aspi treiber dafür odersowas
Das echte Leben ist was für Leute...
... die im Internet keine Freunde finden!
  Mit Zitat antworten Zitat
Benutzerbild von c113plpbr
c113plpbr

Registriert seit: 18. Nov 2003
Ort: localhost
674 Beiträge
 
Delphi 2005 Professional
 
#4

Re: Erkennungszeit von unlesbaren Bytes verkürzen?

  Alt 22. Jun 2004, 13:43
Zitat von supermuckl:
bei clonecd oder dvd decrypter kann man auch über die fehler "hinweg fliegen" aber die dinger benutzen eigene aspi treiber dafür odersowas
Dieses "hinwegfliegen" geht aber nur bei lauferken, die dies auch unterstützen ...

ciao, Philipp
Philipp
There is never enough time to do all the nothing you want.
*HABENWILL*
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#5

Re: Erkennungszeit von unlesbaren Bytes verkürzen?

  Alt 22. Jun 2004, 14:17
Zitat von Kernel32.DLL:
Mein Problem ist, dass ich ein Programm schreibe, welches bei fehlerhaften Dateien (z.B. zerkratzte CD) im Gegensatz zum Windows Explorer den Kopiervorgang nicht sofort abbricht, sondern stur weiterkopiert und die unlesbaren Bytes einfach durch "0" ersetzt.
... dass es ziemlich lange dauert, bis das Programm den Dateizeiger bei einem fehlerhaften Block um 2048 Bytes weitersetzt.
Kann man diese Zeit irgendwie reduzieren?
P.S.: Zum Auslesen benutze ich BlockRead/BlockWrite
Zum Lesen und Schreiben von Dateien gibt es versch. Funktionen, die sich durch unterschiedliche
"Nähe" zum Betriebssystem unterscheiden.
Man kann diese Arten als "highlevel" (weit weg vom OS), "lowlevel" (nahe dran am OS) und
"devicelevel" (direkter Zugriff auf Platte, CD-ROM; Umgehung des Filesystems) unterscheiden.

Die Arbeit mit AssignFile, BlockRead, CloseFile ist "highlevel" und ausserdem gepuffert.
Dagegen ist das Arbeiten mit TFileStream ist ungepuffert (der Cache des Betriebssystems ist aber dennoch wirksam) und näher am Betriebssystem.
Direkt am Betriebssystem sind die Windows API Funktionen CreateFile, ReadFile, CloseHandle.
Je näher du am Betriebssystem ansetzt, desto weniger Overhead ist enthalten und desto schwieriger
wird die Programmierung.

Andererseits wäre es möglich, dass man die Anzahl der Leseversuche irgendwo einstellen kann.
Du kannst ja mal die Forschung in Richtung: DeviceIoControl(hDevice, IOCTL_CHANGER_GET_PARAMETERS,..) richten.
Andreas
  Mit Zitat antworten Zitat
Benutzerbild von sakura
sakura

Registriert seit: 10. Jun 2002
Ort: Unterhaching
11.412 Beiträge
 
Delphi 12 Athens
 
#6

Re: Erkennungszeit von unlesbaren Bytes verkürzen?

  Alt 22. Jun 2004, 14:39
Zitat von shmia:
Dagegen ist das Arbeiten mit TFileStream ist ungepuffert (der Cache des Betriebssystems ist aber dennoch wirksam) und näher am Betriebssystem.
Sorry, aber die Aussage ist falsch. Auch TFileStream arbeitet mit den gepufferten Versionen. Intern ruft TFileStream die Function FileCreate aus SysUtils auf, welche nicht das Flag FILE_FLAG_WRITE_THROUGH setzt, welches den Dateipuffer umgeht.

Original Delphi-7-SysUtils Code:
Delphi-Quellcode:
function FileCreate(const FileName: string): Integer;
{$IFDEF MSWINDOWS}
begin
  Result := Integer(CreateFile(PChar(FileName), GENERIC_READ or GENERIC_WRITE,
    0, nil, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, 0));
end;
{$ENDIF}
{$IFDEF LINUX}
begin
  Result := FileCreate(FileName, FileAccessRights);
end;
{$ENDIF}
müsste aussehen wie folgend, um den Cache zu umgehen:
Code:
function FileCreate(const FileName: string): Integer;
{$IFDEF MSWINDOWS}
begin
  Result := Integer(CreateFile(PChar(FileName), GENERIC_READ or GENERIC_WRITE,
    0, nil, CREATE_ALWAYS, [color=#f50000]FILE_FLAG_WRITE_THROUGH or [/color]FILE_ATTRIBUTE_NORMAL,
    0));
end;
{$ENDIF}
{$IFDEF LINUX}
begin
  Result := FileCreate(FileName, FileAccessRights);
end;
{$ENDIF}
......
Daniel Lizbeth
Ich bin nicht zurück, ich tue nur so
  Mit Zitat antworten Zitat
Benutzerbild von sakura
sakura

Registriert seit: 10. Jun 2002
Ort: Unterhaching
11.412 Beiträge
 
Delphi 12 Athens
 
#7

Re: Erkennungszeit von unlesbaren Bytes verkürzen?

  Alt 22. Jun 2004, 14:40
Zitat von shmia:
(der Cache des Betriebssystems ist aber dennoch wirksam)
Sorry, überlesen

......
Daniel Lizbeth
Ich bin nicht zurück, ich tue nur so
  Mit Zitat antworten Zitat
Kernel32.DLL
(Gast)

n/a Beiträge
 
#8

Re: Erkennungszeit von unlesbaren Bytes verkürzen?

  Alt 22. Jun 2004, 15:40
Das hieße also, wenn ich die WinAPI Funktion CreateFile nehmen würde, und als zusätzlichen Flag "File_Flag_Write_Through" verwenden würde, könnte ich schonmal den DatenPuffer umgehen?

Kann ich vielleicht dann auf dieser Ebene die Zahl der Leseversuche einstellen?

Oder muss ich DeviceIOControl benutzen? Ich hab mich mit diesem Aufruf schonmal erfolglos rumgeschlagen...

Ne'n kleiner Beispiel-Code wär nicht schlecht bzw. eine Erklärung "How2do".

THX
Daniel
  Mit Zitat antworten Zitat
supermuckl

Registriert seit: 1. Feb 2003
1.340 Beiträge
 
FreePascal / Lazarus
 
#9

Re: Erkennungszeit von unlesbaren Bytes verkürzen?

  Alt 22. Jun 2004, 15:53
du könntest ja mal DVDDecrypter disassemblieren und schauen was der für funktionen bzw DLLs verwendet.. vielleicht is ja direkt was auffälliges dabei was die leute verwenden um sogar bei einem lesefehler überhaupt nicht nochmal zu versuchen zu readen
Das echte Leben ist was für Leute...
... die im Internet keine Freunde finden!
  Mit Zitat antworten Zitat
Benutzerbild von Ultimator
Ultimator

Registriert seit: 17. Feb 2004
Ort: Coburg
1.860 Beiträge
 
FreePascal / Lazarus
 
#10

Re: Erkennungszeit von unlesbaren Bytes verkürzen?

  Alt 22. Jun 2004, 15:55
*räusper* Ich glaube nicht, dass das i.O. ist. Die haben sich schließlich auch viel Mühe gegeben, das so hinzubiegen. Und dann kommt einer daher, disassembliert es und alles war wieder (fast) umsonst. Außerdem weiß man ja nicht, ob die da nicht n Patent drauf haben, wie das gemacht wird. Ich denke, dass es rechtlich zumindest bedenklich ist.
Julian J. Pracht
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 14:53 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz