diff --git a/CUETools.Ripper.SCSI/CRC16CCITT.cs b/CUETools.Ripper.SCSI/CRC16CCITT.cs new file mode 100644 index 0000000..e8409e3 --- /dev/null +++ b/CUETools.Ripper.SCSI/CRC16CCITT.cs @@ -0,0 +1,55 @@ +using System; +using System.Collections.Generic; +using System.Text; + +namespace CUETools.Ripper.SCSI +{ + public enum InitialCrcValue { Zeros, NonZero1 = 0xffff, NonZero2 = 0x1D0F } + + class Crc16Ccitt + { + const ushort poly = 4129; + ushort[] table = new ushort[256]; + ushort initialValue = 0; + + public ushort ComputeChecksum(byte[] bytes, int pos, int count) + { + ushort crc = this.initialValue; + for (int i = pos; i < pos + count; i++) + { + crc = (ushort)((crc << 8) ^ table[((crc >> 8) ^ (0xff & bytes[i]))]); + } + return crc; + } + + public byte[] ComputeChecksumBytes(byte[] bytes, int pos, int count) + { + ushort crc = ComputeChecksum(bytes, pos, count); + return new byte[] { (byte)(crc >> 8), (byte)(crc & 0x00ff) }; + } + + public Crc16Ccitt(InitialCrcValue initialValue) + { + this.initialValue = (ushort)initialValue; + ushort temp, a; + for (int i = 0; i < table.Length; i++) + { + temp = 0; + a = (ushort)(i << 8); + for (int j = 0; j < 8; j++) + { + if (((temp ^ a) & 0x8000) != 0) + { + temp = (ushort)((temp << 1) ^ poly); + } + else + { + temp <<= 1; + } + a <<= 1; + } + table[i] = temp; + } + } + } +} diff --git a/CUETools.Ripper.SCSI/Galois.cs b/CUETools.Ripper.SCSI/Galois.cs new file mode 100644 index 0000000..1153420 Binary files /dev/null and b/CUETools.Ripper.SCSI/Galois.cs differ diff --git a/CUETools.Ripper.SCSI/RsDecode.cs b/CUETools.Ripper.SCSI/RsDecode.cs new file mode 100644 index 0000000..8450ce1 Binary files /dev/null and b/CUETools.Ripper.SCSI/RsDecode.cs differ diff --git a/CUETools.Ripper.SCSI/RsEncode.cs b/CUETools.Ripper.SCSI/RsEncode.cs new file mode 100644 index 0000000..707c9df Binary files /dev/null and b/CUETools.Ripper.SCSI/RsEncode.cs differ