AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Win32/Win64 API (native code) Delphi ISO-Image einer CDDA mit CreateFile und ReadFile möglich?
Thema durchsuchen
Ansicht
Themen-Optionen

ISO-Image einer CDDA mit CreateFile und ReadFile möglich?

Ein Thema von Garfield · begonnen am 3. Nov 2006 · letzter Beitrag vom 23. Dez 2006
Antwort Antwort
Seite 2 von 2     12   
Benutzerbild von OldGrumpy
OldGrumpy

Registriert seit: 28. Sep 2006
Ort: Sandhausen
941 Beiträge
 
Delphi 2006 Professional
 
#11

Re: ISO-Image einer CDDA mit CreateFile und ReadFile möglic

  Alt 1. Dez 2006, 22:27
Beim Lesen von Blockdevices muss die Leseposition eine Blockgrenze (bzw. der Anfang eines Blocks) sein, mittendrin anfangen zu lesen klappt nicht. Und weil in deiner Funktion oben (function ReadCDAudioSector) am Anfang mit CB_CDROMSECTOR gearbeitet wird, vermute ich mal dass da mit 2048 statt 2352 bzw. 2336 (je nach Trackmode) gerechnet wird - Der Lesezugriff schlägt dann auf die eine oder andere Art fehl. Beim direkten Lesen von USB-Devices muss darüber hinaus noch der Puffer im Speicher auf Speicherseiten aligned sein, so einen passend plazierten Puffer erhaelt man mittels VirtualAlloc. Ich hatte vor geraumer Zeit auch mal mit diesen Sourcen rumgespielt, dann aber irgendwann keine Zeit mehr gehabt, alles hinzubiegen.
"Tja ja, das Ausrufezeichen... Der virtuelle Spoiler des 21. Jahrhunderts, der Breitreifen für die Datenautobahn, die k3wle Sonnenbrille fürs Usenet. " (Henning Richter)
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.211 Beiträge
 
Delphi 12 Athens
 
#12

Re: ISO-Image einer CDDA mit CreateFile und ReadFile möglic

  Alt 2. Dez 2006, 12:22
Zitat von OldGrumpy:
Beim direkten Lesen von USB-Devices muss darüber hinaus noch der Puffer im Speicher auf Speicherseiten aligned sein, so einen passend plazierten Puffer erhaelt man mittels VirtualAlloc. Ich hatte vor geraumer Zeit auch mal mit diesen Sourcen rumgespielt, dann aber irgendwann keine Zeit mehr gehabt, alles hinzubiegen.
Dem ist ganz nicht so, daß kann ich dir inzwischen bestätigen ... jedenfalls nicht in "aktuellen" Systemen wie XP und 2000.

Laut Muetze1 (ich hoffe er war es) könnte das daran liegen, daß zum Auslesen der Speicher in 'nem bestimmten Bereich ganz weit vorn im RAM liegen muß und demnach Windows wohl über 'nen eigenen Zwischenspeicher geht und dann die Daten erst und deinen Speicher rüberkopiert werden, wobei dort egal ist wo dieser Speicher rumliegt.
Oder so in etwa ... jedenfalls geht es bei mir auch so, ohne aligned Speicher ... ist schon praktisch, wenn man da z.B. auch einfach etwas aus'm Stack nutzen kann und sich die Resourcenschutzblöcke, samt Speicherreservierung/-freigabe spart.

Aber Schaden kann es ja nie
$2B or not $2B
  Mit Zitat antworten Zitat
Muetze1
(Gast)

n/a Beiträge
 
#13

Re: ISO-Image einer CDDA mit CreateFile und ReadFile möglic

  Alt 2. Dez 2006, 12:41
Zitat von himitsu:
Zitat von OldGrumpy:
Beim direkten Lesen von USB-Devices muss darüber hinaus noch der Puffer im Speicher auf Speicherseiten aligned sein, so einen passend plazierten Puffer erhaelt man mittels VirtualAlloc. Ich hatte vor geraumer Zeit auch mal mit diesen Sourcen rumgespielt, dann aber irgendwann keine Zeit mehr gehabt, alles hinzubiegen.
Dem ist ganz nicht so, daß kann ich dir inzwischen bestätigen ... jedenfalls nicht in "aktuellen" Systemen wie XP und 2000.

Laut Muetze1 (ich hoffe er war es) könnte das daran liegen, daß zum Auslesen der Speicher in 'nem bestimmten Bereich ganz weit vorn im RAM liegen muß und demnach Windows wohl über 'nen eigenen Zwischenspeicher geht und dann die Daten erst und deinen Speicher rüberkopiert werden, wobei dort egal ist wo dieser Speicher rumliegt.
Oder so in etwa ... jedenfalls geht es bei mir auch so, ohne aligned Speicher ... ist schon praktisch, wenn man da z.B. auch einfach etwas aus'm Stack nutzen kann und sich die Resourcenschutzblöcke, samt Speicherreservierung/-freigabe spart.
Meine Aussage bezog auf den DMA Transfer, wobei der DMA Baustein keine "grossen" Adressen abkann und nur im unteren 1 MB arbeitet. Daher muss bei der DMA Übertragung der Speicher dort unten liegen. Unter Windows sorgt die WinAPI dafür und kopiert von diesem weiter - und dabei kommt dann kein DMA mehr zum Einsatz und die Adressen können auch "quer" liegen - dieses macht nur wieder den Zugriff der CPU langsamer durch die extra-cyclen die die CPU beim Data-fetch drehen muss...

Virtualisierungen im Sinne des V86 und Protected Modes gelten für die CPU und den Dingen die darauf ablaufen, der DMA Controller hängt aber ausserhalb der CPU im System und kümmert sich soweit selbstständig um die Datenübertragung kann nur mit physikalischen Adressen - und sein Register ist für diese beschränkt.
  Mit Zitat antworten Zitat
Benutzerbild von OldGrumpy
OldGrumpy

Registriert seit: 28. Sep 2006
Ort: Sandhausen
941 Beiträge
 
Delphi 2006 Professional
 
#14

Re: ISO-Image einer CDDA mit CreateFile und ReadFile möglic

  Alt 2. Dez 2006, 19:11
Zitat von himitsu:
Zitat von OldGrumpy:
Beim direkten Lesen von USB-Devices muss darüber hinaus noch der Puffer im Speicher auf Speicherseiten aligned sein, so einen passend plazierten Puffer erhaelt man mittels VirtualAlloc. Ich hatte vor geraumer Zeit auch mal mit diesen Sourcen rumgespielt, dann aber irgendwann keine Zeit mehr gehabt, alles hinzubiegen.
Dem ist ganz nicht so, daß kann ich dir inzwischen bestätigen ... jedenfalls nicht in "aktuellen" Systemen wie XP und 2000.
Sicher? Ich hatte nämlich vor gar nicht mal so langer Zeit genau so einen Fall: Memorycard im USB-Cardreader als physical device zum Lesen geöffnet. Lesen klappte auch super, nur stand im Puffer jede Menge Unsinn drin. Nach langem googlen hatte ich dann in der MSDN einen entsprechenden Hinweis gefunden. Nach Anlegen des Puffers mit VirtualAlloc funktionierte das Lesen dann einwandfrei...

Ich schau mal ob ich die Seite in der MSDN wiederfinde.

Edit: Hier isses: [msdn]http://msdn.microsoft.com/library/default.asp?url=/library/en-us/fileio/fs/readfile.asp[/msdn]

Allerdings hatte ich es etwas anders in Erinnerung, der Puffer muss sector-aligned sein. Da die Pagegröße praktisch immer ein Vielfaches der Sektorgröße ist, erfüllt das Alignment auf Pages den gleichen Zweck
Zitat von MSDN:
File access must begin at byte offsets within the file that are integer multiples of the volume sector size. To determine the sector size of a volume, call the GetDiskFreeSpace function.
File access must be for numbers of bytes that are integer multiples of the volume sector size. For example, if the sector size is 512 bytes, an application can request read and write operations of 512, 1024, 1536, or 2048 bytes, but not of 335, 981, or 7171 bytes.
Buffer addresses for read and write operations must be sector aligned (that is, aligned on addresses in memory that are integer multiples of the volume sector size).
One way to sector align buffers is to use the VirtualAlloc function to allocate the buffers. This function allocates memory that is aligned on addresses that are integer multiples of the system page size. Because both page and volume sector sizes are powers of 2 (two), memory aligned by multiples of the system page size is also aligned by multiples of the volume sector size.
"Tja ja, das Ausrufezeichen... Der virtuelle Spoiler des 21. Jahrhunderts, der Breitreifen für die Datenautobahn, die k3wle Sonnenbrille fürs Usenet. " (Henning Richter)
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.211 Beiträge
 
Delphi 12 Athens
 
#15

