I was unable to reproduce the error, but reviewing the code I found a mistake in a check for a valid integer. I have pushed a fix for this. Hopefully it will clear the error you are seeing.
The value that is meant to be an integer is the volume value from the Volumio status. If you are able to retrigger the error, I would be interested to see the Volumio status from following command
I installed it uncountable times now, each time on a fresh system, different RasPIās - today i gave the updated system a try.
It is working as expected - the only problem that still comes up is - after about 2 to 4 hours running the display freezes.
I created a cron job that runs every 90 minutes and doing a restart of the displayā¦
sudo systemctl stop mpd_oled
sudo systemctl start mpd_oled
but i think this is not the āgoldenā solutionā¦
Is there any specific log i could have a look at - or send it to you, that could explain the hog up ?
Another thing:
90% the title is too long to be displayed completely and is cut in the second line.
I guess it could be doable somehow to let this line scroll to show the whole title This would be really great.
Where do i find the screen configuration ?
Thank you for this excellent work - it is really looking great.
I am not sure what is causing the freeze. I have been running the latest mpd_oled code on the latest Volumio since yesterday, and playing some music now the display is working correctly, but I havenāt been playing a lot of music today. Iāll run it for a while playing music tomorrow. I got a second OLED on Thursday and have just set up another player so I will try it with Volumio on that too.
To troubleshoot, when the display is frozen you could: run top and see whether mpd_oled and cava are running, run ls /tmp and see if you can see the FIFOs mpd_oled_fifo and cava_fifo, you could look at the logs less /var/log/volumio.log and `dmesg | lessā.
Is it a complete screen freeze, or just the spectrum analyser?
I am not sure what you mean by screen configuration. mpd_oled -h will print the command line options. Or if you want to change the layout, the function that draws all the screen elements is draw_spect_display in main.cpp. The screen elements are like widgets and so it is possible to create alternative screen layouts by modifying this function. I might provide an option for some different layouts. The text widget doesnāt currently support scrolling (I had scrolling on an LCD display and didnāt like it!) but I can look at adding it in, with an option for the scroll speed.
In testing today, one of the displays froze after eleven hours of playing music. There is nothing of interest in the logs. The freeze is because mpd_oled is no longer running. The most likely explanation is that it has crashed. I will run it from the command line next and see if there is any error message when it stops.
I ran mpd_oled from the command line, and it ran for 18 hours before stopping. Unfortunately there was no error message. Iāll carry out a general review of the code next.
Quick update. I added some extra error handling but the program still failed. I did however see a crash error message relating to incorrect use of dynamically allocated memory.
I reviewed the program code carefully for this, but couldnāt spot an error. I therefore ran mpd_oled in an environment that monitors memory access (valgrind) to see where the problem was occurring. However, 24 hours of playing music later and the program is still running and there are no messages.
In another test I have been running mpd_oled on Moode while playing music. It has now been running 48 hours without any problems.
In a current test, it is possible to specify a replacement memory allocation implementation that is āsaferā (works around programming errors) and can also warn about incorrect memory use. I am not seeing any immediate errors with it. I will leave it running to see if the program still stops when using it.
MALLOC_CHECK_=1 sudo ./mpd_oled -o 6 -b 21 -f 25
I will also look at compiling mpd_oled with -fsanitize, which will provide extra diagnostic messages. I will also check if the program fails when it is built with Clang rather than GCC.
Iām happy you are working on the stability as i like it really a lot.
Iām just testing marco79cgnās 1st version of his āRadio Paradiseā plugin, that is working good so far.
Can you imagine why the station and title isnāt passed to the display. (May be this is out of scope currently - but could be you have an idea)
Where do i find the display config ?
me againā¦ I know working on the stability is currently for sure the most important thing.
Just another thing (why i asked for where to find the display config):
The bitrate display seems to be limited to 3 characters while there would be enough space to show a 4th character.
If you play flac this leads to end with 999 if the bitrate gets over 1000kBps.
The reason for the missing information with the Radio Paradiso plugin is that it is not available to MPD. Compare the output of the Volumio and MPD status commands
volumio@volumio3:~/proj/mpd_oled$ mpc status
https://apps.radioparadise.com/blocks/chan/0/4/1696274-1696277.flac?src=alexa
[playing] #1/1 6:39/14:02 (47%)
volume: 40% repeat: off random: off single: off consume: on
I can read the Volumio status, and currently use the volume value from it. However, it is very slow to get a status update when a track changes, generally taking around 7 seconds. The MPD status is always returned quickly, but you can see above that besides the missing titles, it also has a different track length/progress. Maybe the Volumio status slowness is only a Pi Zero issue, and it is quick enough on a regular Pi (I donāt have one to test on). I posted about it here determine-current-volume-from-t9493.html#p47431
It makes sense to add the Volumio status values back in as an alternative to the MPD values when running on Volumio.
I am currently 10 hours in to tests of the alternative malloc on one machine, and the Clang build on another. Hopefully both displays will still be running in the morning!
Just to note that, testing again now on the latest Volumio the Volumio status response is improved. I can run āvolumio volumeā repeatedly around 2-4 times per second, and when changing track there are delays ranging 1-4 seconds over around a 10 second period.
You can see the delays by running this command and changing tracks in the Volumio UI (CTRL-C to stop it).
I believe I have found and fixed the bug that was causing the screen to freeze after several hours. With the fix applied, I have been able to play music continuously for 48 hours without any kind of issue.
I also changed to using Volumio status values (when running on on Volumio), which now makes the display compatible with the Radio Paradise plugin. I also added support for the full display of kbitrates with up to 4 digits.
Marco has put the radio station name as the artist, available in the plugin Github code, which fixes this issue. When I tested I simply overwrote a plugin file, so if you grabbed a zip of the plugin it might not have been be included in the latest zip at that time.
I uninstalled the old version of the Radio Paradis plugin, and installed the new official version. The artist is reported by āvolumio statusā (and displayed on the OLED) as āRadio Paradiseā
"title": "Ennio Morricone - The Good, The Bad & The Ugly",
"artist": "Radio Paradise",
"album": "An Hour with Ennio Morricone",
...
"service": "radio_paradise"
Yes - itās working and itās working really stable now for more than 3 days !!!
Also the title and radio station issue with the Radio Paradise plugin is fixed. (Has been an error by me) Thank you and Marco.
The only thing i would wish now is a scrolling āArtist - Titleā line as this is nearly always cut off on the small display.
Do you think this would be doable in the future ?
Also i have the ādreamā of putting 2 of these displays in line and span the text. (Maybe using the rest of the second display to show other data - temperature, alarm clock time, date, weather forecast, left and right channel of the spectrum analyser separated or whateverā¦)
I had a closer look at the display (i also own some of the cheap 4 pin SD1106 version types) and found one can change the I2C address by changing a 0-ohm resistor on the back side of these.
I wished i had more time to improve my own coding skills to be more helpful instead of only offering my ādreamsāā¦
Anyway iām more than happy with what i have now.
Maybe some day there also will be found a volumio developer that is able to build a real plugin around that to make it available to the rest of the community. Itās really looking awesome.
Thank you again for all that effort. Donāt think there are many out there that are able to fix those stability issues the way you did.
I havenāt forgotten your request! I have just pushed some changes that add scrolling for the station/artist and title fields.
I have implemented the scrolling as: start with a delay, then scroll continuously, adding five spaces between the end of the text before the beginning appears again at the right. The scrolling rate and delay can be specified with option -s. The scrolling rate might be close to the frame rate, and this unfortunately affects affects the smoothness of the scrolling.
There are quite a lot of other changes relating to option processing and reporting generally, and I also changed the timing code to allow more screen updates in the paused state, so it is possible there might be some issues.
I also recently added clearing the screen on shutdown.