------------------------------------------------------------------------------ ------------------------------------------------------------------------------ -- This source file was automatically generated by Platypus -- see http://dossen.univ-brest.fr/apl -- -- Any modification of this file will be lost. -- Please see the "platypus" directory instead : it contains the Cheddar's -- model and its meta-model. ------------------------------------------------------------------------------ ------------------------------------------------------------------------------ -- Cheddar is a free real time scheduling tool. -- This program provides services to automatically check temporal constraints -- of real time tasks. -- -- Copyright (C) 2002-2014 Frank Singhoff -- Cheddar is developed by the LAB-STICC Team, University of Brest -- -- This program is free software; you can redistribute it and/or modify -- it under the terms of the GNU General Public License as published by -- the Free Software Foundation; either version 2 of the License, or -- (at your option) any later version. -- -- This program is distributed in the hope that it will be useful, -- but WITHOUT ANY WARRANTY; without even the implied warranty of -- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -- GNU General Public License for more details. -- -- You should have received a copy of the GNU General Public License -- along with this program; if not, write to the Free Software -- Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA -- -- -- Contact : cheddar@listes.univ-brest.fr -- To post to this mailing list, you must be subscribed -- (see http//beru.univ-brest.fr/~singhoff/cheddar for details) -- ------------------------------------------------------------------------------ ------------------------------------------------------------------------------ with Text_io; use Text_io; with unbounded_strings; use unbounded_strings; with primitive_xml_strings; use primitive_xml_strings; Package Body Memories is function XML_String(obj : in Memory_Type) return Unbounded_String is begin return to_unbounded_string(Memory_Type'image (obj) ); end XML_String; function XML_Ref_String (obj : in Memory_Type) return Unbounded_String is begin raise xml_ref_string_error; return to_unbounded_string(""); end XML_Ref_String; -- --------= Generic_Memory =-------- procedure Initialize(obj : in out Generic_Memory) is begin initialize(Named_Object(obj)); obj.size := 0; obj.access_latency := 0; obj.memory_category := Generic_Memory_Type; obj.object_type := Memory_Object_Type; end Initialize; function Copy ( obj : in Generic_Memory ) return Generic_Memory_Ptr is New_Generic_Memory : Generic_Memory_Ptr; begin New_Generic_Memory := new Generic_Memory'(obj); return (New_Generic_Memory); end Copy; function Copy ( obj : in Generic_Memory_Ptr ) return Generic_Memory_Ptr is begin return copy(obj.all); end Copy; procedure Put(obj : in Generic_Memory) is begin put(Named_Object(obj)); put("size: "); standards_io.natural_io.put(obj.size); put ( "; " ); put("access_latency: "); standards_io.natural_io.put(obj.access_latency); put ( "; " ); put("memory_category: "); put(obj.memory_category); put ( "; " ); end Put; procedure Put(obj : in Generic_Memory_Ptr) is begin Put(Obj.All); end Put; procedure Put_Name ( obj : in Generic_Memory_Ptr) is begin Put ( To_String ( Obj.Name ) ); end Put_Name; function Get_Name (obj : in Generic_Memory) return Unbounded_String is begin return obj.name; end Get_Name; function Get_Name (obj : in Generic_Memory_ptr) return Unbounded_String is begin return obj.name; end Get_Name; function type_of ( obj : in Generic_Memory ) return unbounded_string_list is list : unbounded_string_list; s : unbounded_string_ptr; begin Initialize(list); s := new unbounded_string; s.all := to_unbounded_string("OBJECTS.GENERIC_OBJECT"); Add (list, s); s := new unbounded_string; s.all := to_unbounded_string("OBJECTS.NAMED_OBJECT"); Add (list, s); s := new unbounded_string; s.all := to_unbounded_string("MEMORIES.GENERIC_MEMORY"); Add (list, s); return list; end type_of; function type_of ( obj : in Generic_Memory_Ptr ) return unbounded_string_list is begin return type_of(obj.all); end type_of; procedure Build_Attributes_XML_String(obj : in Generic_Memory; result : in out Unbounded_String) is begin Build_Attributes_XML_String(Named_Object(obj), result); if (XML_String(obj.size) /= Empty_String) then result := result & to_unbounded_string("") & XML_String(obj.size) & to_unbounded_string(""); end if; if (XML_String(obj.access_latency) /= Empty_String) then result := result & to_unbounded_string("") & XML_String(obj.access_latency) & to_unbounded_string(""); end if; if (XML_String(obj.memory_category) /= Empty_String) then result := result & to_unbounded_string("") & XML_String(obj.memory_category) & to_unbounded_string(""); end if; end Build_Attributes_XML_String; function XML_String(obj : in Generic_Memory) return Unbounded_String is result : Unbounded_String; begin result := to_unbounded_string(""); Build_Attributes_XML_String(obj, result); result := result & to_unbounded_string(""); return (result); end XML_String; function XML_String(obj : in Generic_Memory_Ptr) return Unbounded_String is begin if obj /= null then return XML_String(obj.all); else return Empty_String; end if; end XML_String; function XML_Ref_String(obj : in Generic_Memory) return Unbounded_String is result : Unbounded_String; begin result := to_unbounded_string(""); return (result); end XML_Ref_String; function XML_Ref_String(obj : in Generic_Memory_Ptr) return Unbounded_String is begin return XML_Ref_String(obj.all); end XML_Ref_String; -- --------= DRAM_Memory =-------- procedure Initialize(obj : in out DRAM_Memory) is begin initialize(Generic_Memory(obj)); obj.shared_access_latency := 0; obj.private_access_latency := 0; obj.l_rw_inter := 0; obj.l_act_inter := 0; obj.l_pre_inter := 0; obj.n_reorder := 0; obj.l_conhit := 0; obj.l_conf := 0; obj.memory_category := DRAM_Type; end Initialize; function Copy ( obj : in DRAM_Memory ) return Generic_Memory_Ptr is New_DRAM_Memory : DRAM_Memory_Ptr; begin New_DRAM_Memory := new DRAM_Memory'(obj); return Generic_Memory_Ptr(New_DRAM_Memory); end Copy; function Copy ( obj : in DRAM_Memory_Ptr ) return Generic_Memory_Ptr is begin return copy(obj.all); end Copy; procedure Put(obj : in DRAM_Memory) is begin put(Generic_Memory(obj)); put("shared_access_latency: "); standards_io.natural_io.put(obj.shared_access_latency); put ( "; " ); put("private_access_latency: "); standards_io.natural_io.put(obj.private_access_latency); put ( "; " ); put("l_rw_inter: "); standards_io.natural_io.put(obj.l_rw_inter); put ( "; " ); put("l_act_inter: "); standards_io.natural_io.put(obj.l_act_inter); put ( "; " ); put("l_pre_inter: "); standards_io.natural_io.put(obj.l_pre_inter); put ( "; " ); put("n_reorder: "); standards_io.natural_io.put(obj.n_reorder); put ( "; " ); put("l_conhit: "); standards_io.natural_io.put(obj.l_conhit); put ( "; " ); put("l_conf: "); standards_io.natural_io.put(obj.l_conf); put ( "; " ); end Put; procedure Put(obj : in DRAM_Memory_Ptr) is begin Put(Obj.All); end Put; procedure Put_Name ( obj : in DRAM_Memory_Ptr) is begin Put ( To_String ( Obj.Name ) ); end Put_Name; function Get_Name (obj : in DRAM_Memory) return Unbounded_String is begin return obj.name; end Get_Name; function Get_Name (obj : in DRAM_Memory_ptr) return Unbounded_String is begin return obj.name; end Get_Name; function type_of ( obj : in DRAM_Memory ) return unbounded_string_list is list : unbounded_string_list; s : unbounded_string_ptr; begin Initialize(list); s := new unbounded_string; s.all := to_unbounded_string("OBJECTS.GENERIC_OBJECT"); Add (list, s); s := new unbounded_string; s.all := to_unbounded_string("OBJECTS.NAMED_OBJECT"); Add (list, s); s := new unbounded_string; s.all := to_unbounded_string("MEMORIES.GENERIC_MEMORY"); Add (list, s); s := new unbounded_string; s.all := to_unbounded_string("MEMORIES.DRAM_MEMORY"); Add (list, s); return list; end type_of; function type_of ( obj : in DRAM_Memory_Ptr ) return unbounded_string_list is begin return type_of(obj.all); end type_of; procedure Build_Attributes_XML_String(obj : in DRAM_Memory; result : in out Unbounded_String) is begin Build_Attributes_XML_String(Generic_Memory(obj), result); if (XML_String(obj.shared_access_latency) /= Empty_String) then result := result & to_unbounded_string("") & XML_String(obj.shared_access_latency) & to_unbounded_string(""); end if; if (XML_String(obj.private_access_latency) /= Empty_String) then result := result & to_unbounded_string("") & XML_String(obj.private_access_latency) & to_unbounded_string(""); end if; if (XML_String(obj.l_rw_inter) /= Empty_String) then result := result & to_unbounded_string("") & XML_String(obj.l_rw_inter) & to_unbounded_string(""); end if; if (XML_String(obj.l_act_inter) /= Empty_String) then result := result & to_unbounded_string("") & XML_String(obj.l_act_inter) & to_unbounded_string(""); end if; if (XML_String(obj.l_pre_inter) /= Empty_String) then result := result & to_unbounded_string("") & XML_String(obj.l_pre_inter) & to_unbounded_string(""); end if; if (XML_String(obj.n_reorder) /= Empty_String) then result := result & to_unbounded_string("") & XML_String(obj.n_reorder) & to_unbounded_string(""); end if; if (XML_String(obj.l_conhit) /= Empty_String) then result := result & to_unbounded_string("") & XML_String(obj.l_conhit) & to_unbounded_string(""); end if; if (XML_String(obj.l_conf) /= Empty_String) then result := result & to_unbounded_string("") & XML_String(obj.l_conf) & to_unbounded_string(""); end if; end Build_Attributes_XML_String; function XML_String(obj : in DRAM_Memory) return Unbounded_String is result : Unbounded_String; begin result := to_unbounded_string(""); Build_Attributes_XML_String(obj, result); result := result & to_unbounded_string(""); return (result); end XML_String; function XML_String(obj : in DRAM_Memory_Ptr) return Unbounded_String is begin if obj /= null then return XML_String(obj.all); else return Empty_String; end if; end XML_String; function XML_Ref_String(obj : in DRAM_Memory) return Unbounded_String is result : Unbounded_String; begin result := to_unbounded_string(""); return (result); end XML_Ref_String; function XML_Ref_String(obj : in DRAM_Memory_Ptr) return Unbounded_String is begin return XML_Ref_String(obj.all); end XML_Ref_String; -- --------= Kalray_Memory =-------- procedure Initialize(obj : in out Kalray_Memory) is begin initialize(Generic_Memory(obj)); obj.nb_bank := 0; obj.partition_mode := false; obj.memory_category := Kalray_Type; end Initialize; function Copy ( obj : in Kalray_Memory ) return Generic_Memory_Ptr is New_Kalray_Memory : Kalray_Memory_Ptr; begin New_Kalray_Memory := new Kalray_Memory'(obj); return Generic_Memory_Ptr(New_Kalray_Memory); end Copy; function Copy ( obj : in Kalray_Memory_Ptr ) return Generic_Memory_Ptr is begin return copy(obj.all); end Copy; procedure Put(obj : in Kalray_Memory) is begin put(Generic_Memory(obj)); put("nb_bank: "); standards_io.natural_io.put(obj.nb_bank); put ( "; " ); put("partition_mode: "); standards_io.boolean_io.put(obj.partition_mode); put ( "; " ); end Put; procedure Put(obj : in Kalray_Memory_Ptr) is begin Put(Obj.All); end Put; procedure Put_Name ( obj : in Kalray_Memory_Ptr) is begin Put ( To_String ( Obj.Name ) ); end Put_Name; function Get_Name (obj : in Kalray_Memory) return Unbounded_String is begin return obj.name; end Get_Name; function Get_Name (obj : in Kalray_Memory_ptr) return Unbounded_String is begin return obj.name; end Get_Name; function type_of ( obj : in Kalray_Memory ) return unbounded_string_list is list : unbounded_string_list; s : unbounded_string_ptr; begin Initialize(list); s := new unbounded_string; s.all := to_unbounded_string("OBJECTS.GENERIC_OBJECT"); Add (list, s); s := new unbounded_string; s.all := to_unbounded_string("OBJECTS.NAMED_OBJECT"); Add (list, s); s := new unbounded_string; s.all := to_unbounded_string("MEMORIES.GENERIC_MEMORY"); Add (list, s); s := new unbounded_string; s.all := to_unbounded_string("MEMORIES.KALRAY_MEMORY"); Add (list, s); return list; end type_of; function type_of ( obj : in Kalray_Memory_Ptr ) return unbounded_string_list is begin return type_of(obj.all); end type_of; procedure Build_Attributes_XML_String(obj : in Kalray_Memory; result : in out Unbounded_String) is begin Build_Attributes_XML_String(Generic_Memory(obj), result); if (XML_String(obj.nb_bank) /= Empty_String) then result := result & to_unbounded_string("") & XML_String(obj.nb_bank) & to_unbounded_string(""); end if; if (XML_String(obj.partition_mode) /= Empty_String) then result := result & to_unbounded_string("") & XML_String(obj.partition_mode) & to_unbounded_string(""); end if; end Build_Attributes_XML_String; function XML_String(obj : in Kalray_Memory) return Unbounded_String is result : Unbounded_String; begin result := to_unbounded_string(""); Build_Attributes_XML_String(obj, result); result := result & to_unbounded_string(""); return (result); end XML_String; function XML_String(obj : in Kalray_Memory_Ptr) return Unbounded_String is begin if obj /= null then return XML_String(obj.all); else return Empty_String; end if; end XML_String; function XML_Ref_String(obj : in Kalray_Memory) return Unbounded_String is result : Unbounded_String; begin result := to_unbounded_string(""); return (result); end XML_Ref_String; function XML_Ref_String(obj : in Kalray_Memory_Ptr) return Unbounded_String is begin return XML_Ref_String(obj.all); end XML_Ref_String; -- --------= Memory_Record =-------- procedure Initialize(obj : out Memory_Record) is begin obj.size := 0; obj.access_latency := 0; obj.memory_category := Generic_Memory_Type; obj.shared_access_latency := 0; obj.private_access_latency := 0; obj.l_rw_inter := 0; obj.l_act_inter := 0; obj.l_pre_inter := 0; obj.n_reorder := 0; obj.l_conhit := 0; obj.l_conf := 0; obj.nb_bank := 0; obj.partition_mode := false; end Initialize; procedure Put(obj : in Memory_Record) is begin put("size: "); standards_io.natural_io.put(obj.size); put ( "; " ); put("access_latency: "); standards_io.natural_io.put(obj.access_latency); put ( "; " ); put("memory_category: "); put(obj.memory_category); put ( "; " ); put("shared_access_latency: "); standards_io.natural_io.put(obj.shared_access_latency); put ( "; " ); put("private_access_latency: "); standards_io.natural_io.put(obj.private_access_latency); put ( "; " ); put("l_rw_inter: "); standards_io.natural_io.put(obj.l_rw_inter); put ( "; " ); put("l_act_inter: "); standards_io.natural_io.put(obj.l_act_inter); put ( "; " ); put("l_pre_inter: "); standards_io.natural_io.put(obj.l_pre_inter); put ( "; " ); put("n_reorder: "); standards_io.natural_io.put(obj.n_reorder); put ( "; " ); put("l_conhit: "); standards_io.natural_io.put(obj.l_conhit); put ( "; " ); put("l_conf: "); standards_io.natural_io.put(obj.l_conf); put ( "; " ); put("nb_bank: "); standards_io.natural_io.put(obj.nb_bank); put ( "; " ); put("partition_mode: "); standards_io.boolean_io.put(obj.partition_mode); put ( "; " ); end Put; procedure Put(obj : in Memory_Record_Ptr) is begin Put(Obj.All); end Put; procedure Build_Attributes_XML_String(obj : in Memory_Record; result : in out Unbounded_String) is begin if (XML_String(obj.size) /= Empty_String) then result := result & to_unbounded_string("") & XML_String(obj.size) & to_unbounded_string(""); end if; if (XML_String(obj.access_latency) /= Empty_String) then result := result & to_unbounded_string("") & XML_String(obj.access_latency) & to_unbounded_string(""); end if; if (XML_String(obj.memory_category) /= Empty_String) then result := result & to_unbounded_string("") & XML_String(obj.memory_category) & to_unbounded_string(""); end if; if (XML_String(obj.shared_access_latency) /= Empty_String) then result := result & to_unbounded_string("") & XML_String(obj.shared_access_latency) & to_unbounded_string(""); end if; if (XML_String(obj.private_access_latency) /= Empty_String) then result := result & to_unbounded_string("") & XML_String(obj.private_access_latency) & to_unbounded_string(""); end if; if (XML_String(obj.l_rw_inter) /= Empty_String) then result := result & to_unbounded_string("") & XML_String(obj.l_rw_inter) & to_unbounded_string(""); end if; if (XML_String(obj.l_act_inter) /= Empty_String) then result := result & to_unbounded_string("") & XML_String(obj.l_act_inter) & to_unbounded_string(""); end if; if (XML_String(obj.l_pre_inter) /= Empty_String) then result := result & to_unbounded_string("") & XML_String(obj.l_pre_inter) & to_unbounded_string(""); end if; if (XML_String(obj.n_reorder) /= Empty_String) then result := result & to_unbounded_string("") & XML_String(obj.n_reorder) & to_unbounded_string(""); end if; if (XML_String(obj.l_conhit) /= Empty_String) then result := result & to_unbounded_string("") & XML_String(obj.l_conhit) & to_unbounded_string(""); end if; if (XML_String(obj.l_conf) /= Empty_String) then result := result & to_unbounded_string("") & XML_String(obj.l_conf) & to_unbounded_string(""); end if; if (XML_String(obj.nb_bank) /= Empty_String) then result := result & to_unbounded_string("") & XML_String(obj.nb_bank) & to_unbounded_string(""); end if; if (XML_String(obj.partition_mode) /= Empty_String) then result := result & to_unbounded_string("") & XML_String(obj.partition_mode) & to_unbounded_string(""); end if; end Build_Attributes_XML_String; function XML_String(obj : in Memory_Record) return Unbounded_String is result : Unbounded_String; begin result := to_unbounded_string(""); Build_Attributes_XML_String(obj, result); result := result & to_unbounded_string(""); return (result); end XML_String; function XML_String(obj : in Memory_Record_Ptr) return Unbounded_String is begin if obj /= null then return XML_String(obj.all); else return Empty_String; end if; end XML_String; function XML_Ref_String(obj : in Memory_Record) return Unbounded_String is result : Unbounded_String; begin raise xml_ref_string_error; return to_unbounded_string(""); end XML_Ref_String; function Copy ( obj : in Memory_Record ) return Memory_Record_Ptr is New_Memory_Record : Memory_Record_Ptr; begin New_Memory_Record := new Memory_Record'(obj); return (New_Memory_Record); end Copy; function Copy ( obj : in Memory_Record_Ptr ) return Memory_Record_Ptr is begin return copy(obj.all); end Copy; End Memories;