web-dev-qa-db-fra.com

Comment compiler un fichier avec "FF" en utilisant dd?

Comment compléter un fichier avec 0xFF en utilisant dd?

Cette commande remplit le fichier de sortie avec des zéros jusqu'à ce que la taille du fichier atteigne 100 Ko:

dd if=inputFile.bin ibs=1k count=100 of=paddedFile.bin conv=sync

Cependant, je souhaite compléter un fichier avec 0xFFs au lieu de 0x00s.

20
XP1

Autant que je sache, il n’ya aucun moyen de dire à dd d’appuyer avec 0xFF. Mais il existe une solution de contournement.

Commencez par créer un fichier avec la longueur requise renseignée avec 0xFF:

$ dd if=/dev/zero ibs=1k count=100 | tr "\000" "\377" >paddedFile.bin
100+0 records in
200+0 records out
102400 bytes (102 kB) copied, 0,0114595 s, 8,9 MB/s

tr est utilisé pour remplacer les zéros par 0xFF. tr attend les arguments en octal. 0xFF en octal est \377.

Résultat:

$ hexdump -C paddedFile.bin 
00000000  ff ff ff ff ff ff ff ff  ff ff ff ff ff ff ff ff  |................|
*
00019000

Ensuite, insérez le fichier d'entrée au début du fichier "padded":

$ dd if=inputFile.bin of=paddedFile.bin conv=notrunc
0+1 records in
0+1 records out
8 bytes (8 B) copied, 7,4311e-05 s, 108 kB/s

Notez le conv=notrunc qui indique à dd de ne pas tronquer le fichier de sortie.

Exemple de fichier d'entrée:

$ hexdump -C inputFile.bin 
00000000  66 6f 6f 0a 62 61 72 0a                           |foo.bar.|
00000008

Résultat:

$ hexdump -C paddedFile.bin 
00000000  66 6f 6f 0a 62 61 72 0a  ff ff ff ff ff ff ff ff  |foo.bar.........|
00000010  ff ff ff ff ff ff ff ff  ff ff ff ff ff ff ff ff  |................|
*
00019000
27
lesmana

Une amélioration possible de la réponse de lesmana consiste à opérer le fichier en place. Cela pourrait être beaucoup plus rapide pour les fichiers d'entrée volumineux et conserverait également les fichiers clairsemés. Cependant, dans de nombreuses situations, vous ne souhaitez pas modifier votre fichier d'entrée et cette méthode sera donc inappropriée.

L'exemple suivant commence par un fichier d'entrée volumineux et fragmenté et le remplit jusqu'à une taille de 1 Go avec des caractères FF. Il suffit de changer newsize à la valeur souhaitée. Comme vous pouvez le constater, la portion dd ne prend qu’une fraction de seconde bien que ce fichier soit très volumineux.

$ ls -ld inputFile.bin
-rw-rw-r-- 1   …   1073741700   …   inputFile.bin
$ hexdump inputFile.bin
0000000 0000 0000 0000 0000 0000 0000 0000 0000
*
3fffff80 0000 0000
3fffff84

$ newsize=$((1024 * 1024 * 1024))
$ filesize=$(stat -c "%s" inputFile.bin)
$ padcount=$((newsize - filesize))
$ dd if=/dev/zero ibs=1 count="$padcount" | tr "\000" "\377" >> inputFile.bin
124+0 records in
0+1 records out
124 bytes (124 B) copied, 0.000162309 s, 764 kB/s

$ ls -ld inputFile.bin
-rw-rw-r-- 1   …   1073741824   …   inputFile.bin
$ hexdump inputFile.bin
0000000 0000 0000 0000 0000 0000 0000 0000 0000
*
3fffff80 0000 0000 ffff ffff ffff ffff ffff ffff
3fffff90 ffff ffff ffff ffff ffff ffff ffff ffff
*
40000000
1
asdf