Commit 8ab48c43 authored by Claes Sjofors's avatar Claes Sjofors

Sev server threads

parent e13b730c
This diff is collapsed.
...@@ -95,10 +95,12 @@ typedef map<int, sev_sThread *>::iterator threadlist_iterator; ...@@ -95,10 +95,12 @@ typedef map<int, sev_sThread *>::iterator threadlist_iterator;
class sev_server { class sev_server {
public: public:
sev_server() : m_server_status(0), m_refid(0), m_msg_id(0), m_storage_cnt(0), sev_server() : m_server_status(0), m_refid(0), m_msg_id(0), m_storage_cnt(0), m_write_cnt(0),
m_db_type(sev_eDbType_Sqlite), m_config(0), m_thread_cnt(0), m_read_threads(0) m_db_type(sev_eDbType_Sqlite), m_config(0), m_thread_cnt(0), m_read_threads(0),
m_thread_key_node(0)
{ memset(&m_stat,0,sizeof(m_stat));} { memset(&m_stat,0,sizeof(m_stat));}
~sev_server();
pwr_tStatus m_sts; pwr_tStatus m_sts;
pwr_tStatus m_server_status; pwr_tStatus m_server_status;
vector<sev_node> m_nodes; vector<sev_node> m_nodes;
...@@ -107,12 +109,14 @@ class sev_server { ...@@ -107,12 +109,14 @@ class sev_server {
sev_db *m_db; sev_db *m_db;
int m_noneth; int m_noneth;
unsigned int m_storage_cnt; unsigned int m_storage_cnt;
unsigned int m_write_cnt;
sev_sStat m_stat; sev_sStat m_stat;
sev_eDbType m_db_type; sev_eDbType m_db_type;
pwr_sClass_SevServer *m_config; pwr_sClass_SevServer *m_config;
unsigned int m_thread_cnt; unsigned int m_thread_cnt;
pwr_tDlid m_config_dlid; pwr_tDlid m_config_dlid;
int m_read_threads; int m_read_threads;
int m_thread_key_node;
map<int, sev_sThread *>m_thread_list; map<int, sev_sThread *>m_thread_list;
int init( int noneth); int init( int noneth);
...@@ -120,15 +124,17 @@ class sev_server { ...@@ -120,15 +124,17 @@ class sev_server {
int request_items( pwr_tNid nid); int request_items( pwr_tNid nid);
int mainloop(); int mainloop();
int check_histitems( sev_sMsgHistItems *msg, unsigned int size); int check_histitems( sev_sMsgHistItems *msg, unsigned int size);
int receive_histdata( sev_sMsgHistDataStore *msg, unsigned int size); int receive_histdata( sev_sMsgHistDataStore *msg, unsigned int size, pwr_tNid nid);
int send_histdata( qcom_sQid tgt, sev_sMsgHistDataGetRequest *msg, unsigned int size); int send_histdata( qcom_sQid tgt, sev_sMsgHistDataGetRequest *msg, unsigned int size);
int send_objecthistdata( qcom_sQid tgt, sev_sMsgHistDataGetRequest *rmsg, unsigned int size); int send_objecthistdata( qcom_sQid tgt, sev_sMsgHistDataGetRequest *rmsg, unsigned int size);
int send_itemlist( qcom_sQid tgt); int send_itemlist( qcom_sQid tgt);
int send_server_status( qcom_sQid tgt); int send_server_status( qcom_sQid tgt);
int delete_item( qcom_sQid tgt, sev_sMsgHistItemDelete *rmsg); int delete_item( qcom_sQid tgt, sev_sMsgHistItemDelete *rmsg);
int receive_events( sev_sMsgEventsStore *msg, unsigned int size); int receive_events( sev_sMsgEventsStore *msg, unsigned int size);
void garbage_collector(); void create_garbage_collector_thread();
void garbage_item( int idx); static void *garbage_collector_thread( void *arg);
void garbage_collector( void *thread);
void garbage_item( void *thread, int idx);
void set_dbtype( sev_eDbType type) { m_db_type = type;} void set_dbtype( sev_eDbType type) { m_db_type = type;}
sev_sThread *find_thread( int key); sev_sThread *find_thread( int key);
static void *receive_histdata_thread( void *arg); static void *receive_histdata_thread( void *arg);
......
...@@ -72,6 +72,9 @@ typedef struct { ...@@ -72,6 +72,9 @@ typedef struct {
float medium_load; float medium_load;
float storage_rate; float storage_rate;
float medium_storage_rate; float medium_storage_rate;
float write_rate;
float medium_write_rate;
float write_quota;
unsigned int datastore_msg_cnt; unsigned int datastore_msg_cnt;
unsigned int dataget_msg_cnt; unsigned int dataget_msg_cnt;
unsigned int items_msg_cnt; unsigned int items_msg_cnt;
...@@ -216,13 +219,13 @@ class sev_db { ...@@ -216,13 +219,13 @@ class sev_db {
virtual int delete_item( pwr_tStatus *sts, pwr_tOid oid, char *aname) { *sts = 0; return 0;} virtual int delete_item( pwr_tStatus *sts, pwr_tOid oid, char *aname) { *sts = 0; return 0;}
virtual int store_value( pwr_tStatus *sts, void *thread, int item_idx, int attr_idx, virtual int store_value( pwr_tStatus *sts, void *thread, int item_idx, int attr_idx,
pwr_tTime time, void *buf, unsigned int size) { *sts = 0; return 0;} pwr_tTime time, void *buf, unsigned int size) { *sts = 0; return 0;}
virtual int get_values( pwr_tStatus *sts, pwr_tOid oid, pwr_tMask options, float deadband, virtual int get_values( pwr_tStatus *sts, void *thread, pwr_tOid oid, pwr_tMask options,
char *aname, pwr_eType type, float deadband, char *aname, pwr_eType type,
unsigned int size, pwr_tFloat32 scantime, pwr_tTime *creatime, pwr_tTime *starttime, unsigned int size, pwr_tFloat32 scantime, pwr_tTime *creatime, pwr_tTime *starttime,
pwr_tTime *endtime, int maxsize, pwr_tTime **tbuf, void **vbuf, pwr_tTime *endtime, int maxsize, pwr_tTime **tbuf, void **vbuf,
unsigned int *bsize) { *sts = 0; return 0;} unsigned int *bsize) { *sts = 0; return 0;}
virtual int get_items( pwr_tStatus *sts) { *sts = 0; return 0;} virtual int get_items( pwr_tStatus *sts) { *sts = 0; return 0;}
virtual int delete_old_data( pwr_tStatus *sts, char *tablename, virtual int delete_old_data( pwr_tStatus *sts, void *thread, char *tablename,
pwr_tMask options, pwr_tTime limit, pwr_tFloat32 scantime, pwr_tFloat32 garbagecycle) pwr_tMask options, pwr_tTime limit, pwr_tFloat32 scantime, pwr_tFloat32 garbagecycle)
{ *sts = 0; return 0;} { *sts = 0; return 0;}
...@@ -244,9 +247,9 @@ class sev_db { ...@@ -244,9 +247,9 @@ class sev_db {
virtual int get_objectitems( pwr_tStatus *sts) { *sts = 0; return 0;} virtual int get_objectitems( pwr_tStatus *sts) { *sts = 0; return 0;}
virtual int check_objectitemattr( pwr_tStatus *sts, char *tablename, pwr_tOid oid, char *aname, char *oname, virtual int check_objectitemattr( pwr_tStatus *sts, char *tablename, pwr_tOid oid, char *aname, char *oname,
pwr_eType type, unsigned int size, unsigned int *idx) { *sts = 0; return 0;} pwr_eType type, unsigned int size, unsigned int *idx) { *sts = 0; return 0;}
virtual int delete_old_objectdata( pwr_tStatus *sts, char *tablename, virtual int delete_old_objectdata( pwr_tStatus *sts, void *thread, char *tablename,
pwr_tMask options, pwr_tTime limit, pwr_tFloat32 scantime, pwr_tFloat32 garbagecycle) { *sts = 0; return 0;} pwr_tMask options, pwr_tTime limit, pwr_tFloat32 scantime, pwr_tFloat32 garbagecycle) { *sts = 0; return 0;}
virtual int get_objectvalues( pwr_tStatus *sts, sev_item *item, virtual int get_objectvalues( pwr_tStatus *sts, void *thread, sev_item *item,
unsigned int size, pwr_tTime *starttime, pwr_tTime *endtime, unsigned int size, pwr_tTime *starttime, pwr_tTime *endtime,
int maxsize, pwr_tTime **tbuf, void **vbuf, unsigned int *bsize) { *sts = 0; return 0;} int maxsize, pwr_tTime **tbuf, void **vbuf, unsigned int *bsize) { *sts = 0; return 0;}
virtual int handle_objectchange(pwr_tStatus *sts, char *tablename, unsigned int item_idx, bool newObject) { *sts = 0; return 0;} virtual int handle_objectchange(pwr_tStatus *sts, char *tablename, unsigned int item_idx, bool newObject) { *sts = 0; return 0;}
...@@ -258,6 +261,7 @@ class sev_db { ...@@ -258,6 +261,7 @@ class sev_db {
virtual int commit_transaction( void *thread) { return 0;} virtual int commit_transaction( void *thread) { return 0;}
virtual char *dbName() { return 0;} virtual char *dbName() { return 0;}
virtual void *new_thread() { return 0;} virtual void *new_thread() { return 0;}
virtual void delete_thread( void *thread) {}
static sev_db *open_database( sev_eDbType type, sev_sDbConfig *cnf); static sev_db *open_database( sev_eDbType type, sev_sDbConfig *cnf);
static int get_systemname( char *name); static int get_systemname( char *name);
......
...@@ -2743,8 +2743,8 @@ int sev_dbhdf5::store_value( pwr_tStatus *sts, void *thread, int item_idx, int a ...@@ -2743,8 +2743,8 @@ int sev_dbhdf5::store_value( pwr_tStatus *sts, void *thread, int item_idx, int a
return 1; return 1;
} }
int sev_dbhdf5::get_values( pwr_tStatus *sts, pwr_tOid oid, pwr_tMask options, float deadband, int sev_dbhdf5::get_values( pwr_tStatus *sts, void *thread, pwr_tOid oid, pwr_tMask options,
char *aname, pwr_eType type, float deadband, char *aname, pwr_eType type,
unsigned int size, pwr_tFloat32 scantime, pwr_tTime *creatime, unsigned int size, pwr_tFloat32 scantime, pwr_tTime *creatime,
pwr_tTime *starttime, pwr_tTime *endtime, pwr_tTime *starttime, pwr_tTime *endtime,
int maxsize, pwr_tTime **tbuf, void **vbuf, unsigned int *bsize) int maxsize, pwr_tTime **tbuf, void **vbuf, unsigned int *bsize)
...@@ -3713,7 +3713,7 @@ int sev_dbhdf5::delete_item( pwr_tStatus *sts, pwr_tOid oid, char *aname) ...@@ -3713,7 +3713,7 @@ int sev_dbhdf5::delete_item( pwr_tStatus *sts, pwr_tOid oid, char *aname)
return 1; return 1;
} }
int sev_dbhdf5::delete_old_data( pwr_tStatus *sts, char *tablename, int sev_dbhdf5::delete_old_data( pwr_tStatus *sts, void *thread, char *tablename,
pwr_tMask options, pwr_tTime limit, pwr_tFloat32 scantime, pwr_tFloat32 garbagecycle) pwr_tMask options, pwr_tTime limit, pwr_tFloat32 scantime, pwr_tFloat32 garbagecycle)
{ {
return 1; return 1;
...@@ -4495,7 +4495,7 @@ int sev_dbhdf5::get_objectitemattributes( pwr_tStatus *sts, sev_item *item, char ...@@ -4495,7 +4495,7 @@ int sev_dbhdf5::get_objectitemattributes( pwr_tStatus *sts, sev_item *item, char
return 1; return 1;
} }
int sev_dbhdf5::delete_old_objectdata( pwr_tStatus *sts, char *tablename, int sev_dbhdf5::delete_old_objectdata( pwr_tStatus *sts, void *thread, char *tablename,
pwr_tMask options, pwr_tTime limit, pwr_tFloat32 scantime, pwr_tFloat32 garbagecycle) pwr_tMask options, pwr_tTime limit, pwr_tFloat32 scantime, pwr_tFloat32 garbagecycle)
{ {
return 1; return 1;
...@@ -4569,7 +4569,7 @@ int sev_dbhdf5::check_deadband(pwr_eType type, unsigned int size, pwr_tFloat32 d ...@@ -4569,7 +4569,7 @@ int sev_dbhdf5::check_deadband(pwr_eType type, unsigned int size, pwr_tFloat32 d
return deadband_active; return deadband_active;
} }
int sev_dbhdf5::get_objectvalues( pwr_tStatus *sts, sev_item *item, int sev_dbhdf5::get_objectvalues( pwr_tStatus *sts, void *thread, sev_item *item,
unsigned int size, pwr_tTime *starttime, pwr_tTime *endtime, unsigned int size, pwr_tTime *starttime, pwr_tTime *endtime,
int maxsize, pwr_tTime **tbuf, void **vbuf, unsigned int *bsize) int maxsize, pwr_tTime **tbuf, void **vbuf, unsigned int *bsize)
{ {
......
...@@ -779,11 +779,11 @@ class sev_dbhdf5 : public sev_db { ...@@ -779,11 +779,11 @@ class sev_dbhdf5 : public sev_db {
pwr_tFloat32 deadband, pwr_tMask options, unsigned int *idx); pwr_tFloat32 deadband, pwr_tMask options, unsigned int *idx);
int store_value( pwr_tStatus *sts, void *thread, int item_idx, int attr_idx, int store_value( pwr_tStatus *sts, void *thread, int item_idx, int attr_idx,
pwr_tTime time, void *buf, unsigned int size); pwr_tTime time, void *buf, unsigned int size);
int get_values( pwr_tStatus *sts, pwr_tOid oid, pwr_tMask options, float deadband, char *aname, int get_values( pwr_tStatus *sts, void *thread, pwr_tOid oid, pwr_tMask options, float deadband,
pwr_eType type, unsigned int size, pwr_tFloat32 scantime, pwr_tTime *creatime, char *aname, pwr_eType type, unsigned int size, pwr_tFloat32 scantime,
pwr_tTime *starttime, pwr_tTime *creatime, pwr_tTime *starttime,
pwr_tTime *endtime, int maxsize, pwr_tTime **tbuf, void **vbuf, unsigned int *bsize); pwr_tTime *endtime, int maxsize, pwr_tTime **tbuf, void **vbuf, unsigned int *bsize);
int delete_old_data( pwr_tStatus *sts, char *tablename, int delete_old_data( pwr_tStatus *sts, void *thread, char *tablename,
pwr_tMask options, pwr_tTime limit, pwr_tFloat32 scantime, pwr_tFloat32 garbagecycle); pwr_tMask options, pwr_tTime limit, pwr_tFloat32 scantime, pwr_tFloat32 garbagecycle);
int delete_item( pwr_tStatus *sts, pwr_tOid oid, char *aname); int delete_item( pwr_tStatus *sts, pwr_tOid oid, char *aname);
...@@ -822,11 +822,12 @@ class sev_dbhdf5 : public sev_db { ...@@ -822,11 +822,12 @@ class sev_dbhdf5 : public sev_db {
int get_objectitemattributes( pwr_tStatus *sts, sev_item *item, char *tablename); int get_objectitemattributes( pwr_tStatus *sts, sev_item *item, char *tablename);
int check_objectitemattr( pwr_tStatus *sts, char *tablename, pwr_tOid oid, char *aname, char *oname, int check_objectitemattr( pwr_tStatus *sts, char *tablename, pwr_tOid oid, char *aname, char *oname,
pwr_eType type, unsigned int size, unsigned int *idx); pwr_eType type, unsigned int size, unsigned int *idx);
int delete_old_objectdata( pwr_tStatus *sts, char *tablename, int delete_old_objectdata( pwr_tStatus *sts, void *thread, char *tablename,
pwr_tMask options, pwr_tTime limit, pwr_tFloat32 scantime, pwr_tFloat32 garbagecycle); pwr_tMask options, pwr_tTime limit, pwr_tFloat32 scantime, pwr_tFloat32 garbagecycle);
int check_deadband(pwr_eType type, unsigned int size, pwr_tFloat32 deadband, void *value, void *oldvalue); int check_deadband(pwr_eType type, unsigned int size, pwr_tFloat32 deadband, void *value, void *oldvalue);
int get_objectvalues( pwr_tStatus *sts, sev_item *item, unsigned int size, pwr_tTime *starttime, pwr_tTime *endtime, int get_objectvalues( pwr_tStatus *sts, void *thread, sev_item *item, unsigned int size,
int maxsize, pwr_tTime **tbuf, void **vbuf, unsigned int *bsize); pwr_tTime *starttime, pwr_tTime *endtime,
int maxsize, pwr_tTime **tbuf, void **vbuf, unsigned int *bsize);
int delete_event_table( pwr_tStatus *sts, char *tablename); int delete_event_table( pwr_tStatus *sts, char *tablename);
int create_event_table( pwr_tStatus *sts, char *tablename, pwr_tMask options, int create_event_table( pwr_tStatus *sts, char *tablename, pwr_tMask options,
......
This diff is collapsed.
...@@ -92,6 +92,7 @@ class sev_dbms_env ...@@ -92,6 +92,7 @@ class sev_dbms_env
MYSQL *createDb(void); MYSQL *createDb(void);
MYSQL *openDb(unsigned int *sts); MYSQL *openDb(unsigned int *sts);
MYSQL *open_thread( unsigned int *sts); MYSQL *open_thread( unsigned int *sts);
void close_thread( MYSQL *con);
bool exists() { return m_exists;} bool exists() { return m_exists;}
int close(void); int close(void);
static int get_systemname(); static int get_systemname();
...@@ -143,11 +144,11 @@ class sev_dbms : public sev_db { ...@@ -143,11 +144,11 @@ class sev_dbms : public sev_db {
pwr_tTime time, void *buf, unsigned int size); pwr_tTime time, void *buf, unsigned int size);
int write_value( pwr_tStatus *sts, int item_idx, int attr_idx, int write_value( pwr_tStatus *sts, int item_idx, int attr_idx,
pwr_tTime time, void *buf, unsigned int size, void *thread); pwr_tTime time, void *buf, unsigned int size, void *thread);
int get_values( pwr_tStatus *sts, pwr_tOid oid, pwr_tMask options, float deadband, char *aname, int get_values( pwr_tStatus *sts, void *thread, pwr_tOid oid, pwr_tMask options, float deadband,
pwr_eType type, unsigned int size, pwr_tFloat32 scantime, pwr_tTime *creatime, char *aname, pwr_eType type, unsigned int size, pwr_tFloat32 scantime,
pwr_tTime *starttime, pwr_tTime *creatime, pwr_tTime *starttime,
pwr_tTime *endtime, int maxsize, pwr_tTime **tbuf, void **vbuf, unsigned int *bsize); pwr_tTime *endtime, int maxsize, pwr_tTime **tbuf, void **vbuf, unsigned int *bsize);
int delete_old_data( pwr_tStatus *sts, char *tablename, int delete_old_data( pwr_tStatus *sts, void *thread, char *tablename,
pwr_tMask options, pwr_tTime limit, pwr_tFloat32 scantime, pwr_tFloat32 garbagecycle); pwr_tMask options, pwr_tTime limit, pwr_tFloat32 scantime, pwr_tFloat32 garbagecycle);
int delete_item( pwr_tStatus *sts, pwr_tOid oid, char *aname); int delete_item( pwr_tStatus *sts, pwr_tOid oid, char *aname);
...@@ -188,11 +189,12 @@ class sev_dbms : public sev_db { ...@@ -188,11 +189,12 @@ class sev_dbms : public sev_db {
int get_objectitemattributes( pwr_tStatus *sts, sev_item *item, char *tablename); int get_objectitemattributes( pwr_tStatus *sts, sev_item *item, char *tablename);
int check_objectitemattr( pwr_tStatus *sts, char *tablename, pwr_tOid oid, char *aname, char *oname, int check_objectitemattr( pwr_tStatus *sts, char *tablename, pwr_tOid oid, char *aname, char *oname,
pwr_eType type, unsigned int size, unsigned int *idx); pwr_eType type, unsigned int size, unsigned int *idx);
int delete_old_objectdata( pwr_tStatus *sts, char *tablename, int delete_old_objectdata( pwr_tStatus *sts, void *thread, char *tablename,
pwr_tMask options, pwr_tTime limit, pwr_tFloat32 scantime, pwr_tFloat32 garbagecycle); pwr_tMask options, pwr_tTime limit, pwr_tFloat32 scantime, pwr_tFloat32 garbagecycle);
int check_deadband(pwr_eType type, unsigned int size, pwr_tFloat32 deadband, void *value, void *oldvalue); int check_deadband(pwr_eType type, unsigned int size, pwr_tFloat32 deadband, void *value, void *oldvalue);
int get_objectvalues( pwr_tStatus *sts, sev_item *item, unsigned int size, pwr_tTime *starttime, pwr_tTime *endtime, int get_objectvalues( pwr_tStatus *sts, void *thread, sev_item *item, unsigned int size,
int maxsize, pwr_tTime **tbuf, void **vbuf, unsigned int *bsize); pwr_tTime *starttime, pwr_tTime *endtime,
int maxsize, pwr_tTime **tbuf, void **vbuf, unsigned int *bsize);
int delete_event_table( pwr_tStatus *sts, char *tablename); int delete_event_table( pwr_tStatus *sts, char *tablename);
int create_event_table( pwr_tStatus *sts, char *tablename, pwr_tMask options); int create_event_table( pwr_tStatus *sts, char *tablename, pwr_tMask options);
int store_event( pwr_tStatus *sts, int item_idx, sev_event *ep); int store_event( pwr_tStatus *sts, int item_idx, sev_event *ep);
...@@ -209,11 +211,12 @@ class sev_dbms : public sev_db { ...@@ -209,11 +211,12 @@ class sev_dbms : public sev_db {
int begin_transaction( void *thread); int begin_transaction( void *thread);
int commit_transaction( void *thread); int commit_transaction( void *thread);
void *new_thread(); void *new_thread();
int get_closest_time( char *tablename, unsigned int options, pwr_tTime *time, int before, void delete_thread( void *thread);
unsigned int *id); int get_closest_time( void *thread, char *tablename, unsigned int options, pwr_tTime *time,
int before, unsigned int *id);
void string_to_mysqlstring( char *in, char *out, int size); void string_to_mysqlstring( char *in, char *out, int size);
void mysqlstring_to_string( char *in, char *out, int size); void mysqlstring_to_string( char *in, char *out, int size);
int get_id_range( pwr_tStatus *sts, sev_item *item, int get_id_range( pwr_tStatus *sts, void *thread, sev_item *item,
pwr_tMask options, unsigned int *first, unsigned int *last); pwr_tMask options, unsigned int *first, unsigned int *last);
int get_time_range( pwr_tStatus *sts, sev_item *item, int get_time_range( pwr_tStatus *sts, sev_item *item,
pwr_tMask options, pwr_tTime *first, pwr_tTime *last); pwr_tMask options, pwr_tTime *first, pwr_tTime *last);
......
...@@ -1009,11 +1009,11 @@ int sev_dbsqlite::store_value( pwr_tStatus *sts, void *thread, int item_idx, int ...@@ -1009,11 +1009,11 @@ int sev_dbsqlite::store_value( pwr_tStatus *sts, void *thread, int item_idx, int
return 1; return 1;
} }
int sev_dbsqlite::get_values( pwr_tStatus *sts, pwr_tOid oid, pwr_tMask options, float deadband, int sev_dbsqlite::get_values( pwr_tStatus *sts, void *thread, pwr_tOid oid, pwr_tMask options,
char *aname, pwr_eType type, float deadband, char *aname, pwr_eType type,
unsigned int size, pwr_tFloat32 scantime, pwr_tTime *creatime, unsigned int size, pwr_tFloat32 scantime, pwr_tTime *creatime,
pwr_tTime *starttime, pwr_tTime *endtime, pwr_tTime *starttime, pwr_tTime *endtime,
int maxsize, pwr_tTime **tbuf, void **vbuf, unsigned int *bsize) int maxsize, pwr_tTime **tbuf, void **vbuf, unsigned int *bsize)
{ {
sev_item item; sev_item item;
get_item(sts, &item, oid, aname); get_item(sts, &item, oid, aname);
...@@ -1685,7 +1685,7 @@ int sev_dbsqlite::delete_item( pwr_tStatus *sts, pwr_tOid oid, char *aname) ...@@ -1685,7 +1685,7 @@ int sev_dbsqlite::delete_item( pwr_tStatus *sts, pwr_tOid oid, char *aname)
return 1; return 1;
} }
int sev_dbsqlite::delete_old_data( pwr_tStatus *sts, char *tablename, int sev_dbsqlite::delete_old_data( pwr_tStatus *sts, void *thread, char *tablename,
pwr_tMask options, pwr_tTime limit, pwr_tFloat32 scantime, pwr_tFloat32 garbagecycle) pwr_tMask options, pwr_tTime limit, pwr_tFloat32 scantime, pwr_tFloat32 garbagecycle)
{ {
char query[300]; char query[300];
...@@ -2585,7 +2585,7 @@ int sev_dbsqlite::get_objectitemattributes( pwr_tStatus *sts, sev_item *item, ch ...@@ -2585,7 +2585,7 @@ int sev_dbsqlite::get_objectitemattributes( pwr_tStatus *sts, sev_item *item, ch
return 1; return 1;
} }
int sev_dbsqlite::delete_old_objectdata( pwr_tStatus *sts, char *tablename, int sev_dbsqlite::delete_old_objectdata( pwr_tStatus *sts, void *thread, char *tablename,
pwr_tMask options, pwr_tTime limit, pwr_tFloat32 scantime, pwr_tFloat32 garbagecycle) pwr_tMask options, pwr_tTime limit, pwr_tFloat32 scantime, pwr_tFloat32 garbagecycle)
{ {
char query[300]; char query[300];
...@@ -2702,7 +2702,7 @@ int sev_dbsqlite::check_deadband(pwr_eType type, unsigned int size, pwr_tFloat32 ...@@ -2702,7 +2702,7 @@ int sev_dbsqlite::check_deadband(pwr_eType type, unsigned int size, pwr_tFloat32
return deadband_active; return deadband_active;
} }
int sev_dbsqlite::get_objectvalues( pwr_tStatus *sts, sev_item *item, int sev_dbsqlite::get_objectvalues( pwr_tStatus *sts, void *thread, sev_item *item,
unsigned int size, pwr_tTime *starttime, pwr_tTime *endtime, unsigned int size, pwr_tTime *starttime, pwr_tTime *endtime,
int maxsize, pwr_tTime **tbuf, void **vbuf, unsigned int *bsize) int maxsize, pwr_tTime **tbuf, void **vbuf, unsigned int *bsize)
{ {
......
...@@ -77,11 +77,11 @@ class sev_dbsqlite : public sev_db { ...@@ -77,11 +77,11 @@ class sev_dbsqlite : public sev_db {
pwr_tFloat32 deadband, pwr_tMask options, unsigned int *idx); pwr_tFloat32 deadband, pwr_tMask options, unsigned int *idx);
int store_value( pwr_tStatus *sts, void *thread, int item_idx, int attr_idx, int store_value( pwr_tStatus *sts, void *thread, int item_idx, int attr_idx,
pwr_tTime time, void *buf, unsigned int size); pwr_tTime time, void *buf, unsigned int size);
int get_values( pwr_tStatus *sts, pwr_tOid oid, pwr_tMask options, float deadband, char *aname, int get_values( pwr_tStatus *sts, void *thread, pwr_tOid oid, pwr_tMask options, float deadband,
pwr_eType type, unsigned int size, pwr_tFloat32 scantime, pwr_tTime *creatime, char *aname, pwr_eType type, unsigned int size, pwr_tFloat32 scantime,
pwr_tTime *starttime, pwr_tTime *creatime, pwr_tTime *starttime,
pwr_tTime *endtime, int maxsize, pwr_tTime **tbuf, void **vbuf, unsigned int *bsize); pwr_tTime *endtime, int maxsize, pwr_tTime **tbuf, void **vbuf, unsigned int *bsize);
int delete_old_data( pwr_tStatus *sts, char *tablename, int delete_old_data( pwr_tStatus *sts, void *thread, char *tablename,
pwr_tMask options, pwr_tTime limit, pwr_tFloat32 scantime, pwr_tFloat32 garbagecycle); pwr_tMask options, pwr_tTime limit, pwr_tFloat32 scantime, pwr_tFloat32 garbagecycle);
int delete_item( pwr_tStatus *sts, pwr_tOid oid, char *aname); int delete_item( pwr_tStatus *sts, pwr_tOid oid, char *aname);
...@@ -121,11 +121,12 @@ class sev_dbsqlite : public sev_db { ...@@ -121,11 +121,12 @@ class sev_dbsqlite : public sev_db {
int get_objectitemattributes( pwr_tStatus *sts, sev_item *item, char *tablename); int get_objectitemattributes( pwr_tStatus *sts, sev_item *item, char *tablename);
int check_objectitemattr( pwr_tStatus *sts, char *tablename, pwr_tOid oid, char *aname, char *oname, int check_objectitemattr( pwr_tStatus *sts, char *tablename, pwr_tOid oid, char *aname, char *oname,
pwr_eType type, unsigned int size, unsigned int *idx); pwr_eType type, unsigned int size, unsigned int *idx);
int delete_old_objectdata( pwr_tStatus *sts, char *tablename, int delete_old_objectdata( pwr_tStatus *sts, void *thread, char *tablename,
pwr_tMask options, pwr_tTime limit, pwr_tFloat32 scantime, pwr_tFloat32 garbagecycle); pwr_tMask options, pwr_tTime limit, pwr_tFloat32 scantime, pwr_tFloat32 garbagecycle);
int check_deadband(pwr_eType type, unsigned int size, pwr_tFloat32 deadband, void *value, void *oldvalue); int check_deadband(pwr_eType type, unsigned int size, pwr_tFloat32 deadband, void *value, void *oldvalue);
int get_objectvalues( pwr_tStatus *sts, sev_item *item, unsigned int size, pwr_tTime *starttime, pwr_tTime *endtime, int get_objectvalues( pwr_tStatus *sts, void *thread, sev_item *item, unsigned int size,
int maxsize, pwr_tTime **tbuf, void **vbuf, unsigned int *bsize); pwr_tTime *starttime, pwr_tTime *endtime,
int maxsize, pwr_tTime **tbuf, void **vbuf, unsigned int *bsize);
int delete_event_table( pwr_tStatus *sts, char *tablename); int delete_event_table( pwr_tStatus *sts, char *tablename);
int create_event_table( pwr_tStatus *sts, char *tablename, pwr_tMask options); int create_event_table( pwr_tStatus *sts, char *tablename, pwr_tMask options);
int store_event( pwr_tStatus *sts, int item_idx, sev_event *ep); int store_event( pwr_tStatus *sts, int item_idx, sev_event *ep);
......
...@@ -44,6 +44,7 @@ ...@@ -44,6 +44,7 @@
#include "rt_gdh.h" #include "rt_gdh.h"
#include "pwr_baseclasses.h" #include "pwr_baseclasses.h"
#include "sev_valuecache.h" #include "sev_valuecache.h"
#include "rt_sev_msg.h"
const int sev_valuecache_double::m_size = VALUECACHE_SIZE; const int sev_valuecache_double::m_size = VALUECACHE_SIZE;
...@@ -110,15 +111,17 @@ void sev_valuecache_double::add( void *value, pwr_tTime *t, void *thread) ...@@ -110,15 +111,17 @@ void sev_valuecache_double::add( void *value, pwr_tTime *t, void *thread)
calculate_epsilon(0); calculate_epsilon(0);
} }
void sev_valuecache_double::evaluate( double maxtime, void *thread) int sev_valuecache_double::evaluate( double maxtime, void *thread)
{ {
int value_added = 1; int value_added = 1;
int sts = SEV__NOWRITE;
while( 1) { while( 1) {
if ( (maxtime != 0 && (m_val[m_last].time - m_wval.time) > maxtime) || if ( (maxtime != 0 && (m_val[m_last].time - m_wval.time) > maxtime) ||
!check_deadband()) { !check_deadband()) {
// Store optimal value // Store optimal value
write( m_last_opt_write + value_added, thread); write( m_last_opt_write + value_added, thread);
sts = SEV__SUCCESS;
} }
else else
break; break;
...@@ -128,6 +131,7 @@ void sev_valuecache_double::evaluate( double maxtime, void *thread) ...@@ -128,6 +131,7 @@ void sev_valuecache_double::evaluate( double maxtime, void *thread)
m_last_opt_write = get_optimal_write(); m_last_opt_write = get_optimal_write();
value_added = 0; value_added = 0;
} }
return sts;
} }
void sev_valuecache_double::calculate_k() void sev_valuecache_double::calculate_k()
...@@ -286,11 +290,14 @@ void sev_valuecache_bool::add( void *value, pwr_tTime *t, void *thread) ...@@ -286,11 +290,14 @@ void sev_valuecache_bool::add( void *value, pwr_tTime *t, void *thread)
} }
} }
void sev_valuecache_bool::evaluate( double maxtime, void *thread) int sev_valuecache_bool::evaluate( double maxtime, void *thread)
{ {
if ( m_val.val != m_wval.val) { if ( m_val.val != m_wval.val) {
write(0, thread); write(0, thread);
return SEV__SUCCESS;
} }
return SEV__NOWRITE;
} }
void sev_valuecache_bool::write( int index, void *thread) void sev_valuecache_bool::write( int index, void *thread)
......
...@@ -39,6 +39,7 @@ ...@@ -39,6 +39,7 @@
#include "pwr.h" #include "pwr.h"
#include "co_time.h" #include "co_time.h"
#include "rt_sev_msg.h"
typedef enum { typedef enum {
sev_eCvType_Point, sev_eCvType_Point,
...@@ -69,9 +70,9 @@ class sev_valuecache { ...@@ -69,9 +70,9 @@ class sev_valuecache {
sev_valuecache( const sev_valuecache& x) : m_type(x.m_type), m_userdata(x.m_userdata), m_useridx(x.m_useridx), sev_valuecache( const sev_valuecache& x) : m_type(x.m_type), m_userdata(x.m_userdata), m_useridx(x.m_useridx),
m_write_cb(x.m_write_cb) {} m_write_cb(x.m_write_cb) {}
virtual ~sev_valuecache() {}; virtual ~sev_valuecache() {};
virtual void add( void *value, pwr_tTime *time, void *thread) {}; virtual void add( void *value, pwr_tTime *time, void *thread) {}
virtual void evaluate( double maxtime, void *thread) {}; virtual int evaluate( double maxtime, void *thread) { return SEV__NOWRITE;}
virtual void write( int index, void *thread) {}; virtual void write( int index, void *thread) {}
virtual void set_write_cb( void (*write_cb)( void *, int, void *, pwr_tTime *, void *), void *userdata, int idx) { virtual void set_write_cb( void (*write_cb)( void *, int, void *, pwr_tTime *, void *), void *userdata, int idx) {
m_write_cb = write_cb; m_write_cb = write_cb;
m_userdata = userdata; m_userdata = userdata;
...@@ -118,7 +119,7 @@ class sev_valuecache_double : public sev_valuecache { ...@@ -118,7 +119,7 @@ class sev_valuecache_double : public sev_valuecache {
sev_sCacheValueDouble& operator[]( const int index); sev_sCacheValueDouble& operator[]( const int index);
sev_sCacheValueDouble& wval() { return m_wval;} sev_sCacheValueDouble& wval() { return m_wval;}
void add( void *value, pwr_tTime *time, void *thread); void add( void *value, pwr_tTime *time, void *thread);
void evaluate( double maxtime, void *thread); int evaluate( double maxtime, void *thread);
void calculate_k(); void calculate_k();
void write( int index, void *thread); void write( int index, void *thread);
void calculate_epsilon(); void calculate_epsilon();
...@@ -147,7 +148,7 @@ class sev_valuecache_bool : public sev_valuecache { ...@@ -147,7 +148,7 @@ class sev_valuecache_bool : public sev_valuecache {
~sev_valuecache_bool() {} ~sev_valuecache_bool() {}
sev_sCacheValueBool& wval() { return m_wval;} sev_sCacheValueBool& wval() { return m_wval;}
void add( void *value, pwr_tTime *time, void *thread); void add( void *value, pwr_tTime *time, void *thread);
void evaluate( double maxtime, void *thread); int evaluate( double maxtime, void *thread);
void write( int index, void *thread); void write( int index, void *thread);
}; };
......
...@@ -55,6 +55,7 @@ range <Unable to get range> /error ...@@ -55,6 +55,7 @@ range <Unable to get range> /error
unknowntype <Unknown data type> /error unknowntype <Unknown data type> /error
nosuchtable <Table doesn't exist> /error nosuchtable <Table doesn't exist> /error
norows <No rows found> /error norows <No rows found> /error
nowrite <Nothings written> /info
.end .end
......
...@@ -54,9 +54,19 @@ SObject pwrb:Class ...@@ -54,9 +54,19 @@ SObject pwrb:Class
Attr StructName = "SevServerThread" Attr StructName = "SevServerThread"
EndBody EndBody
!/** !/**
! Occupied.
!*/
Object Occupied $Attribute 1
Body SysBody
Attr TypeRef = "pwrs:Type-$Boolean"
Attr Flags |= PWR_MASK_NOEDIT
Attr Flags |= PWR_MASK_STATE
EndBody
EndObject
!/**
! Thread key. ! Thread key.
!*/ !*/
Object Key $Attribute 1 Object Key $Attribute 2
Body SysBody Body SysBody
Attr TypeRef = "pwrs:Type-$UInt32" Attr TypeRef = "pwrs:Type-$UInt32"
Attr Flags |= PWR_MASK_NOEDIT Attr Flags |= PWR_MASK_NOEDIT
...@@ -66,7 +76,7 @@ SObject pwrb:Class ...@@ -66,7 +76,7 @@ SObject pwrb:Class
!/** !/**
! Allocated size in thread queue. ! Allocated size in thread queue.
!*/ !*/
Object QueueAlloc $Attribute 2 Object QueueAlloc $Attribute 3
Body SysBody Body SysBody
Attr TypeRef = "pwrs:Type-$UInt32" Attr TypeRef = "pwrs:Type-$UInt32"
Attr Flags |= PWR_MASK_NOEDIT Attr Flags |= PWR_MASK_NOEDIT
...@@ -76,7 +86,7 @@ SObject pwrb:Class ...@@ -76,7 +86,7 @@ SObject pwrb:Class
!/** !/**
! Lost messages. ! Lost messages.
!*/ !*/
Object LostCnt $Attribute 3 Object LostCnt $Attribute 4
Body SysBody Body SysBody
Attr TypeRef = "pwrs:Type-$UInt32" Attr TypeRef = "pwrs:Type-$UInt32"
Attr Flags |= PWR_MASK_NOEDIT Attr Flags |= PWR_MASK_NOEDIT
...@@ -86,7 +96,7 @@ SObject pwrb:Class ...@@ -86,7 +96,7 @@ SObject pwrb:Class
!/** !/**
! Medium load in percentage. ! Medium load in percentage.
!*/ !*/
Object MediumLoad $Attribute 4 Object MediumLoad $Attribute 5
Body SysBody Body SysBody
Attr TypeRef = "pwrs:Type-$Float32" Attr TypeRef = "pwrs:Type-$Float32"
Attr Flags |= PWR_MASK_NOEDIT Attr Flags |= PWR_MASK_NOEDIT
...@@ -96,7 +106,7 @@ SObject pwrb:Class ...@@ -96,7 +106,7 @@ SObject pwrb:Class
!/** !/**
! Storage rate. Values per second. ! Storage rate. Values per second.
!*/ !*/
Object StorageRate $Attribute 5 Object StorageRate $Attribute 6
Body SysBody Body SysBody
Attr TypeRef = "pwrs:Type-$Float32" Attr TypeRef = "pwrs:Type-$Float32"
Attr Flags |= PWR_MASK_NOEDIT Attr Flags |= PWR_MASK_NOEDIT
...@@ -106,7 +116,37 @@ SObject pwrb:Class ...@@ -106,7 +116,37 @@ SObject pwrb:Class
!/** !/**
! Medium storage rate. Values per second. ! Medium storage rate. Values per second.
!*/ !*/
Object MediumStorageRate $Attribute 6 Object MediumStorageRate $Attribute 7
Body SysBody
Attr TypeRef = "pwrs:Type-$Float32"
Attr Flags |= PWR_MASK_NOEDIT
Attr Flags |= PWR_MASK_STATE
EndBody
EndObject
!/**
! Write rate. Values per second.
!*/
Object WriteRate $Attribute 8
Body SysBody
Attr TypeRef = "pwrs:Type-$Float32"
Attr Flags |= PWR_MASK_NOEDIT
Attr Flags |= PWR_MASK_STATE
EndBody
EndObject
!/**
! Medium write rate. Values per second.
!*/
Object MediumWriteRate $Attribute 9
Body SysBody
Attr TypeRef = "pwrs:Type-$Float32"
Attr Flags |= PWR_MASK_NOEDIT
Attr Flags |= PWR_MASK_STATE
EndBody
EndObject
!/**
! Write quota in percentage.
!*/
Object WriteQuota $Attribute 10
Body SysBody Body SysBody
Attr TypeRef = "pwrs:Type-$Float32" Attr TypeRef = "pwrs:Type-$Float32"
Attr Flags |= PWR_MASK_NOEDIT Attr Flags |= PWR_MASK_NOEDIT
...@@ -116,7 +156,7 @@ SObject pwrb:Class ...@@ -116,7 +156,7 @@ SObject pwrb:Class
!/** !/**
! Data store message count. ! Data store message count.
!*/ !*/
Object DataStoreMsgCnt $Attribute 7 Object DataStoreMsgCnt $Attribute 11
Body SysBody Body SysBody
Attr TypeRef = "pwrs:Type-$UInt32" Attr TypeRef = "pwrs:Type-$UInt32"
Attr Flags |= PWR_MASK_NOEDIT Attr Flags |= PWR_MASK_NOEDIT
...@@ -126,7 +166,7 @@ SObject pwrb:Class ...@@ -126,7 +166,7 @@ SObject pwrb:Class
!/** !/**
! Event store message count. ! Event store message count.
!*/ !*/
Object EventStoreMsgCnt $Attribute 8 Object EventStoreMsgCnt $Attribute 12
Body SysBody Body SysBody
Attr TypeRef = "pwrs:Type-$UInt32" Attr TypeRef = "pwrs:Type-$UInt32"
Attr Flags |= PWR_MASK_NOEDIT Attr Flags |= PWR_MASK_NOEDIT
......
...@@ -94,9 +94,39 @@ SObject pwrb:Class ...@@ -94,9 +94,39 @@ SObject pwrb:Class
EndBody EndBody
EndObject EndObject
!/** !/**
! Write rate. Values per second.
!*/
Object WriteRate $Attribute 5
Body SysBody
Attr TypeRef = "pwrs:Type-$Float32"
Attr Flags |= PWR_MASK_NOEDIT
Attr Flags |= PWR_MASK_STATE
EndBody
EndObject
!/**
! Medium write rate. Values per second.
!*/
Object MediumWriteRate $Attribute 6
Body SysBody
Attr TypeRef = "pwrs:Type-$Float32"
Attr Flags |= PWR_MASK_NOEDIT
Attr Flags |= PWR_MASK_STATE
EndBody
EndObject
!/**
! Write quota in percentage
!*/
Object WriteQuota $Attribute 7
Body SysBody
Attr TypeRef = "pwrs:Type-$Float32"
Attr Flags |= PWR_MASK_NOEDIT
Attr Flags |= PWR_MASK_STATE
EndBody
EndObject
!/**
! Data store message count. ! Data store message count.
!*/ !*/
Object DataStoreMsgCnt $Attribute 5 Object DataStoreMsgCnt $Attribute 8
Body SysBody Body SysBody
Attr TypeRef = "pwrs:Type-$UInt32" Attr TypeRef = "pwrs:Type-$UInt32"
Attr Flags |= PWR_MASK_NOEDIT Attr Flags |= PWR_MASK_NOEDIT
...@@ -106,7 +136,7 @@ SObject pwrb:Class ...@@ -106,7 +136,7 @@ SObject pwrb:Class
!/** !/**
! Data get message count. ! Data get message count.
!*/ !*/
Object DataGetMsgCnt $Attribute 6 Object DataGetMsgCnt $Attribute 9
Body SysBody Body SysBody
Attr TypeRef = "pwrs:Type-$UInt32" Attr TypeRef = "pwrs:Type-$UInt32"
Attr Flags |= PWR_MASK_NOEDIT Attr Flags |= PWR_MASK_NOEDIT
...@@ -116,7 +146,7 @@ SObject pwrb:Class ...@@ -116,7 +146,7 @@ SObject pwrb:Class
!/** !/**
! Items message count. ! Items message count.
!*/ !*/
Object ItemsMsgCnt $Attribute 7 Object ItemsMsgCnt $Attribute 10
Body SysBody Body SysBody
Attr TypeRef = "pwrs:Type-$UInt32" Attr TypeRef = "pwrs:Type-$UInt32"
Attr Flags |= PWR_MASK_NOEDIT Attr Flags |= PWR_MASK_NOEDIT
...@@ -126,7 +156,7 @@ SObject pwrb:Class ...@@ -126,7 +156,7 @@ SObject pwrb:Class
!/** !/**
! Event store message count. ! Event store message count.
!*/ !*/
Object EventStoreMsgCnt $Attribute 8 Object EventStoreMsgCnt $Attribute 11
Body SysBody Body SysBody
Attr TypeRef = "pwrs:Type-$UInt32" Attr TypeRef = "pwrs:Type-$UInt32"
Attr Flags |= PWR_MASK_NOEDIT Attr Flags |= PWR_MASK_NOEDIT
......
...@@ -158,7 +158,7 @@ SObject pwrb:Class ...@@ -158,7 +158,7 @@ SObject pwrb:Class
Attr TypeRef = "pwrb:Class-SevServerThread" Attr TypeRef = "pwrb:Class-SevServerThread"
Attr Flags |= PWR_MASK_CLASS Attr Flags |= PWR_MASK_CLASS
Attr Flags |= PWR_MASK_ARRAY Attr Flags |= PWR_MASK_ARRAY
Attr Elements = 20 Attr Elements = 40
EndBody EndBody
EndObject EndObject
EndObject EndObject
......
This diff is collapsed.
This diff is collapsed.
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment