mirror of
https://github.com/aaru-dps/Aaru.git
synced 2025-12-16 19:24:25 +00:00
* LICENSE.LGPL: Added LICENSE files for LGPL and MIT licenses. * DiscImageChef.Devices/Enums.cs: * DiscImageChef.Partitions/MBR.cs: * DiscImageChef.Partitions/RDB.cs: * DiscImageChef.DiscImages/GDI.cs: * DiscImageChef.Partitions/Sun.cs: * DiscImageChef.DiscImages/VHD.cs: * DiscImageChef.Partitions/GPT.cs: * DiscImageChef.Filesystems/FFS.cs: * DiscImageChef.Filesystems/FAT.cs: * DiscImageChef.Partitions/NeXT.cs: * DiscImageChef.Devices/Command.cs: * DiscImageChef.DiscImages/Nero.cs: * DiscImageChef.Decoders/CD/PMA.cs: * DiscImageChef.Decoders/CD/TOC.cs: * DiscImageChef.Filesystems/BFS.cs: * DiscImageChef.Filesystems/ODS.cs: * DiscImageChef.Helpers/PrintHex.cs: * DiscImageChef.Helpers/Swapping.cs: * DiscImageChef.Decoders/DVD/PRI.cs: * DiscImageChef.Decoders/DVD/DMI.cs: * DiscImageChef.Decoders/DVD/DDS.cs: * DiscImageChef.Decoders/DVD/RMD.cs: * DiscImageChef.Decoders/DVD/UDI.cs: * DiscImageChef.Partitions/Atari.cs: * DiscImageChef.Decoders/DVD/BCA.cs: * DiscImageChef.Filesystems/SysV.cs: * DiscImageChef.Filesystems/HPFS.cs: * DiscImageChef.Filesystems/NTFS.cs: * DiscImageChef.Filesystems/APFS.cs: * DiscImageChef.Decoders/DVD/PFI.cs: * DiscImageChef.Decoders/CD/ATIP.cs: * DiscImageChef.Filesystems/Acorn.cs: * DiscImageChef.DiscImages/CDRWin.cs: * DiscImageChef.DiscImages/CDRDAO.cs: * DiscImageChef.Filesystems/BTRFS.cs: * DiscImageChef.Decoders/Xbox/DMI.cs: * DiscImageChef.Helpers/ArrayFill.cs: * DiscImageChef.Settings/Settings.cs: * DiscImageChef.Filesystems/Opera.cs: * DiscImageChef.Filesystems/extFS.cs: * DiscImageChef.Decoders/DVD/CPRM.cs: * DiscImageChef.Decoders/DVD/ADIP.cs: * DiscImageChef.Decoders/CD/Enums.cs: * DiscImageChef.Decoders/DVD/AACS.cs: * DiscImageChef.Decoders/SCSI/EVPD.cs: * DiscImageChef.Filesystems/ProDOS.cs: * DiscImageChef.Metadata/MediaType.cs: * DiscImageChef.Console/DicConsole.cs: * DiscImageChef.Decoders/DVD/Spare.cs: * DiscImageChef.Filesystems/ext2FS.cs: * DiscImageChef.Decoders/DVD/Enums.cs: * DiscImageChef.Filesystems/Symbian.cs: * DiscImageChef.Decoders/SCSI/Types.cs: * DiscImageChef.Filesystems/UNIXBFS.cs: * DiscImageChef.DiscImages/TeleDisk.cs: * DiscImageChef.Decoders/SCSI/Sense.cs: * DiscImageChef.Decoders/CD/FullTOC.cs: * DiscImageChef.Decoders/Blu-ray/DI.cs: * DiscImageChef.Decoders/ATA/Errors.cs: * DiscImageChef.Filesystems/ISO9660.cs: * DiscImageChef.Filesystems/MinixFS.cs: * DiscImageChef.Devices/Linux/Enums.cs: * DiscImageChef.Filesystems/SolarFS.cs: * DiscImageChef.Filesystems/Structs.cs: * DiscImageChef.DiscImages/Apple2MG.cs: * DiscImageChef.Decoders/SCSI/Modes.cs: * DiscImageChef.Metadata/Dimensions.cs: * DiscImageChef.Partitions/AppleMap.cs: * DiscImageChef.Decoders/Floppy/ISO.cs: * DiscImageChef.Decoders/DVD/Layers.cs: * DiscImageChef.Decoders/CD/Session.cs: * DiscImageChef.Decoders/SCSI/Enums.cs: * DiscImageChef.Filesystems/Nintendo.cs: * DiscImageChef.Helpers/DateHandlers.cs: * DiscImageChef.Filesystems/AmigaDOS.cs: * DiscImageChef.DiscImages/ImageInfo.cs: * DiscImageChef.Checksums/MD5Context.cs: * DiscImageChef.Devices/Linux/Extern.cs: * DiscImageChef.Filesystems/AppleHFS.cs: * DiscImageChef.Filesystems/AppleMFS.cs: * DiscImageChef.Helpers/ArrayIsEmpty.cs: * DiscImageChef.Decoders/Blu-ray/BCA.cs: * DiscImageChef.Decoders/Blu-ray/DDS.cs: * DiscImageChef.Filesystems/PCEngine.cs: * DiscImageChef.Decoders/ATA/Identify.cs: * DiscImageChef.Devices/Linux/Command.cs: * DiscImageChef.Devices/FreeBSD/Enums.cs: * DiscImageChef.Decoders/SCSI/Inquiry.cs: * DiscImageChef.Metadata/DeviceReport.cs: * DiscImageChef.Decoders/Floppy/Amiga.cs: * DiscImageChef.Devices/Linux/Structs.cs: * DiscImageChef.Devices/Windows/Enums.cs: * DiscImageChef.Decoders/DVD/CSS&CPRM.cs: * DiscImageChef.Checksums/SHA1Context.cs: * DiscImageChef.DiscImages/DiskCopy42.cs: * DiscImageChef.Partitions/PartPlugin.cs: * DiscImageChef.CommonTypes/Partition.cs: * DiscImageChef.Decoders/Floppy/Enums.cs: * DiscImageChef.CommonTypes/MediaType.cs: * DiscImageChef.Decoders/Floppy/Apple2.cs: * DiscImageChef.Devices/Windows/Extern.cs: * DiscImageChef.Decoders/SCSI/MMC/CPRM.cs: * DiscImageChef.Helpers/StringHandlers.cs: * DiscImageChef.DiscImages/ImagePlugin.cs: * DiscImageChef.Checksums/CRC64Context.cs: * DiscImageChef.Checksums/CRC32Context.cs: * DiscImageChef.DiscImages/ZZZRawImage.cs: * DiscImageChef.Checksums/CRC16Context.cs: * DiscImageChef.Filesystems/LisaFS/Dir.cs: * DiscImageChef.Decoders/DVD/Cartridge.cs: * DiscImageChef.Decoders/Blu-ray/Spare.cs: * DiscImageChef.Filesystems/Filesystem.cs: * DiscImageChef.Decoders/SCSI/MMC/AACS.cs: * DiscImageChef.Devices/FreeBSD/Extern.cs: * DiscImageChef.Devices/Device/Commands.cs: * DiscImageChef.Checksums/SHA384Context.cs: * DiscImageChef.Devices/FreeBSD/Command.cs: * DiscImageChef.Checksums/SHA512Context.cs: * DiscImageChef.Decoders/SCSI/MMC/Enums.cs: * DiscImageChef.Devices/Windows/Command.cs: * DiscImageChef.Devices/FreeBSD/Structs.cs: * DiscImageChef.Devices/Windows/Structs.cs: * DiscImageChef.Filesystems/LisaFS/Info.cs: * DiscImageChef.Checksums/SHA256Context.cs: * DiscImageChef.Filesystems/LisaFS/File.cs: * DiscImageChef.Filesystems/AppleHFSPlus.cs: * DiscImageChef.Filesystems/LisaFS/Super.cs: * DiscImageChef.Filesystems/LisaFS/Xattr.cs: * DiscImageChef.Checksums/Adler32Context.cs: * DiscImageChef.Decoders/Floppy/System34.cs: * DiscImageChef.Checksums/SpamSumContext.cs: * DiscImageChef.Decoders/SCSI/MMC/Hybrid.cs: * DiscImageChef.Devices/Device/Variables.cs: * DiscImageChef.Filesystems/LisaFS/Consts.cs: * DiscImageChef.Filesystems/LisaFS/LisaFS.cs: * DiscImageChef.Decoders/Floppy/Commodore.cs: * DiscImageChef.Checksums/FletcherContext.cs: * DiscImageChef.Filesystems/LisaFS/Extent.cs: * DiscImageChef.Devices/Device/Destructor.cs: * DiscImageChef.Decoders/Floppy/AppleSony.cs: * DiscImageChef.Filesystems/LisaFS/Structs.cs: * DiscImageChef.Decoders/SCSI/VendorString.cs: * DiscImageChef.Decoders/SCSI/MMC/Features.cs: * DiscImageChef.Devices/Device/Constructor.cs: * DiscImageChef.Checksums/RIPEMD160Context.cs: * DiscImageChef.Decoders/CD/CDTextOnLeadIn.cs: * DiscImageChef.Decoders/Blu-ray/Cartridge.cs: * DiscImageChef.Decoders/Floppy/System3740.cs: * DiscImageChef.Filesystems/LisaFS/Encoding.cs: * DiscImageChef.Decoders/SCSI/ModesEncoders.cs: * DiscImageChef.CommonTypes/MediaTypeFromSCSI.cs: * DiscImageChef.Helpers/BigEndianBitConverter.cs: * DiscImageChef.Decoders/Floppy/Perpendicular.cs: * DiscImageChef.Decoders/SCSI/SSC/BlockLimits.cs: * DiscImageChef.Decoders/SCSI/MMC/WriteProtect.cs: * DiscImageChef.Devices/Device/ScsiCommands/HP.cs: * DiscImageChef.Devices/Device/AtaCommands/Cfa.cs: * DiscImageChef.Devices/Device/ScsiCommands/NEC.cs: * DiscImageChef.Helpers/EndianAwareBinaryReader.cs: * DiscImageChef.Devices/Device/ScsiCommands/MMC.cs: * DiscImageChef.Devices/Device/AtaCommands/MCPT.cs: * DiscImageChef.Devices/Device/ScsiCommands/SSC.cs: * DiscImageChef.Devices/Device/ScsiCommands/SPC.cs: * DiscImageChef.Devices/Device/ScsiCommands/SMC.cs: * DiscImageChef.Devices/Device/ScsiCommands/SBC.cs: * DiscImageChef.Metadata/Properties/AssemblyInfo.cs: * DiscImageChef.Devices/Device/AtaCommands/Atapi.cs: * DiscImageChef.Devices/Device/AtaCommands/Ata28.cs: * DiscImageChef.Devices/Device/AtaCommands/Smart.cs: * DiscImageChef.Decoders/SCSI/SSC/DensitySupport.cs: * DiscImageChef.Devices/Device/AtaCommands/Ata48.cs: * DiscImageChef.Decoders/SCSI/MMC/DiscInformation.cs: * DiscImageChef.Devices/Device/AtaCommands/AtaCHS.cs: * DiscImageChef.Devices/Device/ScsiCommands/SyQuest.cs: * DiscImageChef.Devices/Device/ScsiCommands/Plextor.cs: * DiscImageChef.Devices/Device/ScsiCommands/Plasmon.cs: * DiscImageChef.Devices/Device/ScsiCommands/Pioneer.cs: * DiscImageChef.Devices/Device/ScsiCommands/Adaptec.cs: * DiscImageChef.Devices/Device/ScsiCommands/Fujitsu.cs: * DiscImageChef.Devices/Device/ScsiCommands/HL-DT-ST.cs: * DiscImageChef.Devices/Device/ScsiCommands/Certance.cs: * DiscImageChef.Decoders/SCSI/DiscStructureCapabilities.cs: * DiscImageChef.Devices/Device/ScsiCommands/ArchiveCorp.cs: Relicensed as LGPL. Updated standard header. * DiscImageChef/Main.cs: * DiscImageChef/Plugins.cs: * DiscImageChef/Options.cs: * DiscImageChef/Commands/Ls.cs: * DiscImageChef/Core/IBGLog.cs: * DiscImageChef/Core/MHDDLog.cs: * DiscImageChef/AssemblyInfo.cs: * DiscImageChef/Core/Checksum.cs: * DiscImageChef/Commands/Decode.cs: * DiscImageChef/Core/Statistics.cs: * DiscImageChef/Commands/Verify.cs: * DiscImageChef/Commands/Formats.cs: * DiscImageChef/Commands/Entropy.cs: * DiscImageChef/Commands/Compare.cs: * DiscImageChef.Interop/DetectOS.cs: * DiscImageChef/Commands/Analyze.cs: * DiscImageChef/Commands/Commands.cs: * DiscImageChef/Commands/PrintHex.cs: * DiscImageChef/Commands/Checksum.cs: * DiscImageChef/DetectImageFormat.cs: * DiscImageChef/Commands/DumpMedia.cs: * DiscImageChef/Commands/Benchmark.cs: * DiscImageChef/Commands/Configure.cs: * DiscImageChef/Commands/MediaInfo.cs: * DiscImageChef.Interop/PlatformID.cs: * DiscImageChef/Commands/MediaScan.cs: * DiscImageChef/Commands/Statistics.cs: * DiscImageChef/Commands/DeviceInfo.cs: * DiscImageChef.Checksums/ReedSolomon.cs: * DiscImageChef/Commands/DeviceReport.cs: * DiscImageChef/Commands/ExtractFiles.cs: * DiscImageChef.Checksums/CDChecksums.cs: * DiscImageChef/Commands/CreateSidecar.cs: Updated standard header. * DiscImageChef.Checksums/DiscImageChef.Checksums.csproj: Relicensed project as LGPL. Updated standard header. Embed license as resource. * DiscImageChef.Console/DiscImageChef.Console.csproj: * DiscImageChef.Devices/DiscImageChef.Devices.csproj: * DiscImageChef.Helpers/DiscImageChef.Helpers.csproj: * DiscImageChef.Settings/DiscImageChef.Settings.csproj: * DiscImageChef.Decoders/DiscImageChef.Decoders.csproj: * DiscImageChef.Metadata/DiscImageChef.Metadata.csproj: * DiscImageChef.Partitions/DiscImageChef.Partitions.csproj: * DiscImageChef.DiscImages/DiscImageChef.DiscImages.csproj: * DiscImageChef.Filesystems/DiscImageChef.Filesystems.csproj: * DiscImageChef.CommonTypes/DiscImageChef.CommonTypes.csproj: Relicensed as LGPL. Updated standard header. Embed license as resource. * DiscImageChef/DiscImageChef.csproj: * DiscImageChef.Interop/DiscImageChef.Interop.csproj: Updated standard header. Embed license as resource.
5775 lines
171 KiB
C#
5775 lines
171 KiB
C#
// /***************************************************************************
|
|
// The Disc Image Chef
|
|
// ----------------------------------------------------------------------------
|
|
//
|
|
// Filename : Features.cs
|
|
// Author(s) : Natalia Portillo <claunia@claunia.com>
|
|
//
|
|
// Component : Device structures decoders.
|
|
//
|
|
// --[ Description ] ----------------------------------------------------------
|
|
//
|
|
// Decodes SCSI's MMC feature structures.
|
|
//
|
|
// --[ License ] --------------------------------------------------------------
|
|
//
|
|
// This library is free software; you can redistribute it and/or modify
|
|
// it under the terms of the GNU Lesser General Public License as
|
|
// published by the Free Software Foundation; either version 2.1 of the
|
|
// License, or (at your option) any later version.
|
|
//
|
|
// This library is distributed in the hope that it will be useful, but
|
|
// WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
// Lesser General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU Lesser General Public
|
|
// License along with this library; if not, see <http://www.gnu.org/licenses/>.
|
|
//
|
|
// ----------------------------------------------------------------------------
|
|
// Copyright © 2011-2016 Natalia Portillo
|
|
// ****************************************************************************/
|
|
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.Text;
|
|
|
|
|
|
namespace DiscImageChef.Decoders.SCSI.MMC
|
|
{
|
|
|
|
/// <summary>
|
|
/// MMC Feature enumeration
|
|
/// </summary>
|
|
public enum FeatureNumber : ushort
|
|
{
|
|
/// <summary>
|
|
/// Lists all profiles
|
|
/// </summary>
|
|
ProfileList = 0x0000,
|
|
/// <summary>
|
|
/// Mandatory behaviour
|
|
/// </summary>
|
|
Core = 0x0001,
|
|
/// <summary>
|
|
/// Operational changes
|
|
/// </summary>
|
|
Morphing = 0x0002,
|
|
/// <summary>
|
|
/// Removable medium
|
|
/// </summary>
|
|
Removable = 0x0003,
|
|
/// <summary>
|
|
/// Ability to control write protection status
|
|
/// </summary>
|
|
WriteProtect = 0x0004,
|
|
/// <summary>
|
|
/// Ability to read sectors with random addressing
|
|
/// </summary>
|
|
RandomRead = 0x0010,
|
|
/// <summary>
|
|
/// Reads on OSTA Multi-Read
|
|
/// </summary>
|
|
MultiRead = 0x001D,
|
|
/// <summary>
|
|
/// Able to read CD structures
|
|
/// </summary>
|
|
CDRead = 0x001E,
|
|
/// <summary>
|
|
/// Able to read DVD structures
|
|
/// </summary>
|
|
DVDRead = 0x001F,
|
|
/// <summary>
|
|
/// Ability to write sectors with random addressing
|
|
/// </summary>
|
|
RandomWrite = 0x0020,
|
|
/// <summary>
|
|
/// Ability to sequentially write
|
|
/// </summary>
|
|
IncrementalWrite = 0x0021,
|
|
/// <summary>
|
|
/// Support for media that requires erase before write
|
|
/// </summary>
|
|
SectorErasable = 0x0022,
|
|
/// <summary>
|
|
/// Supports formatting media
|
|
/// </summary>
|
|
Formattable = 0x0023,
|
|
/// <summary>
|
|
/// Ability to provide defect-free space
|
|
/// </summary>
|
|
HardwareDefectMgmt = 0x0024,
|
|
/// <summary>
|
|
/// Supports for write-once media in random order
|
|
/// </summary>
|
|
WriteOnce = 0x0025,
|
|
/// <summary>
|
|
/// Supports for media that shall be written from blocking boundaries
|
|
/// </summary>
|
|
RestrictedOverwrite = 0x0026,
|
|
/// <summary>
|
|
/// Supports high speed CD-RW
|
|
/// </summary>
|
|
CDRWCAV = 0x0027,
|
|
/// <summary>
|
|
/// Read and optionally write MRW
|
|
/// </summary>
|
|
MRW = 0x0028,
|
|
/// <summary>
|
|
/// Ability to control RECOVERED ERROR reporting
|
|
/// </summary>
|
|
EnDefectReport = 0x0029,
|
|
/// <summary>
|
|
/// Ability to recognize, read and optionally write DVD+RW
|
|
/// </summary>
|
|
DVDRWPlus = 0x002A,
|
|
/// <summary>
|
|
/// Ability to read DVD+R
|
|
/// </summary>
|
|
DVDRPlus = 0x002B,
|
|
RigidOverWrite = 0x002C,
|
|
/// <summary>
|
|
/// Ability to write CD in Track-at-Once
|
|
/// </summary>
|
|
CDTAO = 0x002D,
|
|
/// <summary>
|
|
/// Ability to write CD in Session-at-Once or RAW
|
|
/// </summary>
|
|
CDMastering = 0x002E,
|
|
/// <summary>
|
|
/// Ability to write DVD structures
|
|
/// </summary>
|
|
DVDRWrite = 0x002F,
|
|
/// <summary>
|
|
/// Ability to read DDCD
|
|
/// </summary>
|
|
DDCD = 0x0030,
|
|
/// <summary>
|
|
/// Ability to write DDCD-R
|
|
/// </summary>
|
|
DDCDR = 0x0031,
|
|
/// <summary>
|
|
/// Ability to write DDCD-RW
|
|
/// </summary>
|
|
DDCDRW = 0x0032,
|
|
/// <summary>
|
|
/// Ability to record in layer jump mode
|
|
/// </summary>
|
|
LayerJump = 0x0033,
|
|
/// <summary>
|
|
/// Ability to perform Layer Jump recording on Rigid Restricted Overwrite
|
|
/// </summary>
|
|
LJRigid = 0x0034,
|
|
/// <summary>
|
|
/// Ability to stop the long immediate operation
|
|
/// </summary>
|
|
StopLong = 0x0035,
|
|
/// <summary>
|
|
/// Ability to report CD-RW media sub-types supported for write
|
|
/// </summary>
|
|
CDRWMediaWrite = 0x0037,
|
|
/// <summary>
|
|
/// Logical block overwrite service on BD-R formatted as SRM+POW
|
|
/// </summary>
|
|
BDRPOW = 0x0038,
|
|
/// <summary>
|
|
/// Ability to read DVD+RW DL
|
|
/// </summary>
|
|
DVDRWDLPlus = 0x003A,
|
|
/// <summary>
|
|
/// Ability to read DVD+R DL
|
|
/// </summary>
|
|
DVDRDLPlus = 0x003B,
|
|
/// <summary>
|
|
/// Ability to read BD discs
|
|
/// </summary>
|
|
BDRead = 0x0040,
|
|
/// <summary>
|
|
/// Ability to write BD discs
|
|
/// </summary>
|
|
BDWrite = 0x0041,
|
|
/// <summary>
|
|
/// Timely, Safe Recording
|
|
/// </summary>
|
|
TSR = 0x0042,
|
|
/// <summary>
|
|
/// Ability to read HD DVD
|
|
/// </summary>
|
|
HDDVDRead = 0x0050,
|
|
/// <summary>
|
|
/// Ability to write HD DVD
|
|
/// </summary>
|
|
HDDVDWrite = 0x0051,
|
|
/// <summary>
|
|
/// Ability to write HD DVD-RW fragmented
|
|
/// </summary>
|
|
HDDVDRWFragment = 0x0052,
|
|
/// <summary>
|
|
/// Supports some Hybrid Discs
|
|
/// </summary>
|
|
Hybrid = 0x0080,
|
|
/// <summary>
|
|
/// Host and device directed power management
|
|
/// </summary>
|
|
PowerMgmt = 0x0100,
|
|
/// <summary>
|
|
/// Supports S.M.A.R.T.
|
|
/// </summary>
|
|
SMART = 0x0101,
|
|
/// <summary>
|
|
/// Single machanism multiple disc changer
|
|
/// </summary>
|
|
Changer = 0x0102,
|
|
/// <summary>
|
|
/// Ability to play CD audio to an analogue output
|
|
/// </summary>
|
|
CDAudioExt = 0x0103,
|
|
/// <summary>
|
|
/// Ability to accept new microcode
|
|
/// </summary>
|
|
MicrocodeUpgrade = 0x0104,
|
|
/// <summary>
|
|
/// Ability to respond to all commands within a specific time
|
|
/// </summary>
|
|
Timeout = 0x0105,
|
|
/// <summary>
|
|
/// Supports DVD CSS/CPPM
|
|
/// </summary>
|
|
CSS = 0x0106,
|
|
/// <summary>
|
|
/// Ability to read and write using host requested performance parameters
|
|
/// </summary>
|
|
RTS = 0x0107,
|
|
/// <summary>
|
|
/// Drive has a unique identifier
|
|
/// </summary>
|
|
DriveSerial = 0x0108,
|
|
/// <summary>
|
|
/// Ability to return unique Media Serial Number
|
|
/// </summary>
|
|
MediaSerial = 0x0109,
|
|
/// <summary>
|
|
/// Ability to read and/or write DCBs
|
|
/// </summary>
|
|
DCBs = 0x010A,
|
|
/// <summary>
|
|
/// Supports DVD CPRM
|
|
/// </summary>
|
|
CPRM = 0x010B,
|
|
/// <summary>
|
|
/// Firmware creation date report
|
|
/// </summary>
|
|
FirmwareInfo = 0x010C,
|
|
/// <summary>
|
|
/// Ability to decode and optionally encode AACS
|
|
/// </summary>
|
|
AACS = 0x010D,
|
|
/// <summary>
|
|
/// Ability to perform DVD CSS managed recording
|
|
/// </summary>
|
|
CSSManagedRec = 0x010E,
|
|
/// <summary>
|
|
/// Ability to decode and optionally encode VCPS
|
|
/// </summary>
|
|
VCPS = 0x0110,
|
|
/// <summary>
|
|
/// Supports SecurDisc
|
|
/// </summary>
|
|
SecurDisc = 0x0113,
|
|
/// <summary>
|
|
/// TCG Optical Security Subsystem Class
|
|
/// </summary>
|
|
OSSC = 0x0142
|
|
}
|
|
|
|
/// <summary>
|
|
/// MMC Profile enumeration
|
|
/// </summary>
|
|
public enum ProfileNumber : ushort
|
|
{
|
|
/// <summary>
|
|
/// Not to use
|
|
/// </summary>
|
|
Reserved = 0x0000,
|
|
/// <summary>
|
|
/// Non-removable disk profile
|
|
/// </summary>
|
|
NonRemovable = 0x0001,
|
|
/// <summary>
|
|
/// Rewritable with removable media
|
|
/// </summary>
|
|
Removable = 0x0002,
|
|
/// <summary>
|
|
/// Magneto-Optical with sector erase
|
|
/// </summary>
|
|
MOErasable = 0x0003,
|
|
/// <summary>
|
|
/// Optical write once
|
|
/// </summary>
|
|
OpticalWORM = 0x0004,
|
|
/// <summary>
|
|
/// Advance Storage - Magneto-Optical
|
|
/// </summary>
|
|
ASMO = 0x0005,
|
|
/// <summary>
|
|
/// Read-only Compact Disc
|
|
/// </summary>
|
|
CDROM = 0x0008,
|
|
/// <summary>
|
|
/// Write-once Compact Disc
|
|
/// </summary>
|
|
CDR = 0x0009,
|
|
/// <summary>
|
|
/// Re-writable Compact Disc
|
|
/// </summary>
|
|
CDRW = 0x000A,
|
|
/// <summary>
|
|
/// Read-only DVD
|
|
/// </summary>
|
|
DVDROM = 0x0010,
|
|
/// <summary>
|
|
/// Write-once sequentially recorded DVD-R
|
|
/// </summary>
|
|
DVDRSeq = 0x0011,
|
|
/// <summary>
|
|
/// DVD-RAM
|
|
/// </summary>
|
|
DVDRAM = 0x0012,
|
|
/// <summary>
|
|
/// Restricted overwrite DVD-RW
|
|
/// </summary>
|
|
DVDRWRes = 0x0013,
|
|
/// <summary>
|
|
/// Sequential recording DVD-RW
|
|
/// </summary>
|
|
DVDRWSeq = 0x0014,
|
|
/// <summary>
|
|
/// Sequential recording DVD-R DL
|
|
/// </summary>
|
|
DVDRDLSeq = 0x0015,
|
|
/// <summary>
|
|
/// Layer jump recording DVD-R DL
|
|
/// </summary>
|
|
DVDRDLJump = 0x0016,
|
|
/// <summary>
|
|
/// DVD-RW DL
|
|
/// </summary>
|
|
DVDRWDL = 0x0017,
|
|
/// <summary>
|
|
/// DVD-Download
|
|
/// </summary>
|
|
DVDDownload = 0x0018,
|
|
/// <summary>
|
|
/// DVD+RW
|
|
/// </summary>
|
|
DVDRWPlus = 0x001A,
|
|
/// <summary>
|
|
/// DVD+R
|
|
/// </summary>
|
|
DVDRPlus = 0x001B,
|
|
/// <summary>
|
|
/// DDCD-ROM
|
|
/// </summary>
|
|
DDCDROM = 0x0020,
|
|
/// <summary>
|
|
/// DDCD-R
|
|
/// </summary>
|
|
DDCDR = 0x0021,
|
|
/// <summary>
|
|
/// DDCD-RW
|
|
/// </summary>
|
|
DDCDRW = 0x0022,
|
|
/// <summary>
|
|
/// DVD+RW DL
|
|
/// </summary>
|
|
DVDRWDLPlus = 0x002A,
|
|
/// <summary>
|
|
/// DVD+R DL
|
|
/// </summary>
|
|
DVDRDLPlus = 0x002B,
|
|
/// <summary>
|
|
/// BD-ROM
|
|
/// </summary>
|
|
BDROM = 0x0040,
|
|
/// <summary>
|
|
/// BD-R SRM
|
|
/// </summary>
|
|
BDRSeq = 0x0041,
|
|
/// <summary>
|
|
/// BD-R RRM
|
|
/// </summary>
|
|
BDRRdm = 0x0042,
|
|
/// <summary>
|
|
/// BD-RE
|
|
/// </summary>
|
|
BDRE = 0x0043,
|
|
/// <summary>
|
|
/// HD DVD-ROM
|
|
/// </summary>
|
|
HDDVDROM = 0x0050,
|
|
/// <summary>
|
|
/// HD DVD-R
|
|
/// </summary>
|
|
HDDVDR = 0x0051,
|
|
/// <summary>
|
|
/// HD DVD-RAM
|
|
/// </summary>
|
|
HDDVDRAM = 0x0052,
|
|
/// <summary>
|
|
/// HD DVD-RW
|
|
/// </summary>
|
|
HDDVDRW = 0x0053,
|
|
/// <summary>
|
|
/// HD DVD-R DL
|
|
/// </summary>
|
|
HDDVDRDL = 0x0058,
|
|
/// <summary>
|
|
/// HD DVD-RW DL
|
|
/// </summary>
|
|
HDDVDRWDL = 0x005A,
|
|
/// <summary>
|
|
/// Drive does not conform to any profiles
|
|
/// </summary>
|
|
Unconforming = 0xFFFF
|
|
}
|
|
|
|
public enum PhysicalInterfaces : uint
|
|
{
|
|
/// <summary>
|
|
/// Unspecified physical interface
|
|
/// </summary>
|
|
Unspecified = 0,
|
|
/// <summary>
|
|
/// SCSI
|
|
/// </summary>
|
|
SCSI = 1,
|
|
/// <summary>
|
|
/// ATAPI
|
|
/// </summary>
|
|
ATAPI = 2,
|
|
/// <summary>
|
|
/// IEEE-1394/1995
|
|
/// </summary>
|
|
IEEE1394 = 3,
|
|
/// <summary>
|
|
/// IEEE-1394A
|
|
/// </summary>
|
|
IEEE1394A = 4,
|
|
/// <summary>
|
|
/// Fibre Channel
|
|
/// </summary>
|
|
FC = 5,
|
|
/// <summary>
|
|
/// IEEE-1394B
|
|
/// </summary>
|
|
IEEE1394B = 6,
|
|
/// <summary>
|
|
/// Serial ATAPI
|
|
/// </summary>
|
|
SerialATAPI = 7,
|
|
/// <summary>
|
|
/// USB
|
|
/// </summary>
|
|
USB = 8,
|
|
/// <summary>
|
|
/// Vendor unique
|
|
/// </summary>
|
|
Vendor = 0xFFFF
|
|
}
|
|
|
|
public struct Profile
|
|
{
|
|
public ProfileNumber Number;
|
|
public bool Current;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Profile List Feature (0000h)
|
|
/// </summary>
|
|
public struct Feature_0000
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// All supported profiles
|
|
/// </summary>
|
|
public Profile[] Profiles;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Core Feature (0001h)
|
|
/// </summary>
|
|
public struct Feature_0001
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Currently in-use physical interface standard
|
|
/// </summary>
|
|
public PhysicalInterfaces PhysicalInterfaceStandard;
|
|
/// <summary>
|
|
/// Supports EVPD, Page Code and 16-bit Allocation Length as defined in SPC-3
|
|
/// </summary>
|
|
public bool INQ2;
|
|
/// <summary>
|
|
/// Supports Device Busy Event
|
|
/// </summary>
|
|
public bool DBE;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Morphing Feature (0002h)
|
|
/// </summary>
|
|
public struct Feature_0002
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Supports Operational Change Request/Nofitication Class Events
|
|
/// of GET EVENT/STATUS NOTIFICATION
|
|
/// </summary>
|
|
public bool OCEvent;
|
|
/// <summary>
|
|
/// Supports asynchronous GET EVENT/STATUS NOTIFICATION
|
|
/// </summary>
|
|
public bool Async;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Removable Medium Feature (0003h)
|
|
/// </summary>
|
|
public struct Feature_0003
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Mechanism type
|
|
/// </summary>
|
|
public byte LoadingMechanismType;
|
|
/// <summary>
|
|
/// Drive is able to load the medium
|
|
/// </summary>
|
|
public bool Load;
|
|
/// <summary>
|
|
/// Device can eject medium
|
|
/// </summary>
|
|
public bool Eject;
|
|
/// <summary>
|
|
/// Device starts in medium ejection/insertion allow
|
|
/// </summary>
|
|
public bool PreventJumper;
|
|
/// <summary>
|
|
/// Reports Device Busy Class events during medium loading/unloading
|
|
/// </summary>
|
|
public bool DBML;
|
|
/// <summary>
|
|
/// Medium is currently locked
|
|
/// </summary>
|
|
public bool Lock;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Write Protect Feature (0004h)
|
|
/// </summary>
|
|
public struct Feature_0004
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Drive can read/write Disc Write Protect PAC on BD-R/-RE media
|
|
/// </summary>
|
|
public bool DWP;
|
|
/// <summary>
|
|
/// Supports reading/writing Write Inhibit DCB on DVD+RW media.
|
|
/// </summary>
|
|
public bool WDCB;
|
|
/// <summary>
|
|
/// Supports PWP status
|
|
/// </summary>
|
|
public bool SPWP;
|
|
/// <summary>
|
|
/// Supports SWPP bit of mode page 1Dh
|
|
/// </summary>
|
|
public bool SSWPP;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Random Readable Feature (0010h)
|
|
/// </summary>
|
|
public struct Feature_0010
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Bytes per logical block
|
|
/// </summary>
|
|
public uint LogicalBlockSize;
|
|
/// <summary>
|
|
/// Number of logical blocks per device readable unit
|
|
/// </summary>
|
|
public ushort Blocking;
|
|
/// <summary>
|
|
/// Read/Write Error Recovery page is present
|
|
/// </summary>
|
|
public bool PP;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Multi-Read Feature (001Dh)
|
|
/// </summary>
|
|
public struct Feature_001D
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
}
|
|
|
|
/// <summary>
|
|
/// CD Read Feature (001Eh)
|
|
/// </summary>
|
|
public struct Feature_001E
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Supports DAP bit in READ CD and READ CD MSF
|
|
/// </summary>
|
|
public bool DAP;
|
|
/// <summary>
|
|
/// Supports C2 Error Pointers
|
|
/// </summary>
|
|
public bool C2;
|
|
/// <summary>
|
|
/// Can read CD-Text with READ TOC/PMA/ATIP
|
|
/// </summary>
|
|
public bool CDText;
|
|
}
|
|
|
|
/// <summary>
|
|
/// DVD Read Feature (001Fh)
|
|
/// </summary>
|
|
public struct Feature_001F
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Compliant with DVD Multi Drive Read-only specifications
|
|
/// </summary>
|
|
public bool MULTI110;
|
|
/// <summary>
|
|
/// Supports reading all DVD-RW DL
|
|
/// </summary>
|
|
public bool DualRW;
|
|
/// <summary>
|
|
/// Supports reading all DVD-R DL including remapping
|
|
/// </summary>
|
|
public bool DualR;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Random Writable Feature (0020h)
|
|
/// </summary>
|
|
public struct Feature_0020
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Last logical block address
|
|
/// </summary>
|
|
public uint LastLBA;
|
|
/// <summary>
|
|
/// Bytes per logical block
|
|
/// </summary>
|
|
public uint LogicalBlockSize;
|
|
/// <summary>
|
|
/// Number of logical blocks per device readable unit
|
|
/// </summary>
|
|
public ushort Blocking;
|
|
/// <summary>
|
|
/// Read/Write Error Recovery page is present
|
|
/// </summary>
|
|
public bool PP;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Incremental Streaming Writable Feature (0021h)
|
|
/// </summary>
|
|
public struct Feature_0021
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Bitmask of supported data types
|
|
/// </summary>
|
|
public ushort DataTypeSupported;
|
|
/// <summary>
|
|
/// Can report Track Resources Information of READ DISC INFORMATION
|
|
/// </summary>
|
|
public bool TRIO;
|
|
/// <summary>
|
|
/// Supports Address Mode in RESERVE TRACK
|
|
/// </summary>
|
|
public bool ARSV;
|
|
/// <summary>
|
|
/// Zero loss linking
|
|
/// </summary>
|
|
public bool BUF;
|
|
/// <summary>
|
|
/// Logical blocks per link
|
|
/// </summary>
|
|
public byte[] LinkSizes;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Sector Erasable Feature (0022h)
|
|
/// </summary>
|
|
public struct Feature_0022
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Formattable Feature (0023h)
|
|
/// </summary>
|
|
public struct Feature_0023
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Supports formatting BD-RE without spare area
|
|
/// </summary>
|
|
public bool RENoSA;
|
|
/// <summary>
|
|
/// Supports expansion of the spare area on BD-RE
|
|
/// </summary>
|
|
public bool Expand;
|
|
/// <summary>
|
|
/// Supports FORMAT type 30h sub-type 11b
|
|
/// </summary>
|
|
public bool QCert;
|
|
/// <summary>
|
|
/// Supports FORMAT type 30h sub-type 10b
|
|
/// </summary>
|
|
public bool Cert;
|
|
/// <summary>
|
|
/// Supports FORMAT type 18h
|
|
/// </summary>
|
|
public bool FRF;
|
|
/// <summary>
|
|
/// Supports FORMAT type 00h/32h sub-type 10b on BD-R
|
|
/// </summary>
|
|
public bool RRM;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Hardware Defect Management Feature (0024h)
|
|
/// </summary>
|
|
public struct Feature_0024
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Supports READ DISC STRUCTURE with Format Code 0Ah (Spare Area Information)
|
|
/// </summary>
|
|
public bool SSA;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Write Once Feature (0025h)
|
|
/// </summary>
|
|
public struct Feature_0025
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Bytes per logical block
|
|
/// </summary>
|
|
public uint LogicalBlockSize;
|
|
/// <summary>
|
|
/// Number of logical blocks per device readable unit
|
|
/// </summary>
|
|
public ushort Blocking;
|
|
/// <summary>
|
|
/// Read/Write Error Recovery page is present
|
|
/// </summary>
|
|
public bool PP;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Restricted Overwrite Feature (0026h)
|
|
/// </summary>
|
|
public struct Feature_0026
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
}
|
|
|
|
/// <summary>
|
|
/// CD-RW CAV Write Feature (0027h)
|
|
/// </summary>
|
|
public struct Feature_0027
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
}
|
|
|
|
/// <summary>
|
|
/// MRW Feature (0028h)
|
|
/// </summary>
|
|
public struct Feature_0028
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Can read DVD+MRW discs
|
|
/// </summary>
|
|
public bool DVDPRead;
|
|
/// <summary>
|
|
/// Can write DVD+MRW discs
|
|
/// </summary>
|
|
public bool DVDPWrite;
|
|
/// <summary>
|
|
/// Can format and write to CD-MRW discs
|
|
/// </summary>
|
|
public bool Write;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Enhanced Defect Reporting Feature (0029h)
|
|
/// </summary>
|
|
public struct Feature_0029
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Supports DRT-DM
|
|
/// </summary>
|
|
public bool DRTDM;
|
|
/// <summary>
|
|
/// Maximum number of DBI cache zones device can handle separately
|
|
/// </summary>
|
|
public byte DBICacheZones;
|
|
/// <summary>
|
|
/// Number of entries in worst case to case DBI overflow
|
|
/// </summary>
|
|
public ushort Entries;
|
|
}
|
|
|
|
/// <summary>
|
|
/// DVD+RW Feature (002Ah)
|
|
/// </summary>
|
|
public struct Feature_002A
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Can format DVD+RW discs
|
|
/// </summary>
|
|
public bool Write;
|
|
/// <summary>
|
|
/// FORMAT UNIT supports quick start formatting
|
|
/// </summary>
|
|
public bool QuickStart;
|
|
/// <summary>
|
|
/// Drive only supports read compatibility stop
|
|
/// </summary>
|
|
public bool CloseOnly;
|
|
}
|
|
|
|
/// <summary>
|
|
/// DVD+R Feature (002Bh)
|
|
/// </summary>
|
|
public struct Feature_002B
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Can write DVD+R
|
|
/// </summary>
|
|
public bool Write;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Rigid Restricted Overwrite Feature (002Ch)
|
|
/// </summary>
|
|
public struct Feature_002C
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Can generate Defect Status Data during formatting
|
|
/// </summary>
|
|
public bool DSDG;
|
|
/// <summary>
|
|
/// Can read Defect Status Data recorded on medium
|
|
/// </summary>
|
|
public bool DSDR;
|
|
/// <summary>
|
|
/// Supports writing on an intermediate state Session and quick formatting
|
|
/// </summary>
|
|
public bool Intermediate;
|
|
/// <summary>
|
|
/// Supports BLANK command types 00h and 01h
|
|
/// </summary>
|
|
public bool Blank;
|
|
}
|
|
|
|
/// <summary>
|
|
/// CD Track at Once Feature (002Dh)
|
|
/// </summary>
|
|
public struct Feature_002D
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Supports zero loss linking
|
|
/// </summary>
|
|
public bool BUF;
|
|
/// <summary>
|
|
/// Supports writing R-W subchannels in raw mode
|
|
/// </summary>
|
|
public bool RWRaw;
|
|
/// <summary>
|
|
/// Supports writing R-W subchannels in packed mode
|
|
/// </summary>
|
|
public bool RWPack;
|
|
/// <summary>
|
|
/// Can perform test writes
|
|
/// </summary>
|
|
public bool TestWrite;
|
|
/// <summary>
|
|
/// Supports overwriting a TAO track with another
|
|
/// </summary>
|
|
public bool CDRW;
|
|
/// <summary>
|
|
/// Can write R-W subchannels with user provided data
|
|
/// </summary>
|
|
public bool RWSubchannel;
|
|
/// <summary>
|
|
/// Bitmask of supported data types
|
|
/// </summary>
|
|
public ushort DataTypeSupported;
|
|
}
|
|
|
|
/// <summary>
|
|
/// CD Mastering (Session at Once) Feature (002Eh)
|
|
/// </summary>
|
|
public struct Feature_002E
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Supports zero loss linking
|
|
/// </summary>
|
|
public bool BUF;
|
|
/// <summary>
|
|
/// Can write in Session at Once
|
|
/// </summary>
|
|
public bool SAO;
|
|
/// <summary>
|
|
/// Can write multi-session in RAW
|
|
/// </summary>
|
|
public bool RAWMS;
|
|
/// <summary>
|
|
/// Can write in RAW
|
|
/// </summary>
|
|
public bool RAW;
|
|
/// <summary>
|
|
/// Can perform test writes
|
|
/// </summary>
|
|
public bool TestWrite;
|
|
/// <summary>
|
|
/// Can overwrite previously recorded data
|
|
/// </summary>
|
|
public bool CDRW;
|
|
/// <summary>
|
|
/// Can write R-W subchannels with user provided data
|
|
/// </summary>
|
|
public bool RW;
|
|
/// <summary>
|
|
/// Maximum length of a Cue Sheet for Session at Once
|
|
/// </summary>
|
|
public uint MaxCueSheet;
|
|
}
|
|
|
|
/// <summary>
|
|
/// DVD-R/-RW Write Feature (002Fh)
|
|
/// </summary>
|
|
public struct Feature_002F
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Buffer Under-run protection
|
|
/// </summary>
|
|
public bool BUF;
|
|
/// <summary>
|
|
/// Supports writing DVD-R DL
|
|
/// </summary>
|
|
public bool RDL;
|
|
/// <summary>
|
|
/// Test write
|
|
/// </summary>
|
|
public bool TestWrite;
|
|
/// <summary>
|
|
/// Can write and erase DVD-RW
|
|
/// </summary>
|
|
public bool DVDRW;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Double Density CD Read Feature (0030h)
|
|
/// </summary>
|
|
public struct Feature_0030
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Double Density CD-R Write Feature (0031h)
|
|
/// </summary>
|
|
public struct Feature_0031
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Test write
|
|
/// </summary>
|
|
public bool TestWrite;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Double Density CD-RW Write Feature (0032h)
|
|
/// </summary>
|
|
public struct Feature_0032
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Supports quick formatting
|
|
/// </summary>
|
|
public bool Intermediate;
|
|
/// <summary>
|
|
/// Supports BLANK command
|
|
/// </summary>
|
|
public bool Blank;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Layer Jump Recording Feature (0033h)
|
|
/// </summary>
|
|
public struct Feature_0033
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
public byte[] LinkSizes;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Stop Long Operation Feature (0035h)
|
|
/// </summary>
|
|
public struct Feature_0035
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
}
|
|
|
|
/// <summary>
|
|
/// CD-RW Media Write Support Feature (0037h)
|
|
/// </summary>
|
|
public struct Feature_0037
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Bitmask of supported CD-RW media sub-types
|
|
/// </summary>
|
|
public byte SubtypeSupport;
|
|
}
|
|
|
|
/// <summary>
|
|
/// BD-R Pseudo-Overwrite (POW) Feature (0038h)
|
|
/// </summary>
|
|
public struct Feature_0038
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
}
|
|
|
|
/// <summary>
|
|
/// DVD+RW Dual Layer Feature (003Ah)
|
|
/// </summary>
|
|
public struct Feature_003A
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Can format DVD+RW DL discs
|
|
/// </summary>
|
|
public bool Write;
|
|
/// <summary>
|
|
/// FORMAT UNIT supports quick start formatting
|
|
/// </summary>
|
|
public bool QuickStart;
|
|
/// <summary>
|
|
/// Drive only supports read compatibility stop
|
|
/// </summary>
|
|
public bool CloseOnly;
|
|
}
|
|
|
|
/// <summary>
|
|
/// DVD+R Dual Layer Feature (003Bh)
|
|
/// </summary>
|
|
public struct Feature_003B
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Can format DVD+R DL discs
|
|
/// </summary>
|
|
public bool Write;
|
|
/// <summary>
|
|
/// FORMAT UNIT supports quick start formatting
|
|
/// </summary>
|
|
public bool QuickStart;
|
|
/// <summary>
|
|
/// Drive only supports read compatibility stop
|
|
/// </summary>
|
|
public bool CloseOnly;
|
|
}
|
|
|
|
/// <summary>
|
|
/// BD Read Feature (0040h)
|
|
/// </summary>
|
|
public struct Feature_0040
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Can read BCA
|
|
/// </summary>
|
|
public bool BCA;
|
|
/// <summary>
|
|
/// Supports reading BD-RE Ver.2
|
|
/// </summary>
|
|
public bool RE2;
|
|
/// <summary>
|
|
/// Supports reading BD-RE Ver.1
|
|
/// </summary>
|
|
public bool RE1;
|
|
/// <summary>
|
|
/// Obsolete
|
|
/// </summary>
|
|
public bool OldRE;
|
|
/// <summary>
|
|
/// Supports reading BD-R Ver.1
|
|
/// </summary>
|
|
public bool R;
|
|
/// <summary>
|
|
/// Obsolete
|
|
/// </summary>
|
|
public bool OldR;
|
|
/// <summary>
|
|
/// Supports reading BD-ROM Ver.1
|
|
/// </summary>
|
|
public bool ROM;
|
|
/// <summary>
|
|
/// Obsolete
|
|
/// </summary>
|
|
public bool OldROM;
|
|
}
|
|
|
|
/// <summary>
|
|
/// BD Write Feature (0041h)
|
|
/// </summary>
|
|
public struct Feature_0041
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Supports verify not required
|
|
/// </summary>
|
|
public bool SVNR;
|
|
/// <summary>
|
|
/// Supports writing BD-RE Ver.2
|
|
/// </summary>
|
|
public bool RE2;
|
|
/// <summary>
|
|
/// Supports writing BD-RE Ver.1
|
|
/// </summary>
|
|
public bool RE1;
|
|
/// <summary>
|
|
/// Obsolete
|
|
/// </summary>
|
|
public bool OldRE;
|
|
/// <summary>
|
|
/// Supports writing BD-R Ver.1
|
|
/// </summary>
|
|
public bool R;
|
|
/// <summary>
|
|
/// Obsolete
|
|
/// </summary>
|
|
public bool OldR;
|
|
}
|
|
|
|
/// <summary>
|
|
/// TSR Feature (0042h)
|
|
/// </summary>
|
|
public struct Feature_0042
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
}
|
|
|
|
/// <summary>
|
|
/// HD DVD Read Feature (0050h)
|
|
/// </summary>
|
|
public struct Feature_0050
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Can read HD DVD-R
|
|
/// </summary>
|
|
public bool HDDVDR;
|
|
/// <summary>
|
|
/// Can read HD DVD-RAM
|
|
/// </summary>
|
|
public bool HDDVDRAM;
|
|
}
|
|
|
|
|
|
/// <summary>
|
|
/// HD DVD Write Feature (0051h)
|
|
/// </summary>
|
|
public struct Feature_0051
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Can write HD DVD-R
|
|
/// </summary>
|
|
public bool HDDVDR;
|
|
/// <summary>
|
|
/// Can write HD DVD-RAM
|
|
/// </summary>
|
|
public bool HDDVDRAM;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Hybrid Disc Feature (0080h)
|
|
/// </summary>
|
|
public struct Feature_0080
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Reset immunity
|
|
/// </summary>
|
|
public bool RI;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Power Management Feature (0100h)
|
|
/// </summary>
|
|
public struct Feature_0100
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
}
|
|
|
|
/// <summary>
|
|
/// S.M.A.R.T. Feature (0101h)
|
|
/// </summary>
|
|
public struct Feature_0101
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Mode Page 1Ch is present
|
|
/// </summary>
|
|
public bool PP;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Embedded Changer Feature (0102h)
|
|
/// </summary>
|
|
public struct Feature_0102
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Side change capable
|
|
/// </summary>
|
|
public bool SCC;
|
|
/// <summary>
|
|
/// Supports Disc Present
|
|
/// </summary>
|
|
public bool SDP;
|
|
/// <summary>
|
|
/// Number of slots - 1
|
|
/// </summary>
|
|
public byte HighestSlotNumber;
|
|
}
|
|
|
|
/// <summary>
|
|
/// CD Audio External Play Feature (0103h)
|
|
/// </summary>
|
|
public struct Feature_0103
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Supports SCAN command
|
|
/// </summary>
|
|
public bool Scan;
|
|
/// <summary>
|
|
/// Separate Channel Mute
|
|
/// </summary>
|
|
public bool SCM;
|
|
/// <summary>
|
|
/// Separate Volume
|
|
/// </summary>
|
|
public bool SV;
|
|
/// <summary>
|
|
/// Number of volume levels
|
|
/// </summary>
|
|
public ushort VolumeLevels;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Microcode Upgrade Feature (0104h)
|
|
/// </summary>
|
|
public struct Feature_0104
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Supports validating 5-bit mode field of READ BUFFER and WRITE BUFFER commands.
|
|
/// </summary>
|
|
public bool M5;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Time-Out Feature (0105h)
|
|
/// </summary>
|
|
public struct Feature_0105
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Supports G3Enable bit and Group3 Timeout field in Mode Page 1Dh
|
|
/// </summary>
|
|
public bool Group3;
|
|
/// <summary>
|
|
/// Indicates a unit of block length, in sectors, corresponding to increase a unit of Group 3 time unit
|
|
/// </summary>
|
|
public ushort UnitLength;
|
|
}
|
|
|
|
/// <summary>
|
|
/// DVD-CSS Feature (0106h)
|
|
/// </summary>
|
|
public struct Feature_0106
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// CSS version
|
|
/// </summary>
|
|
public byte CSSVersion;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Real Time Streaming Feature (0107h)
|
|
/// </summary>
|
|
public struct Feature_0107
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Supports Set Minimum Performance bit in SET STREAMING
|
|
/// </summary>
|
|
public bool SMP;
|
|
/// <summary>
|
|
/// Supports READ BUFFER CAPACITY with block bit set
|
|
/// </summary>
|
|
public bool RBCB;
|
|
/// <summary>
|
|
/// Supports SET CD SPEED
|
|
/// </summary>
|
|
public bool SCS;
|
|
/// <summary>
|
|
/// Has Mode Page 2Ah with Speed Performance Descriptors
|
|
/// </summary>
|
|
public bool MP2A;
|
|
/// <summary>
|
|
/// Supports type 03h of GET PERFORMANCE
|
|
/// </summary>
|
|
public bool WSPD;
|
|
/// <summary>
|
|
/// Supports stream recording
|
|
/// </summary>
|
|
public bool SW;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Drive serial number (0108h)
|
|
/// </summary>
|
|
public struct Feature_0108
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Drive serial number
|
|
/// </summary>
|
|
public string Serial;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Media Serial Number Feature (0109h)
|
|
/// </summary>
|
|
public struct Feature_0109
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Disc Control Blocks Feature (010Ah)
|
|
/// </summary>
|
|
public struct Feature_010A
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
public uint[] DCBs;
|
|
}
|
|
|
|
/// <summary>
|
|
/// DVD CPRM Feature (010Bh)
|
|
/// </summary>
|
|
public struct Feature_010B
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// CPRM version
|
|
/// </summary>
|
|
public byte CPRMVersion;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Firmware Information Feature (010Ch)
|
|
/// </summary>
|
|
public struct Feature_010C
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
public ushort Century;
|
|
public ushort Year;
|
|
public ushort Month;
|
|
public ushort Day;
|
|
public ushort Hour;
|
|
public ushort Minute;
|
|
public ushort Second;
|
|
}
|
|
|
|
/// <summary>
|
|
/// AACS Feature (010Dh)
|
|
/// </summary>
|
|
public struct Feature_010D
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Drive supports reading drive certificate
|
|
/// </summary>
|
|
public bool RDC;
|
|
/// <summary>
|
|
/// Drive can read media key block of CPRM
|
|
/// </summary>
|
|
public bool RMC;
|
|
/// <summary>
|
|
/// Drive can write bus encrypted blocks
|
|
/// </summary>
|
|
public bool WBE;
|
|
/// <summary>
|
|
/// Drive supports bus encryption
|
|
/// </summary>
|
|
public bool BEC;
|
|
/// <summary>
|
|
/// Drive supports generating the binding nonce
|
|
/// </summary>
|
|
public bool BNG;
|
|
/// <summary>
|
|
/// Blocks required to store the binding nonce for the media
|
|
/// </summary>
|
|
public byte BindNonceBlocks;
|
|
/// <summary>
|
|
/// Maximum number of AGIDs supported concurrently
|
|
/// </summary>
|
|
public byte AGIDs;
|
|
/// <summary>
|
|
/// AACS version
|
|
/// </summary>
|
|
public byte AACSVersion;
|
|
}
|
|
|
|
/// <summary>
|
|
/// DVD CSS Managed Recording Feature (010Eh)
|
|
/// </summary>
|
|
public struct Feature_010E
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Maximum number of Scramble Extent information entries in a single SEND DISC STRUCTURE
|
|
/// </summary>
|
|
public byte MaxScrambleExtent;
|
|
}
|
|
|
|
/// <summary>
|
|
/// SecurDisc Feature (0113h)
|
|
/// </summary>
|
|
public struct Feature_0113
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
}
|
|
|
|
/// <summary>
|
|
/// OSSC Feature (0142h)
|
|
/// </summary>
|
|
public struct Feature_0142
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
/// <summary>
|
|
/// Supports PSA updates on write-once media
|
|
/// </summary>
|
|
public bool PSAU;
|
|
/// <summary>
|
|
/// Supports linked OSPBs
|
|
/// </summary>
|
|
public bool LOSPB;
|
|
/// <summary>
|
|
/// Restricted to recording only OSSC disc format
|
|
/// </summary>
|
|
public bool ME;
|
|
public ushort[] Profiles;
|
|
}
|
|
|
|
/// <summary>
|
|
/// VCPS Feature (0110h)
|
|
/// </summary>
|
|
public struct Feature_0110
|
|
{
|
|
/// <summary>
|
|
/// Feature version
|
|
/// </summary>
|
|
public byte Version;
|
|
/// <summary>
|
|
/// Feature is persistent
|
|
/// </summary>
|
|
public bool Persistent;
|
|
/// <summary>
|
|
/// Feature is currently in use
|
|
/// </summary>
|
|
public bool Current;
|
|
}
|
|
|
|
public static class Features
|
|
{
|
|
public static Feature_0000? Decode_0000(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 4)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0000)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0000 decoded = new Feature_0000();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
int offset = 4;
|
|
List<Profile> listProfiles = new List<Profile>();
|
|
while(offset < feature.Length)
|
|
{
|
|
Profile prof = new Profile();
|
|
prof.Number = (ProfileNumber)((feature[offset] << 8) + feature[offset + 1]);
|
|
prof.Current |= (feature[offset + 2] & 0x01) == 0x01;
|
|
listProfiles.Add(prof);
|
|
offset += 4;
|
|
}
|
|
decoded.Profiles = listProfiles.ToArray();
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0001? Decode_0001(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0001)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0001 decoded = new Feature_0001();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
decoded.PhysicalInterfaceStandard = (PhysicalInterfaces)((feature[4] << 24) + (feature[5] << 16) + (feature[6] << 8) + feature[7]);
|
|
|
|
if(decoded.Version >= 1 && feature.Length >= 12)
|
|
decoded.DBE |= (feature[8] & 0x01) == 0x01;
|
|
|
|
if(decoded.Version >= 2 && feature.Length >= 12)
|
|
decoded.INQ2 |= (feature[8] & 0x02) == 0x02;
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0002? Decode_0002(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0002)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0002 decoded = new Feature_0002();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
decoded.Async |= (feature[4] & 0x01) == 0x01;
|
|
|
|
if(decoded.Version >= 1)
|
|
decoded.OCEvent |= (feature[4] & 0x02) == 0x02;
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0003? Decode_0003(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0003)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0003 decoded = new Feature_0003();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
{
|
|
decoded.LoadingMechanismType = (byte)((feature[4] & 0xE0) >> 5);
|
|
decoded.Eject |= (feature[4] & 0x08) == 0x08;
|
|
decoded.PreventJumper |= (feature[4] & 0x04) == 0x04;
|
|
decoded.Lock |= (feature[4] & 0x01) == 0x01;
|
|
}
|
|
|
|
if(decoded.Version >= 2)
|
|
{
|
|
decoded.Load |= (feature[4] & 0x10) == 0x10;
|
|
decoded.DBML |= (feature[4] & 0x02) == 0x02;
|
|
}
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0004? Decode_0004(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0004)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0004 decoded = new Feature_0004();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
{
|
|
decoded.SPWP |= (feature[4] & 0x02) == 0x02;
|
|
decoded.SSWPP |= (feature[4] & 0x01) == 0x01;
|
|
}
|
|
|
|
if(decoded.Version >= 1)
|
|
decoded.WDCB |= (feature[4] & 0x04) == 0x04;
|
|
|
|
if(decoded.Version >= 2)
|
|
decoded.DWP |= (feature[4] & 0x08) == 0x08;
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0010? Decode_0010(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 12)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0010)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0010 decoded = new Feature_0010();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
{
|
|
decoded.LogicalBlockSize = (uint)((feature[4] << 24) + (feature[5] << 16) + (feature[6] << 8) + feature[7]);
|
|
decoded.Blocking = (ushort)((feature[8] << 8) + feature[9]);
|
|
decoded.PP |= (feature[10] & 0x01) == 0x01;
|
|
}
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_001D? Decode_001D(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 4)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x001D)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_001D decoded = new Feature_001D();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_001E? Decode_001E(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x001E)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_001E decoded = new Feature_001E();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 1)
|
|
{
|
|
decoded.C2 |= (feature[4] & 0x02) == 0x02;
|
|
decoded.CDText |= (feature[4] & 0x01) == 0x01;
|
|
}
|
|
|
|
if(decoded.Version >= 2)
|
|
decoded.DAP |= (feature[4] & 0x80) == 0x80;
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_001F? Decode_001F(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 4)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x001F)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_001F decoded = new Feature_001F();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 2 && feature.Length >= 8)
|
|
{
|
|
decoded.MULTI110 |= (feature[4] & 0x01) == 0x01;
|
|
decoded.DualR |= (feature[6] & 0x01) == 0x01;
|
|
}
|
|
|
|
if(decoded.Version >= 2 && feature.Length >= 8)
|
|
decoded.DualRW |= (feature[6] & 0x02) == 0x02;
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0020? Decode_0020(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 16)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0020)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0020 decoded = new Feature_0020();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 1)
|
|
{
|
|
decoded.LastLBA = (uint)((feature[4] << 24) + (feature[5] << 16) + (feature[6] << 8) + feature[7]);
|
|
decoded.LogicalBlockSize = (uint)((feature[8] << 24) + (feature[9] << 16) + (feature[10] << 8) + feature[11]);
|
|
decoded.Blocking = (ushort)((feature[12] << 8) + feature[13]);
|
|
decoded.PP |= (feature[14] & 0x01) == 0x01;
|
|
}
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0021? Decode_0021(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0021)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0021 decoded = new Feature_0021();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 1)
|
|
{
|
|
decoded.DataTypeSupported = (ushort)((feature[4] << 8) + feature[5]);
|
|
decoded.BUF |= (feature[6] & 0x01) == 0x01;
|
|
decoded.LinkSizes = new byte[feature[7]];
|
|
if(feature.Length > (feature[7] + 8))
|
|
Array.Copy(feature, 8, decoded.LinkSizes, 0, feature[7]);
|
|
}
|
|
|
|
if(decoded.Version >= 3)
|
|
{
|
|
decoded.TRIO |= (feature[6] & 0x04) == 0x04;
|
|
decoded.ARSV |= (feature[6] & 0x02) == 0x02;
|
|
}
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0022? Decode_0022(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 4)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0022)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0022 decoded = new Feature_0022();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0023? Decode_0023(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 4)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0023)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0023 decoded = new Feature_0023();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 1 && feature.Length >= 12)
|
|
{
|
|
decoded.RENoSA |= (feature[4] & 0x08) == 0x08;
|
|
decoded.Expand |= (feature[4] & 0x04) == 0x04;
|
|
decoded.QCert |= (feature[4] & 0x02) == 0x02;
|
|
decoded.Cert |= (feature[4] & 0x01) == 0x01;
|
|
decoded.RRM |= (feature[8] & 0x01) == 0x01;
|
|
}
|
|
|
|
if(decoded.Version >= 2 && feature.Length >= 12)
|
|
decoded.FRF |= (feature[4] & 0x80) == 0x80;
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0024? Decode_0024(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 4)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0024)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0024 decoded = new Feature_0024();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 1 && feature.Length >= 8)
|
|
decoded.SSA |= (feature[4] & 0x80) == 0x80;
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0025? Decode_0025(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 12)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0025)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0025 decoded = new Feature_0025();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
{
|
|
decoded.LogicalBlockSize = (uint)((feature[4] << 24) + (feature[5] << 16) + (feature[6] << 8) + feature[7]);
|
|
decoded.Blocking = (ushort)((feature[8] << 8) + feature[9]);
|
|
decoded.PP |= (feature[10] & 0x01) == 0x01;
|
|
}
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0026? Decode_0026(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 4)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0026)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0026 decoded = new Feature_0026();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0027? Decode_0027(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0027)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0027 decoded = new Feature_0027();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0028? Decode_0028(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0028)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0028 decoded = new Feature_0028();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
decoded.Write |= (feature[4] & 0x01) == 0x01;
|
|
|
|
if(decoded.Version >= 1)
|
|
{
|
|
decoded.DVDPWrite |= (feature[4] & 0x04) == 0x04;
|
|
decoded.DVDPRead |= (feature[4] & 0x02) == 0x02;
|
|
}
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0029? Decode_0029(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0029)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0029 decoded = new Feature_0029();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
{
|
|
decoded.DRTDM |= (feature[4] & 0x01) == 0x01;
|
|
decoded.DBICacheZones = feature[5];
|
|
decoded.Entries = (ushort)((feature[6] << 8) + feature[7]);
|
|
}
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_002A? Decode_002A(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x002A)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_002A decoded = new Feature_002A();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
{
|
|
decoded.Write |= (feature[4] & 0x01) == 0x01;
|
|
decoded.CloseOnly |= (feature[5] & 0x01) == 0x01;
|
|
}
|
|
|
|
if(decoded.Version >= 1)
|
|
decoded.QuickStart |= (feature[5] & 0x02) == 0x02;
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_002B? Decode_002B(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x002B)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_002B decoded = new Feature_002B();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
decoded.Write |= (feature[4] & 0x01) == 0x01;
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_002C? Decode_002C(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x002C)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_002C decoded = new Feature_002C();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
{
|
|
decoded.DSDG |= (feature[4] & 0x08) == 0x08;
|
|
decoded.DSDR |= (feature[4] & 0x04) == 0x04;
|
|
decoded.Intermediate |= (feature[4] & 0x02) == 0x02;
|
|
decoded.Blank |= (feature[4] & 0x01) == 0x01;
|
|
}
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_002D? Decode_002D(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x002D)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_002D decoded = new Feature_002D();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
{
|
|
decoded.TestWrite |= (feature[4] & 0x04) == 0x04;
|
|
decoded.CDRW |= (feature[4] & 0x02) == 0x02;
|
|
decoded.RWSubchannel |= (feature[4] & 0x01) == 0x01;
|
|
decoded.DataTypeSupported = (ushort)((feature[6] << 8) + feature[7]);
|
|
}
|
|
|
|
if(decoded.Version >= 2)
|
|
{
|
|
decoded.BUF |= (feature[4] & 0x40) == 0x40;
|
|
decoded.RWRaw |= (feature[4] & 0x10) == 0x10;
|
|
decoded.RWPack |= (feature[4] & 0x08) == 0x08;
|
|
}
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_002E? Decode_002E(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x002E)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_002E decoded = new Feature_002E();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
{
|
|
decoded.SAO |= (feature[4] & 0x20) == 0x20;
|
|
decoded.RAWMS |= (feature[4] & 0x10) == 0x10;
|
|
decoded.RAW |= (feature[4] & 0x08) == 0x08;
|
|
decoded.TestWrite |= (feature[4] & 0x04) == 0x04;
|
|
decoded.CDRW |= (feature[4] & 0x02) == 0x02;
|
|
decoded.RW |= (feature[4] & 0x01) == 0x01;
|
|
decoded.MaxCueSheet = (uint)((feature[5] << 16) + (feature[6] << 8) + feature[7]);
|
|
}
|
|
|
|
if(decoded.Version >= 1)
|
|
decoded.BUF |= (feature[4] & 0x40) == 0x40;
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_002F? Decode_002F(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x002F)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_002F decoded = new Feature_002F();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
{
|
|
decoded.BUF |= (feature[4] & 0x40) == 0x40;
|
|
decoded.TestWrite |= (feature[4] & 0x04) == 0x04;
|
|
}
|
|
|
|
if(decoded.Version >= 1)
|
|
decoded.DVDRW |= (feature[4] & 0x02) == 0x02;
|
|
|
|
if(decoded.Version >= 2)
|
|
decoded.RDL |= (feature[4] & 0x08) == 0x08;
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0030? Decode_0030(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 4)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0030)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0030 decoded = new Feature_0030();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0031? Decode_0031(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0031)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0031 decoded = new Feature_0031();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
decoded.TestWrite |= (feature[4] & 0x04) == 0x04;
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0032? Decode_0032(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0032)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0032 decoded = new Feature_0032();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
{
|
|
decoded.Intermediate |= (feature[4] & 0x02) == 0x02;
|
|
decoded.Blank |= (feature[4] & 0x01) == 0x01;
|
|
}
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0033? Decode_0033(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0033)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0033 decoded = new Feature_0033();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(feature[7] > 0 && feature.Length > (feature[7] + 8))
|
|
{
|
|
decoded.LinkSizes = new byte[feature[7]];
|
|
Array.Copy(feature, 8, decoded.LinkSizes, 0, feature[7]);
|
|
}
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0035? Decode_0035(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 4)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0035)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0035 decoded = new Feature_0035();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0037? Decode_0037(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0037)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0037 decoded = new Feature_0037();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
decoded.SubtypeSupport = feature[5];
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0038? Decode_0038(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0038)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0038 decoded = new Feature_0038();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_003A? Decode_003A(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x003A)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_003A decoded = new Feature_003A();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
{
|
|
decoded.Write |= (feature[4] & 0x01) == 0x01;
|
|
decoded.QuickStart |= (feature[5] & 0x02) == 0x02;
|
|
decoded.CloseOnly |= (feature[5] & 0x01) == 0x01;
|
|
}
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_003B? Decode_003B(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x003B)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_003B decoded = new Feature_003B();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
decoded.Write |= (feature[4] & 0x01) == 0x01;
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0040? Decode_0040(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 32)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0040)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0040 decoded = new Feature_0040();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
{
|
|
decoded.OldRE |= (feature[9] & 0x01) == 0x01;
|
|
decoded.OldR |= (feature[17] & 0x01) == 0x01;
|
|
decoded.OldROM |= (feature[25] & 0x01) == 0x01;
|
|
}
|
|
|
|
if(decoded.Version >= 1)
|
|
{
|
|
decoded.BCA |= (feature[4] & 0x01) == 0x01;
|
|
decoded.RE2 |= (feature[9] & 0x04) == 0x04;
|
|
decoded.RE1 |= (feature[9] & 0x02) == 0x02;
|
|
decoded.R |= (feature[17] & 0x02) == 0x02;
|
|
decoded.ROM |= (feature[25] & 0x02) == 0x02;
|
|
}
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0041? Decode_0041(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 24)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0041)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0041 decoded = new Feature_0041();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
{
|
|
decoded.SVNR |= (feature[4] & 0x01) == 0x01;
|
|
decoded.OldRE |= (feature[9] & 0x01) == 0x01;
|
|
decoded.OldR |= (feature[17] & 0x01) == 0x01;
|
|
}
|
|
|
|
if(decoded.Version >= 1)
|
|
{
|
|
decoded.RE2 |= (feature[9] & 0x04) == 0x04;
|
|
decoded.RE1 |= (feature[9] & 0x02) == 0x02;
|
|
decoded.R |= (feature[17] & 0x02) == 0x02;
|
|
}
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0042? Decode_0042(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 4)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0042)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0042 decoded = new Feature_0042();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0050? Decode_0050(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0050)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0050 decoded = new Feature_0050();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
{
|
|
decoded.HDDVDR |= (feature[4] & 0x01) == 0x01;
|
|
decoded.HDDVDRAM |= (feature[6] & 0x01) == 0x01;
|
|
}
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0051? Decode_0051(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0051)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0051 decoded = new Feature_0051();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
{
|
|
decoded.HDDVDR |= (feature[4] & 0x01) == 0x01;
|
|
decoded.HDDVDRAM |= (feature[6] & 0x01) == 0x01;
|
|
}
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0080? Decode_0080(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0080)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0080 decoded = new Feature_0080();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
decoded.RI |= (feature[4] & 0x01) == 0x01;
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0100? Decode_0100(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 4)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0100)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0100 decoded = new Feature_0100();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0101? Decode_0101(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0101)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0101 decoded = new Feature_0101();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
decoded.PP |= (feature[4] & 0x01) == 0x01;
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0102? Decode_0102(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 4)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0102)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0102 decoded = new Feature_0102();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
{
|
|
decoded.SCC |= (feature[4] & 0x10) == 0x10;
|
|
decoded.SDP |= (feature[4] & 0x04) == 0x04;
|
|
decoded.HighestSlotNumber = (byte)(feature[7] & 0x1F);
|
|
}
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0103? Decode_0103(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0103)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0103 decoded = new Feature_0103();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
{
|
|
decoded.Scan |= (feature[4] & 0x04) == 0x04;
|
|
decoded.SCM |= (feature[4] & 0x02) == 0x02;
|
|
decoded.SV |= (feature[4] & 0x01) == 0x01;
|
|
decoded.VolumeLevels = (ushort)((feature[6] << 8) + feature[7]);
|
|
}
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0104? Decode_0104(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 4)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0104)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0104 decoded = new Feature_0104();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 1 && feature.Length >= 8)
|
|
decoded.M5 |= (feature[4] & 0x01) == 0x01;
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0105? Decode_0105(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 4)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0105)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0105 decoded = new Feature_0105();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 1 && feature.Length >= 8)
|
|
{
|
|
decoded.Group3 |= (feature[4] & 0x01) == 0x01;
|
|
decoded.UnitLength = (ushort)((feature[6] << 8) + feature[7]);
|
|
}
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0106? Decode_0106(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0106)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0106 decoded = new Feature_0106();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
decoded.CSSVersion = feature[7];
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0107? Decode_0107(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 4)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0107)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0107 decoded = new Feature_0107();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 3 && feature.Length >= 8)
|
|
{
|
|
decoded.RBCB |= (feature[4] & 0x10) == 0x10;
|
|
decoded.SCS |= (feature[4] & 0x08) == 0x08;
|
|
decoded.MP2A |= (feature[4] & 0x04) == 0x04;
|
|
decoded.WSPD |= (feature[4] & 0x02) == 0x02;
|
|
decoded.SW |= (feature[4] & 0x01) == 0x01;
|
|
}
|
|
|
|
if(decoded.Version >= 5 && feature.Length >= 8)
|
|
{
|
|
decoded.SMP |= (feature[4] & 0x20) == 0x20;
|
|
decoded.RBCB |= (feature[4] & 0x10) == 0x10;
|
|
}
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0108? Decode_0108(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 4)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0108)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0108 decoded = new Feature_0108();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
{
|
|
byte[] serial = new byte[feature.Length];
|
|
Array.Copy(feature, 4, serial, 0, feature.Length - 4);
|
|
decoded.Serial = StringHandlers.CToString(serial).Trim();
|
|
}
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0109? Decode_0109(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 4)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0109)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0109 decoded = new Feature_0109();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_010A? Decode_010A(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x010A)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_010A decoded = new Feature_010A();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
{
|
|
decoded.DCBs = new uint[feature[3] / 4];
|
|
for(int i = 0; i < decoded.DCBs.Length; i++)
|
|
decoded.DCBs[i] = (uint)((feature[0 + 4 + i * 4] << 24) + (feature[1 + 4 + i * 4] << 16) + (feature[2 + 4 + i * 4] << 8) + feature[3 + 4 + i * 4]);
|
|
}
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_010B? Decode_010B(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 4)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x010B)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_010B decoded = new Feature_010B();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
decoded.CPRMVersion = feature[7];
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_010C? Decode_010C(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 20)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x010C)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_010C decoded = new Feature_010C();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
{
|
|
decoded.Century = (ushort)((feature[4] << 8) + feature[5]);
|
|
decoded.Year = (ushort)((feature[6] << 8) + feature[7]);
|
|
decoded.Month = (ushort)((feature[8] << 8) + feature[9]);
|
|
decoded.Day = (ushort)((feature[10] << 8) + feature[11]);
|
|
decoded.Hour = (ushort)((feature[12] << 8) + feature[13]);
|
|
decoded.Minute = (ushort)((feature[14] << 8) + feature[15]);
|
|
decoded.Second = (ushort)((feature[16] << 8) + feature[17]);
|
|
}
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_010D? Decode_010D(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x010D)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_010D decoded = new Feature_010D();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
{
|
|
decoded.BNG |= (feature[4] & 0x01) == 0x01;
|
|
decoded.BindNonceBlocks = feature[5];
|
|
decoded.AGIDs = (byte)(feature[6] & 0x0F);
|
|
decoded.AACSVersion = feature[7];
|
|
}
|
|
|
|
if(decoded.Version >= 2)
|
|
{
|
|
decoded.RDC |= (feature[4] & 0x10) == 0x10;
|
|
decoded.RMC |= (feature[4] & 0x08) == 0x08;
|
|
decoded.WBE |= (feature[4] & 0x04) == 0x04;
|
|
decoded.BEC |= (feature[4] & 0x02) == 0x02;
|
|
}
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_010E? Decode_010E(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x010E)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_010E decoded = new Feature_010E();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
decoded.MaxScrambleExtent = feature[4];
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0110? Decode_0110(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 8)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0110)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0110 decoded = new Feature_0110();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0113? Decode_0113(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 4)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0113)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0113 decoded = new Feature_0113();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static Feature_0142? Decode_0142(byte[] feature)
|
|
{
|
|
if(feature == null)
|
|
return null;
|
|
|
|
if(feature.Length < 6)
|
|
return null;
|
|
|
|
ushort number = (ushort)((feature[0] << 8) + feature[1]);
|
|
|
|
if(number != 0x0142)
|
|
return null;
|
|
|
|
if((feature[3] + 4) != feature.Length)
|
|
return null;
|
|
|
|
Feature_0142 decoded = new Feature_0142();
|
|
|
|
decoded.Current |= (feature[2] & 0x01) == 0x01;
|
|
decoded.Persistent |= (feature[2] & 0x02) == 0x02;
|
|
decoded.Version = (byte)((feature[2] & 0x3C) >> 2);
|
|
|
|
if(decoded.Version >= 0)
|
|
{
|
|
decoded.PSAU |= (feature[4] & 0x80) == 0x80;
|
|
decoded.LOSPB |= (feature[4] & 0x40) == 0x40;
|
|
decoded.ME |= (feature[4] & 0x01) == 0x01;
|
|
decoded.Profiles = new ushort[feature[5]];
|
|
if(feature[5] * 2 + 6 == feature.Length)
|
|
{
|
|
for(int i = 0; i < feature[5]; i++)
|
|
decoded.Profiles[i] = (ushort)((feature[0 + 6 + 2 * i] << 8) + feature[1 + 6 + 2 * i]);
|
|
}
|
|
}
|
|
|
|
return decoded;
|
|
}
|
|
|
|
public static string Prettify_0000(Feature_0000? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0000 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.AppendLine("MMC Supported Profiles:");
|
|
if(ftr.Profiles != null)
|
|
{
|
|
foreach(Profile prof in ftr.Profiles)
|
|
{
|
|
switch(prof.Number)
|
|
{
|
|
case ProfileNumber.Reserved:
|
|
sb.Append("\tDrive reported a reserved profile number");
|
|
break;
|
|
case ProfileNumber.NonRemovable:
|
|
sb.Append("\tDrive supports non-removable changeable media");
|
|
break;
|
|
case ProfileNumber.Removable:
|
|
sb.Append("\tDrive supports rewritable and removable media");
|
|
break;
|
|
case ProfileNumber.MOErasable:
|
|
sb.Append("\tDrive supports Magnet-Optical media");
|
|
break;
|
|
case ProfileNumber.OpticalWORM:
|
|
sb.Append("\tDrive supports optical write-once media");
|
|
break;
|
|
case ProfileNumber.ASMO:
|
|
sb.Append("\tDrive supports Advanced Storage - Magneto-Optical");
|
|
break;
|
|
case ProfileNumber.CDROM:
|
|
sb.Append("\tDrive supports CD-ROM");
|
|
break;
|
|
case ProfileNumber.CDR:
|
|
sb.Append("\tDrive supports CD-R");
|
|
break;
|
|
case ProfileNumber.CDRW:
|
|
sb.Append("\tDrive supports CD-RW");
|
|
break;
|
|
case ProfileNumber.DVDROM:
|
|
sb.Append("\tDrive supports DVD-ROM");
|
|
break;
|
|
case ProfileNumber.DVDRSeq:
|
|
sb.Append("\tDrive supports DVD-R");
|
|
break;
|
|
case ProfileNumber.DVDRAM:
|
|
sb.Append("\tDrive supports DVD-RAM");
|
|
break;
|
|
case ProfileNumber.DVDRWRes:
|
|
sb.Append("\tDrive supports restricted overwrite DVD-RW");
|
|
break;
|
|
case ProfileNumber.DVDRWSeq:
|
|
sb.Append("\tDrive supports sequentially recorded DVD-RW");
|
|
break;
|
|
case ProfileNumber.DVDRDLSeq:
|
|
sb.Append("\tDrive supports sequentially recorded DVD-R DL");
|
|
break;
|
|
case ProfileNumber.DVDRDLJump:
|
|
sb.Append("\tDrive supports layer jump recorded DVD-R DL");
|
|
break;
|
|
case ProfileNumber.DVDRWDL:
|
|
sb.Append("\tDrive supports DVD-RW DL");
|
|
break;
|
|
case ProfileNumber.DVDDownload:
|
|
sb.Append("\tDrive supports DVD-Download");
|
|
break;
|
|
case ProfileNumber.DVDRWPlus:
|
|
sb.Append("\tDrive supports DVD+RW");
|
|
break;
|
|
case ProfileNumber.DVDRPlus:
|
|
sb.Append("\tDrive supports DVD+R");
|
|
break;
|
|
case ProfileNumber.DDCDROM:
|
|
sb.Append("\tDrive supports DDCD-ROM");
|
|
break;
|
|
case ProfileNumber.DDCDR:
|
|
sb.Append("\tDrive supports DDCD-R");
|
|
break;
|
|
case ProfileNumber.DDCDRW:
|
|
sb.Append("\tDrive supports DDCD-RW");
|
|
break;
|
|
case ProfileNumber.DVDRWDLPlus:
|
|
sb.Append("\tDrive supports DVD+RW DL");
|
|
break;
|
|
case ProfileNumber.DVDRDLPlus:
|
|
sb.Append("\tDrive supports DVD+R DL");
|
|
break;
|
|
case ProfileNumber.BDROM:
|
|
sb.Append("\tDrive supports BD-ROM");
|
|
break;
|
|
case ProfileNumber.BDRSeq:
|
|
sb.Append("\tDrive supports BD-R SRM");
|
|
break;
|
|
case ProfileNumber.BDRRdm:
|
|
sb.Append("\tDrive supports BD-R RRM");
|
|
break;
|
|
case ProfileNumber.BDRE:
|
|
sb.Append("\tDrive supports BD-RE");
|
|
break;
|
|
case ProfileNumber.HDDVDROM:
|
|
sb.Append("\tDrive supports HD DVD-ROM");
|
|
break;
|
|
case ProfileNumber.HDDVDR:
|
|
sb.Append("\tDrive supports HD DVD-R");
|
|
break;
|
|
case ProfileNumber.HDDVDRAM:
|
|
sb.Append("\tDrive supports HD DVD-RAM");
|
|
break;
|
|
case ProfileNumber.HDDVDRW:
|
|
sb.Append("\tDrive supports HD DVD-RW");
|
|
break;
|
|
case ProfileNumber.HDDVDRDL:
|
|
sb.Append("\tDrive supports HD DVD-R DL");
|
|
break;
|
|
case ProfileNumber.HDDVDRWDL:
|
|
sb.Append("\tDrive supports HD DVD-RW DL");
|
|
break;
|
|
case ProfileNumber.Unconforming:
|
|
sb.Append("\tDrive is not conforming to any profile");
|
|
break;
|
|
default:
|
|
sb.AppendFormat("\tDrive informs of unknown profile 0x{0:X4}", (ushort)prof.Number);
|
|
break;
|
|
}
|
|
|
|
if(prof.Current)
|
|
sb.AppendLine(" (current)");
|
|
else
|
|
sb.AppendLine();
|
|
}
|
|
}
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0001(Feature_0001? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0001 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.AppendLine("MMC Core Feature:");
|
|
sb.Append("\tDrive uses ");
|
|
switch(ftr.PhysicalInterfaceStandard)
|
|
{
|
|
case PhysicalInterfaces.Unspecified:
|
|
sb.AppendLine("an unspecified physical interface");
|
|
break;
|
|
case PhysicalInterfaces.SCSI:
|
|
sb.AppendLine("SCSI interface");
|
|
break;
|
|
case PhysicalInterfaces.ATAPI:
|
|
sb.AppendLine("ATAPI interface");
|
|
break;
|
|
case PhysicalInterfaces.IEEE1394:
|
|
sb.AppendLine("IEEE-1394 interface");
|
|
break;
|
|
case PhysicalInterfaces.IEEE1394A:
|
|
sb.AppendLine("IEEE-1394A interface");
|
|
break;
|
|
case PhysicalInterfaces.FC:
|
|
sb.AppendLine("Fibre Channel interface");
|
|
break;
|
|
case PhysicalInterfaces.IEEE1394B:
|
|
sb.AppendLine("IEEE-1394B interface");
|
|
break;
|
|
case PhysicalInterfaces.SerialATAPI:
|
|
sb.AppendLine("Serial ATAPI interface");
|
|
break;
|
|
case PhysicalInterfaces.USB:
|
|
sb.AppendLine("USB interface");
|
|
break;
|
|
case PhysicalInterfaces.Vendor:
|
|
sb.AppendLine("a vendor unique interface");
|
|
break;
|
|
default:
|
|
sb.AppendFormat("an unknown interface with code {0}", (uint)ftr.PhysicalInterfaceStandard).AppendLine();
|
|
break;
|
|
}
|
|
|
|
if(ftr.DBE)
|
|
sb.AppendLine("\tDrive supports Device Busy events");
|
|
if(ftr.INQ2)
|
|
sb.AppendLine("\tDrive supports EVPD, Page Code and 16-bit Allocation Length as described in SPC-3");
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0002(Feature_0002? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0002 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.AppendLine("MMC Morphing:");
|
|
|
|
if(ftr.Async)
|
|
sb.AppendLine("\tDrive supports polling and asynchronous GET EVENT STATUS NOTIFICATION");
|
|
else
|
|
sb.AppendLine("\tDrive supports only polling GET EVENT STATUS NOTIFICATION");
|
|
|
|
if(ftr.OCEvent)
|
|
sb.AppendLine("\tDrive supports operational change request / notification class events");
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0003(Feature_0003? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0003 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.AppendLine("MMC Removable Medium:");
|
|
|
|
switch(ftr.LoadingMechanismType)
|
|
{
|
|
case 0:
|
|
sb.AppendLine("\tDrive uses media caddy");
|
|
break;
|
|
case 1:
|
|
sb.AppendLine("\tDrive uses a tray");
|
|
break;
|
|
case 2:
|
|
sb.AppendLine("\tDrive is pop-up");
|
|
break;
|
|
case 4:
|
|
sb.AppendLine("\tDrive is a changer with individually changeable discs");
|
|
break;
|
|
case 5:
|
|
sb.AppendLine("\tDrive is a changer using cartridges");
|
|
break;
|
|
default:
|
|
sb.AppendFormat("\tDrive uses unknown loading mechanism type {0}", ftr.LoadingMechanismType).AppendLine();
|
|
break;
|
|
}
|
|
|
|
if(ftr.Lock)
|
|
sb.AppendLine("\tDrive can lock media");
|
|
if(ftr.PreventJumper)
|
|
sb.AppendLine("\tDrive power ups locked");
|
|
if(ftr.Eject)
|
|
sb.AppendLine("\tDrive can eject media");
|
|
if(ftr.Load)
|
|
sb.AppendLine("\tDrive can load media");
|
|
if(ftr.DBML)
|
|
sb.AppendLine("\tDrive reports Device Busy Class events during medium loading/unloading");
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0004(Feature_0004? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0004 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.AppendLine("MMC Write Protect:");
|
|
|
|
if(ftr.DWP)
|
|
sb.AppendLine("\tDrive supports reading/writing the Disc Write Protect PAC on BD-R/-RE media");
|
|
if(ftr.WDCB)
|
|
sb.AppendLine("\tDrive supports writing the Write Inhibit DCB on DVD+RW media");
|
|
if(ftr.SPWP)
|
|
sb.AppendLine("\tDrive supports set/release of PWP status");
|
|
if(ftr.SSWPP)
|
|
sb.AppendLine("\tDrive supports the SWPP bit of the Timeout and Protect mode page");
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0010(Feature_0010? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0010 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.Append("MMC Random Readable");
|
|
if(ftr.Current)
|
|
sb.Append(" (current)");
|
|
sb.AppendLine(":");
|
|
|
|
if(ftr.PP)
|
|
sb.AppendLine("\tDrive shall report Read/Write Error Recovery mode page");
|
|
if(ftr.LogicalBlockSize > 0)
|
|
sb.AppendFormat("\t{0} bytes per logical block", ftr.LogicalBlockSize).AppendLine();
|
|
if(ftr.Blocking > 1)
|
|
sb.AppendFormat("\t{0} logical blocks per media readable unit", ftr.Blocking).AppendLine();
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_001D(Feature_001D? feature)
|
|
{
|
|
return !feature.HasValue ? null : "Drive claims capability to read all CD formats according to OSTA Multi-Read Specification\n";
|
|
}
|
|
|
|
public static string Prettify_001E(Feature_001E? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_001E ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.Append("MMC CD Read");
|
|
if(ftr.Current)
|
|
sb.Append(" (current)");
|
|
sb.AppendLine(":");
|
|
|
|
if(ftr.DAP)
|
|
sb.AppendLine("\tDrive supports the DAP bit in the READ CD and READ CD MSF commands");
|
|
if(ftr.C2)
|
|
sb.AppendLine("\tDrive supports C2 Error Pointers");
|
|
if(ftr.CDText)
|
|
sb.AppendLine("\tDrive can return CD-Text from Lead-In");
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_001F(Feature_001F? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_001F ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.Append("MMC DVD Read");
|
|
if(ftr.Current)
|
|
sb.Append(" (current)");
|
|
sb.AppendLine(":");
|
|
sb.AppendLine("\tDrive can read DVD media");
|
|
|
|
if(ftr.DualR)
|
|
sb.AppendLine("\tDrive can read DVD-R DL from all recording modes");
|
|
if(ftr.DualRW)
|
|
sb.AppendLine("\tDrive can read DVD-RW DL from all recording modes");
|
|
if(ftr.MULTI110)
|
|
sb.AppendLine("\tDrive conforms to DVD Multi Drive Read-only Specifications");
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0020(Feature_0020? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0020 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.Append("MMC Random Writable:");
|
|
if(ftr.Current)
|
|
sb.Append(" (current)");
|
|
sb.AppendLine(":");
|
|
|
|
if(ftr.PP)
|
|
sb.AppendLine("\tDrive shall report Read/Write Error Recovery mode page");
|
|
if(ftr.LogicalBlockSize > 0)
|
|
sb.AppendFormat("\t{0} bytes per logical block", ftr.LogicalBlockSize).AppendLine();
|
|
if(ftr.Blocking > 1)
|
|
sb.AppendFormat("\t{0} logical blocks per media writable unit", ftr.Blocking).AppendLine();
|
|
if(ftr.LastLBA > 0)
|
|
sb.AppendFormat("\tLast adressable logical block is {0}", ftr.LastLBA).AppendLine();
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0021(Feature_0021? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0021 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.AppendLine("MMC Incremental Streaming Writable:");
|
|
|
|
if(ftr.DataTypeSupported > 0)
|
|
{
|
|
sb.Append("\tDrive supports data block types:");
|
|
if((ftr.DataTypeSupported & 0x0001) == 0x0001)
|
|
sb.Append(" 0");
|
|
if((ftr.DataTypeSupported & 0x0002) == 0x0002)
|
|
sb.Append(" 1");
|
|
if((ftr.DataTypeSupported & 0x0004) == 0x0004)
|
|
sb.Append(" 2");
|
|
if((ftr.DataTypeSupported & 0x0008) == 0x0008)
|
|
sb.Append(" 3");
|
|
if((ftr.DataTypeSupported & 0x0010) == 0x0010)
|
|
sb.Append(" 4");
|
|
if((ftr.DataTypeSupported & 0x0020) == 0x0020)
|
|
sb.Append(" 5");
|
|
if((ftr.DataTypeSupported & 0x0040) == 0x0040)
|
|
sb.Append(" 6");
|
|
if((ftr.DataTypeSupported & 0x0080) == 0x0080)
|
|
sb.Append(" 7");
|
|
if((ftr.DataTypeSupported & 0x0100) == 0x0100)
|
|
sb.Append(" 8");
|
|
if((ftr.DataTypeSupported & 0x0200) == 0x0200)
|
|
sb.Append(" 9");
|
|
if((ftr.DataTypeSupported & 0x0400) == 0x0400)
|
|
sb.Append(" 10");
|
|
if((ftr.DataTypeSupported & 0x0800) == 0x0800)
|
|
sb.Append(" 11");
|
|
if((ftr.DataTypeSupported & 0x1000) == 0x1000)
|
|
sb.Append(" 12");
|
|
if((ftr.DataTypeSupported & 0x2000) == 0x2000)
|
|
sb.Append(" 13");
|
|
if((ftr.DataTypeSupported & 0x4000) == 0x4000)
|
|
sb.Append(" 14");
|
|
if((ftr.DataTypeSupported & 0x8000) == 0x8000)
|
|
sb.Append(" 15");
|
|
sb.AppendLine();
|
|
}
|
|
|
|
if(ftr.TRIO)
|
|
sb.AppendLine("\tDrive claims support to report Track Resources Information");
|
|
if(ftr.ARSV)
|
|
sb.AppendLine("\tDrive supports address mode reservation on the RESERVE TRACK command");
|
|
if(ftr.BUF)
|
|
sb.AppendLine("\tDrive is capable of zero loss linking");
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0022(Feature_0022? feature)
|
|
{
|
|
return !feature.HasValue ? null : "Drive supports media that require erasing before writing\n";
|
|
}
|
|
|
|
public static string Prettify_0023(Feature_0023? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0023 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.AppendLine("MMC Formattable:");
|
|
sb.AppendLine("\tDrive can format media into logical blocks");
|
|
|
|
if(ftr.RENoSA)
|
|
sb.AppendLine("\tDrive can format BD-RE with no spares allocated");
|
|
if(ftr.Expand)
|
|
sb.AppendLine("\tDrive can expand the spare area on a formatted BD-RE disc");
|
|
if(ftr.QCert)
|
|
sb.AppendLine("\tDrive can format BD-RE discs with quick certification");
|
|
if(ftr.Cert)
|
|
sb.AppendLine("\tDrive can format BD-RE discs with full certification");
|
|
if(ftr.FRF)
|
|
sb.AppendLine("\tDrive can fast re-format BD-RE discs");
|
|
if(ftr.RRM)
|
|
sb.AppendLine("\tDrive can format BD-R discs with RRM format");
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0024(Feature_0024? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0024 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.AppendLine("MMC Hardware Defect Management:");
|
|
sb.AppendLine("\tDrive shall be able to provide a defect-free contiguous address space");
|
|
if(ftr.SSA)
|
|
sb.AppendLine("\tDrive can return Spare Area Information");
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0025(Feature_0025? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0025 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.Append("MMC Write Once");
|
|
if(ftr.Current)
|
|
sb.Append(" (current)");
|
|
sb.AppendLine(":");
|
|
|
|
if(ftr.PP)
|
|
sb.AppendLine("\tDrive shall report Read/Write Error Recovery mode page");
|
|
if(ftr.LogicalBlockSize > 0)
|
|
sb.AppendFormat("\t{0} bytes per logical block", ftr.LogicalBlockSize).AppendLine();
|
|
if(ftr.Blocking > 1)
|
|
sb.AppendFormat("\t{0} logical blocks per media writable unit", ftr.Blocking).AppendLine();
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0026(Feature_0026? feature)
|
|
{
|
|
return !feature.HasValue ? null : "Drive shall have the ability to overwrite logical blocks only in fixed sets at a time\n";
|
|
}
|
|
|
|
public static string Prettify_0027(Feature_0027? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0027 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.Append("Drive can write High-Speed CD-RW");
|
|
if(ftr.Current)
|
|
sb.AppendLine(" (current)");
|
|
else
|
|
sb.AppendLine();
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0028(Feature_0028? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0028 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
if(ftr.Write && ftr.DVDPRead && ftr.DVDPWrite)
|
|
sb.Append("Drive can read and write CD-MRW and DVD+MRW");
|
|
else if(ftr.DVDPRead && ftr.DVDPWrite)
|
|
sb.Append("Drive can read and write DVD+MRW");
|
|
else if(ftr.Write && ftr.DVDPRead)
|
|
sb.Append("Drive and read DVD+MRW and read and write CD-MRW");
|
|
else if(ftr.Write)
|
|
sb.Append("Drive can read and write CD-MRW");
|
|
else if(ftr.DVDPRead)
|
|
sb.Append("Drive can read CD-MRW and DVD+MRW");
|
|
else
|
|
sb.Append("Drive can read CD-MRW");
|
|
|
|
if(ftr.Current)
|
|
sb.AppendLine(" (current)");
|
|
else
|
|
sb.AppendLine();
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0029(Feature_0029? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0029 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.AppendLine("MMC Enhanced Defect Reporting Feature:");
|
|
|
|
if(ftr.DRTDM)
|
|
sb.AppendLine("\tDrive supports DRT-DM mode");
|
|
else
|
|
sb.AppendLine("\tDrive supports Persistent-DM mode");
|
|
|
|
if(ftr.DBICacheZones > 0)
|
|
sb.AppendFormat("\tDrive has {0} DBI cache zones", ftr.DBICacheZones).AppendLine();
|
|
if(ftr.Entries > 0)
|
|
sb.AppendFormat("\tDrive has {0} DBI entries", ftr.Entries).AppendLine();
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_002A(Feature_002A? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_002A ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
if(ftr.Write)
|
|
{
|
|
sb.Append("Drive can read and write DVD+RW");
|
|
if(ftr.Current)
|
|
sb.AppendLine(" (current)");
|
|
else
|
|
sb.AppendLine();
|
|
if(ftr.CloseOnly)
|
|
sb.AppendLine("\tDrive supports only the read compatibility stop");
|
|
else
|
|
sb.AppendLine("\tDrive supports both forms of background format stopping");
|
|
if(ftr.QuickStart)
|
|
sb.AppendLine("\tDrive can do a quick start formatting");
|
|
}
|
|
else
|
|
{
|
|
sb.Append("Drive can read DVD+RW");
|
|
if(ftr.Current)
|
|
sb.AppendLine(" (current)");
|
|
else
|
|
sb.AppendLine();
|
|
}
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_002B(Feature_002B? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_002B ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
if(ftr.Write)
|
|
{
|
|
sb.Append("Drive can read and write DVD+R");
|
|
if(ftr.Current)
|
|
sb.AppendLine(" (current)");
|
|
else
|
|
sb.AppendLine();
|
|
}
|
|
else
|
|
{
|
|
sb.Append("Drive can read DVD+R");
|
|
if(ftr.Current)
|
|
sb.AppendLine(" (current)");
|
|
else
|
|
sb.AppendLine();
|
|
}
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_002C(Feature_002C? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_002C ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.Append("MMC Rigid Restricted Overwrite");
|
|
if(ftr.Current)
|
|
sb.AppendLine(" (current):");
|
|
else
|
|
sb.AppendLine(":");
|
|
|
|
if(ftr.Blank)
|
|
sb.AppendLine("\tDrive supports the BLANK command");
|
|
if(ftr.Intermediate)
|
|
sb.AppendLine("\tDrive supports writing on an intermediate state session and quick formatting");
|
|
if(ftr.DSDR)
|
|
sb.AppendLine("\tDrive can read Defect Status data recorded on the medium");
|
|
if(ftr.DSDG)
|
|
sb.AppendLine("\tDrive can generate Defect Status data during formatting");
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_002D(Feature_002D? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_002D ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.AppendLine("Drive can write CDs in Track at Once Mode:");
|
|
|
|
if(ftr.RWSubchannel)
|
|
{
|
|
sb.AppendLine("\tDrive can write user provided data in the R-W subchannels");
|
|
if(ftr.RWRaw)
|
|
sb.AppendLine("\tDrive accepts RAW R-W subchannel data");
|
|
if(ftr.RWPack)
|
|
sb.AppendLine("\tDrive accepts Packed R-W subchannel data");
|
|
|
|
}
|
|
|
|
if(ftr.CDRW)
|
|
sb.AppendLine("\tDrive can overwrite a TAO track with another in CD-RWs");
|
|
if(ftr.TestWrite)
|
|
sb.AppendLine("\tDrive can do a test writing");
|
|
if(ftr.BUF)
|
|
sb.AppendLine("\tDrive supports zero loss linking");
|
|
|
|
if(ftr.DataTypeSupported > 0)
|
|
{
|
|
sb.Append("\tDrive supports data block types:");
|
|
if((ftr.DataTypeSupported & 0x0001) == 0x0001)
|
|
sb.Append(" 0");
|
|
if((ftr.DataTypeSupported & 0x0002) == 0x0002)
|
|
sb.Append(" 1");
|
|
if((ftr.DataTypeSupported & 0x0004) == 0x0004)
|
|
sb.Append(" 2");
|
|
if((ftr.DataTypeSupported & 0x0008) == 0x0008)
|
|
sb.Append(" 3");
|
|
if((ftr.DataTypeSupported & 0x0010) == 0x0010)
|
|
sb.Append(" 4");
|
|
if((ftr.DataTypeSupported & 0x0020) == 0x0020)
|
|
sb.Append(" 5");
|
|
if((ftr.DataTypeSupported & 0x0040) == 0x0040)
|
|
sb.Append(" 6");
|
|
if((ftr.DataTypeSupported & 0x0080) == 0x0080)
|
|
sb.Append(" 7");
|
|
if((ftr.DataTypeSupported & 0x0100) == 0x0100)
|
|
sb.Append(" 8");
|
|
if((ftr.DataTypeSupported & 0x0200) == 0x0200)
|
|
sb.Append(" 9");
|
|
if((ftr.DataTypeSupported & 0x0400) == 0x0400)
|
|
sb.Append(" 10");
|
|
if((ftr.DataTypeSupported & 0x0800) == 0x0800)
|
|
sb.Append(" 11");
|
|
if((ftr.DataTypeSupported & 0x1000) == 0x1000)
|
|
sb.Append(" 12");
|
|
if((ftr.DataTypeSupported & 0x2000) == 0x2000)
|
|
sb.Append(" 13");
|
|
if((ftr.DataTypeSupported & 0x4000) == 0x4000)
|
|
sb.Append(" 14");
|
|
if((ftr.DataTypeSupported & 0x8000) == 0x8000)
|
|
sb.Append(" 15");
|
|
sb.AppendLine();
|
|
}
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_002E(Feature_002E? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_002E ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
if(ftr.SAO && !ftr.RAW)
|
|
sb.AppendLine("Drive can write CDs in Session at Once Mode:");
|
|
else if(!ftr.SAO && ftr.RAW)
|
|
sb.AppendLine("Drive can write CDs in raw Mode:");
|
|
else
|
|
sb.AppendLine("Drive can write CDs in Session at Once and in Raw Modes:");
|
|
|
|
if(ftr.RAW && ftr.RAWMS)
|
|
sb.AppendLine("\tDrive can write multi-session CDs in raw mode");
|
|
|
|
if(ftr.RW)
|
|
sb.AppendLine("\tDrive can write user provided data in the R-W subchannels");
|
|
|
|
if(ftr.CDRW)
|
|
sb.AppendLine("\tDrive can write CD-RWs");
|
|
if(ftr.TestWrite)
|
|
sb.AppendLine("\tDrive can do a test writing");
|
|
if(ftr.BUF)
|
|
sb.AppendLine("\tDrive supports zero loss linking");
|
|
|
|
if(ftr.MaxCueSheet > 0)
|
|
sb.AppendFormat("\tDrive supports a maximum of {0} bytes in a single cue sheet", ftr.MaxCueSheet).AppendLine();
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_002F(Feature_002F? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_002F ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
if(ftr.DVDRW && ftr.RDL)
|
|
sb.AppendLine("Drive supports writing DVD-R, DVD-RW and DVD-R DL");
|
|
else if(ftr.RDL)
|
|
sb.AppendLine("Drive supports writing DVD-R and DVD-R DL");
|
|
else if(ftr.DVDRW)
|
|
sb.AppendLine("Drive supports writing DVD-R and DVD-RW");
|
|
else
|
|
sb.AppendLine("Drive supports writing DVD-R");
|
|
|
|
if(ftr.TestWrite)
|
|
sb.AppendLine("\tDrive can do a test writing");
|
|
if(ftr.BUF)
|
|
sb.AppendLine("\tDrive supports zero loss linking");
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0030(Feature_0030? feature)
|
|
{
|
|
return !feature.HasValue ? null : "Drive can read DDCDs\n";
|
|
}
|
|
|
|
public static string Prettify_0031(Feature_0031? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0031 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.AppendLine("Drive supports writing DDCD-R");
|
|
|
|
if(ftr.TestWrite)
|
|
sb.AppendLine("\tDrive can do a test writing");
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0032(Feature_0032? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0032 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.AppendLine("Drive supports writing DDCD-RW");
|
|
|
|
if(ftr.Blank)
|
|
sb.AppendLine("\tDrive supports the BLANK command");
|
|
if(ftr.Intermediate)
|
|
sb.AppendLine("\tDrive supports quick formatting");
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0033(Feature_0033? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0033 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.AppendLine("MMC Layer Jump Recording:");
|
|
|
|
if(ftr.LinkSizes != null)
|
|
{
|
|
foreach(byte link in ftr.LinkSizes)
|
|
sb.AppendFormat("\tCurrent media has a {0} bytes link available", link).AppendLine();
|
|
}
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0035(Feature_0035? feature)
|
|
{
|
|
return !feature.HasValue ? null : "Drive can stop a long immediate operation\n";
|
|
}
|
|
|
|
public static string Prettify_0037(Feature_0037? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0037 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.AppendLine("Drive can write CD-RW");
|
|
if(ftr.SubtypeSupport > 0)
|
|
{
|
|
sb.Append("\tDrive supports CD-RW subtypes");
|
|
if((ftr.SubtypeSupport & 0x01) == 0x01)
|
|
sb.Append(" 0");
|
|
if((ftr.SubtypeSupport & 0x02) == 0x02)
|
|
sb.Append(" 1");
|
|
if((ftr.SubtypeSupport & 0x04) == 0x04)
|
|
sb.Append(" 2");
|
|
if((ftr.SubtypeSupport & 0x08) == 0x08)
|
|
sb.Append(" 3");
|
|
if((ftr.SubtypeSupport & 0x10) == 0x10)
|
|
sb.Append(" 4");
|
|
if((ftr.SubtypeSupport & 0x20) == 0x20)
|
|
sb.Append(" 5");
|
|
if((ftr.SubtypeSupport & 0x40) == 0x40)
|
|
sb.Append(" 6");
|
|
if((ftr.SubtypeSupport & 0x80) == 0x80)
|
|
sb.Append(" 7");
|
|
sb.AppendLine();
|
|
}
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0038(Feature_0038? feature)
|
|
{
|
|
return !feature.HasValue ? null : "Drive can write BD-R on Pseudo-OVerwrite SRM mode\n";
|
|
}
|
|
|
|
public static string Prettify_003A(Feature_003A? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_003A ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
if(ftr.Write)
|
|
{
|
|
sb.Append("Drive can read and write DVD+RW DL");
|
|
if(ftr.Current)
|
|
sb.AppendLine(" (current)");
|
|
else
|
|
sb.AppendLine();
|
|
if(ftr.CloseOnly)
|
|
sb.AppendLine("\tDrive supports only the read compatibility stop");
|
|
else
|
|
sb.AppendLine("\tDrive supports both forms of background format stopping");
|
|
if(ftr.QuickStart)
|
|
sb.AppendLine("\tDrive can do a quick start formatting");
|
|
}
|
|
else
|
|
{
|
|
sb.Append("Drive can read DVD+RW DL");
|
|
if(ftr.Current)
|
|
sb.AppendLine(" (current)");
|
|
else
|
|
sb.AppendLine();
|
|
}
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_003B(Feature_003B? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_003B ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
if(ftr.Write)
|
|
{
|
|
sb.Append("Drive can read and write DVD+R DL");
|
|
if(ftr.Current)
|
|
sb.AppendLine(" (current)");
|
|
else
|
|
sb.AppendLine();
|
|
}
|
|
else
|
|
{
|
|
sb.Append("Drive can read DVD+R DL");
|
|
if(ftr.Current)
|
|
sb.AppendLine(" (current)");
|
|
else
|
|
sb.AppendLine();
|
|
}
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0040(Feature_0040? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0040 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.Append("MMC BD Read");
|
|
if(ftr.Current)
|
|
sb.AppendLine(" (current):");
|
|
else
|
|
sb.AppendLine(":");
|
|
|
|
if(ftr.OldROM)
|
|
sb.AppendLine("\tDrive can read BD-ROM pre-1.0");
|
|
if(ftr.ROM)
|
|
sb.AppendLine("\tDrive can read BD-ROM Ver.1");
|
|
if(ftr.OldR)
|
|
sb.AppendLine("\tDrive can read BD-R pre-1.0");
|
|
if(ftr.R)
|
|
sb.AppendLine("\tDrive can read BD-R Ver.1");
|
|
if(ftr.OldRE)
|
|
sb.AppendLine("\tDrive can read BD-RE pre-1.0");
|
|
if(ftr.RE1)
|
|
sb.AppendLine("\tDrive can read BD-RE Ver.1");
|
|
if(ftr.RE2)
|
|
sb.AppendLine("\tDrive can read BD-RE Ver.2");
|
|
|
|
if(ftr.BCA)
|
|
sb.AppendLine("\tDrive can read BD's Burst Cutting Area");
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0041(Feature_0041? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0041 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.Append("MMC BD Write");
|
|
if(ftr.Current)
|
|
sb.AppendLine(" (current):");
|
|
else
|
|
sb.AppendLine(":");
|
|
|
|
if(ftr.OldR)
|
|
sb.AppendLine("\tDrive can write BD-R pre-1.0");
|
|
if(ftr.R)
|
|
sb.AppendLine("\tDrive can write BD-R Ver.1");
|
|
if(ftr.OldRE)
|
|
sb.AppendLine("\tDrive can write BD-RE pre-1.0");
|
|
if(ftr.RE1)
|
|
sb.AppendLine("\tDrive can write BD-RE Ver.1");
|
|
if(ftr.RE2)
|
|
sb.AppendLine("\tDrive can write BD-RE Ver.2");
|
|
|
|
if(ftr.SVNR)
|
|
sb.AppendLine("\tDrive supports write without verify requirement");
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0042(Feature_0042? feature)
|
|
{
|
|
return !feature.HasValue ? null : "Drive is able to detect and report defective writable unit and behave accordinly\n";
|
|
}
|
|
|
|
public static string Prettify_0050(Feature_0050? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0050 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
if(ftr.HDDVDR && ftr.HDDVDRAM)
|
|
sb.Append("Drive can read HD DVD-ROM, HD DVD-RW, HD DVD-R and HD DVD-RAM");
|
|
else if(ftr.HDDVDR)
|
|
sb.Append("Drive can read HD DVD-ROM, HD DVD-RW and HD DVD-R");
|
|
else if(ftr.HDDVDRAM)
|
|
sb.Append("Drive can read HD DVD-ROM, HD DVD-RW and HD DVD-RAM");
|
|
else
|
|
sb.Append("Drive can read HD DVD-ROM and HD DVD-RW");
|
|
|
|
if(ftr.Current)
|
|
sb.AppendLine(" (current)");
|
|
else
|
|
sb.AppendLine();
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0051(Feature_0051? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0051 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
if(ftr.HDDVDR && ftr.HDDVDRAM)
|
|
sb.Append("Drive can write HD DVD-RW, HD DVD-R and HD DVD-RAM");
|
|
else if(ftr.HDDVDR)
|
|
sb.Append("Drive can write HD DVD-RW and HD DVD-R");
|
|
else if(ftr.HDDVDRAM)
|
|
sb.Append("Drive can write HD DVD-RW and HD DVD-RAM");
|
|
else
|
|
sb.Append("Drive can write HD DVD-RW");
|
|
|
|
if(ftr.Current)
|
|
sb.AppendLine(" (current)");
|
|
else
|
|
sb.AppendLine();
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0080(Feature_0080? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0080 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.Append("Drive is able to access Hybrid discs");
|
|
if(ftr.Current)
|
|
sb.AppendLine(" (current)");
|
|
else
|
|
sb.AppendLine();
|
|
|
|
if(ftr.RI)
|
|
sb.AppendLine("\tDrive is able to maintain the online format layer through reset and power cycling");
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0100(Feature_0100? feature)
|
|
{
|
|
return !feature.HasValue ? null : "Drive is able to perform host and drive directed power management\n";
|
|
}
|
|
|
|
public static string Prettify_0101(Feature_0101? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0101 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.AppendLine("Drive supports S.M.A.R.T.");
|
|
if(ftr.PP)
|
|
sb.AppendLine("\tDrive supports the Informational Exceptions Control mode page 1Ch");
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0102(Feature_0102? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0102 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.AppendLine("MMC Embedded Changer:");
|
|
|
|
if(ftr.SCC)
|
|
sb.AppendLine("\tDrive can change disc side");
|
|
if(ftr.SDP)
|
|
sb.AppendLine("\tDrive is able to report slots contents after a reset or change");
|
|
|
|
sb.AppendFormat("\tDrive has {0} slots", ftr.HighestSlotNumber + 1).AppendLine();
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0103(Feature_0103? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0103 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.AppendLine("Drive has an analogue audio output");
|
|
|
|
if(ftr.Scan)
|
|
sb.AppendLine("\tDrive supports the SCAN command");
|
|
if(ftr.SCM)
|
|
sb.AppendLine("\tDrive is able to mute channels separately");
|
|
if(ftr.SV)
|
|
sb.AppendLine("\tDrive supports separate volume per channel");
|
|
|
|
sb.AppendFormat("\tDrive has {0} volume levels", ftr.VolumeLevels + 1).AppendLine();
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0104(Feature_0104? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0104 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.AppendLine("Drive supports Microcode Upgrade");
|
|
if(ftr.M5)
|
|
sb.AppendLine("Drive supports validating the 5-bit Mode of the READ BUFFER and WRITE BUFFER commands");
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0105(Feature_0105? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0105 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.AppendLine("Drive supports Timeout & Protect mode page 1Dh");
|
|
|
|
if(ftr.Group3)
|
|
{
|
|
sb.AppendLine("\tDrive supports the Group3 in Timeout & Protect mode page 1Dh");
|
|
if(ftr.UnitLength > 0)
|
|
sb.AppendFormat("\tDrive has {0} increase of Group 3 time unit", ftr.UnitLength).AppendLine();
|
|
}
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0106(Feature_0106? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0106 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.AppendFormat("Drive supports DVD CSS/CPPM version {0}", ftr.CSSVersion);
|
|
if(ftr.Current)
|
|
sb.AppendLine(" and current disc is encrypted");
|
|
else
|
|
sb.AppendLine();
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0107(Feature_0107? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0107 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.AppendLine("MMC Real Time Streaming:");
|
|
|
|
if(ftr.SMP)
|
|
sb.AppendLine("\tDrive supports Set Minimum Performance with the SET STREAMING command");
|
|
if(ftr.RBCB)
|
|
sb.AppendLine("\tDrive supports the block bit in the READ BUFFER CAPACITY command");
|
|
if(ftr.SCS)
|
|
sb.AppendLine("\tDrive supports the SET CD SPEED command");
|
|
if(ftr.MP2A)
|
|
sb.AppendLine("\tDrive supports the Write Speed Performance Descriptor Blocks in the MMC mode page 2Ah");
|
|
if(ftr.WSPD)
|
|
sb.AppendLine("\tDrive supports the Write Speed data of GET PERFORMANCE and the WRC field of SET STREAMING");
|
|
if(ftr.SW)
|
|
sb.AppendLine("\tDrive supports stream recording");
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0108(Feature_0108? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0108 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.AppendFormat("Drive serial number: {0}", ftr.Serial).AppendLine();
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0109(Feature_0109? feature)
|
|
{
|
|
return !feature.HasValue ? null : "Drive is to read media serial number\n";
|
|
}
|
|
|
|
public static string Prettify_010A(Feature_010A? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_010A ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
if(ftr.DCBs != null)
|
|
{
|
|
foreach(uint DCB in ftr.DCBs)
|
|
sb.AppendFormat("Drive supports DCB {0:X8}h", DCB).AppendLine();
|
|
}
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_010B(Feature_010B? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_010B ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.AppendFormat("Drive supports DVD CPRM version {0}", ftr.CPRMVersion);
|
|
if(ftr.Current)
|
|
sb.AppendLine(" and current disc is or can be encrypted");
|
|
else
|
|
sb.AppendLine();
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_010C(Feature_010C? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_010C ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
string syear, smonth, sday, shour, sminute, ssecond;
|
|
byte[] temp;
|
|
|
|
temp = new byte[4];
|
|
temp[0] = (byte)((ftr.Century & 0xFF00) >> 8);
|
|
temp[1] = (byte)(ftr.Century & 0xFF);
|
|
temp[2] = (byte)((ftr.Year & 0xFF00) >> 8);
|
|
temp[3] = (byte)(ftr.Year & 0xFF);
|
|
syear = Encoding.ASCII.GetString(temp);
|
|
temp = new byte[2];
|
|
temp[0] = (byte)((ftr.Month & 0xFF00) >> 8);
|
|
temp[1] = (byte)(ftr.Month & 0xFF);
|
|
smonth = Encoding.ASCII.GetString(temp);
|
|
temp = new byte[2];
|
|
temp[0] = (byte)((ftr.Day & 0xFF00) >> 8);
|
|
temp[1] = (byte)(ftr.Day & 0xFF);
|
|
sday = Encoding.ASCII.GetString(temp);
|
|
temp = new byte[2];
|
|
temp[0] = (byte)((ftr.Hour & 0xFF00) >> 8);
|
|
temp[1] = (byte)(ftr.Hour & 0xFF);
|
|
shour = Encoding.ASCII.GetString(temp);
|
|
temp = new byte[2];
|
|
temp[0] = (byte)((ftr.Minute & 0xFF00) >> 8);
|
|
temp[1] = (byte)(ftr.Minute & 0xFF);
|
|
sminute = Encoding.ASCII.GetString(temp);
|
|
temp = new byte[2];
|
|
temp[0] = (byte)((ftr.Second & 0xFF00) >> 8);
|
|
temp[1] = (byte)(ftr.Second & 0xFF);
|
|
ssecond = Encoding.ASCII.GetString(temp);
|
|
|
|
try
|
|
{
|
|
DateTime fwDate = new DateTime(Int32.Parse(syear), Int32.Parse(smonth),
|
|
Int32.Parse(sday), Int32.Parse(shour), Int32.Parse(sminute),
|
|
Int32.Parse(ssecond), DateTimeKind.Utc);
|
|
|
|
sb.AppendFormat("Drive firmware is dated {0}", fwDate).AppendLine();
|
|
}
|
|
catch
|
|
{
|
|
}
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_010D(Feature_010D? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_010D ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.AppendFormat("Drive supports AACS version {0}", ftr.AACSVersion);
|
|
if(ftr.Current)
|
|
sb.AppendLine(" and current disc is encrypted");
|
|
else
|
|
sb.AppendLine();
|
|
|
|
if(ftr.RDC)
|
|
sb.AppendLine("\tDrive supports reading the Drive Certificate");
|
|
if(ftr.RMC)
|
|
sb.AppendLine("\tDrive supports reading Media Key Block of CPRM");
|
|
if(ftr.WBE)
|
|
sb.AppendLine("\tDrive supports writing with bus encryption");
|
|
if(ftr.BEC)
|
|
sb.AppendLine("\tDrive supports bus encryption");
|
|
if(ftr.BNG)
|
|
{
|
|
sb.AppendLine("\tDrive supports generating the binding nonce");
|
|
if(ftr.BindNonceBlocks > 0)
|
|
sb.AppendFormat("\t{0} media blocks are required for the binding nonce", ftr.BindNonceBlocks).AppendLine();
|
|
}
|
|
if(ftr.AGIDs > 0)
|
|
sb.AppendFormat("\tDrive supports {0} AGIDs concurrently", ftr.AGIDs).AppendLine();
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_010E(Feature_010E? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_010E ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.Append("Drive supports DVD-Download");
|
|
if(ftr.Current)
|
|
sb.AppendLine(" (current)");
|
|
else
|
|
sb.AppendLine();
|
|
|
|
if(ftr.MaxScrambleExtent > 0)
|
|
sb.AppendFormat("\tMaximum {0} scranble extent information entries", ftr.MaxScrambleExtent).AppendLine();
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0110(Feature_0110? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0110 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
if(ftr.Current)
|
|
sb.AppendLine("Drive and currently inserted media support VCPS");
|
|
else
|
|
sb.AppendLine("Drive supports VCPS");
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0113(Feature_0113? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0113 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
if(ftr.Current)
|
|
sb.AppendLine("Drive and currently inserted media support SecurDisc");
|
|
else
|
|
sb.AppendLine("Drive supports SecurDisc");
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0142(Feature_0142? feature)
|
|
{
|
|
if(!feature.HasValue)
|
|
return null;
|
|
|
|
Feature_0142 ftr = feature.Value;
|
|
StringBuilder sb = new StringBuilder();
|
|
|
|
sb.AppendLine("Drive supports the Trusted Computing Group Optical Security Subsystem Class");
|
|
|
|
if(ftr.Current)
|
|
sb.AppendLine("\tCurrent media is initialized with TCG OSSC");
|
|
if(ftr.PSAU)
|
|
sb.AppendLine("\tDrive supports PSA updates on write-once media");
|
|
if(ftr.LOSPB)
|
|
sb.AppendLine("\tDrive supports linked OSPBs");
|
|
if(ftr.ME)
|
|
sb.AppendLine("\tDrive will only record on the OSSC Disc Format");
|
|
|
|
if(ftr.Profiles != null)
|
|
{
|
|
for(int i = 0; i < ftr.Profiles.Length; i++)
|
|
sb.AppendFormat("\tProfile {0}: {1}", i, ftr.Profiles[i]).AppendLine();
|
|
}
|
|
|
|
return sb.ToString();
|
|
}
|
|
|
|
public static string Prettify_0000(byte[] feature)
|
|
{
|
|
return Prettify_0000(Decode_0000(feature));
|
|
}
|
|
|
|
public static string Prettify_0001(byte[] feature)
|
|
{
|
|
return Prettify_0001(Decode_0001(feature));
|
|
}
|
|
|
|
public static string Prettify_0002(byte[] feature)
|
|
{
|
|
return Prettify_0002(Decode_0002(feature));
|
|
}
|
|
|
|
public static string Prettify_0003(byte[] feature)
|
|
{
|
|
return Prettify_0003(Decode_0003(feature));
|
|
}
|
|
|
|
public static string Prettify_0004(byte[] feature)
|
|
{
|
|
return Prettify_0004(Decode_0004(feature));
|
|
}
|
|
|
|
public static string Prettify_0010(byte[] feature)
|
|
{
|
|
return Prettify_0010(Decode_0010(feature));
|
|
}
|
|
|
|
public static string Prettify_001D(byte[] feature)
|
|
{
|
|
return Prettify_001D(Decode_001D(feature));
|
|
}
|
|
|
|
public static string Prettify_001E(byte[] feature)
|
|
{
|
|
return Prettify_001E(Decode_001E(feature));
|
|
}
|
|
|
|
public static string Prettify_001F(byte[] feature)
|
|
{
|
|
return Prettify_001F(Decode_001F(feature));
|
|
}
|
|
|
|
public static string Prettify_0020(byte[] feature)
|
|
{
|
|
return Prettify_0020(Decode_0020(feature));
|
|
}
|
|
|
|
public static string Prettify_0021(byte[] feature)
|
|
{
|
|
return Prettify_0021(Decode_0021(feature));
|
|
}
|
|
|
|
public static string Prettify_0022(byte[] feature)
|
|
{
|
|
return Prettify_0022(Decode_0022(feature));
|
|
}
|
|
|
|
public static string Prettify_0023(byte[] feature)
|
|
{
|
|
return Prettify_0023(Decode_0023(feature));
|
|
}
|
|
|
|
public static string Prettify_0024(byte[] feature)
|
|
{
|
|
return Prettify_0024(Decode_0024(feature));
|
|
}
|
|
|
|
public static string Prettify_0025(byte[] feature)
|
|
{
|
|
return Prettify_0025(Decode_0025(feature));
|
|
}
|
|
|
|
public static string Prettify_0026(byte[] feature)
|
|
{
|
|
return Prettify_0026(Decode_0026(feature));
|
|
}
|
|
|
|
public static string Prettify_0027(byte[] feature)
|
|
{
|
|
return Prettify_0027(Decode_0027(feature));
|
|
}
|
|
|
|
public static string Prettify_0028(byte[] feature)
|
|
{
|
|
return Prettify_0028(Decode_0028(feature));
|
|
}
|
|
|
|
public static string Prettify_0029(byte[] feature)
|
|
{
|
|
return Prettify_0029(Decode_0029(feature));
|
|
}
|
|
|
|
public static string Prettify_002A(byte[] feature)
|
|
{
|
|
return Prettify_002A(Decode_002A(feature));
|
|
}
|
|
|
|
public static string Prettify_002B(byte[] feature)
|
|
{
|
|
return Prettify_002B(Decode_002B(feature));
|
|
}
|
|
|
|
public static string Prettify_002C(byte[] feature)
|
|
{
|
|
return Prettify_002C(Decode_002C(feature));
|
|
}
|
|
|
|
public static string Prettify_002D(byte[] feature)
|
|
{
|
|
return Prettify_002D(Decode_002D(feature));
|
|
}
|
|
|
|
public static string Prettify_002E(byte[] feature)
|
|
{
|
|
return Prettify_002E(Decode_002E(feature));
|
|
}
|
|
|
|
public static string Prettify_002F(byte[] feature)
|
|
{
|
|
return Prettify_002F(Decode_002F(feature));
|
|
}
|
|
|
|
public static string Prettify_0030(byte[] feature)
|
|
{
|
|
return Prettify_0030(Decode_0030(feature));
|
|
}
|
|
|
|
public static string Prettify_0031(byte[] feature)
|
|
{
|
|
return Prettify_0031(Decode_0031(feature));
|
|
}
|
|
|
|
public static string Prettify_0032(byte[] feature)
|
|
{
|
|
return Prettify_0032(Decode_0032(feature));
|
|
}
|
|
|
|
public static string Prettify_0033(byte[] feature)
|
|
{
|
|
return Prettify_0033(Decode_0033(feature));
|
|
}
|
|
|
|
public static string Prettify_0035(byte[] feature)
|
|
{
|
|
return Prettify_0035(Decode_0035(feature));
|
|
}
|
|
|
|
public static string Prettify_0037(byte[] feature)
|
|
{
|
|
return Prettify_0037(Decode_0037(feature));
|
|
}
|
|
|
|
public static string Prettify_0038(byte[] feature)
|
|
{
|
|
return Prettify_0038(Decode_0038(feature));
|
|
}
|
|
|
|
public static string Prettify_003A(byte[] feature)
|
|
{
|
|
return Prettify_003A(Decode_003A(feature));
|
|
}
|
|
|
|
public static string Prettify_003B(byte[] feature)
|
|
{
|
|
return Prettify_003B(Decode_003B(feature));
|
|
}
|
|
|
|
public static string Prettify_0040(byte[] feature)
|
|
{
|
|
return Prettify_0040(Decode_0040(feature));
|
|
}
|
|
|
|
public static string Prettify_0041(byte[] feature)
|
|
{
|
|
return Prettify_0041(Decode_0041(feature));
|
|
}
|
|
|
|
public static string Prettify_0042(byte[] feature)
|
|
{
|
|
return Prettify_0042(Decode_0042(feature));
|
|
}
|
|
|
|
public static string Prettify_0050(byte[] feature)
|
|
{
|
|
return Prettify_0050(Decode_0050(feature));
|
|
}
|
|
|
|
public static string Prettify_0051(byte[] feature)
|
|
{
|
|
return Prettify_0051(Decode_0051(feature));
|
|
}
|
|
|
|
public static string Prettify_0080(byte[] feature)
|
|
{
|
|
return Prettify_0080(Decode_0080(feature));
|
|
}
|
|
|
|
public static string Prettify_0100(byte[] feature)
|
|
{
|
|
return Prettify_0100(Decode_0100(feature));
|
|
}
|
|
|
|
public static string Prettify_0101(byte[] feature)
|
|
{
|
|
return Prettify_0101(Decode_0101(feature));
|
|
}
|
|
|
|
public static string Prettify_0102(byte[] feature)
|
|
{
|
|
return Prettify_0102(Decode_0102(feature));
|
|
}
|
|
|
|
public static string Prettify_0103(byte[] feature)
|
|
{
|
|
return Prettify_0103(Decode_0103(feature));
|
|
}
|
|
|
|
public static string Prettify_0104(byte[] feature)
|
|
{
|
|
return Prettify_0104(Decode_0104(feature));
|
|
}
|
|
|
|
public static string Prettify_0105(byte[] feature)
|
|
{
|
|
return Prettify_0105(Decode_0105(feature));
|
|
}
|
|
|
|
public static string Prettify_0106(byte[] feature)
|
|
{
|
|
return Prettify_0106(Decode_0106(feature));
|
|
}
|
|
|
|
public static string Prettify_0107(byte[] feature)
|
|
{
|
|
return Prettify_0107(Decode_0107(feature));
|
|
}
|
|
|
|
public static string Prettify_0108(byte[] feature)
|
|
{
|
|
return Prettify_0108(Decode_0108(feature));
|
|
}
|
|
|
|
public static string Prettify_0109(byte[] feature)
|
|
{
|
|
return Prettify_0109(Decode_0109(feature));
|
|
}
|
|
|
|
public static string Prettify_010A(byte[] feature)
|
|
{
|
|
return Prettify_010A(Decode_010A(feature));
|
|
}
|
|
|
|
public static string Prettify_010B(byte[] feature)
|
|
{
|
|
return Prettify_010B(Decode_010B(feature));
|
|
}
|
|
|
|
public static string Prettify_010C(byte[] feature)
|
|
{
|
|
return Prettify_010C(Decode_010C(feature));
|
|
}
|
|
|
|
public static string Prettify_010D(byte[] feature)
|
|
{
|
|
return Prettify_010D(Decode_010D(feature));
|
|
}
|
|
|
|
public static string Prettify_010E(byte[] feature)
|
|
{
|
|
return Prettify_010E(Decode_010E(feature));
|
|
}
|
|
|
|
public static string Prettify_0110(byte[] feature)
|
|
{
|
|
return Prettify_0110(Decode_0110(feature));
|
|
}
|
|
|
|
public static string Prettify_0113(byte[] feature)
|
|
{
|
|
return Prettify_0113(Decode_0113(feature));
|
|
}
|
|
|
|
public static string Prettify_0142(byte[] feature)
|
|
{
|
|
return Prettify_0142(Decode_0142(feature));
|
|
}
|
|
|
|
public struct FeatureDescriptor
|
|
{
|
|
public ushort Code;
|
|
public byte[] Data;
|
|
}
|
|
|
|
public struct SeparatedFeatures
|
|
{
|
|
public uint DataLength;
|
|
public ushort CurrentProfile;
|
|
public FeatureDescriptor[] Descriptors;
|
|
}
|
|
|
|
public static SeparatedFeatures Separate(byte[] response)
|
|
{
|
|
SeparatedFeatures dec = new SeparatedFeatures();
|
|
dec.DataLength = (uint)((response[0] << 24) + (response[1] << 16) + (response[2] << 8) + response[4]);
|
|
dec.CurrentProfile = (ushort)((response[6] << 8) + response[7]);
|
|
uint offset = 8;
|
|
List<FeatureDescriptor> descLst = new List<FeatureDescriptor>();
|
|
|
|
while(offset < response.Length)
|
|
{
|
|
FeatureDescriptor desc = new FeatureDescriptor();
|
|
desc.Code = (ushort)((response[offset + 0] << 8) + response[offset + 1]);
|
|
desc.Data = new byte[response[offset + 3] + 4];
|
|
Array.Copy(response, offset, desc.Data, 0, desc.Data.Length);
|
|
offset += (uint)(desc.Data.Length);
|
|
|
|
descLst.Add(desc);
|
|
}
|
|
|
|
dec.Descriptors = descLst.ToArray();
|
|
|
|
return dec;
|
|
}
|
|
}
|
|
}
|
|
|