Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
P
proview
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Esteban Blanc
proview
Commits
6c660180
Commit
6c660180
authored
Sep 08, 2011
by
Claes Sjofors
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Sev, triggered storage and dynamic disable function added
parent
d0f0e8a0
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
93 additions
and
41 deletions
+93
-41
src/exe/rt_sevhistmon/src/rt_sevhistmon.cpp
src/exe/rt_sevhistmon/src/rt_sevhistmon.cpp
+52
-41
src/exe/rt_sevhistmon/src/rt_sevhistmon.h
src/exe/rt_sevhistmon/src/rt_sevhistmon.h
+4
-0
src/wbl/pwrb/src/pwrb_c_sevhist.wb_load
src/wbl/pwrb/src/pwrb_c_sevhist.wb_load
+13
-0
src/wbl/pwrb/src/pwrb_c_sevhistobject.wb_load
src/wbl/pwrb/src/pwrb_c_sevhistobject.wb_load
+13
-0
src/wbl/pwrb/src/pwrb_td_sevhistoptionsmask.wb_load
src/wbl/pwrb/src/pwrb_td_sevhistoptionsmask.wb_load
+11
-0
No files found.
src/exe/rt_sevhistmon/src/rt_sevhistmon.cpp
View file @
6c660180
...
...
@@ -196,20 +196,19 @@ int rt_sevhistmon::init_objects()
ODD
(
sts
);
sts
=
gdh_GetNextAttrRef
(
pwr_cClass_SevHist
,
&
h_aref
,
&
h_aref
))
{
sev_sevhist
h
;
pwr_sClass_SevHist
*
h_p
;
int
hs_idx
;
m_sts
=
gdh_
AttrRefToPointer
(
&
h_aref
,
(
void
**
)
&
h_p
);
m_sts
=
gdh_
DLRefObjectInfoAttrref
(
&
h_aref
,
(
void
**
)
&
h
.
hsp
,
&
h
.
hs_refid
);
if
(
EVEN
(
m_sts
))
throw
co_error
(
m_sts
);
h
.
aref
=
h
_
p
->
Attribute
;
h
.
aref
=
h
.
hs
p
->
Attribute
;
m_sts
=
gdh_AttrrefToName
(
&
h_aref
,
hname
,
sizeof
(
hname
),
cdh_mName_volumeStrict
);
if
(
EVEN
(
m_sts
))
throw
co_error
(
m_sts
);
hs_idx
=
-
1
;
for
(
int
i
=
0
;
i
<
(
int
)
m_hs
.
size
();
i
++
)
{
if
(
cdh_ObjidIsEqual
(
h
_
p
->
ThreadObject
,
m_hs
[
i
].
oid
))
{
if
(
cdh_ObjidIsEqual
(
h
.
hs
p
->
ThreadObject
,
m_hs
[
i
].
oid
))
{
hs_idx
=
i
;
break
;
}
...
...
@@ -219,7 +218,7 @@ int rt_sevhistmon::init_objects()
continue
;
}
m_sts
=
gdh_GetAttributeCharAttrref
(
&
h
_
p
->
Attribute
,
&
a_tid
,
&
a_size
,
&
a_offset
,
&
a_dim
);
m_sts
=
gdh_GetAttributeCharAttrref
(
&
h
.
hs
p
->
Attribute
,
&
a_tid
,
&
a_size
,
&
a_offset
,
&
a_dim
);
if
(
EVEN
(
m_sts
))
{
errh_Error
(
"Invalid SevHist Attribute %s"
,
hname
);
continue
;
...
...
@@ -227,14 +226,14 @@ int rt_sevhistmon::init_objects()
h
.
sevid
.
nid
=
m_nodes
[
0
].
nid
;
h
.
sevid
.
rix
=
m_next_rix
++
;
h
.
storagetime
=
h
_
p
->
StorageTime
;
h
.
deadband
=
h
_
p
->
DeadBand
;
h
.
options
=
h
_
p
->
Options
;
h
.
disabled
=
h
_
p
->
Disable
;
strncpy
(
h
.
description
,
h
_
p
->
Description
,
sizeof
(
h
.
description
));
h
.
storagetime
=
h
.
hs
p
->
StorageTime
;
h
.
deadband
=
h
.
hs
p
->
DeadBand
;
h
.
options
=
h
.
hs
p
->
Options
;
h
.
disabled
=
h
.
hs
p
->
Disable
;
strncpy
(
h
.
description
,
h
.
hs
p
->
Description
,
sizeof
(
h
.
description
));
// Get unit from attribute object
sts
=
gdh_ArefANameToAref
(
&
h
_
p
->
Attribute
,
"Unit"
,
&
uaref
);
sts
=
gdh_ArefANameToAref
(
&
h
.
hs
p
->
Attribute
,
"Unit"
,
&
uaref
);
if
(
ODD
(
sts
))
{
sts
=
gdh_GetObjectInfoAttrref
(
&
uaref
,
&
h
.
unit
,
sizeof
(
h
.
unit
));
if
(
EVEN
(
sts
))
...
...
@@ -252,7 +251,7 @@ int rt_sevhistmon::init_objects()
continue
;
}
m_sts
=
gdh_AttrrefToName
(
&
h
_
p
->
Attribute
,
h
.
aname
,
sizeof
(
h
.
aname
),
cdh_mName_volumeStrict
);
m_sts
=
gdh_AttrrefToName
(
&
h
.
hs
p
->
Attribute
,
h
.
aname
,
sizeof
(
h
.
aname
),
cdh_mName_volumeStrict
);
if
(
EVEN
(
m_sts
))
throw
co_error
(
m_sts
);
m_sts
=
gdh_RefObjectInfo
(
h
.
aname
,
&
h
.
datap
,
&
h
.
refid
,
h
.
size
);
...
...
@@ -284,20 +283,19 @@ int rt_sevhistmon::init_sevhistobjects()
ODD
(
sts
);
sts
=
gdh_GetNextAttrRef
(
pwr_cClass_SevHistObject
,
&
h_aref
,
&
h_aref
))
{
sev_sevhistobject
h
;
pwr_sClass_SevHistObject
*
h_p
;
int
hs_idx
;
m_sts
=
gdh_
AttrRefToPointer
(
&
h_aref
,
(
void
**
)
&
h_p
);
m_sts
=
gdh_
DLRefObjectInfoAttrref
(
&
h_aref
,
(
void
**
)
&
h
.
hsp
,
&
h
.
hs_refid
);
if
(
EVEN
(
m_sts
))
throw
co_error
(
m_sts
);
h
.
aref
=
h
_
p
->
Object
;
h
.
aref
=
h
.
hs
p
->
Object
;
m_sts
=
gdh_AttrrefToName
(
&
h_aref
,
hname
,
sizeof
(
hname
),
cdh_mName_volumeStrict
);
if
(
EVEN
(
m_sts
))
throw
co_error
(
m_sts
);
hs_idx
=
-
1
;
for
(
int
i
=
0
;
i
<
(
int
)
m_hs
.
size
();
i
++
)
{
if
(
cdh_ObjidIsEqual
(
h
_
p
->
ThreadObject
,
m_hs
[
i
].
oid
))
{
if
(
cdh_ObjidIsEqual
(
h
.
hs
p
->
ThreadObject
,
m_hs
[
i
].
oid
))
{
hs_idx
=
i
;
break
;
}
...
...
@@ -307,17 +305,17 @@ int rt_sevhistmon::init_sevhistobjects()
continue
;
}
m_sts
=
gdh_GetAttributeCharAttrref
(
&
h
_
p
->
Object
,
&
a_tid
,
&
a_size
,
&
a_offset
,
&
a_dim
);
m_sts
=
gdh_GetAttributeCharAttrref
(
&
h
.
hs
p
->
Object
,
&
a_tid
,
&
a_size
,
&
a_offset
,
&
a_dim
);
if
(
EVEN
(
m_sts
))
{
errh_Error
(
"Invalid SevHistObject Attribute %s"
,
hname
);
continue
;
}
h
.
storagetime
=
h
_
p
->
StorageTime
;
h
.
deadband
=
h
_
p
->
DeadBand
;
h
.
options
=
h
_
p
->
Options
;
h
.
disabled
=
h
_
p
->
Disable
;
strncpy
(
h
.
description
,
h
_
p
->
Description
,
sizeof
(
h
.
description
));
h
.
storagetime
=
h
.
hs
p
->
StorageTime
;
h
.
deadband
=
h
.
hs
p
->
DeadBand
;
h
.
options
=
h
.
hs
p
->
Options
;
h
.
disabled
=
h
.
hs
p
->
Disable
;
strncpy
(
h
.
description
,
h
.
hs
p
->
Description
,
sizeof
(
h
.
description
));
h
.
scantime
=
m_hs
[
hs_idx
].
scantime
;
...
...
@@ -325,7 +323,7 @@ int rt_sevhistmon::init_sevhistobjects()
h
.
sevid
.
rix
=
m_next_rix
++
;
//Time to fetch all attributes for the object and put them into a list
m_sts
=
gdh_AttrrefToName
(
&
h
_
p
->
Object
,
hname
,
sizeof
(
hname
),
cdh_mName_volumeStrict
);
m_sts
=
gdh_AttrrefToName
(
&
h
.
hs
p
->
Object
,
hname
,
sizeof
(
hname
),
cdh_mName_volumeStrict
);
if
(
EVEN
(
m_sts
))
throw
co_error
(
m_sts
);
strcpy
(
h
.
aname
,
hname
);
get_sevhistobjectattributes
(
hname
,
&
h
.
sevhistobjectattrlist
,
hs_idx
,
true
);
...
...
@@ -580,8 +578,10 @@ bool rt_sevhistmon::correct_histtype(const pwr_eType type)
int
rt_sevhistmon
::
close_objects
()
{
for
(
unsigned
int
i
=
0
;
i
<
m_hs
.
size
();
i
++
)
{
for
(
unsigned
int
j
=
0
;
j
<
m_hs
[
i
].
sevhistlist
.
size
();
j
++
)
gdh_UnrefObjectInfo
(
m_hs
[
i
].
sevhistlist
[
j
].
refid
);
for
(
unsigned
int
j
=
0
;
j
<
m_hs
[
i
].
sevhistlist
.
size
();
j
++
)
{
gdh_UnrefObjectInfo
(
m_hs
[
i
].
sevhistlist
[
j
].
hs_refid
);
gdh_UnrefObjectInfo
(
m_hs
[
i
].
sevhistlist
[
j
].
refid
);
}
gdh_UnrefObjectInfo
(
m_hs
[
i
].
refid
);
}
m_hs
.
clear
();
...
...
@@ -637,7 +637,13 @@ int rt_sevhistmon::send_data()
dp
=
(
sev_sHistData
*
)
&
msg
->
Data
;
for
(
unsigned
int
j
=
0
;
j
<
m_hs
[
i
].
sevhistlist
.
size
();
j
++
)
{
if
(
!
m_hs
[
i
].
sevhistlist
[
j
].
disabled
)
{
if
(
!
m_hs
[
i
].
sevhistlist
[
j
].
hsp
->
Disable
)
{
if
(
m_hs
[
i
].
sevhistlist
[
j
].
hsp
->
Options
&
pwr_mSevOptionsMask_Event
&&
m_hs
[
i
].
sevhistlist
[
j
].
hsp
->
Trigger
)
m_hs
[
i
].
sevhistlist
[
j
].
hsp
->
Trigger
=
0
;
else
continue
;
dp
->
sevid
=
m_hs
[
i
].
sevhistlist
[
j
].
sevid
;
dp
->
type
=
m_hs
[
i
].
sevhistlist
[
j
].
type
;
dp
->
size
=
m_hs
[
i
].
sevhistlist
[
j
].
size
;
...
...
@@ -648,11 +654,17 @@ int rt_sevhistmon::send_data()
void
*
dpp
;
for
(
unsigned
int
j
=
0
;
j
<
m_hs
[
i
].
sevhistobjectlist
.
size
();
j
++
)
{
dp
->
sevid
=
m_hs
[
i
].
sevhistobjectlist
[
j
].
sevid
;
dp
->
size
=
m_hs
[
i
].
sevhistobjectlist
[
j
].
datasize
;
dpp
=
&
(
dp
->
data
);
for
(
unsigned
int
k
=
0
;
k
<
m_hs
[
i
].
sevhistobjectlist
[
j
].
sevhistobjectattrlist
.
size
();
k
++
)
{
if
(
!
m_hs
[
i
].
sevhistobjectlist
[
j
].
disabled
)
{
if
(
!
m_hs
[
i
].
sevhistobjectlist
[
j
].
hsp
->
Disable
)
{
if
(
m_hs
[
i
].
sevhistobjectlist
[
j
].
hsp
->
Options
&
pwr_mSevOptionsMask_Event
&&
m_hs
[
i
].
sevhistobjectlist
[
j
].
hsp
->
Trigger
)
m_hs
[
i
].
sevhistobjectlist
[
j
].
hsp
->
Trigger
=
0
;
else
continue
;
dp
->
sevid
=
m_hs
[
i
].
sevhistobjectlist
[
j
].
sevid
;
dp
->
size
=
m_hs
[
i
].
sevhistobjectlist
[
j
].
datasize
;
dpp
=
&
(
dp
->
data
);
for
(
unsigned
int
k
=
0
;
k
<
m_hs
[
i
].
sevhistobjectlist
[
j
].
sevhistobjectattrlist
.
size
();
k
++
)
{
//dp->type = m_hs[i].sevhistobjectlist[j].sevhistobjectattrlist[k].type;
//printf("sevhistobj[%d].attrlist[%d].aname: %s size:%d\n", j, k, m_hs[i].sevhistobjectlist[j].sevhistobjectattrlist[k].aname, m_hs[i].sevhistobjectlist[j].sevhistobjectattrlist[k].size);
//if( m_hs[i].sevhistobjectlist[j].sevhistobjectattrlist[k].type == pwr_eType_String ) {
...
...
@@ -661,8 +673,8 @@ int rt_sevhistmon::send_data()
memcpy
(
dpp
,
m_hs
[
i
].
sevhistobjectlist
[
j
].
sevhistobjectattrlist
[
k
].
datap
,
m_hs
[
i
].
sevhistobjectlist
[
j
].
sevhistobjectattrlist
[
k
].
size
);
dpp
=
(
sev_sHistData
*
)((
char
*
)
dpp
+
m_hs
[
i
].
sevhistobjectlist
[
j
].
sevhistobjectattrlist
[
k
].
size
);
}
dp
=
(
sev_sHistData
*
)((
char
*
)
dp
+
sizeof
(
*
dp
)
-
sizeof
(
dp
->
data
)
+
dp
->
size
);
}
dp
=
(
sev_sHistData
*
)((
char
*
)
dp
+
sizeof
(
*
dp
)
-
sizeof
(
dp
->
data
)
+
dp
->
size
);
}
tgt
.
nid
=
m_hs
[
i
].
nid
;
...
...
@@ -869,15 +881,14 @@ int rt_sevhistmon::send_itemlist( pwr_tNid nid)
for
(
unsigned
int
i
=
0
;
i
<
m_hs
.
size
();
i
++
)
{
if
(
m_hs
[
i
].
configerror
)
continue
;
if
(
nid
==
m_hs
[
i
].
nid
)
{
item_cnt
+=
m_hs
[
i
].
sevhistlist
.
size
();
attr_cnt
+=
m_hs
[
i
].
sevhistlist
.
size
();
objectitem_cnt
+=
m_hs
[
i
].
sevhistobjectlist
.
size
();
for
(
size_t
j
=
0
;
j
<
m_hs
[
i
].
sevhistobjectlist
.
size
();
j
++
)
{
attr_cnt
+=
m_hs
[
i
].
sevhistobjectlist
[
j
].
sevhistobjectattrlist
.
size
();
histobjectsize
+=
(
m_hs
[
i
].
sevhistobjectlist
[
j
].
sevhistobjectattrlist
.
size
()
*
sizeof
(
sev_sHistAttr
));
}
if
(
nid
==
m_hs
[
i
].
nid
)
{
item_cnt
+=
m_hs
[
i
].
sevhistlist
.
size
();
attr_cnt
+=
m_hs
[
i
].
sevhistlist
.
size
();
objectitem_cnt
+=
m_hs
[
i
].
sevhistobjectlist
.
size
();
for
(
size_t
j
=
0
;
j
<
m_hs
[
i
].
sevhistobjectlist
.
size
();
j
++
)
{
attr_cnt
+=
m_hs
[
i
].
sevhistobjectlist
[
j
].
sevhistobjectattrlist
.
size
();
histobjectsize
+=
(
m_hs
[
i
].
sevhistobjectlist
[
j
].
sevhistobjectattrlist
.
size
()
*
sizeof
(
sev_sHistAttr
));
}
}
}
...
...
src/exe/rt_sevhistmon/src/rt_sevhistmon.h
View file @
6c660180
...
...
@@ -46,6 +46,8 @@ class sev_sevhist {
public:
pwr_tAttrRef
aref
;
pwr_tAName
aname
;
pwr_sClass_SevHist
*
hsp
;
pwr_tRefId
hs_refid
;
pwr_tRefId
refid
;
void
*
datap
;
pwr_tDeltaTime
storagetime
;
...
...
@@ -76,6 +78,8 @@ class sev_sevhistobject {
public:
pwr_tAttrRef
aref
;
pwr_tAName
aname
;
pwr_sClass_SevHistObject
*
hsp
;
pwr_tRefId
hs_refid
;
pwr_tDeltaTime
storagetime
;
pwr_tFloat32
deadband
;
pwr_tMask
options
;
...
...
src/wbl/pwrb/src/pwrb_c_sevhist.wb_load
View file @
6c660180
...
...
@@ -138,6 +138,19 @@ SObject pwrb:Class
Attr TypeRef = "pwrs:Type-$Boolean"
EndBody
EndObject
!/**
! Trigger a storage when event controlled storage is configured.
! Trigger can be set from the application or from a process graph,
! and when it has been detected by the rt_sevhistmon process, it
! will be reset by this process.
!
! To configure even controlled storage, set Event in Options.
!*/
Object Trigger $Attribute 8
Body SysBody
Attr TypeRef = "pwrs:Type-$Boolean"
EndBody
EndObject
EndObject
Object Template SevHist
Body RtBody
...
...
src/wbl/pwrb/src/pwrb_c_sevhistobject.wb_load
View file @
6c660180
...
...
@@ -133,6 +133,19 @@ SObject pwrb:Class
Attr TypeRef = "pwrs:Type-$Boolean"
EndBody
EndObject
!/**
! Trigger a storage when event controlled storage is configured.
! Trigger can be set from the application or from a process graph,
! and when it has been detected by the rt_sevhistmon process, it
! will be reset by this process.
!
! To configure even controlled storage, set Event in Options.
!*/
Object Trigger $Attribute 8
Body SysBody
Attr TypeRef = "pwrs:Type-$Boolean"
EndBody
EndObject
EndObject
Object Template SevHistObject
Body RtBody
...
...
src/wbl/pwrb/src/pwrb_td_sevhistoptionsmask.wb_load
View file @
6c660180
...
...
@@ -115,6 +115,17 @@ SObject pwrb:Type
Attr Value = 16
EndBody
EndObject
!/**
! Event controlled storage. The attribute will only be stored
! one time when the trigger is activated.
!*/
Object Event $Bit
Body SysBody
Attr PgmName = "Event"
Attr Text = "Event"
Attr Value = 32
EndBody
EndObject
EndObject
EndSObject
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment