Main Page | Namespace List | Class Hierarchy | Class List | File List | Namespace Members | Class Members | File Members | Related Pages

rk.h

Go to the documentation of this file.
00001 /*
00002  * rk.h
00003  *
00004  * Copyright (c) 2003, 2004 The University of Utah and the Flux Group.
00005  * All rights reserved.
00006  *
00007  * This file is licensed under the terms of the GNU Public License.  
00008  * See the file "license.terms" for restrictions on redistribution 
00009  * of this file, and for a DISCLAIMER OF ALL WARRANTIES.
00010  */
00011 
00012 /**
00013  * @file rk.h
00014  *
00015  * This file contains a replica of the TimeSys resource control APIs.  The goal
00016  * is to provide a close enough approximation that the same code can be used in
00017  * the simulated and real worlds.  The only visible difference between the two
00018  * is the definition of RK_STUB, so any simulation specific code should be
00019  * enclosed in an "#if defined(RK_STUB)".
00020  *
00021  * @sa rk_stub.h
00022  */
00023 
00024 #ifndef _rk_h
00025 #define _rk_h
00026 
00027 #include <sys/types.h>
00028 #if TIME_WITH_SYS_TIME
00029 # include <sys/time.h>
00030 # include <time.h>
00031 #else
00032 # if HAVE_SYS_TIME_H
00033 #  include <sys/time.h>
00034 # else
00035 #  include <time.h>
00036 # endif
00037 #endif
00038 
00039 #ifdef __cplusplus
00040 extern "C" {
00041 #endif
00042 
00043 /**
00044  * Inform the includer that this is the stub version.
00045  */
00046 #define RK_STUB 1
00047 
00048 /**
00049  * Maximum length for resource kernel names in general.
00050  */
00051 #define RK_NAME_LEN 16
00052 
00053 /**
00054  * Maximum length for resource set names.
00055  */
00056 #define RSET_NAME_LEN RK_NAME_LEN
00057 
00058 /**
00059  * Minimum period of periodic process
00060  */
00061 #define RT_MIN_PERIOD (struct timespec){0, 20000} /* 20uS */
00062 
00063 /**
00064  * Enumeration that can be used to specify which CPU a resource set can be
00065  * bound to.
00066  */
00067 typedef enum {
00068     RK_ANY_CPU = -1,    /**< Use any CPU available on the system. */
00069 } rk_processor_t;
00070 
00071 /**
00072  * The resource reservation modes.
00073  */
00074 typedef enum {
00075     RSV_HARD = 0x1,     /**< Hard reservation */
00076     RSV_FIRM = 0x2,     /**< Firm reservation */
00077     RSV_SOFT = 0x4,     /**< Soft reservation */
00078 } rk_reserve_mode_t;
00079 
00080 /**
00081  * The resource reservation parameters.
00082  *
00083  * XXX Currently, all three fields @e must contain the same RSV value.
00084  */
00085 typedef struct rk_reserve_param {
00086     rk_reserve_mode_t sch_mode; /**< Scheduling mode */
00087     rk_reserve_mode_t enf_mode; /**< Enforcement mode */
00088     rk_reserve_mode_t rep_mode; /**< Replenishment mode */
00089 } *rk_reserve_param_t;
00090 
00091 /**
00092  * The CPU reservation parameters.
00093  */
00094 typedef struct cpu_reserve_attr {
00095     struct timespec compute_time;
00096     struct timespec period;
00097     struct timespec deadline;
00098     struct timespec blocking_time;
00099     struct timespec start_time;
00100     struct rk_reserve_param reserve_type;
00101     rk_processor_t processor;
00102 } *cpu_reserve_attr_t;
00103 
00104 /**
00105  * Opaque reference to a resource set.
00106  */
00107 typedef struct rk_resource_set *rk_resource_set_t;
00108 
00109 /**
00110  * Opaque reference to a resource reserve.
00111  */
00112 typedef void *rk_reserve_t;
00113 
00114 /**
00115  * NULL constant value for a resource set.
00116  */
00117 #define NULL_RESOURCE_SET ((rk_resource_set_t)0)
00118 
00119 /**
00120  * NULL constant value for a reserve.
00121  */
00122 #define NULL_RESERVE ((rk_reserve_t)0)
00123 
00124 /**
00125  * @e Not implemented.
00126  */
00127 void rk_inherit_mode(int dummy);
00128 
00129 /**
00130  * Query the system for the list of mock resource sets.
00131  *
00132  * @param rs_inout An array that can hold atleast 'count' rk_resource_set_t
00133  * elements.
00134  * @param count The size of the 'rs_inout' array.
00135  * @return The actual number of elements in the 'rs_inout' array that were
00136  * filled in with resource set pointers.
00137  */
00138 int rk_resource_sets_get_list(rk_resource_set_t *rs_inout, int count);
00139 
00140 /**
00141  * @return The number of mock resource sets that are currently active.
00142  */
00143 int rk_resource_sets_get_num(void);
00144 
00145 /**
00146  * Construct a mock resource set with the given name.  The name has special
00147  * meaning in the simulator, it will be used as the base for any files that are
00148  * produced or read by the stub code.  For example, a file produced or read by
00149  * the CPU reserve will use file names of the form: @<name@>_cpu_@<file-type@>.
00150  *
00151  * @sa rk_cpu_reserve_create
00152  * @sa rk_cpu_reserve_trace_t
00153  *
00154  * @param name The name for the resource set.
00155  * @return A new rk_resource_set_t object or NULL if the creation failed.
00156  */
00157 rk_resource_set_t rk_resource_set_create(const char *name);
00158 
00159 /**
00160  * Destroy a resource set.
00161  *
00162  * @param rs The resource set to destroy.
00163  */
00164 int rk_resource_set_destroy(rk_resource_set_t rs);
00165 
00166 /**
00167  * Set the name of a resource set.  This is provided for compatibility and is
00168  * otherwise unwise to use since the name has meaning in the simulation code.
00169  *
00170  * @param rs The resource set to rename.
00171  * @param name The new name.
00172  * @return Zero if the name was valid, an errno value otherwise.
00173  */
00174 int rk_resource_set_set_name(rk_resource_set_t rs, const char *name);
00175 
00176 /**
00177  * Get the name of a resource set.
00178  *
00179  * @param rs The resource set to query.
00180  * @param name_out The character array, of atleast RSET_NAME_LEN length, to
00181  *                 fill out with the name of the resource set.
00182  * @return Zero if the parameters were valid, an errno value otherwise.
00183  */
00184 int rk_resource_set_get_name(rk_resource_set_t rs, char *name_out);
00185 
00186 /**
00187  * Get the CPU reserve from the given resource set.
00188  *
00189  * @param rs The resource set to query.
00190  * @return A pointer to the CPU reserve or NULL if the resource set did not
00191  *         have a CPU reserve attached.
00192  */
00193 rk_reserve_t rk_resource_set_get_cpu_rsv(rk_resource_set_t rs);
00194 
00195 /**
00196  * Attach a process to the resource set so that its callbacks will be used
00197  * when a data period is starting/ending.
00198  *
00199  * @e Note: The simulator only supports one process being attached at a time.
00200  *
00201  * @param rs The resource set that will be attached to the process.
00202  * @param pid The fake process ID to attach to the resource set.
00203  * @return Zero if the process was successfully attached, an errno value
00204  *         otherwise.
00205  */
00206 int rk_resource_set_attach_process(rk_resource_set_t rs, pid_t pid);
00207 
00208 /**
00209  * Detach a process from the resource set.
00210  *
00211  * @param rs The attached resource set.
00212  * @param pid The fake process ID to detach from the resource set.
00213  * @return Zero if the process was successfully detached, an errno value
00214  *         otherwise.
00215  */
00216 int rk_resource_set_detach_process(rk_resource_set_t rs, pid_t pid);
00217 
00218 /**
00219  * @param rs The resource set to query.
00220  * @return The number of processes attached to the given resource set.
00221  */
00222 int rk_resource_set_get_num_procs(rk_resource_set_t rs);
00223 
00224 /**
00225  * Query the system for the list of processes attached to the given resource
00226  * set.
00227  *
00228  * @e Note: The simulator only supports one process being attached at a time.
00229  *
00230  * @param rs The resource set to query for attached processes.
00231  * @param procs_inout An array that can hold atleast 'count' pid_t elements.
00232  * @param count The size of the 'procs_inout' array.
00233  * @return The actual number of elements in the 'procs_inout' array that were
00234  * filled in with pid's.
00235  */
00236 int rk_resource_set_get_proclist(rk_resource_set_t rs,
00237                                  pid_t *procs_inout,
00238                                  int count);
00239 
00240 /**
00241  * Get the resource set attached to the given process.
00242  *
00243  * @param pid The fake process ID to query.
00244  * @return The resource set that is attached to the process or NULL if none is
00245  *         attached.
00246  */
00247 rk_resource_set_t rk_proc_get_rset(pid_t pid);
00248 
00249 /**
00250  * Create a CPU reserve for the given resource set.  In order to simulate this
00251  * reserve, a "times" file must be available in the current directory.  The
00252  * contents of the file should be a whitespace separated list of floats that
00253  * specify the percentage of CPU time required by the process for a repeating
00254  * sequence of periods.  For example, the times file for a resource set named
00255  * "steady_50" that required 50% of the CPU at every period would be named
00256  * "steady_50_cpu_times" and contain only "50.0".  Another, more complex
00257  * example, would be a reserve that oscillated between 10% and 50% with 10%
00258  * steps would contain "10.0 20.0 30.0 40.0 50.0 40.0 30.0 20.0 10.0".
00259  *
00260  * The output of CPU simulation is a set of files that can be fed into gnuplot.
00261  * The contents of the file are two columns of numbers, a time value, and a CPU
00262  * percentage or an arbitrary value that marks some event.  The current list of
00263  * files is:
00264  *
00265  * @li @e _cpu_period The CPU reserve's period.
00266  * @li @e _cpu_deadline The CPU reserve's deadline.
00267  * @li @e _cpu_complete Marks the completion of a data period.
00268  * @li @e _cpu_drop Marks a data period as being dropped.
00269  * @li @e _cpu_realtime The CPU time required by the process.
00270  * @li @e _cpu_success The actual CPU time received by a process that is making
00271  *                     its deadlines.
00272  * @li @e _cpu_fail The actual CPU time received by a process that is missing
00273  *                  its deadlines.
00274  *
00275  * @param rs The resource set that will hold the CPU reserve.
00276  * @param r_out A pointer that can be set to the new CPU reserve.
00277  * @param ra_in The reservation parameters.
00278  * @return Zero if the reserve was created successfully, an errno value
00279  *         otherwise.
00280  */
00281 int rk_cpu_reserve_create(rk_resource_set_t rs,
00282                           rk_reserve_t *r_out,
00283                           cpu_reserve_attr_t ra_in);
00284 
00285 /**
00286  * Delete a CPU reserve held by a resource set.
00287  *
00288  * @param rs A resource set.
00289  * @return Zero on success, -1 on error.
00290  */
00291 int rk_cpu_reserve_delete(rk_resource_set_t rs);
00292 
00293 /**
00294  * Get the reservation parameters for a given CPU reserve.
00295  *
00296  * @param cr The CPU reserve to query.
00297  * @param ra_out The cpu_reserve_attr object to fill with the CPU reserve's
00298  *               current parameters.
00299  * @return Zero if the query was successful, an errno value otherwise.
00300  */
00301 int rk_cpu_reserve_get_attr(rk_reserve_t cr, cpu_reserve_attr_t ra_out);
00302 
00303 /**
00304  * Change a CPU reserve's scheduling parameters.
00305  *
00306  * @param rs The CPU reserve to change.
00307  * @param ra_in The new scheduling parameters.
00308  * @return Zero if the change was successful, an errno value otherwise.
00309  */
00310 int rk_cpu_reserve_ctl(rk_resource_set_t rs, cpu_reserve_attr_t ra_in);
00311 
00312 #if !defined(HAVE_CLOCKID_T)
00313 /**
00314  * A clockid_t enumeration for those OS's that do not support it.
00315  */
00316 typedef enum {
00317     CLOCK_REALTIME,
00318     CLOCK_VIRTUAL,
00319     CLOCK_PROF
00320 } clockid_t;
00321 #endif
00322 
00323 /**
00324  * Get the simulator's virtual time.
00325  *
00326  * @param clock_id The clock type, only CLOCK_REALTIME is supported.
00327  * @param ts The timespec object to fill out.
00328  * @return Zero if the query was successful, otherwise it returns -1 and sets
00329  *         errno appropriately.
00330  */
00331 int rk_clock_gettime(clockid_t clock_id, struct timespec *ts);
00332 
00333 /**
00334  * Set the simulator's virtual time.  This function should really only be used
00335  * to set the time to a value _before_ the next event.
00336  *
00337  * @param clock_id The clock type, only CLOCK_REALTIME is supported.
00338  * @param ts The new virtual time value.
00339  * @return Zero if the query was successful, otherwise it returns -1 and sets
00340  *         errno appropriately.
00341  */
00342 int rk_clock_settime(clockid_t clock_id, struct timespec *ts);
00343 
00344 /**
00345  * Get the simulator's virtual clock resolution.
00346  *
00347  * @param clock_id The clock type, only CLOCK_REALTIME is supported.
00348  * @param ts The timespec object to fill out.
00349  * @return Zero if the query was successful, otherwise it returns -1 and sets
00350  *         errno appropriately.
00351  */
00352 int rk_clock_getres(clockid_t clock_id, struct timespec *ts);
00353 
00354 #ifdef __cplusplus
00355 }
00356 #endif
00357 
00358 #endif

Generated on Fri Oct 22 07:50:24 2004 for CPU Broker by  doxygen 1.3.9.1