Files
Aaru/DiscImageChef.Decoders/SCSI/MMC/Features.cs
Natalia Portillo b2ab03407f * LICENSE.MIT:
* 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.
2016-07-28 18:13:49 +01:00

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