Low-Energy Muon (LEM) Experiment  0.5.2
k2700_scfe.cxx
Go to the documentation of this file.
1 /********************************************************************\
2 
3  Name: k2700_scfe.cxx
4  Created by: Gerard Nieuwenhuys
5 
6  Contents: Midas slow control frontend for Keithtley 2700
7 
8 \********************************************************************/
9 
10 #include <cstdio>
11 #include <cstdlib>
12 #include <cstring>
13 #include <cmath>
14 
15 #include "midas.h"
16 #include "mfe.h"
17 
18 #include "class/multi.h"
19 #include "keithley2700.h"
20 #include "tcpip_rs232.h"
21 
22 //-- Globals -------------------------------------------------------
23 
25 const char *frontend_name = "K2700 SC";
27 const char *frontend_file_name = __FILE__;
28 
30 BOOL frontend_call_loop = TRUE;
31 
33 INT display_period = 1000;
34 
36 INT max_event_size = 10000;
37 
39 INT max_event_size_frag = 5*1024*1024;
40 
42 INT event_buffer_size = 10*10000;
43 
44 //-- Equipment list ------------------------------------------------
45 
49 DEVICE_DRIVER K2700_driver[] = {
50  { "K2700", keithley2700, 20, tcpip_rs232, DF_INPUT },
51  { "" }
52 };
53 
63 
65 EQUIPMENT equipment[] = {
66 
67  { "K2700", // equipment name
68  {95, 0, // event ID, trigger mask
69  "SYSTEM", // event buffer
70  EQ_SLOW, // equipment type
71  0, // event source
72  "FIXED", // format
73  TRUE, // enabled
74  RO_RUNNING |
75  RO_TRANSITIONS, // read when running and on transitions
76  1000, // read every 1 sec
77  0, // stop run after this event limit
78  0, // number of sub events
79  1, // log history every event
80  "", "", "",},
81  cd_multi_read, // readout routine
82  cd_multi, // class driver main routine
83  K2700_driver, // device driver list
84  NULL, // init string
85  },
86 
87  { "" }
88 };
89 
90 
91 
92 //-- Dummy routines ------------------------------------------------
93 
94 INT poll_event(INT source, INT count, BOOL test) {return 1;};
95 INT interrupt_configure(INT cmd, INT source, POINTER_T adr) {return 1;};
96 
97 //-- Frontend Init -------------------------------------------------
103 {
104  // de-register run-transition notifications
105  cm_deregister_transition(TR_START);
106  cm_deregister_transition(TR_STOP);
107  cm_deregister_transition(TR_PAUSE);
108  cm_deregister_transition(TR_RESUME);
109 
110  return CM_SUCCESS;
111 }
112 
113 //-- Frontend Exit -------------------------------------------------
119 {
120  return CM_SUCCESS;
121 }
122 
123 //-- Frontend Loop -------------------------------------------------
129 {
130  return CM_SUCCESS;
131 }
132 
133 //-- Begin of Run --------------------------------------------------
138 INT begin_of_run(INT run_number, char *error)
139 {
140  return CM_SUCCESS;
141 }
142 
143 //-- End of Run ----------------------------------------------------
148 INT end_of_run(INT run_number, char *error)
149 {
150  return CM_SUCCESS;
151 }
152 
153 //-- Pause Run -----------------------------------------------------
158 INT pause_run(INT run_number, char *error)
159 {
160  return CM_SUCCESS;
161 }
162 
163 //-- Resume Run ----------------------------------------------------
168 INT resume_run(INT run_number, char *error)
169 {
170  return CM_SUCCESS;
171 }
172 
173 //------------------------------------------------------------------
const char * frontend_name
&lt; created by ODBedit, command &quot;make&quot;
Definition: vme_fe.cxx:167
INT max_event_size
maximum event size produced by this frontend
Definition: vme_fe.cxx:179
BOOL frontend_call_loop
frontend_loop is called periodically if this variable is TRUE
Definition: vme_fe.cxx:173
INT display_period
a frontend status page is displayed with this frequency in ms
Definition: vme_fe.cxx:176
INT event_buffer_size
buffer size to hold events
Definition: vme_fe.cxx:185
INT frontend_exit()
Definition: vme_fe.cxx:565
EQUIPMENT equipment[]
Definition: vme_fe.cxx:343
INT begin_of_run(INT run_number, char *error)
Definition: vme_fe.cxx:597
INT interrupt_configure(INT cmd, INT source, PTYPE adr)
Definition: vme_fe.cxx:2105
INT frontend_loop()
Definition: vme_fe.cxx:957
INT resume_run(INT run_number, char *error)
Definition: vme_fe.cxx:900
INT max_event_size_frag
maximum event size for fragmented events (EQ_FRAGMENTED)
Definition: vme_fe.cxx:182
INT frontend_init()
Definition: vme_fe.cxx:429
BOOL equipment_common_overwrite
Definition: vme_fe.cxx:341
INT end_of_run(INT run_number, char *error)
Definition: vme_fe.cxx:865
INT poll_event(INT source, INT count, BOOL test)
Definition: vme_fe.cxx:2088
INT pause_run(INT run_number, char *error)
Definition: vme_fe.cxx:893
const char * frontend_file_name
The frontend file name, don&#39;t change it.
Definition: vme_fe.cxx:170
DEVICE_DRIVER K2700_driver[]
Definition: k2700_scfe.cxx:49