mirror of
https://github.com/aaru-dps/Aaru.git
synced 2025-12-16 19:24:25 +00:00
Add pregap to second session in redump gdrom
This commit is contained in:
@@ -120,15 +120,18 @@ namespace Aaru.DiscImages
|
|||||||
foreach((ushort index, int position) in cdrTrack.Indexes)
|
foreach((ushort index, int position) in cdrTrack.Indexes)
|
||||||
aaruTrack.Indexes[index] = position;
|
aaruTrack.Indexes[index] = position;
|
||||||
|
|
||||||
if(_discImage.IsRedumpGigadisc &&
|
|
||||||
cdrTrack.Session == 2 &&
|
|
||||||
previousStartSector < gdRomSession2Offset)
|
|
||||||
aaruTrack.StartSector = gdRomSession2Offset;
|
|
||||||
|
|
||||||
previousTrackFile = cdrTrack.TrackFile.DataFilter.Filename;
|
previousTrackFile = cdrTrack.TrackFile.DataFilter.Filename;
|
||||||
|
|
||||||
aaruTrack.EndSector = aaruTrack.StartSector + cdrTrack.Sectors - 1;
|
aaruTrack.EndSector = aaruTrack.StartSector + cdrTrack.Sectors - 1;
|
||||||
|
|
||||||
|
if(_discImage.IsRedumpGigadisc &&
|
||||||
|
cdrTrack.Session == 2 &&
|
||||||
|
previousStartSector < gdRomSession2Offset)
|
||||||
|
{
|
||||||
|
aaruTrack.StartSector = (ulong)cdrTrack.Indexes[0];
|
||||||
|
aaruTrack.EndSector = gdRomSession2Offset + cdrTrack.Sectors - (uint)cdrTrack.Pregap - 1;
|
||||||
|
}
|
||||||
|
|
||||||
if(cdrTrack.TrackType == CDRWIN_TRACK_TYPE_CDG)
|
if(cdrTrack.TrackType == CDRWIN_TRACK_TYPE_CDG)
|
||||||
{
|
{
|
||||||
aaruTrack.SubchannelFilter = cdrTrack.TrackFile.DataFilter;
|
aaruTrack.SubchannelFilter = cdrTrack.TrackFile.DataFilter;
|
||||||
|
|||||||
@@ -1319,8 +1319,10 @@ namespace Aaru.DiscImages
|
|||||||
track.Session == 2 &&
|
track.Session == 2 &&
|
||||||
firstTrackInSession)
|
firstTrackInSession)
|
||||||
{
|
{
|
||||||
track.Indexes.Add(0, (int)(0 - (ulong)track.Pregap));
|
currentSector = (int)gdRomSession2Offset - track.Pregap;
|
||||||
currentSector = (int)gdRomSession2Offset;
|
track.Indexes.Add(0, 0);
|
||||||
|
track.Indexes[1] = track.Pregap;
|
||||||
|
track.Sectors += (ulong)track.Pregap;
|
||||||
firstTrackInSession = false;
|
firstTrackInSession = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1420,7 +1422,8 @@ namespace Aaru.DiscImages
|
|||||||
|
|
||||||
if(_discImage.IsRedumpGigadisc &&
|
if(_discImage.IsRedumpGigadisc &&
|
||||||
_discImage.Tracks[i].Sequence == 3)
|
_discImage.Tracks[i].Sequence == 3)
|
||||||
_offsetMap.Add(_discImage.Tracks[i].Sequence, gdRomSession2Offset);
|
_offsetMap.Add(_discImage.Tracks[i].Sequence,
|
||||||
|
gdRomSession2Offset - (ulong)_discImage.Tracks[i].Pregap);
|
||||||
else if(_discImage.Tracks[i].Indexes.TryGetValue(0, out int idx0))
|
else if(_discImage.Tracks[i].Indexes.TryGetValue(0, out int idx0))
|
||||||
_offsetMap.Add(_discImage.Tracks[i].Sequence, (ulong)idx0);
|
_offsetMap.Add(_discImage.Tracks[i].Sequence, (ulong)idx0);
|
||||||
else if(_discImage.Tracks[i].Sequence > 1)
|
else if(_discImage.Tracks[i].Sequence > 1)
|
||||||
@@ -1824,6 +1827,29 @@ namespace Aaru.DiscImages
|
|||||||
sectorAddress -= _lostPregap;
|
sectorAddress -= _lostPregap;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(_discImage.IsRedumpGigadisc &&
|
||||||
|
aaruTrack.Session == 2 &&
|
||||||
|
aaruTrack.Indexes[0] >= 45000 - aaruTrack.Pregap &&
|
||||||
|
aaruTrack.Indexes[1] <= 45000)
|
||||||
|
{
|
||||||
|
if(sectorAddress < (ulong)(aaruTrack.Indexes[1] - aaruTrack.Indexes[0]))
|
||||||
|
{
|
||||||
|
if(sectorAddress + length + (ulong)aaruTrack.Indexes[0] <= (ulong)aaruTrack.Indexes[1])
|
||||||
|
return buffer;
|
||||||
|
|
||||||
|
ulong pregapPos = (ulong)(aaruTrack.Indexes[1] - aaruTrack.Indexes[0]) - sectorAddress;
|
||||||
|
|
||||||
|
byte[] presentData = ReadSectors((ulong)(aaruTrack.Indexes[1] - aaruTrack.Indexes[0]),
|
||||||
|
(uint)(length - pregapPos), track);
|
||||||
|
|
||||||
|
Array.Copy(presentData, 0, buffer, (long)(pregapPos * sectorSize), presentData.Length);
|
||||||
|
|
||||||
|
return buffer;
|
||||||
|
}
|
||||||
|
|
||||||
|
sectorAddress -= (ulong)(aaruTrack.Indexes[1] - aaruTrack.Indexes[0]);
|
||||||
|
}
|
||||||
|
|
||||||
_imageStream = aaruTrack.TrackFile.DataFilter.GetDataForkStream();
|
_imageStream = aaruTrack.TrackFile.DataFilter.GetDataForkStream();
|
||||||
var br = new BinaryReader(_imageStream);
|
var br = new BinaryReader(_imageStream);
|
||||||
|
|
||||||
@@ -2239,6 +2265,29 @@ namespace Aaru.DiscImages
|
|||||||
sectorAddress -= _lostPregap;
|
sectorAddress -= _lostPregap;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(_discImage.IsRedumpGigadisc &&
|
||||||
|
aaruTrack.Session == 2 &&
|
||||||
|
aaruTrack.Indexes[0] >= 45000 - aaruTrack.Pregap &&
|
||||||
|
aaruTrack.Indexes[1] <= 45000)
|
||||||
|
{
|
||||||
|
if(sectorAddress < (ulong)(aaruTrack.Indexes[1] - aaruTrack.Indexes[0]))
|
||||||
|
{
|
||||||
|
if(sectorAddress + length + (ulong)aaruTrack.Indexes[0] <= (ulong)aaruTrack.Indexes[1])
|
||||||
|
return buffer;
|
||||||
|
|
||||||
|
ulong pregapPos = (ulong)(aaruTrack.Indexes[1] - aaruTrack.Indexes[0]) - sectorAddress;
|
||||||
|
|
||||||
|
byte[] presentData = ReadSectorsLong((ulong)(aaruTrack.Indexes[1] - aaruTrack.Indexes[0]),
|
||||||
|
(uint)(length - pregapPos), track);
|
||||||
|
|
||||||
|
Array.Copy(presentData, 0, buffer, (long)(pregapPos * sectorSize), presentData.Length);
|
||||||
|
|
||||||
|
return buffer;
|
||||||
|
}
|
||||||
|
|
||||||
|
sectorAddress -= (ulong)(aaruTrack.Indexes[1] - aaruTrack.Indexes[0]);
|
||||||
|
}
|
||||||
|
|
||||||
_imageStream = aaruTrack.TrackFile.DataFilter.GetDataForkStream();
|
_imageStream = aaruTrack.TrackFile.DataFilter.GetDataForkStream();
|
||||||
var br = new BinaryReader(_imageStream);
|
var br = new BinaryReader(_imageStream);
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user