open Preamble open Extra_bool open Coqlib open Values open FrontEndVal open GenMem open FrontEndMem open Globalenvs open String open Sets open Listb open LabelledObjects open BitVectorTrie open Graphs open I8051 open Order open Registers open CostLabel open Hide open Proper open PositiveMap open Deqsets open ErrorMessages open PreIdentifiers open Errors open Extralib open Lists open Identifiers open Integers open AST open Division open Exp open Arithmetic open Setoids open Monad open Option open Extranat open Vector open Div_and_mod open Jmeq open Russell open List open Util open FoldStuff open BitVector open Types open Bool open Relations open Nat open Hints_declaration open Core_notation open Pts open Logic open Positive open Z open BitVectorZ open Pointers open ByteValues open BackEndOps open Joint open Joint_LTL_LIN (** val lIN : Joint.lin_params **) let lIN = Joint_LTL_LIN.lTL_LIN type lin_program = Joint.joint_program (** val lIN_premain : lin_program -> Joint.joint_closed_internal_function **) let lIN_premain p = let l3 = Positive.P1 Positive.One in let code = List.Cons ({ Types.fst = Types.None; Types.snd = (Joint.Sequential ((Joint.COST_LABEL p.Joint.init_cost_label), (Obj.magic Types.It))) }, (List.Cons ({ Types.fst = Types.None; Types.snd = (Joint.Sequential ((Joint.CALL ((Types.Inl p.Joint.joint_prog.AST.prog_main), (Obj.magic Nat.O), (Obj.magic Types.It))), (Obj.magic Types.It))) }, (List.Cons ({ Types.fst = (Types.Some l3); Types.snd = (Joint.Final (Joint.GOTO l3)) }, List.Nil))))) in { Joint.joint_if_luniverse = (Positive.P0 (Positive.P0 Positive.One)); Joint.joint_if_runiverse = Positive.One; Joint.joint_if_result = (Obj.magic Types.It); Joint.joint_if_params = (Obj.magic Types.It); Joint.joint_if_stacksize = Nat.O; Joint.joint_if_local_stacksize = Nat.O; Joint.joint_if_code = (Obj.magic code); Joint.joint_if_entry = (Obj.magic Nat.O) }