Add pregap to second session in redump gdrom

This commit is contained in:
Rebecca Wallander
2021-09-25 20:49:57 +01:00
committed by Natalia Portillo
parent 8b4d3f7254
commit bfd5b4f390
2 changed files with 61 additions and 9 deletions

View File

@@ -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;

View File

@@ -1319,9 +1319,11 @@ 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);
firstTrackInSession = false; track.Indexes[1] = track.Pregap;
track.Sectors += (ulong)track.Pregap;
firstTrackInSession = false;
} }
currentFileStartSector = currentSector; currentFileStartSector = currentSector;
@@ -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);