Re: ISO-Image einer CDDA mit CreateFile und ReadFile möglic

  Alt 4. Dez 2006, 17:32
@Muetze1: OK, wenn man dat so sieht, dann könnte es hinkommen

Zitat von OldGrumpy:
Sicher? Ich hatte nämlich vor gar nicht mal so langer Zeit genau so einen Fall: Memorycard im USB-Cardreader als physical device zum Lesen geöffnet. Lesen klappte auch super, nur stand im Puffer jede Menge Unsinn drin.
Jo, denn ich hatte es erst selber nur über nicht ausgerichteten Speicher gemacht und dann meinte Muetze1 der Speicher müsse ausgerichtet werden ... aber es ging/geht auch so. ^^

Bei ReadFile/WriteFile und beim DMA-Trasfer ... was an Daten drin stand war eigentlich ganz OK
$2B or not $2B
  Mit Zitat antworten Zitat
Benutzerbild von OldGrumpy
OldGrumpy

Registriert seit: 28. Sep 2006
Ort: Sandhausen
941 Beiträge
 
Delphi 2006 Professional
 
#16

Re: ISO-Image einer CDDA mit CreateFile und ReadFile möglic

  Alt 4. Dez 2006, 17:56
Vielleicht hattest Du einfach nur Glück und Deine Puffer waren zufällig halt entsprechend aligned Zumindest unter W2K (hab es später nicht mehr auf XP getestet, da ich es für sinnvoller hielt, eine Lösung zu implementieren die unter beiden Systemen funktioniert...) gehts mit krummen Werten definitiv nicht gut. Von mir aus kann ich gerne mal den Source rauswühlen und Samples posten
"Tja ja, das Ausrufezeichen... Der virtuelle Spoiler des 21. Jahrhunderts, der Breitreifen für die Datenautobahn, die k3wle Sonnenbrille fürs Usenet. " (Henning Richter)
  Mit Zitat antworten Zitat
Benutzerbild von Garfield
Garfield

Registriert seit: 9. Jul 2004
Ort: Aken (Anhalt-Bitterfeld)
1.335 Beiträge
 
Delphi XE5 Professional
 
#17

Re: ISO-Image einer CDDA mit CreateFile und ReadFile möglic

  Alt 23. Dez 2006, 22:19
Entschuldigung für die späte Antwort. Ich war ein paar Wochen auf Montage und hatte keinen Internetzugang.

Zitat von himitsu:
Was passiert wohl, wenn du versuchst eine schreibgeschützte CD mit Schreibrechten zu öffnen
Meiner Ansicht nach wird nicht die schreibgeschützte CD sondern das Gerät geöffnet. Falls der Benutzer keine Schreibrechte bzw in diesem Fall keine Brennrechte besitzt, erhält er auch kein gültiges Handle. Des weiteren sind für einige Funktionen wie im vorliegenden Fall Schreibrechte erforderlich. Deshalb arbeitet zum Beispiel VCDEasy mit SPTI nur unter Administratorkonten.

Zitat von himitsu:
Mal nachgesehen, ob die Sektoren wirklich 4096 Byte groß sind?
Diese Größe bezieht sich auf die Nutzdaten von zwei Datensektoren. Ist aber eher unwichtig, weil der Source funktioniert.

FILE_FLAG_NO_BUFFERING werde ich mal versuchen,

Zitat von OldGrumpy:
... Und weil in deiner Funktion oben (function ReadCDAudioSector) am Anfang mit CB_CDROMSECTOR gearbeitet wird, vermute ich mal dass da mit 2048 statt 2352 bzw. 2336 (je nach Trackmode) gerechnet wird - Der Lesezugriff schlägt dann auf die eine oder andere Art fehl.
Die Sektoren sind auf jeder CD gleich groß und unterscheiden sich lediglich im Aufbau. 2048, 2352 und 2336 sind dabei jeweils die Größe der Nutzdaten. AudioCD zum Beispiel: http://de.wikipedia.org/wiki/Audio-CD

In allen Sourcen, welche ich fand, wurde bei der Positionierung mit der Größe der Nutzdaten von Datensektoren gerechnet. Anschließend wird der Typ des Sektors eingestellt und die tatsächliche Größe der Nutzdaten gelesen.
Gruss Garfield
Ubuntu 22.04: Laz2.2.2/FPC3.2.2 - VirtBox6.1+W10: D7PE, DXE5Prof
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 2     12   


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 06:17 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 by Thomas Breitkreuz