DD (Data Description) voor Windows (software)
Informatie (ENG):
dd – convert and copy a file
This version does not actually do any conversion but it allows the flexible copying of data under in a win32 environment. At the moment block devices under Win9x are not supported but that will be added soon.
Usage:
dd [bs=SIZE[SUFFIX]] [count=BLOCKS[SUFFIX]] if=FILE of=FILE [seek=BLOCKS[SUFFIX]] [skip=BLOCKS[SUFFIX]] [--size] [--list] [--progress]
bs is the block size. The block size can be specified in bytes or with one of the following suffix:
Description | Suffix | Size |
---|---|---|
Characters | c | 1 |
Words | w | 2 |
Double Words | d | 4 |
Quad Words | q | 8 |
Kilobytes | k | 1,024 |
Megabytes | M | 1,048,576 |
Gigabytes | G | 1,073,741,824 |
The default block size is 512 which will work for most files and devices but the copy will be a lot faster if you use a larger block size. For example a floppy disk read with bs=1k count=1440 takes almost twice as long than if you use bs=1440k count=1. Don’t make the block size too large because windows will run out of memory. 1M is probably a good size and upper limit. Most CD/DVDs have a 2k sector size and probably will not work with a block size which is not a multiple of that.
skip is the distance to skip over the input file before reading is commenced. It is in blocks so the distance will be skip * blocksize. You can also use a suffix here so skip=1k will skip 1024 blocks. You can remember that skip relates to the input file by thinking of a ‘skipping rope’.
seek is the distance to seek over in the output file before writing is commenced. It is also in blocks do the distance will be seek * blocksize. You can also use a suffix here so seek=1k will seek 1024 blocks. You just have to remember that if skip is for in then seek is for out.
count is the number of blocks to copy. If it is not specified then the dd will continue until the end of the file/device is reached. On many usb devices this is not reliable so you should use –size to guess the size of the device, see below. You can also use a suffix here so count=1k will copy 1024 blocks.
Versie 0.6b ondersteunt nog geen conv=notrunc !!
Using –size
Traditionally when using dd, if you wanted to copy an entire device, you did not specify a block count and dd would read until it reached the end of the device. If you tried to read past the end of the device, the data up to the end of the device would be returned and if you kept reading you would get an error message. Windows however does not always do this so –size will tell dd to figure out the size of the device and make sure it does not read past that point. This is important for USB sticks which stop working if you read past the end of them. This is not on by default because getting the correct size of the device is not always possible. Some devices also keep returning bogus data past the end of the device without returning a suitable error code
Using –list
Windows provides a number of ways to name a device. The –list will output the preferred names. Under NT4, only the \\?\Device\Harddisk<n>\Partition<n> method is available. Partition0 is the entire disk. Under Windows XP, some partitions may not have a Volume device. In this case you can still use the Harddisk<n>\Partition<n> name.
Windows 2000 and later have Volume devices which are unique GUIDs which identify a disk or partition (what MS call a Volume). These are listed along with any mount point that they may be mounted on. Most of the time this is a drive letter but it may be a path on another filesystem. If you want to read the underlying device, do not include the trailing \ character. If the volume is not mounted there is no easy way to identify it so be careful. Under XP SP2, many partitions can not be read directly, even if they are not in use. There is a work around which I call reading partitions via the back door.
Using –progress
–progress is an non-standard enhancement to dd which will show you progress as each block is copied.
Virtual devices
Virtual devices are a new feature in version 0.4beta1.
Because windows does not have devices like the unix /dev/zero or /dev/random these have been implemented inside dd. You can use these as input files to supply an infinite amount of zeros or pseudo random data.
Standard I/O
Standard Input (stdin) is now the default input file if you do not specify a value for if. You can also explictly use stdin with if=-. Standard Out (stdout) is now the default output file if you do not specify a value for of. You can also explictly use stdout with of=-. Progress and error messages are written to Standard Error (stderr). This allows the use of dd with pipe commands.
Safety with –filter=
To prevent accidental overwriting of the wrong disk, a safety filter can be enforced
You can enforce a filter by renaming dd.exe to dd-<filter>.exe. For example, dd-removable.exe can only write to removable disks like USB and CF, making sure that you don’t accidently write to a fixed hard disk.
Examples
Make an image of a floppy disk:
dd if=\\.\a: of=c:\temp\disk1.img bs=1440k
Write the image back to a floppy disk:
dd if=c:\temp\disk1.img of=\\.\a: bs=1440k
Rip an .iso from a CD
dd if=\\?\Device\CdRom0 of=c:\temp\disc1.iso bs=1M
Read a partition from a USB memory device
dd if=\\.\Volume{c18588c0-02e9-11d8-853f-00902758442b} of=c:\temp\usb1.img bs=1M
Read the entire USB memory device
dd if=\\?\Device\Harddisk1\Partition0 of=c:\temp\usb2.img bs=1M --size --progress
You can write to any file or block device which windows will allow you to write to. You can use the standard \\.\
notation for win32 exported devices or the dd specific \\?\
notation to access windows native devices.
Note: You can not write to a CD with this program. Get microsoft cdburn from the windows XP resource kit.
Note: Floppy disks are extremely unreliable. If you get errors, please try another floppy disk or reformatting the disk.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 |
Changes in version 0.6beta3 add errorlevel exit code progress is written to stderr Changes in version 0.6beta2 Implemented of=/dev/null which will just throw away the data skip on stdin now works fix checking size of floppy disks Changes in version 0.6beta1 --progress output is in the same unit as bs is specified with new filter type 'file' which will Only write to a fileystem file new feature id=<drive>/od=<drive> for input disk and output disk. if <drive> is the only partition on a disk, then the entire disk is selected. Eg: if you insert a USB disk and it is mounted as f: then 'id=f:' will select the USB disk (not just the partition like if=\\.\f: would do) Changes in version 0.5 count, seek and skip can now use a multiplicative suffix like bs stdin and stdout are now the defaults Changes in version 0.4beta6 Implemented of=- for stdout Renamed if=- for stdin Messages are now printed to stderr Changes in version 0.4beta5 If a partial block write fails, the buffer is padded to the end of the block and the write is attempted again This allows disk images which are not an exact multiple of the block size to be written to disk Changes in version 0.4beta4 Implemented if=stdin --filter= added Changes in version 0.4beta2 --list shows disk and partition sizes --size added Changes in version 0.4beta1 --list shows correct syntax for drive letters virtual devices added Changes in version 0.3 Modified native device scan to find noncontiguously numbered devices Show symlink destinations in device scan Open source file with FILE_SHARE_READ Stupid bug opening native output devices (assigned handle to input instead of output) Stupid bug where native devices were always read only added progress indicator |
Download @ www.chrysocome.net
[#/software/dd_windows” ]