summaryrefslogtreecommitdiff
path: root/checklink/PPC_utils.ml
blob: d027649e3a3c387fc9af9437dfae4d0114c93d67 (plain)
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
open ELF_types
open ELF_utils
open Library
open PPC_parsers
open PPC_types

let code_at_vaddr (e: elf) (vaddr: int32) (nb_instr: int): ecode option =
  match section_at_vaddr e vaddr with
  | None -> None
  | Some(sndx) ->
      let code_bs =
        bitstring_at_vaddr e sndx vaddr (32 * nb_instr) in
      Some (parse_code_as_list code_bs)

let code_of_sym_ndx (e: elf) (ndx: int): ecode option =
  let sym = e.e_symtab.(ndx) in
  match sym.st_type with
  | STT_FUNC ->
      let sym_vaddr = sym.st_value in
      let sym_size = Safe.(of_int32 sym.st_size * 8) in
      let sym_sndx = sym.st_shndx in
      let code_bs =
        bitstring_at_vaddr e sym_sndx sym_vaddr sym_size in
      Some (parse_code_as_list code_bs)
  | _ -> None

let code_of_sym_name (e: elf) (name: string): ecode option =
  match ndx_of_sym_name e name with
  | Some ndx -> code_of_sym_ndx e ndx
  | None     -> None