00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018 #define DV_DRV
00019 #define DV_DRV_MAIN
00020
00021
00022 int nObs,nODEs,nSCPI;
00023
00024 #include "md_device.h"
00025
00026 using namespace boost::interprocess;
00027 using namespace std;
00028
00029 #ifndef _WIN32_WINNT
00030 void setSignals();
00031 void signal_handler(int);
00032 #endif
00033
00034 int problem=OK;
00035
00036 void additionalUserMsgs() {
00037
00038
00039
00040 mdErrors->additionalUserMsg(1000,"Replace me with your text");
00041
00042 }
00043 void stubCmdProcessor(char *cmd,char *fullText) {
00044
00045 int rc = OK;
00046
00047
00048
00049
00050
00051 mdDDAPI->mdCmdResult(rc);
00052
00053 }
00054 bool regMySCPI() {
00055
00056 int rc=OK;
00057
00058 if (!rc) { rc=mdDDAPI->mdRegisterCommandCallback(stubCmdProcessor,"RST"); nSCPI++; }
00059
00060
00061 if (rc) mdDDAPI->log->logN(1,"Error registering cmd cb: %s.",mdErrors->what());
00062
00063 return (rc == OK);
00064
00065 }
00066 int regMyData() {
00067
00068 bool doConfTests=false,rules=false;
00069 mdObservable *obs=NULL;
00070 mdOperationalDataElement *ode=NULL;
00071 int rc=OK;
00072
00073
00074
00075
00076
00077
00078
00079
00080
00081 if (doConfTests) {
00082
00083 if (obs=mdDDAPI->mdRegisterObservable("bogus"))
00084 {mdDDAPI->log->logN(0,"MD accepted an invalid observation.");
00085 goto done;
00086 }
00087 if (ode=mdDDAPI->mdRegisterODE("_bogus"))
00088 {mdDDAPI->log->logN(0,"MD accepted an invalid operational datum.");
00089 goto done;
00090 }
00091 mdDDAPI->log->logN(0,"Data Element registration API tested OK.");
00092
00093 }
00094
00095 if (!obs && (obs=mdDDAPI->mdRegisterObservable("device"))) {myObs["device"] = obs; nObs++;}
00096 if (rules) {
00097 if (obs && (obs=mdDDAPI->mdRegisterObservable("pressure"))) {myObs["pressure"] = obs; nObs++;}
00098 if (obs && (obs=mdDDAPI->mdRegisterObservable("temperature"))) {myObs["temperature"] = obs; nObs++;}
00099
00100 }
00101 if (!obs) mdDDAPI->log->logN(1,"Error registering observable: %s.",mdErrors->what());
00102
00103 if (!ode && (ode=mdDDAPI->mdRegisterODE("_device"))) {myODEs["_device"] = ode; nODEs++;}
00104 if (rules) {
00105 if (!ode && (ode=mdDDAPI->mdRegisterODE("_powered"))) {myODEs["_powered"] = ode; nODEs++;}
00106 if (ode && (ode=mdDDAPI->mdRegisterODE("_spinning"))) {myODEs["_spinning"] = ode; nODEs++;}
00107 }
00108
00109
00110 if (!ode) mdDDAPI->log->logN(1,"Error registering ODE: %s.",mdErrors->what());
00111
00112 rc = (ode != NULL && obs != NULL);
00113
00114 done: return rc;
00115
00116 }
00117 int
00118 main(int const argc,
00119 const char ** const argv)
00120 {
00121 #ifndef _WIN32_WINNT
00122 setSignals();
00123 aucDevice();
00124 #endif
00125 mdError stub;
00126 stub.get(&mdErrors);
00127 additionalUserMsgs();
00128 nObs = nODEs = nSCPI = 0;
00129
00130
00131
00132
00133 struct shm_remove
00134 {
00135 shm_remove() { shared_memory_object::remove("auc_dv_global"); }
00136 ~shm_remove() { shared_memory_object::remove("auc_dv_global"); }
00137 } remover;
00138
00139 shared_memory_object shm(create_only, "auc_dv_global", read_write);
00140 shm.truncate(sizeof(auc_dv_global));
00141 mapped_region dv_telemetry_frame(shm, read_write);
00142 memset(dv_telemetry_frame.get_address(), 0, dv_telemetry_frame.get_size());
00143 gm = (auc_dv_global *)dv_telemetry_frame.get_address();
00144
00145
00146 strcpy(gm->id,"auc_dv_global");
00147 strcmp(gm->id,"auc_dv_global");
00148
00149
00150
00151 mdEmbeddedAPI thisMDEmbedding =
00152 mdEmbeddedAPI(
00153
00154
00155
00156
00157 "67.223.227.29", "4242",
00158 "208.109.106.127", "4242");
00159
00160
00161
00162
00163
00164
00165 thisMDEmbedding.setSingleton(gm);
00166 mdDDAPI = &thisMDEmbedding;
00167
00168
00169
00170 while (!*mdDDAPI->cdConnected) {
00171 boost::system_time const alarum=boost::get_system_time() + boost::posix_time::seconds(5);
00172 boost::this_thread::sleep(alarum);
00173 }
00174
00175
00176
00177
00178
00179
00180
00181 mdDDAPI->log->logN(0,"Registering data and SCPI for this device.");
00182 if (regMyData() && regMySCPI())
00183 mdDDAPI->mdResume();
00184 else exit(problem);
00185
00186
00187
00188
00189
00190
00191
00192
00193
00194
00195
00196
00197
00198
00199
00200
00201
00202
00203
00204
00205
00206
00207
00208
00209
00210
00211
00212
00213
00214
00215
00216
00217
00218
00219 bool dlt = mdDDAPI->data_layer->joinable(),
00220 tt = mdDDAPI->telemetry->joinable();
00221
00222 if (dlt && tt)
00223 {
00224 mdDDAPI->log->logN(3,"%d observations, %d operational variables, %d SCPI commands registered with MD",nObs,nODEs,nSCPI);
00225 mdDDAPI->data_layer->join();
00226 mdDDAPI->telemetry->join();
00227 }
00228 else mdDDAPI->log->logN(0,"Initialization failed, process ends.");
00229 mdDDAPI->log->logN(0,"MD Device Interface EOJ.");
00230
00231 }
00232 #ifndef _WIN32_WINNT
00233 void setSignals() {
00234
00235 signal(SIGCHLD,SIG_IGN);
00236 signal(SIGTSTP,SIG_IGN);
00237 signal(SIGTTOU,SIG_IGN);
00238 signal(SIGTTIN,SIG_IGN);
00239 signal(SIGSEGV,signal_handler);
00240 signal(SIGUSR1,signal_handler);
00241 signal(SIGUSR2,signal_handler);
00242 signal(SIGHUP,signal_handler);
00243 signal(SIGTERM,signal_handler);
00244
00245 }
00246 void signal_handler(int sig)
00247 {
00248 switch(sig) {
00249 case SIGSEGV:
00250 break;
00251 case SIGUSR1:
00252 break;
00253 case SIGUSR2:
00254 break;
00255 case SIGHUP:
00256 mdDDAPI->log->logN(0,"hangup signal caught, currently auc-md ignores this.");
00257 break;
00258 case SIGTERM:
00259 mdDDAPI->log->logN(0,"terminate signal caught, auc-md will shutdown.");
00260 exit(0);
00261 break;
00262 }
00263 }
00264 #endif