Radare2 Reference Card

    Those are the basic commands you will want to know and use for moving around a binary and getting information about it.

    Flags

    Flags are like bookmarks, but they carry some extra information like size, tags or associated flagspace. Use the command to list, set, get them.

    CommandDescription
    fList flags
    fd $$Describe an offset
    fjDisplay flags in JSON
    flShow flag length
    fx [flagname]Show hexdump of flag
    fC [name] [comment]Set flag comment

    Flagspaces

    Flags are created into a flagspace, by default none is selected, and listing flags will list them all. To display a subset of flags you can use the fs command to restrict it.

    CommandDescription
    iiInformation on imports
    iIInfo on binary
    ieDisplay entrypoint
    iSDisplay sections
    irDisplay relocations
    izList strings (izz, izzz)

    Print string

    There are different ways to represent a string in memory. The ps command allows us to print it in utf-16, pascal, zero terminated, .. formats.

    Visual mode

    The visual mode is the standard interactive interface of radare2.

    To enter in visual mode use the v or V command, and then you’ll only have to press keys to get the actions happen instead of commands.

    CommandDescription
    VEnter visual mode
    p/PRotate modes (hex, disasm, debug, words, buf)
    cToggle (c)ursor
    qBack to Radare shell
    hjklMove around (or HJKL) (left-down-up-right)
    EnterFollow address of jump/call
    sSStep/step over
    oToggle asm.pseudo and asm.esil
    .Seek to program counter
    /In cursor mode, search in current block
    :cmdRun radare command
    ;[-]cmtAdd/remove comment
    /*+-[]Change block size, [] = resize hex.cols
    <,>Seek aligned to block size
    i/a/A(i)nsert hex, (a)ssemble code, visual (A)ssembler
    bToggle breakpoint
    BBrowse evals, symbols, flags, classes, …
    d[f?]Define function, data, code, ..
    DEnter visual diff mode (set diff.from/to)
    eEdit eval configuration variables
    f/FSet/unset flag
    gGGo seek to begin and end of file (0-$s)
    mK/’KMark/go to Key (any key)
    MWalk the mounted filesystems
    n/NSeek next/prev function/flag/hit (scr.nkey)
    CToggle (C)olors
    RRandomize color palette (ecr)
    tTTab related. see also
    vVisual code analysis menu
    V(V)iew graph (agv?)
    wWSeek cursor to next/prev word
    uUUndo/redo seek
    xShow xrefs of current func from/to data/code
    yYCopy and paste selection
    zfold/unfold comments in diassembly

    This feature has broken and not been resolved at the time of writing these words (Nov.16th 2020). check #Issue 6945: META - Project files and for more details.

    To save your analysis for now, write your own script which records the function name, variable name, etc. for example:

    1. vim sample_A.r2
    2. s 0x000403ce0
    3. s fcn.00403130
    4. afn return_delta_to_heapaddr
    5. afvn iter var_04h

    The ?$? command will display the variables that can be used in any math operation inside the r2 shell. For example, using the command to evaluate a number or ?v to just the value in one format.

    CommandDescription
    $$here (current virtual seek)
    $$$current non-temporary virtual seek
    $?last comparison value
    $alias=valuealias commands (simple macros)
    $bblock size
    $Bbase address (aligned lowest map address)
    $fjump fail address (e.g. jz 0x10 => next instruction)
    $flflag length (size) at current address (fla; pD $l @ entry0)
    $Fcurrent function size
    $FBbegin of function
    $Fbaddress of the current basic block
    $Fssize of the current basic block
    $FEend of function
    $FSfunction size
    $Fjfunction jump destination
    $Fffunction false destination
    $FIfunction instructions
    $c,$rget width and height of terminal
    $Cnget nth call of function
    $Dnget nth data reference in function
    $Dcurrent debug map base address ?v $D @ rsp
    $DDcurrent debug map size
    $e1 if end of block, else 0
    $jjump address (e.g. jmp 0x10, jz 0x10 => 0x10)
    $Jaget nth jump of function
    $Xnget nth xref of function
    $lopcode length
    $mopcode memory reference (e.g. mov eax,[0x10] => 0x10)
    $Mmap address (lowest map address)
    $ohere (current disk io offset)
    $pgetpid()
    $Ppid of children (only in debug)
    $sfile size
    $Ssection offset
    $SSsection size
    $vopcode immediate value (e.g. lui a0,0x8010 => 0x8010)
    $wget word size, 4 if asm.bits=32, 8 if 64, …
    ${ev}get value of eval config variable
    $r{reg}get value of named register
    $k{kv}get value of an sdb query value
    $s{flag}get size of flag
    RNum$variables usable in math expressions