|  30 Apr 2022, Konstantin Olchanski, Info, added web pages for "show odb clients" and "show open records" | 
| for a long time, midas web pages have been missing the equivalent of odbedit "scl" and "sor" to display current odb clients and current odb open records.
 
 | 
|  04 May 2022, Stefan Ritt, Info, added web pages for "show odb clients" and "show open records" | 
| Concerning the "scl" page, we are currently having a discussion. At the moment, one can see midas clients in three different places:
 
 | 
|  01 May 2022, Konstantin Olchanski, Info, added web page for "mdump" | 
| added JSON RPC for bm_receive_event() and added a web page for "mdump". 
 the event dump is a hex dump for now.
 | 
|  01 May 2022, Konstantin Olchanski, Info, added web page for "mdump" | 
| > added JSON RPC for bm_receive_event() 
 there is a number of problems with implementing bm_receive_event() as a RPC:
 | 
|  01 May 2022, Konstantin Olchanski, Info, added web page for "mdump" | 
| > added a web page for "mdump". 
 missing functions:
 | 
|  02 May 2022, Stefan Ritt, Info, added web page for "mdump" | 
| Here are some of my thoughts: 
 - I volunteer to write the JavaScript midas bank decoder. Just a couple of pure javascript functions, no
 | 
|  30 Apr 2022, Giovanni Mazzitelli, Forum, S3 Object Storage | 
| Dear all, We are storing raw MIDAS files to S3 Object Storage, but MIDAS file are not
 optimised for readout from such kind of storage. There is any work around on
 | 
|  30 Apr 2022, Konstantin Olchanski, Forum, S3 Object Storage | 
| > We are storing raw MIDAS files to S3 Object Storage, but MIDAS file are not > optimised for readout from such kind of storage. There is any work around on
 > evolution of midas raw output or, beyond simulated posix fs,  to develop midas
 | 
|  01 May 2022, Giovanni Mazzitelli, Forum, S3 Object Storage | 
| > > We are storing raw MIDAS files to S3 Object Storage, but MIDAS file are not > > optimised for readout from such kind of storage. There is any work around on
 > > evolution of midas raw output or, beyond simulated posix fs,  to develop midas
 | 
