Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Use boost::intrusive in CpuTi
[simgrid.git] / src / surf / cpu_ti.hpp
index 7e27e52..83d176e 100644 (file)
@@ -1,3 +1,9 @@
+/* Copyright (c) 2013-2014. The SimGrid Team.
+ * All rights reserved.                                                     */
+
+/* This program is free software; you can redistribute it and/or modify it
+ * under the terms of the license (GNU LGPL) which comes with this package. */
+
 #include "cpu_interface.hpp"
 #include "trace_mgr_private.h"
 #include "surf/surf_routing.h"
@@ -23,6 +29,15 @@ typedef CpuTi *CpuTiPtr;
 class CpuTiAction;
 typedef CpuTiAction *CpuTiActionPtr;
 
+typedef boost::intrusive::list<CpuTi> CpuTiList;
+typedef CpuTiList* CpuTiListPtr;
+typedef boost::intrusive::list_base_hook<> cpuTiHook;
+
+struct tiTag;
+typedef boost::intrusive::list<CpuTiAction, boost::intrusive::base_hook<boost::intrusive::list_base_hook<boost::intrusive::tag<tiTag> > > > ActionTiList;
+typedef ActionTiList* ActionTiListPtr;
+typedef boost::intrusive::list_base_hook<boost::intrusive::tag<tiTag> > actionTiHook;
+
 /*********
  * Trace *
  *********/
@@ -44,7 +59,7 @@ private:
 };
 
 enum trace_type {
-  
+
   TRACE_FIXED,                /*< Trace fixed, no availability file */
   TRACE_DYNAMIC               /*< Dynamic, availability file disponible */
 };
@@ -71,7 +86,6 @@ public:
   tmgr_trace_t p_powerTrace;
 };
 
-
 /*********
  * Model *
  *********/
@@ -79,21 +93,18 @@ class CpuTiModel : public CpuModel {
 public:
   CpuTiModel();
   ~CpuTiModel();
-
-  void parseInit(sg_platf_host_cbarg_t host);
-  CpuTiPtr createResource(const char *name,  xbt_dynar_t powerPeak,
+  CpuPtr createCpu(const char *name,  xbt_dynar_t powerPeak,
                           int pstate, double power_scale,
                           tmgr_trace_t power_trace, int core,
                           e_surf_resource_state_t state_initial,
                           tmgr_trace_t state_trace,
                           xbt_dict_t cpu_properties);
-  CpuTiActionPtr createAction(double cost, bool failed);
   double shareResources(double now);
   void updateActionsState(double now, double delta);
   void addTraces();
 
-  xbt_swag_t p_runningActionSetThatDoesNotNeedBeingChecked;
-  xbt_swag_t p_modifiedCpu;
+  ActionListPtr p_runningActionSetThatDoesNotNeedBeingChecked;
+  CpuTiListPtr p_modifiedCpu;
   xbt_heap_t p_tiActionHeap;
 
 protected:
@@ -108,7 +119,7 @@ protected:
 /************
  * Resource *
  ************/
-class CpuTi : public Cpu {
+class CpuTi : public cpuTiHook, public Cpu {
 public:
   CpuTi() {};
   CpuTi(CpuTiModelPtr model, const char *name, xbt_dynar_t powerPeak,
@@ -117,7 +128,7 @@ public:
        xbt_dict_t properties) ;
   ~CpuTi();
 
-  void updateState(tmgr_trace_event_t event_type, double value, double date);  
+  void updateState(tmgr_trace_event_t event_type, double value, double date);
   void updateActionsFinishTime(double now);
   bool isUsed();
   void printCpuTiModel();
@@ -125,25 +136,19 @@ public:
   CpuActionPtr sleep(double duration);
   double getAvailableSpeed();
 
-  xbt_dynar_t getWattsRangeList() {THROW_UNIMPLEMENTED;};
-  double getCurrentWattsValue(double /*cpu_load*/) {THROW_UNIMPLEMENTED;};
-  void updateEnergy(double /*cpu_load*/) {THROW_UNIMPLEMENTED;};
-
   double getCurrentPowerPeak() {THROW_UNIMPLEMENTED;};
   double getPowerPeakAt(int /*pstate_index*/) {THROW_UNIMPLEMENTED;};
   int getNbPstates() {THROW_UNIMPLEMENTED;};
   void setPowerPeakAt(int /*pstate_index*/) {THROW_UNIMPLEMENTED;};
-  double getConsumedEnergy() {THROW_UNIMPLEMENTED;};
+  void modified(bool modified);
 
   CpuTiTgmrPtr p_availTrace;       /*< Structure with data needed to integrate trace file */
   tmgr_trace_event_t p_stateEvent;       /*< trace file with states events (ON or OFF) */
   tmgr_trace_event_t p_powerEvent;       /*< trace file with availability events */
-  xbt_swag_t p_actionSet;        /*< set with all actions running on cpu */
-  s_xbt_swag_hookup_t p_modifiedCpuHookup;      /*< hookup to swag that indicates whether share resources must be recalculated or not */
+  ActionTiListPtr p_actionSet;        /*< set with all actions running on cpu */
   double m_sumPriority;          /*< the sum of actions' priority that are running on cpu */
   double m_lastUpdate;           /*< last update of actions' remaining amount done */
 
-  int m_pstate;                                                                /*< Current pstate (index in the power_peak_list)*/
   double current_frequency;
 
   void updateRemainingAmount(double now);
@@ -153,14 +158,13 @@ public:
  * Action *
  **********/
 
-class CpuTiAction: public CpuAction {
+class CpuTiAction: public actionTiHook, public CpuAction {
   friend CpuActionPtr CpuTi::execute(double size);
   friend CpuActionPtr CpuTi::sleep(double duration);
   friend void CpuTi::updateActionsFinishTime(double now);//FIXME
   friend void CpuTi::updateRemainingAmount(double now);//FIXME
 
 public:
-  CpuTiAction() {};
   CpuTiAction(CpuTiModelPtr model, double cost, bool failed,
                                 CpuTiPtr cpu);
 
@@ -176,11 +180,9 @@ public:
   void setPriority(double priority);
   double getRemains();
   void setAffinity(CpuPtr /*cpu*/, unsigned long /*mask*/) {};
-  void setBound(double /*bound*/) {};
 
   CpuTiPtr p_cpu;
   int m_indexHeap;
-  s_xbt_swag_hookup_t p_cpuListHookup;
   int m_suspended;
 private:
 };