From b09885021826152da46dbb26750f5a509a4e2327 Mon Sep 17 00:00:00 2001 From: Jan Michel Date: Mon, 22 Jul 2024 09:29:49 +0200 Subject: [PATCH] few slow control updates, add Trb5sc ADC AddOn registers --- web/CtsPlugins/CtsMod18.pm | 2 +- web/htdocs/addons/digitizer.pl | 56 +++++++ xml-db/database/Digitizer.xml | 296 +++++++++++++++++++++++++++++++++ xml-db/database/MediaECP5.xml | 4 +- 4 files changed, 355 insertions(+), 3 deletions(-) create mode 100755 web/htdocs/addons/digitizer.pl create mode 100644 xml-db/database/Digitizer.xml diff --git a/web/CtsPlugins/CtsMod18.pm b/web/CtsPlugins/CtsMod18.pm index bdbf84f..53c9621 100644 --- a/web/CtsPlugins/CtsMod18.pm +++ b/web/CtsPlugins/CtsMod18.pm @@ -47,7 +47,7 @@ sub init { $regs->{$key}{'_defs'}{'input'}{'enum'}{$k+$chanStart} = "kel[$k]"; } - my $chanStart = 36; + $chanStart = 36; for(my $k=0; $k<9; $k++) { $regs->{$key}{'_defs'}{'input'}{'enum'}{$k*2+$chanStart} = "bkpl[$k][0]"; $regs->{$key}{'_defs'}{'input'}{'enum'}{$k*2+1+$chanStart} = "bkpl[$k][1]"; diff --git a/web/htdocs/addons/digitizer.pl b/web/htdocs/addons/digitizer.pl new file mode 100755 index 0000000..fba1e14 --- /dev/null +++ b/web/htdocs/addons/digitizer.pl @@ -0,0 +1,56 @@ +#!/usr/bin/perl +if ($ENV{'SERVER_SOFTWARE'} =~ /HTTPi/i) { + print "HTTP/1.0 200 OK\n"; + print "Content-type: text/html\r\n\r\n"; + } +else { + use lib '..'; + use if (!($ENV{'SERVER_SOFTWARE'} =~ /HTTPi/i)), apacheEnv; + print "Content-type: text/html\n\n"; + } + +use CGI ':standard'; +use XML::LibXML; +use POSIX; +use CGI::Carp qw(fatalsToBrowser); + +use lib qw|../commands htdocs/commands|; +use xmlpage; + +my $page; + +$page->{title} = "Digitizer AddOn"; +$page->{link} = "../"; + +my @setup; + +push(@setup,({name => "Input & Control", + cmd => "Digitizer-0xfd86-BasicControl&Digitizer-0xfd86-InputBuffer", + period => 1000, + address => 1})); + +push(@setup,({name => "BufferConfig", + cmd => "Digitizer-0xfd86-BufferConfig", + period => 1000, + address => 1})); + +push(@setup,({name => "BlockModeConfig", + cmd => "Digitizer-0xfd86-BlockModeConfig", + period => 1000, + address => 1})); + +push(@setup,({name => "ProcessorStatus", + cmd => "Digitizer-0xfd86-ProcessorStatus", + period => 1000, + address => 1})); + + + +xmlpage::initPage(\@setup,$page); + + + + +1; + + diff --git a/xml-db/database/Digitizer.xml b/xml-db/database/Digitizer.xml new file mode 100644 index 0000000..cd7dda1 --- /dev/null +++ b/xml-db/database/Digitizer.xml @@ -0,0 +1,296 @@ + + + Control and Status registers related to Trb5sc ADC AddOn + + + Configuration registers + + + + + + + + + + + + + + + + + + Strobe signals + + + + + + + + + Setting the input multiplexer for processors + + + + + + + + + + + + + + Input Buffer Status + + Current ADC data word + + + + Debug information for ADC A inputs + + Status of the input word align + Idle + Wait fo 0011 + + + + + + + + + + + Debug information for ADC B inputs + + + + Debug information for ADC B inputs + + + + + + Configuration of buffer handling + + Processor Config + + Number of samples to be stored in the buffer + + + Number of samples to take after reference time signal arrived + + + + + Processor Config + + How many blocks of different downsampling settings should be processed + + + Downsampling of ADC samples before storing in buffer. Make sure values can not exceed 20 Bit (18 with PSA) + + + Averaging time for baseline calculation. 2**N samples are taken. Baseline is calculated from buffer output data, triggered events are suppressed. + + + + + Settings of trigger signal generation + + Offset from the calculated baseline that must be reached to generate a trigger signal for the CTS + + + Selects positive (unset) or negative (set) signal inputs. If negative is selected, a trigger is generated if the input signal is below the baseline plus the set (negative) threshold + + + Selects positive (unset) or negative (set) signal inputs. If negative is selected, a trigger is generated if the input signal is below the baseline plus the set (negative) threshold + + + + + Processor Config + + Offset from the calculated baseline that must be reached to generate a readout from this channel. + + + Selects positive (unset) or negative (set) signal inputs. If negative is selected, a readout is generated if the input signal is below the baseline minus the set threshold + + + + + Sets a defined reset value of the baseline. If not active, baseline is resetted to 0 or MAX depending on polarity selection of trigger generation. + To fix the baseline at this value, BaselineReset + + Do not do baseline calculations, always fix to the reset value. + + + Baseline calculation is always on + + + Subtract baseline during processing of ADC values + + + Use this value as baseline if BaselineFixed is set + + + + + Processor Config + + Disable processing of ADC channel + + + Kind of data processing - e.g. block read-out, pulse shape processing + Block mode + Pulse Shape Processing + + + + + Processor Config + + Check incoming words for validity. Either this word or its inverse are accepted + + + + + + + + + + Register for block mode readout + + Number of readings to sum + + + Number of words in a block + + + Scale factor for data (2**N) + + + + Register for block mode readout + + Number of readings to sum + + + Number of words in a block + + + Scale factor for data (2**N) + + + + Register for block mode readout + + Number of readings to sum + + + Number of words in a block + + + Scale factor for data (2**N) + + + + Register for block mode readout + + Number of readings to sum + + + Number of words in a block + + + Scale factor for data (2**N) + + + + + + + + + Buffer fill level + + + + Status of the state machines + + Status of the Readout handler FSM + Idle + ReleaseDirect + WaitForEnd + CheckStatusTrigger + Start + Readout + NextBlock + SendStatus + + + Status of the processor FSM + Idle + ReadChannel + NextBlock + RdoDone + RdoWaitAfter + + + + The current calculated baseline of the ADC value + + + + Number of words not matching the given pattern + + + + Several bits of status information + + Data word removed from RAM + + + Trigger signal generated + + + Stop writing for readout + + + Data needs to be read out + + + + + + + + Signed PSA coefficient + + + + + + + + + + + + + diff --git a/xml-db/database/MediaECP5.xml b/xml-db/database/MediaECP5.xml index f403bb6..6435f44 100644 --- a/xml-db/database/MediaECP5.xml +++ b/xml-db/database/MediaECP5.xml @@ -51,7 +51,7 @@ - + RX Control Status @@ -95,7 +95,7 @@ - + -- 2.43.0