SR630 reduce to 8 channels and 600 second polls, change driver name
This commit is contained in:
@@ -1,16 +1,16 @@
|
||||
# Generated driver for stanford_sr630
|
||||
# Generated driver for srs_sr630
|
||||
# vim: ft=tcl tabstop=8 softtabstop=2 shiftwidth=2 nocindent smartindent
|
||||
#
|
||||
|
||||
namespace eval ::scobj::stanford_sr630 {
|
||||
namespace eval ::scobj::srs_sr630 {
|
||||
set debug_threshold 5
|
||||
}
|
||||
|
||||
proc ::scobj::stanford_sr630::debug_log {tc_root debug_level debug_string} {
|
||||
proc ::scobj::srs_sr630::debug_log {tc_root debug_level debug_string} {
|
||||
set catch_status [ catch {
|
||||
set debug_threshold [hgetpropval ${tc_root} debug_threshold]
|
||||
if {${debug_level} >= ${debug_threshold}} {
|
||||
set fd [open "../log/stanford_sr630_[basename ${tc_root}].log" "a"]
|
||||
set fd [open "../log/srs_sr630_[basename ${tc_root}].log" "a"]
|
||||
set line "[clock format [clock seconds] -format "%T"] ${debug_string}"
|
||||
puts ${fd} "${line}"
|
||||
close ${fd}
|
||||
@@ -18,17 +18,17 @@ proc ::scobj::stanford_sr630::debug_log {tc_root debug_level debug_string} {
|
||||
} catch_message ]
|
||||
}
|
||||
|
||||
proc ::scobj::stanford_sr630::sics_log {debug_level debug_string} {
|
||||
proc ::scobj::srs_sr630::sics_log {debug_level debug_string} {
|
||||
set catch_status [ catch {
|
||||
set debug_threshold ${::scobj::stanford_sr630::debug_threshold}
|
||||
set debug_threshold ${::scobj::srs_sr630::debug_threshold}
|
||||
if {${debug_level} >= ${debug_threshold}} {
|
||||
sicslog "::scobj::stanford_sr630::${debug_string}"
|
||||
sicslog "::scobj::srs_sr630::${debug_string}"
|
||||
}
|
||||
} catch_message ]
|
||||
}
|
||||
|
||||
# check function for hset change
|
||||
proc ::scobj::stanford_sr630::checkrange {tc_root} {
|
||||
proc ::scobj::srs_sr630::checkrange {tc_root} {
|
||||
set catch_status [ catch {
|
||||
debug_log ${tc_root} 1 "checkrange tc_root=${tc_root} sct=[sct] target=[sct target]"
|
||||
set setpoint [sct target]
|
||||
@@ -54,7 +54,7 @@ proc ::scobj::stanford_sr630::checkrange {tc_root} {
|
||||
}
|
||||
|
||||
# function to request the read of a parameter on a device
|
||||
proc ::scobj::stanford_sr630::fetch_id {tc_root nextState cmd_str} {
|
||||
proc ::scobj::srs_sr630::fetch_id {tc_root nextState cmd_str} {
|
||||
set catch_status [ catch {
|
||||
debug_log ${tc_root} 1 "fetch_id tc_root=${tc_root} sct=[sct] cmd=${cmd_str}"
|
||||
if { [hpropexists [sct] geterror] } {
|
||||
@@ -65,7 +65,7 @@ proc ::scobj::stanford_sr630::fetch_id {tc_root nextState cmd_str} {
|
||||
if {[hval [sct]] == "UNKNOWN"} {
|
||||
set cmd "[clock format [clock seconds] -format "DATE %m,%d,%Y;TIME %H,%M,%S;*IDN?"]"
|
||||
} else {
|
||||
set cmd "*IDN?;DATE?;TIME?"
|
||||
set cmd "*IDN?"
|
||||
}
|
||||
# fetch_id hook code ends
|
||||
if { [hpropexists [sct] geterror] } {
|
||||
@@ -82,7 +82,7 @@ proc ::scobj::stanford_sr630::fetch_id {tc_root nextState cmd_str} {
|
||||
}
|
||||
|
||||
# function to request the read of a parameter on a device
|
||||
proc ::scobj::stanford_sr630::getSensor {tc_root nextState cmd_str} {
|
||||
proc ::scobj::srs_sr630::getSensor {tc_root nextState cmd_str} {
|
||||
set catch_status [ catch {
|
||||
debug_log ${tc_root} 1 "getSensor tc_root=${tc_root} sct=[sct] cmd=${cmd_str}"
|
||||
if { [hpropexists [sct] geterror] } {
|
||||
@@ -106,7 +106,7 @@ proc ::scobj::stanford_sr630::getSensor {tc_root nextState cmd_str} {
|
||||
}
|
||||
|
||||
# function to check the write parameter on a device
|
||||
proc ::scobj::stanford_sr630::noResponse {tc_root} {
|
||||
proc ::scobj::srs_sr630::noResponse {tc_root} {
|
||||
set catch_status [ catch {
|
||||
debug_log ${tc_root} 1 "noResponse tc_root=${tc_root} sct=[sct] resp=[sct result]"
|
||||
# noResponse hook code goes here
|
||||
@@ -116,7 +116,7 @@ proc ::scobj::stanford_sr630::noResponse {tc_root} {
|
||||
}
|
||||
|
||||
# function to parse the read of a parameter on a device
|
||||
proc ::scobj::stanford_sr630::readSensor {tc_root} {
|
||||
proc ::scobj::srs_sr630::readSensor {tc_root} {
|
||||
set catch_status [ catch {
|
||||
debug_log ${tc_root} 1 "readSensor tc_root=${tc_root} sct=[sct] result=[sct result]"
|
||||
if { [hpropexists [sct] geterror] } {
|
||||
@@ -142,7 +142,7 @@ proc ::scobj::stanford_sr630::readSensor {tc_root} {
|
||||
}
|
||||
|
||||
# function to parse the read of a parameter on a device
|
||||
proc ::scobj::stanford_sr630::read_id {tc_root} {
|
||||
proc ::scobj::srs_sr630::read_id {tc_root} {
|
||||
set catch_status [ catch {
|
||||
debug_log ${tc_root} 1 "read_id tc_root=${tc_root} sct=[sct] result=[sct result]"
|
||||
if { [hpropexists [sct] geterror] } {
|
||||
@@ -168,7 +168,7 @@ proc ::scobj::stanford_sr630::read_id {tc_root} {
|
||||
}
|
||||
|
||||
# function to write a parameter value on a device
|
||||
proc ::scobj::stanford_sr630::setValue {tc_root nextState cmd_str} {
|
||||
proc ::scobj::srs_sr630::setValue {tc_root nextState cmd_str} {
|
||||
set catch_status [ catch {
|
||||
debug_log ${tc_root} 1 "setValue tc_root=${tc_root} sct=[sct] cmd=${cmd_str}"
|
||||
if { [hpropexists [sct] geterror] } {
|
||||
@@ -191,8 +191,8 @@ proc ::scobj::stanford_sr630::setValue {tc_root nextState cmd_str} {
|
||||
handle_exception ${catch_status} ${catch_message}
|
||||
}
|
||||
|
||||
proc ::scobj::stanford_sr630::mkDriver { sct_controller name ip_address tcp_port } {
|
||||
::scobj::stanford_sr630::sics_log 9 "::scobj::stanford_sr630::mkDriver ${sct_controller} ${name} ${ip_address} ${tcp_port}"
|
||||
proc ::scobj::srs_sr630::mkDriver { sct_controller name ip_address tcp_port } {
|
||||
::scobj::srs_sr630::sics_log 9 "::scobj::srs_sr630::mkDriver ${sct_controller} ${name} ${ip_address} ${tcp_port}"
|
||||
set ns "[namespace current]"
|
||||
set catch_status [ catch {
|
||||
|
||||
@@ -321,50 +321,22 @@ proc ::scobj::stanford_sr630::mkDriver { sct_controller name ip_address tcp_port
|
||||
hsetprop ${scobj_hpath}/sensor_08 type "part"
|
||||
hsetprop ${scobj_hpath}/sensor_08 nxalias "${name}_sensor_08"
|
||||
|
||||
hfactory ${scobj_hpath}/sensor_09 plain user float
|
||||
hsetprop ${scobj_hpath}/sensor_09 read ${ns}::getSensor ${scobj_hpath} readSensor {9}
|
||||
hsetprop ${scobj_hpath}/sensor_09 readSensor ${ns}::readSensor ${scobj_hpath}
|
||||
hsetprop ${scobj_hpath}/sensor_09 control true
|
||||
hsetprop ${scobj_hpath}/sensor_09 data true
|
||||
hsetprop ${scobj_hpath}/sensor_09 mutable true
|
||||
hsetprop ${scobj_hpath}/sensor_09 nxsave true
|
||||
hsetprop ${scobj_hpath}/sensor_09 oldval 0.0
|
||||
hsetprop ${scobj_hpath}/sensor_09 klass "parameter"
|
||||
hsetprop ${scobj_hpath}/sensor_09 sdsinfo "::nexus::scobj::sdsinfo"
|
||||
hsetprop ${scobj_hpath}/sensor_09 type "part"
|
||||
hsetprop ${scobj_hpath}/sensor_09 nxalias "${name}_sensor_09"
|
||||
|
||||
hfactory ${scobj_hpath}/sensor_10 plain user float
|
||||
hsetprop ${scobj_hpath}/sensor_10 read ${ns}::getSensor ${scobj_hpath} readSensor {10}
|
||||
hsetprop ${scobj_hpath}/sensor_10 readSensor ${ns}::readSensor ${scobj_hpath}
|
||||
hsetprop ${scobj_hpath}/sensor_10 control true
|
||||
hsetprop ${scobj_hpath}/sensor_10 data true
|
||||
hsetprop ${scobj_hpath}/sensor_10 mutable true
|
||||
hsetprop ${scobj_hpath}/sensor_10 nxsave true
|
||||
hsetprop ${scobj_hpath}/sensor_10 oldval 0.0
|
||||
hsetprop ${scobj_hpath}/sensor_10 klass "parameter"
|
||||
hsetprop ${scobj_hpath}/sensor_10 sdsinfo "::nexus::scobj::sdsinfo"
|
||||
hsetprop ${scobj_hpath}/sensor_10 type "part"
|
||||
hsetprop ${scobj_hpath}/sensor_10 nxalias "${name}_sensor_10"
|
||||
|
||||
hsetprop ${scobj_hpath} data "true"
|
||||
hsetprop ${scobj_hpath} klass "@none"
|
||||
hsetprop ${scobj_hpath} type "part"
|
||||
|
||||
if {[string equal -nocase [SplitReply [environment_simulation]] "false"]} {
|
||||
${sct_controller} poll ${scobj_hpath}/id 10
|
||||
${sct_controller} poll ${scobj_hpath}/sensor_01 1
|
||||
${sct_controller} poll ${scobj_hpath}/sensor_02 60
|
||||
${sct_controller} poll ${scobj_hpath}/sensor_03 60
|
||||
${sct_controller} poll ${scobj_hpath}/sensor_04 60
|
||||
${sct_controller} poll ${scobj_hpath}/sensor_05 60
|
||||
${sct_controller} poll ${scobj_hpath}/sensor_06 60
|
||||
${sct_controller} poll ${scobj_hpath}/sensor_07 60
|
||||
${sct_controller} poll ${scobj_hpath}/sensor_08 60
|
||||
${sct_controller} poll ${scobj_hpath}/sensor_09 60
|
||||
${sct_controller} poll ${scobj_hpath}/sensor_10 60
|
||||
${sct_controller} poll ${scobj_hpath}/id 5
|
||||
${sct_controller} poll ${scobj_hpath}/sensor_01 60
|
||||
${sct_controller} poll ${scobj_hpath}/sensor_02 5
|
||||
${sct_controller} poll ${scobj_hpath}/sensor_03 5
|
||||
${sct_controller} poll ${scobj_hpath}/sensor_04 5
|
||||
${sct_controller} poll ${scobj_hpath}/sensor_05 5
|
||||
${sct_controller} poll ${scobj_hpath}/sensor_06 5
|
||||
${sct_controller} poll ${scobj_hpath}/sensor_07 5
|
||||
${sct_controller} poll ${scobj_hpath}/sensor_08 5
|
||||
} else {
|
||||
::scobj::stanford_sr630::sics_log 9 "[environment_simulation] => No poll/write for stanford_sr630"
|
||||
::scobj::srs_sr630::sics_log 9 "[environment_simulation] => No poll/write for srs_sr630"
|
||||
}
|
||||
hsetprop ${scobj_hpath} klass environment
|
||||
hsetprop ${scobj_hpath} data true
|
||||
@@ -374,39 +346,39 @@ proc ::scobj::stanford_sr630::mkDriver { sct_controller name ip_address tcp_port
|
||||
handle_exception ${catch_status} ${catch_message}
|
||||
}
|
||||
|
||||
namespace eval ::scobj::stanford_sr630 {
|
||||
namespace eval ::scobj::srs_sr630 {
|
||||
namespace export debug_threshold
|
||||
namespace export debug_log
|
||||
namespace export sics_log
|
||||
namespace export mkDriver
|
||||
}
|
||||
|
||||
proc add_stanford_sr630 {name ip_address tcp_port} {
|
||||
proc add_srs_sr630 {name ip_address tcp_port} {
|
||||
set catch_status [ catch {
|
||||
::scobj::stanford_sr630::sics_log 9 "add_stanford_sr630 ${name} ${ip_address} ${tcp_port}"
|
||||
::scobj::srs_sr630::sics_log 9 "add_srs_sr630 ${name} ${ip_address} ${tcp_port}"
|
||||
if {[string equal -nocase [SplitReply [environment_simulation]] "false"]} {
|
||||
if {[string equal -nocase "aqadapter" "${ip_address}"]} {
|
||||
::scobj::stanford_sr630::sics_log 9 "makesctcontroller sct_${name} aqadapter ${tcp_port}"
|
||||
::scobj::srs_sr630::sics_log 9 "makesctcontroller sct_${name} aqadapter ${tcp_port}"
|
||||
makesctcontroller sct_${name} aqadapter ${tcp_port}
|
||||
} else {
|
||||
::scobj::stanford_sr630::sics_log 9 "makesctcontroller sct_${name} std ${ip_address}:${tcp_port}"
|
||||
::scobj::srs_sr630::sics_log 9 "makesctcontroller sct_${name} std ${ip_address}:${tcp_port}"
|
||||
makesctcontroller sct_${name} std ${ip_address}:${tcp_port}
|
||||
}
|
||||
} else {
|
||||
::scobj::stanford_sr630::sics_log 9 "[environment_simulation] => No sctcontroller for stanford_sr630"
|
||||
::scobj::srs_sr630::sics_log 9 "[environment_simulation] => No sctcontroller for srs_sr630"
|
||||
}
|
||||
::scobj::stanford_sr630::sics_log 1 "::scobj::stanford_sr630::mkDriver sct_${name} ${name} ${ip_address} ${tcp_port}"
|
||||
::scobj::stanford_sr630::mkDriver sct_${name} ${name} ${ip_address} ${tcp_port}
|
||||
::scobj::srs_sr630::sics_log 1 "::scobj::srs_sr630::mkDriver sct_${name} ${name} ${ip_address} ${tcp_port}"
|
||||
::scobj::srs_sr630::mkDriver sct_${name} ${name} ${ip_address} ${tcp_port}
|
||||
} catch_message ]
|
||||
handle_exception ${catch_status} ${catch_message}
|
||||
}
|
||||
|
||||
clientput "file evaluation of sct_stanford_sr630.tcl"
|
||||
::scobj::stanford_sr630::sics_log 9 "file evaluation of sct_stanford_sr630.tcl"
|
||||
clientput "file evaluation of sct_srs_sr630.tcl"
|
||||
::scobj::srs_sr630::sics_log 9 "file evaluation of sct_srs_sr630.tcl"
|
||||
|
||||
proc ::scobj::stanford_sr630::read_config {} {
|
||||
proc ::scobj::srs_sr630::read_config {} {
|
||||
set catch_status [ catch {
|
||||
set ns "::scobj::stanford_sr630"
|
||||
set ns "::scobj::srs_sr630"
|
||||
dict for {k u} $::config_dict {
|
||||
if { [dict exists $u "implementation"] } {
|
||||
if { !([dict exists $u "name"] && [dict exists $u "enabled"]) } {
|
||||
@@ -425,7 +397,7 @@ proc ::scobj::stanford_sr630::read_config {} {
|
||||
if { !([dict exists $v "driver"]) } {
|
||||
continue
|
||||
}
|
||||
if { [string equal -nocase [dict get $v "driver"] "stanford_sr630"] } {
|
||||
if { [string equal -nocase [dict get $v "driver"] "srs_sr630"] } {
|
||||
if { ![string equal -nocase [SplitReply [environment_simulation]] "false"] } {
|
||||
set asyncqueue "null"
|
||||
${ns}::sics_log 9 "[environment_simulation] => using null asyncqueue"
|
||||
@@ -455,9 +427,9 @@ proc ::scobj::stanford_sr630::read_config {} {
|
||||
}
|
||||
}
|
||||
if { [string equal -nocase ${asyncqueue} "sct"] } {
|
||||
add_stanford_sr630 ${name} ${ip_address} ${tcp_port}
|
||||
add_srs_sr630 ${name} ${ip_address} ${tcp_port}
|
||||
} else {
|
||||
add_stanford_sr630 ${name} "aqadapter" ${asyncqueue}
|
||||
add_srs_sr630 ${name} "aqadapter" ${asyncqueue}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -467,7 +439,7 @@ proc ::scobj::stanford_sr630::read_config {} {
|
||||
}
|
||||
|
||||
if { [info exists ::config_dict] } {
|
||||
::scobj::stanford_sr630::read_config
|
||||
::scobj::srs_sr630::read_config
|
||||
} else {
|
||||
::scobj::stanford_sr630::sics_log 5 "No config dict"
|
||||
::scobj::srs_sr630::sics_log 5 "No config dict"
|
||||
}
|
||||
@@ -1,6 +1,6 @@
|
||||
# Stanford Research Systems SR630 Thermocouple Monitor
|
||||
# vim: ts=8 sts=2 sw=2 expandtab nocindent autoindent smartindent
|
||||
driver stanford_sr630 = {
|
||||
driver srs_sr630 = {
|
||||
vendor = StanfordResearchSystems; device=SR630;
|
||||
protocol = std;
|
||||
class = environment;
|
||||
@@ -9,7 +9,7 @@ driver stanford_sr630 = {
|
||||
group = {
|
||||
priv = user;
|
||||
var id = {
|
||||
readable = 10;
|
||||
readable = 600;
|
||||
type = text;
|
||||
fetch_function = fetch_id;
|
||||
read_function = read_id;
|
||||
@@ -19,37 +19,27 @@ driver stanford_sr630 = {
|
||||
type = float;
|
||||
fetch_function = getSensor;
|
||||
read_function = readSensor;
|
||||
var sensor_01 = { readable = 1; read_command = "1"; }
|
||||
var sensor_02 = { readable = 60; read_command = "2"; }
|
||||
var sensor_03 = { readable = 60; read_command = "3"; }
|
||||
var sensor_04 = { readable = 60; read_command = "4"; }
|
||||
var sensor_05 = { readable = 60; read_command = "5"; }
|
||||
var sensor_06 = { readable = 60; read_command = "6"; }
|
||||
var sensor_07 = { readable = 60; read_command = "7"; }
|
||||
var sensor_08 = { readable = 60; read_command = "8"; }
|
||||
var sensor_09 = { readable = 60; read_command = "9"; }
|
||||
var sensor_10 = { readable = 60; read_command = "10"; }
|
||||
var sensor_01 = { readable = 60; read_command = "1"; }
|
||||
var sensor_02 = { readable = 600; read_command = "2"; }
|
||||
var sensor_03 = { readable = 600; read_command = "3"; }
|
||||
var sensor_04 = { readable = 600; read_command = "4"; }
|
||||
var sensor_05 = { readable = 600; read_command = "5"; }
|
||||
var sensor_06 = { readable = 600; read_command = "6"; }
|
||||
var sensor_07 = { readable = 600; read_command = "7"; }
|
||||
var sensor_08 = { readable = 600; read_command = "8"; }
|
||||
}
|
||||
code fetch_id = {
|
||||
@TCL
|
||||
code fetch_id = {%%
|
||||
if {[hval [sct]] == "UNKNOWN"} {
|
||||
set cmd "[clock format [clock seconds] -format "DATE %m,%d,%Y;TIME %H,%M,%S;*IDN?"]"
|
||||
} else {
|
||||
set cmd "*IDN?;DATE?;TIME?"
|
||||
set cmd "*IDN?"
|
||||
}
|
||||
@END
|
||||
}
|
||||
code read_id = {
|
||||
@TCL
|
||||
@END
|
||||
}
|
||||
code getSensor = {
|
||||
@TCL
|
||||
%%}
|
||||
code read_id = {%%
|
||||
%%}
|
||||
code getSensor = {%%
|
||||
set cmd "UNIT ${cmd_str},ABS;MEAS? ${cmd_str}"
|
||||
@END
|
||||
}
|
||||
code readSensor = {
|
||||
@TCL
|
||||
@END
|
||||
}
|
||||
%%}
|
||||
code readSensor = {%%
|
||||
%%}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user