|
|
|
/*
|
|
|
|
* vim: set ft=rust:
|
|
|
|
* vim: set ft=reason:
|
|
|
|
*
|
|
|
|
* Copyright (c) 2009 - 2013 Monoidics ltd.
|
|
|
|
* Copyright (c) 2013 - present Facebook, Inc.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* This source code is licensed under the BSD style license found in the
|
|
|
|
* LICENSE file in the root directory of this source tree. An additional grant
|
|
|
|
* of patent rights can be found in the PATENTS file in the same directory.
|
|
|
|
*/
|
|
|
|
open! IStd;
|
|
|
|
|
|
|
|
|
|
|
|
/** Control Flow Graph for Interprocedural Analysis */
|
|
|
|
|
|
|
|
/** A control-flow graph */
|
|
|
|
type cfg;
|
|
|
|
|
|
|
|
|
|
|
|
/** Load a cfg from a file */
|
|
|
|
let load_cfg_from_file: DB.filename => option cfg;
|
|
|
|
|
|
|
|
|
|
|
|
/** Save a cfg into a file, and save a copy of the source files if the boolean is true */
|
|
|
|
let store_cfg_to_file: source_file::SourceFile.t => DB.filename => cfg => unit;
|
|
|
|
|
|
|
|
|
|
|
|
/** {2 Functions for manipulating an interprocedural CFG} */
|
|
|
|
|
|
|
|
/** create a new empty cfg */
|
|
|
|
let create_cfg: unit => cfg;
|
|
|
|
|
|
|
|
|
|
|
|
/** Create a new procdesc */
|
|
|
|
let create_proc_desc: cfg => ProcAttributes.t => Procdesc.t;
|
|
|
|
|
|
|
|
|
|
|
|
/** Iterate over all the procdesc's */
|
|
|
|
let iter_proc_desc: cfg => (Procname.t => Procdesc.t => unit) => unit;
|
|
|
|
|
|
|
|
|
|
|
|
/** Find the procdesc given the proc name. Return None if not found. */
|
|
|
|
let find_proc_desc_from_name: cfg => Procname.t => option Procdesc.t;
|
|
|
|
|
|
|
|
|
|
|
|
/** Get all the procedures (defined and declared) */
|
|
|
|
let get_all_procs: cfg => list Procdesc.t;
|
|
|
|
|
|
|
|
|
|
|
|
/** Get the procedures whose body is defined in this cfg */
|
|
|
|
let get_defined_procs: cfg => list Procdesc.t;
|
|
|
|
|
|
|
|
|
|
|
|
/** Iterate over all the nodes in the cfg */
|
|
|
|
let iter_all_nodes: sorted::bool? => (Procdesc.t => Procdesc.Node.t => unit) => cfg => unit;
|
|
|
|
|
|
|
|
|
|
|
|
/** checks whether a cfg is connected or not */
|
|
|
|
let check_cfg_connectedness: cfg => unit;
|
|
|
|
|
|
|
|
|
|
|
|
/** Remove the procdesc from the control flow graph. */
|
|
|
|
let remove_proc_desc: cfg => Procname.t => unit;
|
|
|
|
|
|
|
|
|
|
|
|
/** Creates a copy of a procedure description and a list of type substitutions of the form
|
|
|
|
(name, typ) where name is a parameter. The resulting procdesc is isomorphic but
|
|
|
|
all the type of the parameters are replaced in the instructions according to the list.
|
|
|
|
The virtual calls are also replaced to match the parameter types */
|
|
|
|
let specialize_types: Procdesc.t => Procname.t => list (Exp.t, Typ.t) => Procdesc.t;
|