| ID  | Date | Author | Topic | Subject | 
| 2817 | 01 Sep 2024 | Marius Koeppel | Suggestion | Improve Event Documentation | 
| > > Hi,
> > 
> > I am writing a Rust based midas file reader however it was kind of hard to understand the full midas file 
> > structure from the documentation.
> > 
> > Only at the end of the page 
> > https://daq00.triumf.ca/MidasWiki/index.php/Event_Structure#MIDAS_Format_Event one finds under the 
> > headline “tape format” that there are special events which mark the start and the end of the run. It would 
> > be better to place this information more prominent maybe we a headline: “Special Events”. Maybe a link to 
> > this section at the top of the page could help. Also at the mlogger page there is no information about this.
> > 
> > Best,
> > Marius
> 
> Ben was so kind to update the event documentation:
> 
>   https://daq00.triumf.ca/MidasWiki/index.php/Event_Structure
> 
> Please have a look and let us know if that's better now.
> 
> Best,
> Stefan
Thank you Ben! Now its super clear! | 
| 2816 | 01 Sep 2024 | Stefan Ritt | Suggestion | Improve Event Documentation | 
| > Hi,
> 
> I am writing a Rust based midas file reader however it was kind of hard to understand the full midas file 
> structure from the documentation.
> 
> Only at the end of the page 
> https://daq00.triumf.ca/MidasWiki/index.php/Event_Structure#MIDAS_Format_Event one finds under the 
> headline “tape format” that there are special events which mark the start and the end of the run. It would 
> be better to place this information more prominent maybe we a headline: “Special Events”. Maybe a link to 
> this section at the top of the page could help. Also at the mlogger page there is no information about this.
> 
> Best,
> Marius
Ben was so kind to update the event documentation:
  https://daq00.triumf.ca/MidasWiki/index.php/Event_Structure
Please have a look and let us know if that's better now.
Best,
Stefan | 
| 2815 | 30 Aug 2024 | Zaher Salman | Bug Report | Params not initialized when starting sequencer | 
| The issue with the parameters should be fixed now. Please test and let me know if it still happens. 
 
 
 | Thomas Senger wrote: |  | Hi Zaher, thanks for your help.
 I just tried the bug fix, but it still seems not to work properly.
 It seems that if the script is short, it will work, but if many SUBROUTINES are integrated, it does not work and the parameter are initialized empty.
 Best regards,
 Thomas
 | 
 | 
| 2814 | 30 Aug 2024 | Marius Koeppel | Suggestion | Improve Event Documentation | 
| Hi,
I am writing a Rust based midas file reader however it was kind of hard to understand the full midas file 
structure from the documentation.
Only at the end of the page 
https://daq00.triumf.ca/MidasWiki/index.php/Event_Structure#MIDAS_Format_Event one finds under the 
headline “tape format” that there are special events which mark the start and the end of the run. It would 
be better to place this information more prominent maybe we a headline: “Special Events”. Maybe a link to 
this section at the top of the page could help. Also at the mlogger page there is no information about this.
Best,
Marius | 
| 2813 | 26 Aug 2024 | Adrian Fisher | Info | Help parsing scdms_v1 data? | 
| 
 | Stefan Ritt wrote: |  | The MIDAS event format is described here: 
 https://daq00.triumf.ca/MidasWiki/index.php/Event_Structure
 
 All banks are aligned on a 8-byte boundary, so that one has effective 64-bit CPU access.
 
 If you have sections of 168 or 192 bytes, this must be something else, like another bank (scaler event, slow control event, ...).
 
 The easiest for you is to check how this events got created using the bk_create() function.
 
 Best,
 Stefan
 | 
 Upon further investigation, the sections I'm looking at appear to be clusters of headers for empty banks.
 
 Thank you!
 | 
| 2812 | 26 Aug 2024 | Stefan Ritt | Info | Help parsing scdms_v1 data? | 
| The MIDAS event format is described here: 
 https://daq00.triumf.ca/MidasWiki/index.php/Event_Structure
 
 All banks are aligned on a 8-byte boundary, so that one has effective 64-bit CPU access.
 
 If you have sections of 168 or 192 bytes, this must be something else, like another bank (scaler event, slow control event, ...).
 
 The easiest for you is to check how this events got created using the bk_create() function.
 
 Best,
 Stefan
 | 
