-
Notifications
You must be signed in to change notification settings - Fork 274
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
implements AVR ABI and refines AVR targets
- Loading branch information
Showing
4 changed files
with
111 additions
and
15 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,5 +1,21 @@ | ||
open Bap_core_theory | ||
|
||
val parent : Theory.target | ||
|
||
val load : unit -> unit | ||
|
||
type r8 | ||
type reg = r8 Theory.Bitv.t Theory.var | ||
|
||
val parent : Theory.target | ||
|
||
val tiny : Theory.target | ||
val mega : Theory.target | ||
val xmega : Theory.target | ||
|
||
module Gcc : sig | ||
val args : reg list | ||
val rets : reg list | ||
val tiny : Theory.target | ||
val mega : Theory.target | ||
val xmega : Theory.target | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,12 +1,47 @@ | ||
open Bap_main | ||
open Bap_core_theory | ||
|
||
module AT = Bap_avr_target | ||
|
||
module Abi = struct | ||
open Bap_c.Std | ||
|
||
module Arg = C.Abi.Arg | ||
open Arg.Let | ||
open Arg.Syntax | ||
|
||
let model = new C.Size.base `LP32 | ||
|
||
let define t = | ||
C.Abi.define t model @@ fun _ {C.Type.Proto.return=r; args} -> | ||
let* iregs = Arg.Arena.create AT.Gcc.args in | ||
let* irets = Arg.Arena.create AT.Gcc.rets in | ||
let pass_via regs (_,t) = | ||
let open Arg in | ||
choice [ | ||
sequence [ | ||
align_even regs; | ||
registers regs t; | ||
]; | ||
sequence [ | ||
deplet regs; | ||
memory t; | ||
] | ||
] in | ||
let args = Arg.List.iter args ~f:(pass_via iregs) in | ||
let return = match r with | ||
| `Void -> None | ||
| r -> Some (pass_via irets ("",r)) in | ||
Arg.define ?return args | ||
|
||
let setup () = | ||
List.iter define AT.Gcc.[tiny; mega; xmega] | ||
end | ||
|
||
let main _ctxt = | ||
Bap_avr_target.load (); | ||
AT.load (); | ||
Abi.setup (); | ||
Ok () | ||
|
||
|
||
let () = Bap_main.Extension.declare main | ||
~provides:[ | ||
"avr"; | ||
"lifter"; | ||
] | ||
~provides:["avr"; "lifter"; "disassembler"] |