|  16 Mar 2022, Stefan Ritt, Info, New midas sequencer version | 
| A new version of the midas sequencer has been developed and now available in the develop/seq_eval branch. Many thanks to Lewis Van Winkle and his TinyExpr library
 (https://codeplea.com/tinyexpr), which has now been integrated into the sequencer
 | 
|  22 Mar 2022, Stefan Ritt, Info, New midas sequencer version | 
| After several days of testing in various experiments, the new sequencer has been merged into the develop branch. One more feature was added. The path to
 the ODB can now contain variables which are substituted with their values.
 | 
|  15 Apr 2022, Stefan Ritt, Info, New midas sequencer version   | 
| I prepared some slides about the new features of the sequencer and post it here so people can have a quick look at get some inspiration.
 
 | 
|  05 Apr 2013, Konstantin Olchanski, Info, ODB JSON support | 
| odbedit can now save ODB in JSON-formatted files. (JSON is a popular data encoding standard associated with Javascript). The intent is to eventually use the ODB JSON encoder in mhttpd to simplify passing of
 ODB data to custom web pages. In mhttpd I also intend to support the JSON-P variation of JSON (via the
 | 
|  10 May 2013, Konstantin Olchanski, Info, mhttpd JSON support | 
| > odbedit can now save ODB in JSON-formatted files. > Added functions:
 >    INT EXPRT db_save_json(HNDLE hDB, HNDLE hKey, const char *file_name);
 | 
|  17 May 2013, Konstantin Olchanski, Info, mhttpd JSON-P support | 
| > > Added JSON encoding format to Javascript ODBCopy(path,format) ("jcopy"). Use format="json", Javascript example updated with an example example.
 >
 | 
|  31 May 2013, Konstantin Olchanski, Info, mhttpd JSON-P support | 
| > To see how it all works, please look at examples/javascript1/example.html. >
 > - JSON encoding has an extra layer of objects (variables.Variables.foo instead of variables.foo)
 | 
|  27 Sep 2013, Konstantin Olchanski, Info, ODB JSON support | 
| > odbedit can now save ODB in JSON-formatted files. >
 > JSON encoding implementation follows specifications at:
 | 
|  09 Oct 2013, Konstantin Olchanski, Info, ODB JSON support | 
| > > odbedit can now save ODB in JSON-formatted files. > A bug was reported in my JSON ODB encoder: NaN values are not encoded correctly.
 
 | 
|  17 Mar 2014, Konstantin Olchanski, Info, ODB JSON support | 
| > > > odbedit can now save ODB in JSON-formatted files. > encode NaN, Inf and -Inf as JSON string values "NaN", "Infinity" and "-Infinity". (Corresponding to the respective Javascript values).
 
 | 
|  12 Apr 2022, Konstantin Olchanski, Info, ODB JSON support | 
| > > > > odbedit can now save ODB in JSON-formatted files. > > encode NaN, Inf and -Inf as JSON string values "NaN", "Infinity" and "-Infinity". (Corresponding to the respective Javascript values).
 > http://docs.oasis-open.org/odata/odata-json-format/v4.0/os/odata-json-format-v4.0-os.html
 | 
|  13 Apr 2022, Stefan Ritt, Info, ODB JSON support | 
| > Per xkcd, there is a new json standard "json5". In addition to other things, numeric > values NaN, +Infinity and -Infinity are encoded as literals NaN, Infinity and -Infinity (without quotes):
 > https://spec.json5.org/#numbers
 | 
|  13 Apr 2022, Konstantin Olchanski, Info, ODB JSON support | 
| > > Per xkcd, there is a new json standard "json5". In addition to other things, numeric > > values NaN, +Infinity and -Infinity are encoded as literals NaN, Infinity and -Infinity (without quotes):
 > > https://spec.json5.org/#numbers
 | 
|  31 Mar 2022, Konstantin Olchanski, Bug Fix, "run stop" trouble in mlogger, fixed | 
| while debugging something else, I ran into a bit of trouble in mlogger. 
 I set the mlogger event limit to 100, and after reaching 100 events, mlogger
 | 
|  30 Mar 2022, Konstantin Olchanski, Bug Fix, erroneous removal of odb clients, fixed | 
| commit https://bitbucket.org/tmidas/midas/commits/b1fe21445109774be3f059c2124727b414abf835 made on 2022-02-21 fixed a serious bug in ODB.
 
 | 
|  29 Mar 2022, Konstantin Olchanski, Bug Fix, mdump can read lz4 and bz2 files now | 
| I converted mdump file i/o from older mdsupport library to newer midasio library and it can now read .mid, .mid.gz, .mid.lz4 and .mid.bz2 files. Output should be
 identical to what it printed before, if you see any differences, please report
 | 
|  29 Mar 2022, Hunter Lowe, Forum, Triggering without LAM signal - mcstd_libgpmc_camac driver | 
| Hello, 
 I have a question for anyone experienced with simple CAMAC systems.
 | 
|  12 Dec 2021, Marius Koeppel, Bug Report, Writting MIDAS Events via FPGAs   | 
| Dear all, 
 in 13 Feb 2020 to 21 Feb 2020 we had a talk about how I try to create MIDAS events directly on a FPGA and
 | 
|  26 Jan 2022, Konstantin Olchanski, Bug Report, Writting MIDAS Events via FPGAs | 
| > today I did not get the data into MIDAS. 
 Any error messages printed by the frontend? any error message in midas.log? core dumps? crashes?
 | 
|  26 Jan 2022, Marius Koeppel, Bug Report, Writting MIDAS Events via FPGAs | 
| > Any error messages printed by the frontend? any error message in midas.log? core dumps? crashes?
 > I do not understand what you mean by "did not get the data into midas". You create events
 | 
|  26 Jan 2022, Konstantin Olchanski, Bug Report, Writting MIDAS Events via FPGAs | 
| > > > Any error messages printed by the frontend? any error message in midas.log? core dumps? crashes?
 > > I do not understand what you mean by "did not get the data into midas". You create events
 | 
|  26 Jan 2022, Marius Koeppel, Bug Report, Writting MIDAS Events via FPGAs | 
| > If you are connected locally (no mserver), I want to know the value returned by bm_send_event(). Simplest
 > if you edit mfe.c and everywhere it calls bm_send_event() and rpc_send_event(), print the returned value.
 | 
|  28 Jan 2022, Stefan Ritt, Bug Report, Writting MIDAS Events via FPGAs   | 
| I finally got the dummy program working. There were several issues: 
 - event_buffer_size was defined as 10000 * 32 MB = 320 GB, exceeding the RAM of the computer
 | 
|  16 Feb 2022, Marius Koeppel, Bug Report, Writting MIDAS Events via FPGAs | 
| I just came back to this and started to use the dummy frontend. Unfortunately, I have a problem during run cycles:
 
 | 
|  03 Mar 2022, Stefan Ritt, Bug Report, Writting MIDAS Events via FPGAs | 
| > Starting the frontend and starting a run works fine -> seeing events with mdump and also on the web GUI. > But when I stop the run and try to start the next run the frontend is sending no events anymore.
 > It get stuck at line 221 (if (status == DB_TIMEOUT)).
 | 
|  07 Mar 2022, Marius Koeppel, Bug Report, Writting MIDAS Events via FPGAs | 
| > This problem has (likely) been fixed in the current version. Please pull develop and try again. Was a recursive call to the event collection routine which is only triggered if you send events faster than
 > the logger can digest, so not many people see it.
 | 
|  25 Mar 2022, Marius Koeppel, Bug Report, Writting MIDAS Events via FPGAs | 
| I finally found the problem why the readout stops after a run transition. 
 In my dummy frontend the serial number was not reset to zero at run start.
 | 
|  23 Mar 2022, Konstantin Olchanski, Bug Fix, mhttpd bug fixed | 
| the mhttpd bug should be fixed now (branch feature/buffer_mutex). 
 simplest way to reproduce:
 | 
|  24 Mar 2022, Stefan Ritt, Bug Fix, mhttpd bug fixed | 
| > 1st wget stops (by ctrl-C), socket is closed, mongoose frees it's mg_connection object > (corresponding worker is still labouring, hmm... actually sleeping, and now has a stale nc pointer)
 >
 | 
|  24 Mar 2022, Konstantin Olchanski, Bug Fix, mhttpd bug fixed | 
| > > 1st wget stops (by ctrl-C), socket is closed, mongoose frees it's mg_connection object > > (corresponding worker is still labouring, hmm... actually sleeping, and now has a stale nc pointer)
 > >
 | 
|  24 Mar 2022, Stefan Ritt, Bug Fix, mhttpd bug fixed | 
| I see, now I understand. 
 As for the browser cache problem: This Chrome extension is your friend:
 | 
|  24 Mar 2022, Konstantin Olchanski, Bug Fix, mhttpd bug fixed | 
| > As for the browser cache problem: This Chrome extension is your friend ... 
 for google chrome, it is easy, open the javascript debugger (left-click "inspect"),
 | 
|  10 Aug 2020, Ivo Schulthess, Bug Report, data missing in runXXXXXX.mid | 
| Dear all 
 We just started our beam time at ILL and just found yesterday that for certain
 | 
|  10 Aug 2020, Stefan Ritt, Bug Report, data missing in runXXXXXX.mid | 
| > Dear all >
 > We just started our beam time at ILL and just found yesterday that for certain
 | 
|  10 Aug 2020, Ivo Schulthess, Bug Report, data missing in runXXXXXX.mid | 
| > > Dear all > >
 > > We just started our beam time at ILL and just found yesterday that for certain
 | 
|  10 Aug 2020, Stefan Ritt, Bug Report, data missing in runXXXXXX.mid | 
| > Both set to -1. We only have one logging channel. If we run a sequence with a few runs and the > same settings, sometimes data is in the .mid file and sometimes it is not.
 
 | 
|  10 Aug 2020, Ivo Schulthess, Bug Report, data missing in runXXXXXX.mid | 
| > Then I'm running out of ideas. Things I would check: >
 > - Are the file sizes about the same?
 | 
|  10 Aug 2020, Stefan Ritt, Bug Report, data missing in runXXXXXX.mid | 
| > So I did a quick check. The file size is about the same (322K and 329K). When I dump the .mid I don't see > the banks. It only prints two lines with "------ Event# 0 ------" and "------ Event# 1 ------" whereas for
 > the file with data I get the two banks with all the data. Our online analyzer also fails to see the banks.
 | 
|  10 Aug 2020, Ivo Schulthess, Bug Report, data missing in runXXXXXX.mid | 
| > with "dump" I meant a true object dump like "hexdump -C run000001.mid". I produced a file with ADC0 and TDC0 > banks (that's the example from the distribution under exampels/experiments/frontend.cxx), and I get
 >
 | 
|  10 Aug 2020, Stefan Ritt, Bug Report, data missing in runXXXXXX.mid | 
| Have you tried longer files? Maybe a few 100 MB or so. Maybe a buffer is not flushed correctly at the end of a run. | 
|  10 Aug 2020, Ivo Schulthess, Bug Report, data missing in runXXXXXX.mid | 
| > Have you tried longer files? Maybe a few 100 MB or so. Maybe a buffer is not flushed correctly at the end of a run. 
 Yes, I did. This 7 KB of the data bank is about the limit. If we go only 1 KB higher it seems that we save all data. In
 | 
|  10 Aug 2020, Stefan Ritt, Bug Report, data missing in runXXXXXX.mid | 
| I have to reproduce the problem to fix it. Why don't you go and modify midas/examples/experiment/frontend.cxx in such a way that it creates exactly the banks you have, just with random data. If you see the same problem, send me your frontend file so that I
 can reproduce it.
 | 
|  11 Aug 2020, Konstantin Olchanski, Bug Report, data missing in runXXXXXX.mid | 
| > I have to reproduce the problem to fix it. Why don't you go and modify midas/examples/experiment/frontend.cxx in such a way that > it creates exactly the banks you have, just with random data. If you see the same problem, send me your frontend file so that I
 > can reproduce it.
 | 
|  11 Aug 2020, Ivo Schulthess, Bug Report, data missing in runXXXXXX.mid | 
| > It would be good to pin point there the data is lost. This is the sequence: >
 > frontend user code -> mfe.c code -> SYSTEM buffer -> mlogger -> disk
 | 
|  24 Mar 2022, Konstantin Olchanski, Bug Report, data missing in runXXXXXX.mid | 
| > > It would be good to pin point there the data is lost. This is the sequence: > >
 > > frontend user code -> mfe.c code -> SYSTEM buffer -> mlogger -> disk
 | 
|  24 Mar 2022, Stefan Ritt, Bug Report, data missing in runXXXXXX.mid | 
| One idea: we should have a look at mlogger::close_channels(). There the SYSTEM buffer is emptied through the cm_yield() call. Instrumenting this with some debugging code will enlighten us.
 
 | 
|  24 Mar 2022, Konstantin Olchanski, Bug Report, data missing in runXXXXXX.mid | 
| > One idea: we should have a look at mlogger::close_channels(). > There the SYSTEM buffer is emptied through the cm_yield() call.
 > Instrumenting this with some debugging code will enlighten us.
 | 
|  22 Mar 2022, Konstantin Olchanski, Bug Fix, fix for event buffer corruption in bm_flush_cache() | 
| multithreaded frontends have an unusual event buffer corruption if the write cache is enabled. For a long time now I had to disable the write cache on
 all multithreaded frontends in alpha-g, I was hitting this bug quite often.
 | 
|  22 Mar 2022, Stefan Ritt, Bug Fix, fix for event buffer corruption in bm_flush_cache() | 
| Thanks Konstantin for your detailed description. 
 I wonder why we never saw this problem at PSI. Here is the reason: In multil-threaded environments, we never call bm_send_event() directly
 | 
|  23 Mar 2022, Konstantin Olchanski, Bug Fix, fix for event buffer corruption in bm_flush_cache() | 
| I confirm, there is no problem in single-threaded programs, and there is no problem if all bm_send_event() and bm_flush_cache() are called
 from the same thread.
 | 
|  24 Mar 2022, Stefan Ritt, Bug Fix, fix for event buffer corruption in bm_flush_cache() | 
| > > ... instead of struggling with all your locks. >
 > it is better to have midas fully thread safe. ODB has been so for a long time,
 | 
|  23 Mar 2022, Ivo Schulthess, Bug Fix, fix for event buffer corruption in bm_flush_cache() | 
| Thanks for the investigation. Back in 2020, we had some issues of losing data between the system buffer and the logger writing them to disk (https://daq00.triumf.ca/elog-midas/Midas/1966). This was polled equipment but we had a multithreaded FE running at the same time. Could this be related to the same problem?
 
 | 
|  24 Mar 2022, Konstantin Olchanski, Bug Fix, fix for event buffer corruption in bm_flush_cache() | 
| > Thanks for the investigation. Back in 2020, we had some issues > of losing data between the system buffer and the logger writing them
 > to disk (https://daq00.triumf.ca/elog-midas/Midas/1966). This was polled equipment
 | 
|  23 Mar 2022, Hunter Lowe, Forum, ODB has issue with example analyzer | 
| Trying to play with midas file but I get error: 
 [Analyzer,ERROR] [odb.cxx:845:db_validate_name,ERROR] Invalid name "/Analyzer/Tests/low_sum/Rate [Hz]" passed to db_create_key_wlocked: should not contain
 | 
|  15 Mar 2022, Konstantin Olchanski, Bug Fix, mhttpd ipv6 bind should be fixed now | 
| Something changed after my initial implementation of ipv6 in mhttpd and listening to ipv6 http/https connections was broken.
 
 | 
|  23 Mar 2022, Konstantin Olchanski, Bug Fix, mhttpd ipv6 bind should be fixed now | 
| > Something changed after my initial implementation of ipv6 in mhttpd > and listening to ipv6 http/https connections was broken.
 
 | 
|  10 Mar 2022, Gennaro Tortone, Bug Report, Python ODB watch | 
| Hi, 
 I have an issue with ODB watch on MIDAS Python library;
 | 
|  16 Mar 2022, Ben Smith, Bug Report, Python ODB watch | 
| > It seems that the second write operation "overlaps" the first one... 
 Hi Gennaro,
 | 
|  21 Mar 2022, Stefan Ritt, Bug Report, Python ODB watch | 
| What you describe is a well-known problem with the ODB. At PSI we have similar issues. There are two approaches to solve it:
 
 | 
|  03 Mar 2022, Konstantin Olchanski, Info, manalyzer updated | 
| manalyzer was updated to latest version. mostly multi-threading improvements from Joseph and myself. K.O.
 | 
|  03 Mar 2022, Konstantin Olchanski, Info, zlib required, lz4 internal | 
| as of commit 8eb18e4ae9c57a8a802219b90d4dc218eb8fdefb, the gzip compression library is required, not optional.
 
 | 
|  23 Feb 2022, Stefan Ritt, Info, Midas slow control event generation switched to 32-bit banks | 
| The midas slow control system class drivers automatically read their equipment and generate events containing midas banks. So far these have been 16-bit banks using bk_init(). But now more and more experiments use large amount of channels, so the 16-bit address space is exceeded. Until last week, there
 was even no check that this happens, leading to unpredictable crashes.
 | 
|  08 Feb 2022, jago aartsen, Bug Fix, ODBINC/Sequencer Issue   | 
| Hi all, 
 I am having some issues getting the ODBINC command to work within the MIDAS
 | 
|  08 Feb 2022, Konstantin Olchanski, Bug Fix, ODBINC/Sequencer Issue | 
| Please post the output of odbedit "ls -l" for /eq/ar.../variables. (you posted the variable name as an image, and I cannot cut-and-paste the odb path!). BTW data size 4 is
 correct, 4 bytes for INT32/UINT32/FLOAT. For DOUBLE it should be 8. For you it prints 32
 | 
|  09 Feb 2022, jago aartsen, Bug Fix, ODBINC/Sequencer Issue | 
| > Please post the output of odbedit "ls -l" for /eq/ar.../variables. (you posted the > variable name as an image, and I cannot cut-and-paste the odb path!). BTW data size 4 is
 > correct, 4 bytes for INT32/UINT32/FLOAT. For DOUBLE it should be 8. For you it prints 32
 | 
|  09 Feb 2022, Konstantin Olchanski, Bug Fix, ODBINC/Sequencer Issue | 
| > > [local:mu3eMSci:S]/>cd Equipment/ArduinoTestStation/Variables
 > [local:mu3eMSci:S]Variables>ls -l
 | 
|  10 Feb 2022, Stefan Ritt, Bug Fix, ODBINC/Sequencer Issue | 
| I tried following script: 
 ODBSET /Equipment/ArduinoTestStation/Variables/_S_, 10
 | 
|  14 Feb 2022, jago aartsen, Bug Fix, ODBINC/Sequencer Issue | 
| > I tried following script: >
 > ODBSET /Equipment/ArduinoTestStation/Variables/_S_, 10
 | 
|  14 Feb 2022, Stefan Ritt, Bug Fix, ODBINC/Sequencer Issue | 
| Just post here a minimal script which produces the error, so that I can try myself. 
 ... and make sure that you have the latest develop version of midas.
 | 
|  14 Feb 2022, jago aartsen, Bug Fix, ODBINC/Sequencer Issue | 
| > Just post here a minimal script which produces the error, so that I can try myself. >
 > ... and make sure that you have the latest develop version of midas.
 | 
|  14 Feb 2022, Stefan Ritt, Bug Fix, ODBINC/Sequencer Issue | 
| > I noticed that "Jacob Thorne"  in the forum had the same issue as us in Novemeber last > year. Indeed we have not installed any later versions of MIDAS since then so we will
 > double check we have the latest version.
 | 
|  14 Feb 2022, jago aartsen, Bug Fix, ODBINC/Sequencer Issue | 
| > > I noticed that "Jacob Thorne"  in the forum had the same issue as us in Novemeber last > > year. Indeed we have not installed any later versions of MIDAS since then so we will
 > > double check we have the latest version.
 | 
|  15 Feb 2022, Stefan Ritt, Bug Fix, ODBINC/Sequencer Issue | 
| > But the error still persists. Is there another way to update which we are missing? 
 The bug was definitively fixed in this modification:
 | 
|  16 Feb 2022, jago aartsen, Bug Fix, ODBINC/Sequencer Issue | 
| > > But the error still persists. Is there another way to update which we are missing? >
 > The bug was definitively fixed in this modification:
 | 
|  14 Feb 2022, jago aartsen, Bug Fix, ODBINC/Sequencer Issue | 
| > > > > [local:mu3eMSci:S]/>cd Equipment/ArduinoTestStation/Variables
 > > [local:mu3eMSci:S]Variables>ls -l
 |