| 2811 | 25 Aug 2024 | Adrian Fisher | Info | Help parsing scdms_v1 data? | 
| Hi! I'm working on creating a ksy file to help with parsing some data, but I'm having trouble finding some information. Right now, I have it set up very rudimentary - it grabs the event header and then uses the data bank size to grab the size of the data, but then I'm needing additional padding after the data bank to reach the next event. However, there's some irregularity in the "padding" between data banks that I haven't been able to find any documentation for. For some reason, after the data banks, there's sections of data of either 168 or 192 bytes, and it's seemingly arbitrary which size is used.
 I'm just wondering if anyone has any information about this so that I'd be able to make some more progress in parsing the data.
 The data I'm working with can be found at https://github.com/det-lab/dataReaderWriter/blob/master/data/07180808_1735_F0001.mid.gz
 And the ksy file that I've created so far is at https://github.com/det-lab/dataReaderWriter/blob/master/kaitai/ksy/scdms_v1.ksy
 
 There's also a block of data after the odb that runs for 384 bytes that I'm unsure the purpose of, if anyone could point me to some information about that.
 
 Thank you!
 | 
| 2810 | 23 Aug 2024 | Stefan Ritt | Info | mana.cxx | 
| Ok, no relevant complains so far, so I removed mana and rmana from the CMake build 
process, but left the file mana.cxx still in the repository for educational 
purposes ;-)
Stefan | 
| 2809 | 22 Aug 2024 | Scott Oser | Forum | "Safe" abort of sequencer scripts | 
| > This request came more than once in the past. One thing I could implement is a "atexit" function similarly to the C funciton atexit().
> 
> Then we would have a function in the script which gets called whenever one does "stop immediately". This function can then restore
> some ODB values or do whatever is necessary. 
> 
> If the sequencer gets killed in the middle, it can safely be restarted since the complete sequencer state is kept in the ODB under
> /Sequencer/State. After the restart, the sequencer continues exactly where it has been killed before.
> 
> Would that solve your problem?
> 
> Stefan
Yes, an "atexit" functionality within the Midas Sequencer Language would be useful for us with this issue.  Is this easy for you to implement?
Thanks,
Scott Oser | 
| 2808 | 19 Aug 2024 | Konstantin Olchanski | Release | kernel-module-universe updated to -KO7 | 
| > > The linux kernel driver for the Universe-II VME to PCI bridge is updated to 
> > version -KO7. It now builds and runs with Debian-12 stock kernel 6.1.0-22-686.
Ahem, and the location is:
git clone https://daq00.triumf.ca/~olchansk/git/kernel-module-universe.git
K.O. | 
| 2807 | 19 Aug 2024 | Konstantin Olchanski | Release | kernel-module-universe updated to -KO7 | 
| > The linux kernel driver for the Universe-II VME to PCI bridge is updated to 
> version -KO7. It now builds and runs with Debian-12 stock kernel 6.1.0-22-686.
I have a report that this driver might work on 64-bit VME CPUs (minus a bug in the 
MIDAS VME library). I do not have such hardware, cannot test, cannot confirm. (All our 
64-bit VME CPUs have the tsi148 bridge and run Ubuntu kernels and userland).
https://daq00.triumf.ca/elog-midas/Midas/2566
K.O. | 
| 2806 | 19 Aug 2024 | Konstantin Olchanski | Release | kernel-module-universe updated to -KO7 | 
| The linux kernel driver for the Universe-II VME to PCI bridge is updated to 
version -KO7. It now builds and runs with Debian-12 stock kernel 6.1.0-22-686.
I pxe boot (isolinux/pxelinux) the linux kernel and NFS-mount the stock 32-bit 
Debian-12 userland. Userland tarball is available by request. PXE and NFS-Root 
configuration is written up on the wiki at daq.triumf.ca, example config files 
are available on request.
https://daq00.triumf.ca/DaqWiki/index.php/Ubuntu#setup_diskless_network_booting
https://daq00.triumf.ca/DaqWiki/index.php/VME-CPU
The Debian-11 kernel also works (use -KO6 driver is -KO7 bombs), but Debian-11 
kernel with Debian-12 userland and Ubuntu-22 NFS server fails with "file too 
big" errors, the best I can tell this has to do with old 32-bit kernels getting 
unhappy about 64-bit NFS inode numbers.
Cross-compilation from 64-bit Ubuntu-22 to 32-bit VME processors running 32-bit 
Debian-12 is written up here:
https://daq00.triumf.ca/DaqWiki/index.php/Ubuntu#32-bit_intel_cross-compiler
To cross-build 32-bit MIDAS for 32-bit VME processor use "make linux32" or build 
natively (pretty slow on 1 GHz Pentium-III).
K.O. | 
| 2805 | 19 Aug 2024 | Stefan Ritt | Forum | "Safe" abort of sequencer scripts | 
| This request came more than once in the past. One thing I could implement is a "atexit" function similarly to the C funciton atexit().
Then we would have a function in the script which gets called whenever one does "stop immediately". This function can then restore
some ODB values or do whatever is necessary. 
If the sequencer gets killed in the middle, it can safely be restarted since the complete sequencer state is kept in the ODB under
/Sequencer/State. After the restart, the sequencer continues exactly where it has been killed before.
Would that solve your problem?
Stefan | 
| 2804 | 15 Aug 2024 | Scott Oser | Forum | "Safe" abort of sequencer scripts | 
| We often use the MIDAS sequencer to temporarily control detector settings, such as:
* <change some setting>
* WAIT 60 seconds
* <revert setting to original value>
The question arises of what happens if the sequencer scripts gets aborted during that wait, preventing the value from being reset.  Depending on the setting, this could be undesirable or even damage something if left uncorrected for too long.
Is there any way to have a "safe abort" from the sequencer so that the "Stop immediately" button will call some cleanup script to leave things in a safe state?  Or what about if the sequencer process itself gets killed in the middle of a script?
How have other experiments using MIDAS protected themselves from unplanned terminations of sequencer scripts? | 
| 2803 | 08 Aug 2024 | Stefan Ritt | Info | mana.cxx | 
| We are considering to remove the analyzer framework mana.cxx from MIDAS. It 
currently has some compiler warnings and we wonder if we should fix them which 
would take some time or just remove the file. We have now to much more modern 
analyzer frameworks "manalyzer" and "ROOTANA" which should be used instead.
Is anybody still using the mana.cxx framework?
/Stefan | 
| 2801 | 07 Aug 2024 | Stefan Ritt | Bug Report | File name bug in csv export | 
| Fixed as well. | 
| 2800 | 07 Aug 2024 | Lukas Gerritzen | Bug Report | File name bug in csv export | 
| Thanks. I think, mplot.js:1844 should be changed as well, but I haven't tried it with mplot. | 
| 2799 | 07 Aug 2024 | Stefan Ritt | Bug Report | File name bug in csv export | 
| Thanks. Fixed. Committed. Pulled on megon02. 
 Stefan
 | 
| 2798 | 07 Aug 2024 | Lukas Gerritzen | Bug Report | File name bug in csv export | 
| When I export data from a history plot, I get nonsensical filenames. For example, for data from today, I got "Xenon-Vacuum-20247107-152815-20247107-160032.csv". The month shouldn't be 71 but rather 08. The problem is that in the code it's generated as
 ("0" + leftDate.getUTCMonth() + 1).slice(-2)The first '+' is a string concatenation, and so is the second. It should be an addition though. A possible fix is to add parentheses around the addition:("0" + (leftDate.getUTCMonth() + 1)).slice(-2) | 
| 2797 | 06 Aug 2024 | Stefan Ritt | Suggestion | cmake-installing more files ? | 
| I don't see any bad side effects at the moment, so I accepted the changes and committed them.
Stefan |