No, I didn't made any mistake while posting the dumps and Plextor ones are not the same: There are three 01s in the D8 dump (channels R-W) where in the READ CD dump are 00s. The only mistake I made is that XORing as explained does NOT result in Plextor's READ CD result but in LG's one. Tonight I will burn a test CD with some data on subchannels R-W and read that one out using D8 - should give some clue about what Plextor really returns on D8 as I don't have trust anymore that it really returns raw subchannel data for P-W. I deeply hope that it's a fault in my interleaving code but I don't believe so.
EDIT: If everything goes bad, a plain D8 dump wouldn't be sufficient. The proposed C2 reporting still needs a check and for now returned subchannel data doesn't look like being proper and as themabus set D8 along with code 08 can be guessed not to be supported by all D8-capable drives. I'm afraid we run into real problems here and have these variants:
1. We can choose between D8/08 and D8/02 for either receiving C2 pointers or correct subchannel data, the first one probably not supported by all drives.
2. If we go for D8/02 immediate re-read with normal READ CD command (and C2 pointer selection) might return the wanted C2 pointers, but only if the drive caches data, so this method is pretty unsafe IMO - but how to get C2 pointers for our D8-read data then?
3. As for audio sectors I believe READ CD pretty much should return the same data as D8 - shouldn't we switch to plain READ CD (+C2+SUB) after receiving the first audio sector with D8?
4. Are C2 pointers really needed when reading data sectors using D8? Wouldn't descrambling, calculating ECC/EDC and re-reads (maybe multiple times like EAC) on ECC/EDC differences between stored and calculated data be sufficient?