Skip to content

Commit

Permalink
replace --aarch64-dir with --export-aarch64
Browse files Browse the repository at this point in the history
this is more useful once the MRA files are bundled.

* update coverage run.sh to remove --aarch64-dir usage

* update coverage run.sh to substitute away embedded file paths
  • Loading branch information
katrinafyi committed Jun 24, 2024
1 parent 60a162e commit 0b20c65
Show file tree
Hide file tree
Showing 6 changed files with 28 additions and 10 deletions.
14 changes: 7 additions & 7 deletions bin/asli.ml
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ let opt_prelude : string ref = ref "prelude.asl"
let opt_filenames : string list ref = ref []
let opt_print_version = ref false
let opt_no_default_aarch64 = ref false
let opt_print_aarch64_dir = ref false
let opt_export_aarch64_dir = ref ""
let opt_verbose = ref false


Expand Down Expand Up @@ -309,8 +309,8 @@ let rec repl (tcenv: TC.Env.t) (cpu: Cpu.cpu): unit =
let options = Arg.align ([
( "-x", Arg.Set_int Dis.debug_level, " Partial evaluation debugging (requires debug level argument >= 0)");
( "-v", Arg.Set opt_verbose, " Verbose output");
( "--no-aarch64", Arg.Set opt_no_default_aarch64 , " Disable bundled AArch64 semantics");
( "--aarch64-dir", Arg.Set opt_print_aarch64_dir, " Print directory of bundled AArch64 semantics");
( "--no-aarch64", Arg.Set opt_no_default_aarch64 , " Disable bundled AArch64 semantics");
( "--export-aarch64", Arg.Set_string opt_export_aarch64_dir, " Export bundled AArch64 MRA to the given directory");
( "--version", Arg.Set opt_print_version, " Print version");
( "--prelude", Arg.Set_string opt_prelude," ASL prelude file (default: ./prelude.asl)");
] )
Expand Down Expand Up @@ -338,10 +338,10 @@ let _ =

let main () =
if !opt_print_version then Printf.printf "%s\n" version
else if !opt_print_aarch64_dir then
match Arm_env.aarch64_asl_dir with
| Some d -> Printf.printf "%s\n" d
| None -> (Printf.eprintf "Unable to retrieve installed asl directory\n"; exit 1)
else if "" <> !opt_export_aarch64_dir then
let dir = !opt_export_aarch64_dir in
ignore @@ Sys.readdir dir;
List.iter LoadASL.(write_source dir) Arm_env.(prelude_blob :: asl_blobs);
else begin
if !opt_verbose then List.iter print_endline banner;
if !opt_verbose then print_endline "\nType :? for help";
Expand Down
1 change: 0 additions & 1 deletion libASL/arm_env.ml
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,6 @@ let asl_blobs : LoadASL.source list = [
let aarch64_asl_files: (LoadASL.source * LoadASL.source list) option =
Some (prelude_blob, asl_blobs)


let aarch64_evaluation_environment ?(verbose = false) (): Eval.Env.t option =
Option.bind aarch64_asl_files
(fun (prelude, filenames) -> Eval.evaluation_environment prelude filenames verbose)
Expand Down
9 changes: 9 additions & 0 deletions libASL/loadASL.ml
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,15 @@ let read_source = function
x
| DataSource (_, data) -> data

let write_source prefix = function
| FileSource _ -> failwith "write_source for FileSource is unsupported"
| DataSource (name, data) ->
let name = Filename.concat prefix name in
Utils.mkdir_p (Filename.dirname name);
let chan = open_out_bin name in
output_string chan data;
close_out chan

let report_parse_error (on_error: unit -> 'a) (f: unit -> 'a): 'a =
(try
f ()
Expand Down
1 change: 1 addition & 0 deletions libASL/loadASL.mli
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ type source = FileSource of string | DataSource of string * string
val pp_source : source -> string
val name_of_source : source -> string
val read_source : source -> string
val write_source : string -> source -> unit

val mkLoc : string -> string -> AST.l

Expand Down
9 changes: 9 additions & 0 deletions libASL/utils.ml
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,15 @@

(** Generic utility functions *)

let rec mkdir_p p =
let open Filename in
if Sys.file_exists p then
()
else
(* make parents, then make final directory. *)
(mkdir_p (dirname p); Sys.mkdir p 0o755)


(****************************************************************
* Pretty-printer related
****************************************************************)
Expand Down
4 changes: 2 additions & 2 deletions tests/coverage/run.sh
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

pattern="${1:?requires regex pattern as first argument}"

asl_dir="$(asli --aarch64-dir)"
output="$(echo ":coverage A64 $pattern" | asli)"

echo "$output" | sed "s#$asl_dir#.#g"
# substitute paths of the form <data:[...]> with ./[...]
echo "$output" | sed 's#<data:\([^>]*\)>#./\1#g'

0 comments on commit 0b20c65

Please sign in to comment.