Writing Data

Radare can manipulate a loaded binary file in many ways. You can resize the file, move and copy/paste bytes, insert new bytes (shifting data to the end of the block or file), or simply overwrite bytes. New data may be given as a wide-string, assembler instructions, or the data may be read in from another file.

Resize the file using the r command. It accepts a numeric argument. A positive value sets a new size for the file. A negative one will truncate the file to the current seek position minus N bytes.

  1. r 1024 ; resize the file to 1024 bytes
  2. r -10 @ 33 ; strip 10 bytes at offset 33

Write bytes using the w command. It accepts multiple input formats like inline assembly, endian-friendly dwords, files, hexpair files, wide strings:

  1. [0x00404888]> w?
  2. Usage: w[x] [str] [<file] [<<EOF] [@addr]
  3. | w[1248][+-][n] increment/decrement byte,word..
  4. | w foobar write string 'foobar'
  5. | w0 [len] write 'len' bytes with value 0x00
  6. | w6[de] base64/hex write base64 [d]ecoded or [e]ncoded string
  7. | wa[?] push ebp write opcode, separated by ';' (use '"' around the command)
  8. | waf f.asm assemble file and write bytes
  9. | waF f.asm assemble file and write bytes and show 'wx' op with hexpair bytes of assembled code
  10. | wao[?] op modify opcode (change conditional of jump. nop, etc)
  11. | wA[?] r 0 alter/modify opcode at current seek (see wA?)
  12. | wb 010203 fill current block with cyclic hexpairs
  13. | wB[-]0xVALUE set or unset bits with given value
  14. | wc list all write changes
  15. | wc[?][jir+-*?] write cache undo/commit/reset/list (io.cache)
  16. | wd [off] [n] duplicate N bytes from offset at current seek (memcpy) (see y?)
  17. | we[?] [nNsxX] [arg] extend write operations (insert instead of replace)
  18. | wf[fs] -|file write contents of file at current offset
  19. | wh r2 whereis/which shell command
  20. | wm f0ff set binary mask hexpair to be used as cyclic write mask
  21. | wo[?] hex write in block with operation. 'wo?' fmi
  22. | wp[?] -|file apply radare patch file. See wp? fmi
  23. | wr 10 write 10 random bytes
  24. | ws pstring write 1 byte for length and then the string
  25. | wt[f][?] file [sz] write to file (from current seek, blocksize or sz bytes)
  26. | wts host:port [sz] send data to remote host:port via tcp://
  27. | ww foobar write wide string 'f\x00o\x00o\x00b\x00a\x00r\x00'
  28. | wx[?][fs] 9090 write two intel nops (from wxfile or wxseek)
  29. | wv[?] eip+34 write 32-64 bit value honoring cfg.bigendian
  30. | wz string write zero terminated string (like w + \x00)

Some examples:

  1. [0x00000000]> wx 123456 @ 0x8048300
  2. [0x00000000]> wv 0x8048123 @ 0x8049100
  3. [0x00000000]> wa jmp 0x8048320

Write Over

The wo command (write over) has many subcommands, each combines the existing data with the new data using an operator. The command is applied to the current block. Supported operators include XOR, ADD, SUB…

  1. [0x4A13B8C0]> wo?
  2. |Usage: wo[asmdxoArl24] [hexpairs] @ addr[:bsize]
  3. |Example:
  4. | wox 0x90 ; xor cur block with 0x90
  5. | wox 90 ; xor cur block with 0x90
  6. | wox 0x0203 ; xor cur block with 0203
  7. | woa 02 03 ; add [0203][0203][...] to curblk
  8. | woe 02 03 ; create sequence from 2 to 255 with step 3
  9. |Supported operations:
  10. | wow == write looped value (alias for 'wb')
  11. | woa += addition
  12. | wos -= substraction
  13. | wom *= multiply
  14. | wod /= divide
  15. | wox ^= xor
  16. | woo |= or
  17. | woA &= and
  18. | woR random bytes (alias for 'wr $b'
  19. | wor >>= shift right
  20. | wol <<= shift left
  21. | wo2 2= 2 byte endian swap
  22. | wo4 4= 4 byte endian swap

It is possible to implement cipher-algorithms using radare core primitives and wo. A sample session performing xor(90) + add(01, 02):

  1. [0x7fcd6a891630]> px
  2. - offset - 0 1 2 3 4 5 6 7 8 9 A B C D E F
  3. 0x7fcd6a891630 4889 e7e8 6839 0000 4989 c48b 05ef 1622
  4. 0x7fcd6a891640 005a 488d 24c4 29c2 5248 89d6 4989 e548
  5. 0x7fcd6a891650 83e4 f048 8b3d 061a 2200 498d 4cd5 1049
  6. 0x7fcd6a891660 8d55 0831 ede8 06e2 0000 488d 15cf e600
  7. [0x7fcd6a891630]> wox 90
  8. [0x7fcd6a891630]> px
  9. - offset - 0 1 2 3 4 5 6 7 8 9 A B C D E F
  10. 0x7fcd6a891630 d819 7778 d919 541b 90ca d81d c2d8 1946
  11. 0x7fcd6a891640 1374 60d8 b290 d91d 1dc5 98a1 9090 d81d
  12. 0x7fcd6a891650 90dc 197c 9f8f 1490 d81d 95d9 9f8f 1490
  13. 0x7fcd6a891660 13d7 9491 9f8f 1490 13ff 9491 9f8f 1490
  14. [0x7fcd6a891630]> woa 01 02
  15. [0x7fcd6a891630]> px
  16. - offset - 0 1 2 3 4 5 6 7 8 9 A B C D E F
  17. 0x7fcd6a891630 d91b 787a 91cc d91f 1476 61da 1ec7 99a3
  18. 0x7fcd6a891640 91de 1a7e d91f 96db 14d9 9593 1401 9593
  19. 0x7fcd6a891650 c4da 1a6d e89a d959 9192 9159 1cb1 d959
  20. 0x7fcd6a891660 9192 79cb 81da 1652 81da 1456 a252 7c77