------------------------------------------------------------------------------
------------------------------------------------------------------------------
-- 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 GNU GPL real-time scheduling analysis tool.
-- This program provides services to automatically check schedulability and
-- other performance criteria of real-time architecture models.
--
-- Copyright (C) 2002-2016 Frank Singhoff, Alain Plantec, Jerome Legrand
--
-- The Cheddar project was started in 2002 by
-- Frank Singhoff, Lab-STICC UMR 6285 laboratory, Université de Bretagne Occidentale
--
-- Cheddar has been published in the "Agence de Protection des Programmes/France" in 2008.
-- Since 2008, Ellidiss technologies also contributes to the development of
-- Cheddar and provides industrial support.
--
-- The full list of contributors and sponsors can be found in AUTHORS.txt and SPONSORS.txt
--
-- 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;