Audio DAC for RPi - Networked Audio Player using Volumio [160198]
This is an Audio DAC designed for the Raspberry Pi. Using app Volumio it can be used as a stand alone networked Audio Player or operated thru a WebUI.
Searching for a small stand-alone networked audio player with a touch screen mostly big consumer amplifiers are found. The one’s with network support have no touch screen or are very expensive. If space and mobility is an issue these are not suitable. So, why not build one yourself. Luckily there are many who already did. A good start is to look for applications that use a raspberry pi. DACs with good quality are already on the market. But since we want to build de audio player ourselves, we designed an audio DAC for the raspberry pi using first class parts. In the past we designed High End DACs for normal use. ICs from Burr Brown (now Texas Instruments) were and still are among the best. We had good experiences with DACs made by Burr Brown and so the choice was easy to use one of their top models, the PCM1794A. It is a 24 bit DAC , can handle sample rates up to 200 kHz and has a built-in 8x oversampling filter.
Power supplies
The PCM1794A (IC1) requires two different power supply voltages. +3.3 V for the digital part and +5 V for the analog part. Later on we will explain why we increased this supply voltage to +5.2 V (still within recommended operating range!). We could use the RPi power supplies available on the GPIO Expansion connector but these are very noisy. We need to make an independent +3.3 V and +5 V. Another option is to use the power supply of the DAC to supply the RPi. But that would mean degrading the power supply of the DAC. Downside of keeping the power supplies separate is two DC adapters are needed. To avoid having to use a third power supply for the I/V-converter and analog output filter a negative power supply is derived from the +5 V. The positive supply voltage for the analog output section is set to 4.74 V using a low noise regulator and the negative power supply is also derived from the +5.2 V power supply using a special Low-Noise Regulated Switched Capacitor Voltage Inverter: the LM27761 (IC8). As the name explains it uses switched-capacitor techniques to invert the input voltage followed by a linear low noise regulator to create a stabilized negative supply voltage. In our case the output voltage is set to -4.81 V by divider R30/R31 (Vout = -(R30/R31 + 1) * 1.22 V). The IC can supply up to 250 mA and the IC measures only 2 x 2 mm. It’s size and operating frequency of 2 MHz means very little noise is introduced. Two ultralow-noise positive linear regulators of type TPS7A4901 are used for the +3.3 V (IC9) and +4.74 V (IC7) ensuring the best power supply quality for the DAC and filters. The maximum output current is 150 mA The output voltages (Vout = (R28/R29 + 1) * 1.185 V) are set to +4.74 V by divider R28/R29 and +3.3 V by divider R32/R33.
Ultralow-noise low-dropout voltage regulator TPS7A4700 is used to generate the +5.2 V main power supply. It can deliver 1 A output current and has a low drop-out voltage of 307 mV (at 1 A). It has internal resistors so the output voltage can be set by connecting specific pins to ground. If connected to ground each pin adds a voltage to the output. The minimum voltage is the reference voltage of 1.4 V. To get +5.2 V pins 6, 10 and 11 are connected to ground: Vout = 1.4 + 3.2 + 0.4 + 0.2 V = 5.2 V. The slightly higher output voltage was chosen to ensure the maximum undistorted output voltage of the filter stages can be 1 V. Conventional maximum output voltage is often 2 VRMS but that would require rail to rail opamps or a higher supply voltage. A design criteria was to avoid additional power supply voltages. Most rail-to-rail opamps don’t have the specifications that special high quality audio opamps have. We used two dual opamps type LME49720 for the I/V-converters and two single opamps type LME49710 for the filters. Although their power supply range is specified ±2.5 V to ±17 V the linear output voltage range measurements have shown the linear output voltage range (at this low power supply voltage) is a about 1.4 V from each supply line. The I/V-converter is the limiting factor here, partially caused by the low resistor values (higher drop across the internal output transistors). This is discussed in the filter section in more detail. This is the reason the original symmetrical power supply voltage of ±4.5 V was increased to +4.74 V and – 4.81 V (the use of E-24 values provide these voltages). Now the maximum (0 dB) output voltage of 1.06 V is undistorted.
The input for the power supply (K7) is protected against wrong polarity by a schottky diode (D1). The voltage drop across the diode is about 0.3 V. At 8 V input voltage the supply current is 124 mA playing at a sample rate of 32 kHz and 184 mA playing at a sample frequency of 192 kHz.
Master clock
Making the audio DAC work we configured Raspbian (operating system of the RPi) for a HiFiBerry DAC. If this is done correctly I2S serial bus signals (Inter-IC Sound) are available on the GPIO Expansion connector. Official names of the signals are continuous serial clock SCK (or bit clock BCLK/BCK), word select WS (or left-right clock LRCLK/LRCK) and serial data SD (or SDATA/DATA and many more). Originally not part of the I2S standard is a master clock needed to synchronize devices. The master clock is missing on the expansion connector and so our circuit has to generate one. For this purpose we added a frequency multiplier with integrated PLL. The ICS570BILF from IDT has a zero delay buffer which means the rising edges of input and outputs are perfectly aligned. The multiplication can be set from 0.5x to 32x by two three level inputs (S0/S1). Output range of CLK is according to the AC Electrical Characteristics 10 to 170 MHz. We set the multiplication to 6x using the CLK/2 output and connected it to the feedback input. This configuration has the best input range setting. According to the Clock Multiplier Decoding Table and M/M setting in the datasheet setting both S0 and S1 to M (unconnected) the input range is 2.5 to 12.5 MHz and the output range is 15 to 75 MHz. This would mean that a 32 kHz sample frequency track should not be able to play, yet is does and it does so perfectly. But there is a bigger problem. To test the audio DAC all kinds of 32 bit wave files were used: stepped sine, stepped amplitude, single tone and IMD with sample frequencies from 32 kHz to 192 kHz. Doing tests with a few 24 bit wave files gave exact same results. So next to do were tests and measurements with 16 bit waves and big surprise: no output signal! What the f***…Well it took it a long time to come to the conclusion that although the datasheet states the PCM1794A supports 16 and 24 bit audio, it does not in the I2S mode. The only indication I found in the datasheet (SLES117B –AUGUST 2004–REVISED DECEMBER 2015) was in Figure 22. Audio Data Input Formats. The timing diagram for I2S Data Format mentions Audio Data Word = 24-Bit. And there’s no other I2S diagram. The audio player used by Volumio halves the serial clock and data bits when the audio data is 16 bit. Setting the master clock to higher frequencies doesn’t help. Does this mean 16 bit audio is not supported in our setup. Well yes and no. Playing the song directly doesn’t work but luckily the version of Volumio we used (1.55) still has an option for sample rate conversion (three quality settings). A variety of sample rates and bit combinations are available. This feature should be implemented in a next update of Volumio 2 (version 2.041 of 12-12-2016 still doesn’t, but then Volumio 2 has internet radio, and plug-ins…).
Table 1:
fs[kHz] bits BCK[MHz] S0 S1 * SCK[MHz] output signal
32 24/32 2.048 M M 6 12.288 yes
44.1 24/32 2.8224 M M 6 16.9344 yes
48 24/32 3.072 M M 6 18.432 yes
96 24/32 6.144 M M 6 36.864 yes
192 24/32 12.288 M M 6 73.728 yes
32 16 1.024 M M 6 unstable no
44.1 16 1.4112 M M 6 unstable no
48 16 1.536 M M 6 9.216 no
96 16 3.072 M M 6 18.432 no
192 16 6.144 M M 6 36.864 no
M (half the supply voltage, unconnected)
16 bit audio data can be the reason there’s no sound using internet radio in Volumio 2. Use resampling to 24 bit to get the music playing. If anyone has a solution how to keep the I2S bus in 32 bit data mode permanently please let us know.
Other master clock frequencies can be set by S0 and S1 located on the bottom side by using 0 Ω resistors (0805) or thin wires. Don’t connect all three pads of JP1 and JP2. This will short circuit the +3.3 V power supply.
PCM1794ADB
The DAC has a built-in 8x oversampling digital filter and is compatible with sampling frequencies from 10 to 200 kHz. The datasheet also states ‘Accepts 16-Bit and 24-Bit Audio Data’ but apparently not in I2S mode. I’m not going to duplicate the contents of the datasheet but instead walk through the schematic. The I2S signals are connected through four 22 Ω resistors (R22..R25) to prevent RF noise of these high frequency signals getting to the analog side of the DAC. At a sampling rate of 192 kHz our master clock is almost 74 MHz! The hardware select lines (MONO, CHSL, DEM, MUTE, FMT0, FMT1, RESET) are connected to a 7way DIP switch and a 7way 47 kΩ resistor array used as pull-ups. This makes changing settings very easy. The zero output (pin 13), active when the audio input data in the L-channel and the R-channel is continuously zero for 1024 LRCKs in the PCM mode (or 1024WDCKs in the external filter mode), is connected to LED1 indicating the absence of data. The minimum output level of the ZERO output at a current of 2 mA is according to the datasheet 2.4 V. This is enough for a green led. In our prototype the output voltage was 3.09 V and the led current 4.3 mA. The output current reference bias pin 20 is connected to a 10 kΩ resistor. This is according to the typical application schematic and evaluation board but other than the value no information is given. The left and right channel internal bias decoupling pins (VCOML/VCOMR) are decoupled by 10 µF electrolytic capacitors but again no information is given. To decouple the power supplies we used aluminum polymer capacitors (C19,C23,C25,C27) because of their low ESR (40 mΩ @ 100 kHz). Downside of these capacitors is the relatively high leakage current of 100 µA maximal. Since it is unclear if this leakage current will influence the internal bias setting two normal electrolytic capacitors are used (1.06 Ω @ 100 kHz and 4 µA leakage current). For those who like to experiment footprints of all electrolytic capacitors are designed to hold 2 to 2.5 mm pitch capacitors with a maximum diameter of 6.3 mm. The 47 nF ceramic decoupling capacitors of the power supply pins (C22,C24,C26) are size 1206 with X7R dielectric. Would the use of NP0/C0G dielectric improve performance?
The output filter
Although sampling artifacts are largely suppressed by the 8x digital oversampling filter there are still high frequency components present. A reconstruction filter is used to suppress them. But since we’re using an 8x oversampling filter its task is foremost suppressing the higher frequencies above half the sample frequency. A 3rd order Butterworth is used. The I/V-converters IC2/IC3 are part of the filter. The cut-off frequency is 64.5 kHz. At a sampling frequency of 44.1 kHz the 8x frequency component of 352.8 kHz is suppressed by more than 40 dB. At a sampling frequency of 192 kHz the 8x frequency component will be suppressed by approximately 80 dB. The chosen cut-off frequency is of course a compromise between sufficient filtering at lower sampling frequencies and low frequency bandwidth of the audio signal at the higher sampling frequencies. The filter bandwidth is now more than three times the human hearing range. The DAC has balanced current outputs so an external filter can be used. To convert these balanced currents to a single ended output signal first an I/V-converter per output is needed. The two voltages of IC2A/IC2B (IC3A/IC3B) are followed by a 2nd order filter stage configured as a differential to single ended amplifier. IC4 for the left channel and IC5 for the right channel. The topology is a differential multiple feedback filter. Combined with the filtering of the I/V-converter the total filter characteristic is a 3rd order Butterworth filter. The filter was calculated with exact E-12 values for the capacitors and theoretical values for the resistors. The resistor values were rounded to E-24 values.
In our prototype the balanced output currents were just 5.8 mA (no signal) instead of the 6.2 mA according to the datasheet. If the tolerance is this big (6.5 %) there’s also the possibility the current is equally higher. Hopefully this doesn’t mean the I/V-converter is clipping if a full-scale signal is applied. Not only is the center current lower but the full-scale peak-peak current is also proportionally lower. The measured output voltages of the I/V-converters were 2.08 in one channel and 2.06 in the other. Peak-peak voltage was about 2.7 Vp-p. Maybe tweaking R20 is an option in case the signals are clipping at full-scale. We haven’t tried. Another option to use a higher symmetrical power supply for the filter. In that case remove 0 Ω resistors R26 and R27 and connect the external power supply to K6.
For the output stage a multiple feedback filter is used since it can easily be extended to also function as differential to single ended converter. If familiar with a standard multiple feedback filter transforming it to one with a differential input is simple. Just mirror the circuit connected to the inverting input and place it at the non-inverting input. The resistor and capacitor connected to the output are connected to ground. That’s it, well almost. If you look at the circuit you see that there’s only one capacitor (C9/C14) were you would expect two capacitors connected to ground. The original two capacitors can be combined to one with only half the value. The bigger the value of high quality capacitors like we used in the filter the higher the cost. By replacing two capacitors by one smaller capacitor per channel we save some money but more importantly we save space. The idea was to keep the PCB of the DAC exactly the same size as the RPi PCB and components should only be mounted on the top side. To limit the output voltage to 1 V the filter has to attenuate the differential signal of the I/V-converters. Gain of IC4/IC5 is 0.56, set by the ratio of R6/R5 and R9/R8. DC output offset is only in the mV range. -1.6 mV in one channel and +1.3 mV in the other channel. The common mode voltage of both I/V-converters per channel is suppressed by IC4 and IC5. The single ended output signal is made available on PCB mounted RCA connectors K1 and K2 through connectors K3 and K4. A shunt jumper on K3/K4 can be used to make a direct connection to the RCA connectors. K3 and K4 can also be used to connect a stereo potentiometer to have a simple volume control. The DAC itself has no volume control. Volumio can change volume by software but then resolution is lost. This would seriously compromise sound quality and is not really an option. Another possibility is to insert a hardware volume control like a PGA2311 (another PCB) and change volume by remote control (work in progress). Recently there is plug-in available for Volumio 2 to connect push buttons to the RPi to control basic functions. These can be added to the other PCB.
The symmetrical analog power supply for the filter and the I/V-converter is decoupled from the digital power supplies by a common-mode choke and RF inductors for each channel.
PCB
Only a single power supply of 7 to 8 V is needed (K7). The RPi works on a separate 5 V! Any higher will cause more dissipation in the voltage regulator IC10 but 9 or 12 V are also possible. The DC power connector jack and RCA phono jacks are on the same side. DIP switch S1 is on the opposite side of the PCB. This is the spot on the RPi 3 where the WiFi antenna is located. The 40-pin GPIO Stacking Header K5 is mounted on the bottom side. Don’t put the plastic body of the header against the PCB but keep it 1 to 1.5 mm from the PCB and keep the distance equal (perfect parallel to the PCB) so it will fit on the corresponding connector on the RPi without a problem. Cut the protruding pins on the bottom side of K1, K2, K3, K4, K6 and K7 as short as possible to avoid short circuits occur with the metal cases from the network and USB connectors on the RPi. Maybe place something insulating in-between. We used four M2 screws of sufficient length to act as spacers (and 12 nuts). The standard spacers are not long enough. The footprint for the capacitors that are part of the filter is designed so 3 different types of capacitors can be used (C1, C2, C5, C6, C9, C10, C11, C14, C15, C16). SMD 0805 capacitors can be used but also standard through hole capacitors with 5 mm spacing. We strongly recommend the use of 1 % polystyrene capacitors for best performance (see BOM). These capacitor have the pins placed diagonally. The number 1 pins of all ICs are marked with a white dot next to it. The dot of IC7 is a bit hard to see, it is half absorbed by C38. Because there is not enough space to place the designators of all 0805 resistors and 0805 and 1206 capacitors next to the components they are placed inside the component. This means they will not be visible on the PCB. If the components are soldered by hand (hot air or oven) use an enlarged print out of the top overlay to place all SMD at the right place. Many 0805 components are not easily replaced once the through hole components are mounted! Through hole components should be mounted last. Jumpers JP1 and JP2 are located at the bottom. But by default these can be left open (SCK = 6 x BCK). The RCA Phono connectors are types from Switchcraft and have two connection closer together than more standard 10 mm versions. If other types are used they probably won’t fit!
Place the 3.5” display 17 mm above the Audio DAC. Don’t push the connector all the way through. The connector should make sufficient contact. If doubtful use another standard size stacking header and place the display higher. The 26way socket of the display will then be at a distance of about 3,5 mm from the Audio DAC PCB. 17 mm M2.5 standoffs can be used (Ettinger 05.12.173, Farnell 1466854) to secure the Audio DAC on top of the Raspberry Pi.
Volumio 1.55
The following text is a step-by-step description how to install Volumio 1.55 on a Raspberry Pi 3 (if the links are still valid and not updated to Volumio 2) in combination with a 480x320 3.5” LCD to work as a stand-alone music player
First install a copy of the Raspbian image from https://www.raspberrypi.org/downloads/raspbian/ on a Micro SD Card of at least 8 GB. We used 2016-09-23-raspbian-jessie.img. The 3.5” LCD we used comes with a preinstalled Raspian image but we strongly recommend not to use it. This image eventually produced errors (language incompatibilities and more)
Connect a monitor (HDMI), mouse and keyboard
After start-up has finished open a terminal and run:
sudo apt-get update
sudo apt-get upgrade (be patient, this may take a while)
sudo raspi-config (to extend the partition to the full size of the micro SD card and maybe change the keyboard layout to your country, default is English UK)
sudo rpi-update (this updates the firmware of the Raspberry Pi to the latest version)
sudo reboot (to reboot and reactivate the new firmware)
sudo apt-get install midori (an internet browser we know how to start full screen)
Following instructions to disable the screensaver are often given but didn’t work.
sudo nano ~/.config/lxsession/LXDE-pi/autostart it should contain the following lines:
#@xscreensaver -no-splash
@xset s off #disable screensaver
@xset -dpms
@xset s noblank #disable screensaver blanking
@unclutter -idle 0 #disable mouse pointing
midori -e Fullscreen -a http://localhost
Another instruction that should disable the screensaver permanently (worked for us):
sudo nano /etc/lightdm/lightdm.conf and add in the [SeatDefaults] section the following command:
xserver-command=X -s 0 -dpms
sudo apt-get remove --purge minecraft-pi –y (not needed, remove application)
sudo apt-get remove --purge wolfram-engine –y (not needed, remove application, saves space)
sudo reboot (alt-F4 to close midori)
sudo apt-get install alsa-utils mpd mpc minidlna usbmount ntfs-3g -y
sudo nano /etc/mpd.conf comment the following line with #
bind_to_address "localhost"
sudo apt-get install nginx sqlite3 php5-fpm php5-curl php5-sqlite php5-cli php5-gd php5-imagick -y
sudo apt-get install samba samba-common-bin -y
sudo apt-get install ntfs-3g minidlna autofs -y
sudo nano /etc/auto.master add the following line at the end:
/media/ /etc/auto.ext-usb --timeout=10,defaults,user,exec,uid=1000
sudo mkdir /var/www (probably exists already)
sudo mkdir /mnt/disk1
sudo mkdir /mnt/disk2
sudo mkdir -p /mnt/NAS
sudo mkdir -p /mnt/USB
sudo ln -s /mnt/NAS /var/lib/mpd/music/NAS
sudo ln -s /mnt/USB /var/lib/mpd/music/USB
sudo git clone https://github.com/volumio/Volumio-WebUI.git /var/www if next error appears:
fatal: destination path ‘/var/www’ already exists and is not an empty directory.
sudo rm -r /var/www (to delete all contents in /var/www and try again)
sudo chmod 775 /var/www/_OS_SETTINGS/etc/rc.local
sudo chmod 755 /var/www/_OS_SETTINGS/etc/php5/mods-available/apc.ini
sudo chmod -R 777 /var/www/command/
sudo chmod -R 777 /var/www/db/
sudo chmod -R 777 /var/www/inc/
sudo cp -var /var/www/_OS_SETTINGS/etc /
cd /var/lib/mpd/music ; sudo ln -s /mnt/disk1/Music
sudo ln -s /mnt/NAS /var/lib/mpd/music/NAS
sudo ln -s /mnt/USB /var/lib/mpd/music/USB
sudo reboot
At this stage the LCD is still not used, just the HDMI output.
To use the 3.5” display from Waveshare, copy the driver on the CD (in our case the file was called LCD-show-160520.tar.gz) to a directory on the Raspberry Pi. Easiest way to do this is the use of thumb drive. Follow the instruction in the user manual on the CD. It states to run ‘tar xvf LCD-show.tar.gz’.
But of course use the correct path and filename and then run (depending on the location you copied the driver file to):
tar xvf /home/pi/Documents/LCD-show-160520.tar.gz and then run
sudo ./LCD35-show
The system will reboot and Volumio should appear in full screen on the LCD. If you still want to use the Raspberry Pi for other purposes pressing F11 will leave full screen and the Desktop is accessible. Pressing F11 again will put Midori in full screen again (if it’s the active window). Adding/changing contents to a location in Volumio to the library requires a reboot before it becomes visible and accessible.
Because the installation of the LCD overwrites or changes /boot/config.txt we save enabling hifiberry to last. Add the following lines to the file /etc/modules:
snd_soc_bcm2708
bcm2708_dmaengine
snd_soc_hifiberry_dac
Configure ALSA
Create /etc/asound.conf with the following content:
pcm.!default {
type hw card 0
}
ctl.!default {
type hw card 0
}
Enable I2S in /boot/config.txt
Uncomment or add the line:
dtparam=i2s=on
Add line:
dtoverlay=hifiberry-dac
If finally everything works there’s one minor issue. The Menu item ‘Turn off’ is outside the screen on the LCD. To properly powering down the player is either by WebUI on an external device or through the use of an to the RPi attached keyboard and mouse. Getting to know Volumio will prove easy. To get the first track playing after power up one has to push play 3 or 4 times…!?
Measurements
Laboratory Power supply 8 V, 10 kΩ connected to both outputs
S1-1 = L (De-emphasis for 44.1 kHz disabled)
S1-2 = L (Digital Filter Roll Off Sharp)
S1-3 = L (Monaural mode disabled)
S1-4 = L (Mute off)
S1-5 = L, S1-6 = L (I2S mode)
S1-7 = H (Reset disabled)
Supply current (K7) no data 120 mA
32 kHz 127.5 mA
44.1 kHz 131.7 mA
48 kHz 133 mA
96 kHz 149.5 mA
192 kHz 182.1 mA
THD+N
Sampling frequency 48kHz 96 kHz 192 kHz
1 kHz B = 22 kHz 0.0008 % 0.0009 % 0.0013 %
B = 80 kHz 0.0028 % 0.0012 % 0.0014%
7 kHz B = 22 kHz 0.00095 % 0.0011 % 0.0013 %
B = 80 kHz 0.003 % 0.0014 % 0.0016 %
IMD
50 Hz : 7 kHz = 4 : 1 0.0014 % 0.002 % 0.0036 %
Bandwidth analog filter 64.5 kHz
Maximum sine wave 1.06 V
We also recorded some plots with our Audio Precision Analyzer
Plot A shows amplitude as a function of frequency using a stepped sine wave with 70 frequencies at full-scale and a sample frequency of 192 kHz. The upper (green) curve is recorded with sharp roll off mode. The lower curve (cyan) is recorded with the digital filter in slow roll off mode. The cut-off frequency is 63.5 kHz (theoretically 64.5 kHz). At 90 kHz amplitude is -9.2 dB for the sharp roll off mode and -12.3 dB for slow roll off mode. At 45 and 51 kHz the amplitudes are the same for both, -0.5 and -1 dB respectively.
Plot B shows channel separation as a function of frequency. The upper curve (green) is the crosstalk from the left channel on the right channel. This curve is slightly higher than the other way around (cyan curve is crosstalk from right to left). The connection to the RCA output connectors are not of equal length. The track for the right output signal is longer and therefore the crosstalk from left to right is higher. But considering the compact design this is pretty good. The levels are in the µV range. Although measurement is done with a sharp band filter and measurements are averaged noise at these low levels makes the curves a bit jumpy. This measurement was performed using two stereo stepped sine waves with 100 frequencies and a sampling frequency of 96 kHz with the other channel digital 0.
Plot C shows total harmonic distortion plus noise as a function of frequency at sampling rates of 48, 96 and 192 kHz. The bandwidth is 80 kHz for all three measurements. The THD+N at a sampling frequency of 48 kHz is much lower if we use a bandwidth of 22 kHz. If we look at the frequency spectrum we see a increase in noise just outside the audio bandwidth. We suspect this is due to noise shaping at 48 kHz. This increase in noise is absent in the spectra of 96 and 192 kHz sampling frequency.
Plot D shows the FFT analysis of a 1 kHz full-scale sine wave at a sampling frequency of 32 kHz. Noticeable is the increase in noise just above the audio bandwidth (noise shaping?). THD+N at a bandwidth of 22 kHz is just 0.0007 % (0.012% at 80 kHz). A lot of spurious frequencies are visible caused by the Raspberry Pi just underneath (common mode noise from the power supply of the RPi, a simple AC adapter with USB output), surrounding equipment at the test setup and maybe jitter from the master clock. But -120 dB means 1 µV! The second and third harmonic are barely visible (around -120 dB)
Plot E shows the FFT analysis of a 1 kHz full-scale sine wave at a sampling frequency of 44.1 kHz. The high frequency noise is less than the 32 kHz plot. THD+N at a bandwidth of 22 kHz is 0.0006 % (0.0038 % at 80 kHz). The other frequencies are not that different and look very much like the 32 kHz plot. The second and third harmonics are a bit more prominent, -117 and -118 dB respectively. This amount to a harmonic distortion (just the two harmonics without noise) of only 0.00019 %.
Plot F shows the FFT analysis of a 1 kHz full-scale sine wave at a sampling frequency of 48 kHz. Best guess is with higher sampling frequency more RF noise is picked up at the analog side of the DAC. But don’t let the plot fool you. THD+N at a bandwidth of 22 kHz is only 0.0008 % (0.0028 % at 80 kHz). The high frequency noise is a little lower compared to the 44.1 kHz plot.
Plot G shows the FFT analysis of a 1 kHz full-scale sine wave at a sampling frequency of 96 kHz. The high frequency noise is gone and a instead a highly suppressed sampling frequency is visible. The harmonics have increased but none the less THD+N at a bandwidth of 22 kHz is 0.0009 % (0.0012 % at 80 kHz).
Plot H shows the FFT analysis of a 1 kHz full-scale sine wave at a sampling frequency of 192 kHz. The sampling frequency is outside the range of our Audio Precision analyzer. Distinct difference is the increase in amplitude of the harmonics which shows clearly in the THD+N of 0.0013 % at a bandwidth of 22 kHz (0.0014 % at 80 kHz). For the most part due to the third harmonic. But THD+N is better than the typical value in datasheet. And our measurement is done at almost a fifth of the output voltage from the datasheet (4.5 V).
The following plots are made using16 bit wave files resampled on the fly, a feature in Volumio 1.55. The same sampling frequencies are used in the 16 bit files as the previous plots and are resampled to 24 bit and a sampling frequency of 96 kHz. As already explained the resampling to 24 bit (or 32) is necessary to play 16 bit files with Volumio.
Plot I shows the FFT analysis of a 16 bit 1 kHz full-scale sine wave at a sampling frequency of 32 kHz resampled to 24 bit/96 kHz. At a first glance the spectrum looks ‘cleaner’ but not really. The noise floor and the harmonics are higher. THD+N at a bandwidth of 22 kHz is 0.0016 % (0.0019 % at 80 kHz). This value is purely caused by the increase in harmonics (the source is only 16 bit!). Noticeable is the absence of the high frequency noise visible in plot D.
Plot J shows the FFT analysis of a 16 bit 1 kHz full-scale sine wave at a sampling frequency of 44.1 kHz resampled to 24 bit/96 kHz. Numerous intermodulation frequencies but at a lower level than the harmonics and the sudden drop of the noise floor at 20 kHz are clearly different from plot I and caused by the ratio of the two sampling frequencies. THD+N is at a bandwidth of 22 kHz is 0.0017 % (0.002 % at 80 kHz).
Plot K shows the FFT analysis of a 16 bit 1 kHz full-scale sine wave at a sampling frequency of 48 kHz resampled to 24 bit/96 kHz. Due to the lower resolution the harmonic distortion is slightly higher and also the high frequency noise is gone. THD+N at a bandwidth of 22 kHz is 0.002 % (0.0022 % at 80 kHz).
Plot L shows the FFT analysis of a 16 bit 1 kHz full-scale sine wave at a sampling frequency of 96 kHz resampled to 24 bit/96 kHz. Some intermodulation frequencies above 20 kHz are visible now that were not present in plot G. Is this audible? THD+N at a bandwidth of 22 kHz is 0.0016 % (0.002 % at 80 kHz).
Plot M shows the FFT analysis of a 16 bit 1 kHz full-scale sine wave at a sampling frequency of 192 kHz resampled to 24 bit/96 kHz. Surprisingly the number of intermodulation frequencies are few. Distortion is mainly defined by harmonics. THD+N at a bandwidth of 22 kHz is 0.0015 % (0.0018 % at 80 kHz).
Bill of materials
Resistor
R1,R2,R3,R4,R7,R10,R13,R16 = 360 Ω, 125 mW, 1 %, SMD 0805
R5,R8,R11,R14,R34 = 1 k, 125 mW, 1 %, SMD 0805
R6,R9,R12,R15 = 560 Ω, 125 mW, 1 %, SMD 0805
R17,R18 = 47 Ω, 125 mW, 1 %, SMD 0805
R19 = 270 Ω, 125 mW, 1 %, SMD 0805
R20 = 10 k, 125 mW, 1 %, SMD 0805
R21 = 47k, Resistor Array 7 bussed, 125 mW, 2 %
R22,R23,R24,R25 = 22 Ω, 125 mW, 1 %, SMD 0805
R26,R27 = 0 Ω, 125 mW, 1 %, SMD 0805
R28 = 300 k, 125 mW, 1 %, SMD 0805
R29,R33 = 100 k, 125 mW, 1 %, SMD 0805
R30 = 150 k, 125 mW, 1 %, SMD 0805
R31 = 51 k, 125 mW, 1 %, SMD 0805
R32 = 180 k, 125 mW, 1 %, SMD 0805Ω
Capacitor
C1,C2,C5,C6,C9,C14 = 6n8, 63 V, 1 %, polystyrene, EXFS/HR 6800PF +/- 1%, LCR Components
(alternative lead spacing 5 mm or 0805)
C3,C4,C7,C8,C12,C13,C17,C18,C29,C34,C35 = 100 n, 50 V, 10 %, X7R, SMD 0805
C10,C11,C15,C16 = 2n2, 63 V, 1 %, polystyrene, EXFS/HR 2200PF +/- 1%, LCR Components
(alternative lead spacing 5 mm or 0805)
C19,C23,C25,C27 = 10µF, 35V, 0.04Ω, diam. 6.3 mm max., lead spacing 2/2.5 mm
870055673001 (WCAP-PTHR Series), Würth Elektronik
C20,C21 = 10 µF, 63V, 1.06 Ω, diam. 6.3 mm max., lead spacing 2/2.5mm
UPM1J100MDD, Nichicon
C22,C24,C26 = 47 n, 50 V, 10 %, X7R, SMD 1206
C28 = 10 n, 50 V, 10 %, X7R, SMD 0603
C30,C31,C32,C33,C36,C37,C40,C41,C43,C44,C46,C47,C48,C49,C52,C53 = 4µ7, 25 V, 10 %, X5R, SMD 0805
C38,C39,C50,C51 = 10 n, 50 V, 10 %, X7R, SMD 0805
C42 = 2µ2, 10 V, 10 %, X7R, SMD 0805
C45,C55 = 1 µ, 16 V, 10 %, X7R, SMD 0805
C54 = 47 µF, 16 V, 20 %, X5R, SMD 1210
C56,C57 = 10 µF, 25 V, 10 %, X5R, SMD 1206
C58 = 47 µF, 16 V, 10 %, tantalum, SMD Cased C (2312), TR3C476K016C0350, Vishay
Inductor
L1,L2,L3,L4,L6,L7 = 600 Ω @ 100 MHz, 0.15 Ω, 1.3 A, SMD 0603, BLM18KG601SN1D, Murata
L5 = ACM4520-231-2P-T, 2 x 0.05 Ω, 230 Ω @ 100 MHz, 2.6 A, SMD, TDK
Semiconductor
D1 = PMEG6030EP, 60 V, 3 A, SMD SOD-128
LED1,LED2 = Led, green, low-power, SMD 0805
IC1 = PCM1794ADB., SMD SSOP-28
IC2,IC3 = LME49720MA/NOPB, SMD SOIC-8
IC4,IC5 = LME49710MA, SMD SOIC-8
IC6 = ICS570BILF, SMD, SOIC-8
IC7,IC9 = TPS7A4901DGNT, SMD MSOP-8
IC8 = LM27761DSGT, SMD WSON-8
IC10 = TPS7A4700RGWT, SMD VQFN-20
Other
K1 = RCA phono jack, white, PCB mount, right angle, gold, PJRAN1X1U02AUX, Switchcraft
K2 = RCA phono jack, red, PCB mount, right angle, gold, PJRAN1X1U03AUX, Switchcraft
K3,K4,K6 = 3-way pinheader, vertical, pitch 2.54 mm
K3,K4 = Shunt jumper, 2.54 mm spacing
K5 = 40-pin GPIO Stacking Header - 2x20 Female - Extra Tall
K7 = DC Power Connector, Jack, 3 A, 1.95 mm, Lumberg NEB 21 R
S1 = 7-way DIP switch
4 M2.5 17 mm standoffs
4 M2.5 6mm screws
4 M2.5 nuts
Misc.
PCB 160198-1 v1.1
Power supplies
The PCM1794A (IC1) requires two different power supply voltages. +3.3 V for the digital part and +5 V for the analog part. Later on we will explain why we increased this supply voltage to +5.2 V (still within recommended operating range!). We could use the RPi power supplies available on the GPIO Expansion connector but these are very noisy. We need to make an independent +3.3 V and +5 V. Another option is to use the power supply of the DAC to supply the RPi. But that would mean degrading the power supply of the DAC. Downside of keeping the power supplies separate is two DC adapters are needed. To avoid having to use a third power supply for the I/V-converter and analog output filter a negative power supply is derived from the +5 V. The positive supply voltage for the analog output section is set to 4.74 V using a low noise regulator and the negative power supply is also derived from the +5.2 V power supply using a special Low-Noise Regulated Switched Capacitor Voltage Inverter: the LM27761 (IC8). As the name explains it uses switched-capacitor techniques to invert the input voltage followed by a linear low noise regulator to create a stabilized negative supply voltage. In our case the output voltage is set to -4.81 V by divider R30/R31 (Vout = -(R30/R31 + 1) * 1.22 V). The IC can supply up to 250 mA and the IC measures only 2 x 2 mm. It’s size and operating frequency of 2 MHz means very little noise is introduced. Two ultralow-noise positive linear regulators of type TPS7A4901 are used for the +3.3 V (IC9) and +4.74 V (IC7) ensuring the best power supply quality for the DAC and filters. The maximum output current is 150 mA The output voltages (Vout = (R28/R29 + 1) * 1.185 V) are set to +4.74 V by divider R28/R29 and +3.3 V by divider R32/R33.
Ultralow-noise low-dropout voltage regulator TPS7A4700 is used to generate the +5.2 V main power supply. It can deliver 1 A output current and has a low drop-out voltage of 307 mV (at 1 A). It has internal resistors so the output voltage can be set by connecting specific pins to ground. If connected to ground each pin adds a voltage to the output. The minimum voltage is the reference voltage of 1.4 V. To get +5.2 V pins 6, 10 and 11 are connected to ground: Vout = 1.4 + 3.2 + 0.4 + 0.2 V = 5.2 V. The slightly higher output voltage was chosen to ensure the maximum undistorted output voltage of the filter stages can be 1 V. Conventional maximum output voltage is often 2 VRMS but that would require rail to rail opamps or a higher supply voltage. A design criteria was to avoid additional power supply voltages. Most rail-to-rail opamps don’t have the specifications that special high quality audio opamps have. We used two dual opamps type LME49720 for the I/V-converters and two single opamps type LME49710 for the filters. Although their power supply range is specified ±2.5 V to ±17 V the linear output voltage range measurements have shown the linear output voltage range (at this low power supply voltage) is a about 1.4 V from each supply line. The I/V-converter is the limiting factor here, partially caused by the low resistor values (higher drop across the internal output transistors). This is discussed in the filter section in more detail. This is the reason the original symmetrical power supply voltage of ±4.5 V was increased to +4.74 V and – 4.81 V (the use of E-24 values provide these voltages). Now the maximum (0 dB) output voltage of 1.06 V is undistorted.
The input for the power supply (K7) is protected against wrong polarity by a schottky diode (D1). The voltage drop across the diode is about 0.3 V. At 8 V input voltage the supply current is 124 mA playing at a sample rate of 32 kHz and 184 mA playing at a sample frequency of 192 kHz.
Master clock
Making the audio DAC work we configured Raspbian (operating system of the RPi) for a HiFiBerry DAC. If this is done correctly I2S serial bus signals (Inter-IC Sound) are available on the GPIO Expansion connector. Official names of the signals are continuous serial clock SCK (or bit clock BCLK/BCK), word select WS (or left-right clock LRCLK/LRCK) and serial data SD (or SDATA/DATA and many more). Originally not part of the I2S standard is a master clock needed to synchronize devices. The master clock is missing on the expansion connector and so our circuit has to generate one. For this purpose we added a frequency multiplier with integrated PLL. The ICS570BILF from IDT has a zero delay buffer which means the rising edges of input and outputs are perfectly aligned. The multiplication can be set from 0.5x to 32x by two three level inputs (S0/S1). Output range of CLK is according to the AC Electrical Characteristics 10 to 170 MHz. We set the multiplication to 6x using the CLK/2 output and connected it to the feedback input. This configuration has the best input range setting. According to the Clock Multiplier Decoding Table and M/M setting in the datasheet setting both S0 and S1 to M (unconnected) the input range is 2.5 to 12.5 MHz and the output range is 15 to 75 MHz. This would mean that a 32 kHz sample frequency track should not be able to play, yet is does and it does so perfectly. But there is a bigger problem. To test the audio DAC all kinds of 32 bit wave files were used: stepped sine, stepped amplitude, single tone and IMD with sample frequencies from 32 kHz to 192 kHz. Doing tests with a few 24 bit wave files gave exact same results. So next to do were tests and measurements with 16 bit waves and big surprise: no output signal! What the f***…Well it took it a long time to come to the conclusion that although the datasheet states the PCM1794A supports 16 and 24 bit audio, it does not in the I2S mode. The only indication I found in the datasheet (SLES117B –AUGUST 2004–REVISED DECEMBER 2015) was in Figure 22. Audio Data Input Formats. The timing diagram for I2S Data Format mentions Audio Data Word = 24-Bit. And there’s no other I2S diagram. The audio player used by Volumio halves the serial clock and data bits when the audio data is 16 bit. Setting the master clock to higher frequencies doesn’t help. Does this mean 16 bit audio is not supported in our setup. Well yes and no. Playing the song directly doesn’t work but luckily the version of Volumio we used (1.55) still has an option for sample rate conversion (three quality settings). A variety of sample rates and bit combinations are available. This feature should be implemented in a next update of Volumio 2 (version 2.041 of 12-12-2016 still doesn’t, but then Volumio 2 has internet radio, and plug-ins…).
Table 1:
fs[kHz] bits BCK[MHz] S0 S1 * SCK[MHz] output signal
32 24/32 2.048 M M 6 12.288 yes
44.1 24/32 2.8224 M M 6 16.9344 yes
48 24/32 3.072 M M 6 18.432 yes
96 24/32 6.144 M M 6 36.864 yes
192 24/32 12.288 M M 6 73.728 yes
32 16 1.024 M M 6 unstable no
44.1 16 1.4112 M M 6 unstable no
48 16 1.536 M M 6 9.216 no
96 16 3.072 M M 6 18.432 no
192 16 6.144 M M 6 36.864 no
M (half the supply voltage, unconnected)
16 bit audio data can be the reason there’s no sound using internet radio in Volumio 2. Use resampling to 24 bit to get the music playing. If anyone has a solution how to keep the I2S bus in 32 bit data mode permanently please let us know.
Other master clock frequencies can be set by S0 and S1 located on the bottom side by using 0 Ω resistors (0805) or thin wires. Don’t connect all three pads of JP1 and JP2. This will short circuit the +3.3 V power supply.
PCM1794ADB
The DAC has a built-in 8x oversampling digital filter and is compatible with sampling frequencies from 10 to 200 kHz. The datasheet also states ‘Accepts 16-Bit and 24-Bit Audio Data’ but apparently not in I2S mode. I’m not going to duplicate the contents of the datasheet but instead walk through the schematic. The I2S signals are connected through four 22 Ω resistors (R22..R25) to prevent RF noise of these high frequency signals getting to the analog side of the DAC. At a sampling rate of 192 kHz our master clock is almost 74 MHz! The hardware select lines (MONO, CHSL, DEM, MUTE, FMT0, FMT1, RESET) are connected to a 7way DIP switch and a 7way 47 kΩ resistor array used as pull-ups. This makes changing settings very easy. The zero output (pin 13), active when the audio input data in the L-channel and the R-channel is continuously zero for 1024 LRCKs in the PCM mode (or 1024WDCKs in the external filter mode), is connected to LED1 indicating the absence of data. The minimum output level of the ZERO output at a current of 2 mA is according to the datasheet 2.4 V. This is enough for a green led. In our prototype the output voltage was 3.09 V and the led current 4.3 mA. The output current reference bias pin 20 is connected to a 10 kΩ resistor. This is according to the typical application schematic and evaluation board but other than the value no information is given. The left and right channel internal bias decoupling pins (VCOML/VCOMR) are decoupled by 10 µF electrolytic capacitors but again no information is given. To decouple the power supplies we used aluminum polymer capacitors (C19,C23,C25,C27) because of their low ESR (40 mΩ @ 100 kHz). Downside of these capacitors is the relatively high leakage current of 100 µA maximal. Since it is unclear if this leakage current will influence the internal bias setting two normal electrolytic capacitors are used (1.06 Ω @ 100 kHz and 4 µA leakage current). For those who like to experiment footprints of all electrolytic capacitors are designed to hold 2 to 2.5 mm pitch capacitors with a maximum diameter of 6.3 mm. The 47 nF ceramic decoupling capacitors of the power supply pins (C22,C24,C26) are size 1206 with X7R dielectric. Would the use of NP0/C0G dielectric improve performance?
The output filter
Although sampling artifacts are largely suppressed by the 8x digital oversampling filter there are still high frequency components present. A reconstruction filter is used to suppress them. But since we’re using an 8x oversampling filter its task is foremost suppressing the higher frequencies above half the sample frequency. A 3rd order Butterworth is used. The I/V-converters IC2/IC3 are part of the filter. The cut-off frequency is 64.5 kHz. At a sampling frequency of 44.1 kHz the 8x frequency component of 352.8 kHz is suppressed by more than 40 dB. At a sampling frequency of 192 kHz the 8x frequency component will be suppressed by approximately 80 dB. The chosen cut-off frequency is of course a compromise between sufficient filtering at lower sampling frequencies and low frequency bandwidth of the audio signal at the higher sampling frequencies. The filter bandwidth is now more than three times the human hearing range. The DAC has balanced current outputs so an external filter can be used. To convert these balanced currents to a single ended output signal first an I/V-converter per output is needed. The two voltages of IC2A/IC2B (IC3A/IC3B) are followed by a 2nd order filter stage configured as a differential to single ended amplifier. IC4 for the left channel and IC5 for the right channel. The topology is a differential multiple feedback filter. Combined with the filtering of the I/V-converter the total filter characteristic is a 3rd order Butterworth filter. The filter was calculated with exact E-12 values for the capacitors and theoretical values for the resistors. The resistor values were rounded to E-24 values.
In our prototype the balanced output currents were just 5.8 mA (no signal) instead of the 6.2 mA according to the datasheet. If the tolerance is this big (6.5 %) there’s also the possibility the current is equally higher. Hopefully this doesn’t mean the I/V-converter is clipping if a full-scale signal is applied. Not only is the center current lower but the full-scale peak-peak current is also proportionally lower. The measured output voltages of the I/V-converters were 2.08 in one channel and 2.06 in the other. Peak-peak voltage was about 2.7 Vp-p. Maybe tweaking R20 is an option in case the signals are clipping at full-scale. We haven’t tried. Another option to use a higher symmetrical power supply for the filter. In that case remove 0 Ω resistors R26 and R27 and connect the external power supply to K6.
For the output stage a multiple feedback filter is used since it can easily be extended to also function as differential to single ended converter. If familiar with a standard multiple feedback filter transforming it to one with a differential input is simple. Just mirror the circuit connected to the inverting input and place it at the non-inverting input. The resistor and capacitor connected to the output are connected to ground. That’s it, well almost. If you look at the circuit you see that there’s only one capacitor (C9/C14) were you would expect two capacitors connected to ground. The original two capacitors can be combined to one with only half the value. The bigger the value of high quality capacitors like we used in the filter the higher the cost. By replacing two capacitors by one smaller capacitor per channel we save some money but more importantly we save space. The idea was to keep the PCB of the DAC exactly the same size as the RPi PCB and components should only be mounted on the top side. To limit the output voltage to 1 V the filter has to attenuate the differential signal of the I/V-converters. Gain of IC4/IC5 is 0.56, set by the ratio of R6/R5 and R9/R8. DC output offset is only in the mV range. -1.6 mV in one channel and +1.3 mV in the other channel. The common mode voltage of both I/V-converters per channel is suppressed by IC4 and IC5. The single ended output signal is made available on PCB mounted RCA connectors K1 and K2 through connectors K3 and K4. A shunt jumper on K3/K4 can be used to make a direct connection to the RCA connectors. K3 and K4 can also be used to connect a stereo potentiometer to have a simple volume control. The DAC itself has no volume control. Volumio can change volume by software but then resolution is lost. This would seriously compromise sound quality and is not really an option. Another possibility is to insert a hardware volume control like a PGA2311 (another PCB) and change volume by remote control (work in progress). Recently there is plug-in available for Volumio 2 to connect push buttons to the RPi to control basic functions. These can be added to the other PCB.
The symmetrical analog power supply for the filter and the I/V-converter is decoupled from the digital power supplies by a common-mode choke and RF inductors for each channel.
PCB
Only a single power supply of 7 to 8 V is needed (K7). The RPi works on a separate 5 V! Any higher will cause more dissipation in the voltage regulator IC10 but 9 or 12 V are also possible. The DC power connector jack and RCA phono jacks are on the same side. DIP switch S1 is on the opposite side of the PCB. This is the spot on the RPi 3 where the WiFi antenna is located. The 40-pin GPIO Stacking Header K5 is mounted on the bottom side. Don’t put the plastic body of the header against the PCB but keep it 1 to 1.5 mm from the PCB and keep the distance equal (perfect parallel to the PCB) so it will fit on the corresponding connector on the RPi without a problem. Cut the protruding pins on the bottom side of K1, K2, K3, K4, K6 and K7 as short as possible to avoid short circuits occur with the metal cases from the network and USB connectors on the RPi. Maybe place something insulating in-between. We used four M2 screws of sufficient length to act as spacers (and 12 nuts). The standard spacers are not long enough. The footprint for the capacitors that are part of the filter is designed so 3 different types of capacitors can be used (C1, C2, C5, C6, C9, C10, C11, C14, C15, C16). SMD 0805 capacitors can be used but also standard through hole capacitors with 5 mm spacing. We strongly recommend the use of 1 % polystyrene capacitors for best performance (see BOM). These capacitor have the pins placed diagonally. The number 1 pins of all ICs are marked with a white dot next to it. The dot of IC7 is a bit hard to see, it is half absorbed by C38. Because there is not enough space to place the designators of all 0805 resistors and 0805 and 1206 capacitors next to the components they are placed inside the component. This means they will not be visible on the PCB. If the components are soldered by hand (hot air or oven) use an enlarged print out of the top overlay to place all SMD at the right place. Many 0805 components are not easily replaced once the through hole components are mounted! Through hole components should be mounted last. Jumpers JP1 and JP2 are located at the bottom. But by default these can be left open (SCK = 6 x BCK). The RCA Phono connectors are types from Switchcraft and have two connection closer together than more standard 10 mm versions. If other types are used they probably won’t fit!
Place the 3.5” display 17 mm above the Audio DAC. Don’t push the connector all the way through. The connector should make sufficient contact. If doubtful use another standard size stacking header and place the display higher. The 26way socket of the display will then be at a distance of about 3,5 mm from the Audio DAC PCB. 17 mm M2.5 standoffs can be used (Ettinger 05.12.173, Farnell 1466854) to secure the Audio DAC on top of the Raspberry Pi.
Volumio 1.55
The following text is a step-by-step description how to install Volumio 1.55 on a Raspberry Pi 3 (if the links are still valid and not updated to Volumio 2) in combination with a 480x320 3.5” LCD to work as a stand-alone music player
First install a copy of the Raspbian image from https://www.raspberrypi.org/downloads/raspbian/ on a Micro SD Card of at least 8 GB. We used 2016-09-23-raspbian-jessie.img. The 3.5” LCD we used comes with a preinstalled Raspian image but we strongly recommend not to use it. This image eventually produced errors (language incompatibilities and more)
Connect a monitor (HDMI), mouse and keyboard
After start-up has finished open a terminal and run:
sudo apt-get update
sudo apt-get upgrade (be patient, this may take a while)
sudo raspi-config (to extend the partition to the full size of the micro SD card and maybe change the keyboard layout to your country, default is English UK)
sudo rpi-update (this updates the firmware of the Raspberry Pi to the latest version)
sudo reboot (to reboot and reactivate the new firmware)
sudo apt-get install midori (an internet browser we know how to start full screen)
Following instructions to disable the screensaver are often given but didn’t work.
sudo nano ~/.config/lxsession/LXDE-pi/autostart it should contain the following lines:
#@xscreensaver -no-splash
@xset s off #disable screensaver
@xset -dpms
@xset s noblank #disable screensaver blanking
@unclutter -idle 0 #disable mouse pointing
midori -e Fullscreen -a http://localhost
Another instruction that should disable the screensaver permanently (worked for us):
sudo nano /etc/lightdm/lightdm.conf and add in the [SeatDefaults] section the following command:
xserver-command=X -s 0 -dpms
sudo apt-get remove --purge minecraft-pi –y (not needed, remove application)
sudo apt-get remove --purge wolfram-engine –y (not needed, remove application, saves space)
sudo reboot (alt-F4 to close midori)
sudo apt-get install alsa-utils mpd mpc minidlna usbmount ntfs-3g -y
sudo nano /etc/mpd.conf comment the following line with #
bind_to_address "localhost"
sudo apt-get install nginx sqlite3 php5-fpm php5-curl php5-sqlite php5-cli php5-gd php5-imagick -y
sudo apt-get install samba samba-common-bin -y
sudo apt-get install ntfs-3g minidlna autofs -y
sudo nano /etc/auto.master add the following line at the end:
/media/ /etc/auto.ext-usb --timeout=10,defaults,user,exec,uid=1000
sudo mkdir /var/www (probably exists already)
sudo mkdir /mnt/disk1
sudo mkdir /mnt/disk2
sudo mkdir -p /mnt/NAS
sudo mkdir -p /mnt/USB
sudo ln -s /mnt/NAS /var/lib/mpd/music/NAS
sudo ln -s /mnt/USB /var/lib/mpd/music/USB
sudo git clone https://github.com/volumio/Volumio-WebUI.git /var/www if next error appears:
fatal: destination path ‘/var/www’ already exists and is not an empty directory.
sudo rm -r /var/www (to delete all contents in /var/www and try again)
sudo chmod 775 /var/www/_OS_SETTINGS/etc/rc.local
sudo chmod 755 /var/www/_OS_SETTINGS/etc/php5/mods-available/apc.ini
sudo chmod -R 777 /var/www/command/
sudo chmod -R 777 /var/www/db/
sudo chmod -R 777 /var/www/inc/
sudo cp -var /var/www/_OS_SETTINGS/etc /
cd /var/lib/mpd/music ; sudo ln -s /mnt/disk1/Music
sudo ln -s /mnt/NAS /var/lib/mpd/music/NAS
sudo ln -s /mnt/USB /var/lib/mpd/music/USB
sudo reboot
At this stage the LCD is still not used, just the HDMI output.
To use the 3.5” display from Waveshare, copy the driver on the CD (in our case the file was called LCD-show-160520.tar.gz) to a directory on the Raspberry Pi. Easiest way to do this is the use of thumb drive. Follow the instruction in the user manual on the CD. It states to run ‘tar xvf LCD-show.tar.gz’.
But of course use the correct path and filename and then run (depending on the location you copied the driver file to):
tar xvf /home/pi/Documents/LCD-show-160520.tar.gz and then run
sudo ./LCD35-show
The system will reboot and Volumio should appear in full screen on the LCD. If you still want to use the Raspberry Pi for other purposes pressing F11 will leave full screen and the Desktop is accessible. Pressing F11 again will put Midori in full screen again (if it’s the active window). Adding/changing contents to a location in Volumio to the library requires a reboot before it becomes visible and accessible.
Because the installation of the LCD overwrites or changes /boot/config.txt we save enabling hifiberry to last. Add the following lines to the file /etc/modules:
snd_soc_bcm2708
bcm2708_dmaengine
snd_soc_hifiberry_dac
Configure ALSA
Create /etc/asound.conf with the following content:
pcm.!default {
type hw card 0
}
ctl.!default {
type hw card 0
}
Enable I2S in /boot/config.txt
Uncomment or add the line:
dtparam=i2s=on
Add line:
dtoverlay=hifiberry-dac
If finally everything works there’s one minor issue. The Menu item ‘Turn off’ is outside the screen on the LCD. To properly powering down the player is either by WebUI on an external device or through the use of an to the RPi attached keyboard and mouse. Getting to know Volumio will prove easy. To get the first track playing after power up one has to push play 3 or 4 times…!?
Measurements
Laboratory Power supply 8 V, 10 kΩ connected to both outputs
S1-1 = L (De-emphasis for 44.1 kHz disabled)
S1-2 = L (Digital Filter Roll Off Sharp)
S1-3 = L (Monaural mode disabled)
S1-4 = L (Mute off)
S1-5 = L, S1-6 = L (I2S mode)
S1-7 = H (Reset disabled)
Supply current (K7) no data 120 mA
32 kHz 127.5 mA
44.1 kHz 131.7 mA
48 kHz 133 mA
96 kHz 149.5 mA
192 kHz 182.1 mA
THD+N
Sampling frequency 48kHz 96 kHz 192 kHz
1 kHz B = 22 kHz 0.0008 % 0.0009 % 0.0013 %
B = 80 kHz 0.0028 % 0.0012 % 0.0014%
7 kHz B = 22 kHz 0.00095 % 0.0011 % 0.0013 %
B = 80 kHz 0.003 % 0.0014 % 0.0016 %
IMD
50 Hz : 7 kHz = 4 : 1 0.0014 % 0.002 % 0.0036 %
Bandwidth analog filter 64.5 kHz
Maximum sine wave 1.06 V
We also recorded some plots with our Audio Precision Analyzer
Plot A shows amplitude as a function of frequency using a stepped sine wave with 70 frequencies at full-scale and a sample frequency of 192 kHz. The upper (green) curve is recorded with sharp roll off mode. The lower curve (cyan) is recorded with the digital filter in slow roll off mode. The cut-off frequency is 63.5 kHz (theoretically 64.5 kHz). At 90 kHz amplitude is -9.2 dB for the sharp roll off mode and -12.3 dB for slow roll off mode. At 45 and 51 kHz the amplitudes are the same for both, -0.5 and -1 dB respectively.
Plot B shows channel separation as a function of frequency. The upper curve (green) is the crosstalk from the left channel on the right channel. This curve is slightly higher than the other way around (cyan curve is crosstalk from right to left). The connection to the RCA output connectors are not of equal length. The track for the right output signal is longer and therefore the crosstalk from left to right is higher. But considering the compact design this is pretty good. The levels are in the µV range. Although measurement is done with a sharp band filter and measurements are averaged noise at these low levels makes the curves a bit jumpy. This measurement was performed using two stereo stepped sine waves with 100 frequencies and a sampling frequency of 96 kHz with the other channel digital 0.
Plot C shows total harmonic distortion plus noise as a function of frequency at sampling rates of 48, 96 and 192 kHz. The bandwidth is 80 kHz for all three measurements. The THD+N at a sampling frequency of 48 kHz is much lower if we use a bandwidth of 22 kHz. If we look at the frequency spectrum we see a increase in noise just outside the audio bandwidth. We suspect this is due to noise shaping at 48 kHz. This increase in noise is absent in the spectra of 96 and 192 kHz sampling frequency.
Plot D shows the FFT analysis of a 1 kHz full-scale sine wave at a sampling frequency of 32 kHz. Noticeable is the increase in noise just above the audio bandwidth (noise shaping?). THD+N at a bandwidth of 22 kHz is just 0.0007 % (0.012% at 80 kHz). A lot of spurious frequencies are visible caused by the Raspberry Pi just underneath (common mode noise from the power supply of the RPi, a simple AC adapter with USB output), surrounding equipment at the test setup and maybe jitter from the master clock. But -120 dB means 1 µV! The second and third harmonic are barely visible (around -120 dB)
Plot E shows the FFT analysis of a 1 kHz full-scale sine wave at a sampling frequency of 44.1 kHz. The high frequency noise is less than the 32 kHz plot. THD+N at a bandwidth of 22 kHz is 0.0006 % (0.0038 % at 80 kHz). The other frequencies are not that different and look very much like the 32 kHz plot. The second and third harmonics are a bit more prominent, -117 and -118 dB respectively. This amount to a harmonic distortion (just the two harmonics without noise) of only 0.00019 %.
Plot F shows the FFT analysis of a 1 kHz full-scale sine wave at a sampling frequency of 48 kHz. Best guess is with higher sampling frequency more RF noise is picked up at the analog side of the DAC. But don’t let the plot fool you. THD+N at a bandwidth of 22 kHz is only 0.0008 % (0.0028 % at 80 kHz). The high frequency noise is a little lower compared to the 44.1 kHz plot.
Plot G shows the FFT analysis of a 1 kHz full-scale sine wave at a sampling frequency of 96 kHz. The high frequency noise is gone and a instead a highly suppressed sampling frequency is visible. The harmonics have increased but none the less THD+N at a bandwidth of 22 kHz is 0.0009 % (0.0012 % at 80 kHz).
Plot H shows the FFT analysis of a 1 kHz full-scale sine wave at a sampling frequency of 192 kHz. The sampling frequency is outside the range of our Audio Precision analyzer. Distinct difference is the increase in amplitude of the harmonics which shows clearly in the THD+N of 0.0013 % at a bandwidth of 22 kHz (0.0014 % at 80 kHz). For the most part due to the third harmonic. But THD+N is better than the typical value in datasheet. And our measurement is done at almost a fifth of the output voltage from the datasheet (4.5 V).
The following plots are made using16 bit wave files resampled on the fly, a feature in Volumio 1.55. The same sampling frequencies are used in the 16 bit files as the previous plots and are resampled to 24 bit and a sampling frequency of 96 kHz. As already explained the resampling to 24 bit (or 32) is necessary to play 16 bit files with Volumio.
Plot I shows the FFT analysis of a 16 bit 1 kHz full-scale sine wave at a sampling frequency of 32 kHz resampled to 24 bit/96 kHz. At a first glance the spectrum looks ‘cleaner’ but not really. The noise floor and the harmonics are higher. THD+N at a bandwidth of 22 kHz is 0.0016 % (0.0019 % at 80 kHz). This value is purely caused by the increase in harmonics (the source is only 16 bit!). Noticeable is the absence of the high frequency noise visible in plot D.
Plot J shows the FFT analysis of a 16 bit 1 kHz full-scale sine wave at a sampling frequency of 44.1 kHz resampled to 24 bit/96 kHz. Numerous intermodulation frequencies but at a lower level than the harmonics and the sudden drop of the noise floor at 20 kHz are clearly different from plot I and caused by the ratio of the two sampling frequencies. THD+N is at a bandwidth of 22 kHz is 0.0017 % (0.002 % at 80 kHz).
Plot K shows the FFT analysis of a 16 bit 1 kHz full-scale sine wave at a sampling frequency of 48 kHz resampled to 24 bit/96 kHz. Due to the lower resolution the harmonic distortion is slightly higher and also the high frequency noise is gone. THD+N at a bandwidth of 22 kHz is 0.002 % (0.0022 % at 80 kHz).
Plot L shows the FFT analysis of a 16 bit 1 kHz full-scale sine wave at a sampling frequency of 96 kHz resampled to 24 bit/96 kHz. Some intermodulation frequencies above 20 kHz are visible now that were not present in plot G. Is this audible? THD+N at a bandwidth of 22 kHz is 0.0016 % (0.002 % at 80 kHz).
Plot M shows the FFT analysis of a 16 bit 1 kHz full-scale sine wave at a sampling frequency of 192 kHz resampled to 24 bit/96 kHz. Surprisingly the number of intermodulation frequencies are few. Distortion is mainly defined by harmonics. THD+N at a bandwidth of 22 kHz is 0.0015 % (0.0018 % at 80 kHz).
Bill of materials
Resistor
R1,R2,R3,R4,R7,R10,R13,R16 = 360 Ω, 125 mW, 1 %, SMD 0805
R5,R8,R11,R14,R34 = 1 k, 125 mW, 1 %, SMD 0805
R6,R9,R12,R15 = 560 Ω, 125 mW, 1 %, SMD 0805
R17,R18 = 47 Ω, 125 mW, 1 %, SMD 0805
R19 = 270 Ω, 125 mW, 1 %, SMD 0805
R20 = 10 k, 125 mW, 1 %, SMD 0805
R21 = 47k, Resistor Array 7 bussed, 125 mW, 2 %
R22,R23,R24,R25 = 22 Ω, 125 mW, 1 %, SMD 0805
R26,R27 = 0 Ω, 125 mW, 1 %, SMD 0805
R28 = 300 k, 125 mW, 1 %, SMD 0805
R29,R33 = 100 k, 125 mW, 1 %, SMD 0805
R30 = 150 k, 125 mW, 1 %, SMD 0805
R31 = 51 k, 125 mW, 1 %, SMD 0805
R32 = 180 k, 125 mW, 1 %, SMD 0805Ω
Capacitor
C1,C2,C5,C6,C9,C14 = 6n8, 63 V, 1 %, polystyrene, EXFS/HR 6800PF +/- 1%, LCR Components
(alternative lead spacing 5 mm or 0805)
C3,C4,C7,C8,C12,C13,C17,C18,C29,C34,C35 = 100 n, 50 V, 10 %, X7R, SMD 0805
C10,C11,C15,C16 = 2n2, 63 V, 1 %, polystyrene, EXFS/HR 2200PF +/- 1%, LCR Components
(alternative lead spacing 5 mm or 0805)
C19,C23,C25,C27 = 10µF, 35V, 0.04Ω, diam. 6.3 mm max., lead spacing 2/2.5 mm
870055673001 (WCAP-PTHR Series), Würth Elektronik
C20,C21 = 10 µF, 63V, 1.06 Ω, diam. 6.3 mm max., lead spacing 2/2.5mm
UPM1J100MDD, Nichicon
C22,C24,C26 = 47 n, 50 V, 10 %, X7R, SMD 1206
C28 = 10 n, 50 V, 10 %, X7R, SMD 0603
C30,C31,C32,C33,C36,C37,C40,C41,C43,C44,C46,C47,C48,C49,C52,C53 = 4µ7, 25 V, 10 %, X5R, SMD 0805
C38,C39,C50,C51 = 10 n, 50 V, 10 %, X7R, SMD 0805
C42 = 2µ2, 10 V, 10 %, X7R, SMD 0805
C45,C55 = 1 µ, 16 V, 10 %, X7R, SMD 0805
C54 = 47 µF, 16 V, 20 %, X5R, SMD 1210
C56,C57 = 10 µF, 25 V, 10 %, X5R, SMD 1206
C58 = 47 µF, 16 V, 10 %, tantalum, SMD Cased C (2312), TR3C476K016C0350, Vishay
Inductor
L1,L2,L3,L4,L6,L7 = 600 Ω @ 100 MHz, 0.15 Ω, 1.3 A, SMD 0603, BLM18KG601SN1D, Murata
L5 = ACM4520-231-2P-T, 2 x 0.05 Ω, 230 Ω @ 100 MHz, 2.6 A, SMD, TDK
Semiconductor
D1 = PMEG6030EP, 60 V, 3 A, SMD SOD-128
LED1,LED2 = Led, green, low-power, SMD 0805
IC1 = PCM1794ADB., SMD SSOP-28
IC2,IC3 = LME49720MA/NOPB, SMD SOIC-8
IC4,IC5 = LME49710MA, SMD SOIC-8
IC6 = ICS570BILF, SMD, SOIC-8
IC7,IC9 = TPS7A4901DGNT, SMD MSOP-8
IC8 = LM27761DSGT, SMD WSON-8
IC10 = TPS7A4700RGWT, SMD VQFN-20
Other
K1 = RCA phono jack, white, PCB mount, right angle, gold, PJRAN1X1U02AUX, Switchcraft
K2 = RCA phono jack, red, PCB mount, right angle, gold, PJRAN1X1U03AUX, Switchcraft
K3,K4,K6 = 3-way pinheader, vertical, pitch 2.54 mm
K3,K4 = Shunt jumper, 2.54 mm spacing
K5 = 40-pin GPIO Stacking Header - 2x20 Female - Extra Tall
K7 = DC Power Connector, Jack, 3 A, 1.95 mm, Lumberg NEB 21 R
S1 = 7-way DIP switch
4 M2.5 17 mm standoffs
4 M2.5 6mm screws
4 M2.5 nuts
Misc.
PCB 160198-1 v1.1
Updates from the author
TonGiesberts 3 years ago
To make the 9 V even cleaner the 5 V input voltage of MOD2 is filtered (C3,C4,L1) and the 9 V output with common choke L2. Both output voltages are protected by TVS diodes (D1,D2, Transient Voltage Suppressors).
The official AC-DC adapter for a RPi has a 5.1 V output voltage to compensate for voltage drops caused by the resistance of the cable and USB connector. I added a USB-A connector to the 5 V output. But, using a standard 1 m USB-A to micro-USB cable makes the power supply on the Rpi drop regularly below 4.7 V. Best is to use a shorter 20 cm long micro-USB cable like one from Delock (Cable USB 2.0 Micro-B 2 x open wires). Wire gauge of both wires is 22AWG. There are also types that have thinner 24AWG wires and a length of up to 1.8 m and of course far too long and the 5 V of the Rpi would be too low. In that case it’s best to reduce length to a maximum of 30 cm or so.
One of the features of the MP-LD15-23B05R2 module mentioned in its datasheet is an ‘Ultra-wide 85 - 305VAC and 100 - 430V DC input voltage range’. However, on the actual module itself it says ‘IN 100-277 ~’. But the module has a wide input voltage range, whatever the correct range is. Maybe the values on the module take a certain tolerance into account for safety (?). Maximum output current is 3 A, but in case the load on the 9V is maximal, the maximum output current of the 5 V is about 2.25 A then. The TVN module has 80 % efficiency and would take 0.75 A from the 5V supply (maybe more ?, 9V is the nominal input voltage). I/O isolation is 1600 VDC and the output is short-circuit protected.
The minimum input voltage of the Audio DAC is 7 V and any voltage drop across a standard 1.8 m power cord is not an issue here. Supply current of the DAC is less than 200 mA max. But, you don’t need the 1.8 m and this cord can be shortened quite a bit.
The PCB is designed to fit inside a plastic (ABS) enclosure of Bud Industries, type CU-1474 (dimensions approx. 104 x 57 x 38 mm). Four long screws are part of the package to fasten top to bottom half but not the screws to fix the PCB to the standoffs, 4 #4-1/4 self-tapping screws have to be purchased separately. Be careful when turning these screws to fasten the PCB, a little too much force and the screws will get loose!
The plastic of the enclosure is soft and the rectangular notch for the USB connector and mains power cord can be cut using a sharp knife (be careful not to cut your fingers!). The round holes for a grommet or other strain relief for the low voltage power cords can be filed. This takes little effort and is maybe too easy. Use little force and check correct position and size of the holes regularly. Best location to make holes for all cables is between the edges of top and bottom half of the enclosure.
The use of SMT components is unavoidable when trying to suppress RF radiation from DC-DC converters. But these type of components used here can still be soldered with a soldering iron with a fine tip. Place all SMT components first, two little 0805 capacitors are on the bottom side (C1,C5), each one located as close as possible between the output pins of each module. The through hole components must be soldered with a bigger tip. Consider soldering the power cords for 5 V and 9 V directly into the PCB instead of using the screw terminals. But if you do, do this before fastening the PCB to the enclosure. Keep the two DC power cords at maximum distance from each other, in case there’s still some RF noise coming from the 5V. I didn’t use a strain relief for the short micro-USB cable. Diameter of the Delock version is about 3 mm and if you make the hole a little too small its secured well enough (maybe glue it to the bottom half, not the top also!). The grommet used for the 9V power cord (flat, two parallel wires) is round but very flexible so you can make the hole elongated/oval instead of round. I tied a knot inside the enclosure so the cable will never put strain on the wires to the screw terminal K4. I also tied a knot in the mains cable for the same reason (strain relief for wires to screw terminal K1). If you can find a proper strain relief for the mains power cord that will fit in the side of the enclosure use it. But, this power supply is meant for a static usage and so there will be no repetitive strain on the cables. I didn’t use the led, if connected to a RPi with the Audio DAC the presence of both voltages is already indicated by LED's.
If everything is mounted, before closing the case, connect the power supply to the mains and measure both voltages, but be aware the circuit is connected to the mains then! If a voltage is 0,7 V or there about a TVS diode is probably mounted the wrong way around. Most important, be sure to connect the wires of the micro-USB cable the correct way: red is 5 V, black is GND. The text ‘0 +5V’ next to K3 in the photo of my prototype should be swapped, oops. The zipped gerbers in the attachments are correct. Center contact of the 9 V plug must be positive (wire with white stripe of power cord is plus). The Audio DAC is protected by a diode against wrong polarity, so no harm will be done here should the 9V be connected the wrong way round.
Bill of materials
Resistor
R1 = 6.8 Ω, 3 W, 1500 V pulse (AC03000006808JAC00, Vishay/Draloric)
R2 = 1.5 kΩ, 0.25 W, 5 %
Capacitor
C1,C5 = 1 µF, 25 V, 5 %, SMD 0805
C2 = 220 µF, 16 V, aluminium polymer, 10 mΩ, diam. 8 mm, lead spacing 2.5/3.5 mm (870135374003, Würth Elektronik)
C3,C4 = 22 µF, 25 V, X7R, SMD 1210
C7 = 100 nF, 50 V, 5 %, X7R, SMD 0805
Inductor
L1 = 4.7 µH, 1.2 A, 0.117 Ω, SMD 4x4 mm (TYS40184R7M-10, Laird Performance Materials)
L2 = Common mode choke M-524CT, 0.5 A, 700 Ω @ 10 MHz, RDC 0.1 Ω (Kemet)
Semiconductor
D1 = TVS diode SMBJ7.0A, SMD DO-214AA-2
D2 = TVS diode SMBJ12A, SMD DO-214AA-2
LED1 = 3 mm led, optional
Other
K1 = Terminal block, pitch 7.62 mm (GMKDSN 1.5/ 2-7.62 – 1707027, Phoenix Contact)
K2 = USB Type A Receptacle, PCB mount, (87520-0010BLF, Amphenol ICC)
K3,K4 = Terminal block, pitch 3.5 mm (PT 1,5/ 2-3,5-H – 1984617, Phoenix Contact)
F1 = Leaded fuse 3.15 A, time-delay, 300 VAC, radial pitch 5.08 mm (SS-5H-3.15A-APH, Bussmann/Eaton)
MOV1 = MOV S14K350 (B72214P2351K103, Epcos/TDK)
MOD1 = MP-LD15-23B05R2, AC-DC converter module, 5VDC/15W (Multicomp Pro)
MOD2 = TVN 3-0919, DC-DC converter 3 W, 4.5-13.2V in, 9V/333mA out (Traco Power)
Enclosure CU-1474, black, ABS (Bud Industries)
4 x #4-1/4 self-tapping screw (6004, Serpac)
No Receptacle Power Cord,1.8 m (361002-E01, Qualtek, plug CEE7/XVI for western Europe)
DC power cord for 9 V= DC power cord, 2.1mm DC power plug, 6A max., 24AWG (172-4101, Kobicon)
Cable USB 2.0 Micro-B 2 x open wires, 22 AWG, 20 cm (Delock)
Grommet, flexible, black, inside diameter 3.2 mm (HG-2, Essentra)
b.JPG (1214kb)
c.JPG (1589kb)
d.JPG (1112kb)
schematic-supply-rpi-dac-20210408144446.png (103kb)
Topoverlay_Supply_RPi-DAC.PDF (134kb)
Copper_top_bottom_Supply_RPi-DAC.PDF (123kb)
Gerber_Supply_RPi-DAC.zip (22kb)
TonGiesberts 5 years ago
https://www.runeaudio.com/forum/runeaudio-0-5-beta-for-all-raspberry-pi-models-t6532.html
but also new features are added:
https://www.runeaudio.com/forum/runeaudio-r-e1-an-improved-version-of-runeaudio-t6883.html
The latter is the one I used and is recently updated (20191109). But, there’s even a version for the Raspberry Pi 4. I used the version for a Rpi 3 (RuneAudio+R_e2-RPi2-3.img, for download see link above), because it’s more than powerful enough for an audio player and probably more people already have this one.
Things are a bit different installing the 3.5 inch touchscreen display from Waveshare in the new version compared to the v0.4 beta (RuneAudio_rpi2_rp3_0.4-beta_20160321_2GB) more than two years ago. See project update ‘From the lab - using RuneAudio’ at https://www.elektormagazine.com/labs/audio-dac-for-rpi-networked-audio-player-using-volumio
Before making changes to the image configure RuneAudio for your DAC using the WebUI. Changes in the configuration of RuneAudio after you make changes to the image can have unexpected results. For instance, selecting your DAC in System and MPD menu changes the config.txt file in the /boot directory accordingly. But some lines are also removed that are unrelated to audio, like ’dtoverlay=waveshare35a’, if present. After a reboot the 3.5” LCD won’t work anymore. Probably a bug in a script somewhere (?). So, after changing the config.txt file, and checking if the LCD is working, make a copy like:
cp config.txt config.txt.v1
Or choose whatever name you prefer. It’s easier then to see what changes caused the LCD to stop working, should it occur, by comparing the present config.txt with your working backup version.
Write the image
After downloading the image write the image to a micro-SD card using a program like Win32DiskImager in Windows. Always make sure the correct device (your card reader) is selected or you can corrupt your system. This program can also read the micro-SD card and create an image file of the same size as the total memory space on the micro-SD card. Do this to create a backup image of your micro-SD card when everything is working. Zip the image file to reduce size. The image used is 3.17 Gb meaning any micro-SD card of 4 GB or larger can be used.
Update and configure RuneAudio+R e2
To configure Rune Audio you can use the WebUI or connect a monitor to the HDMI connector of the Rpi and don’t forget to connect a a USB-mouse then. A wired connection is the faster way to use the WebUI or setup a wifi connection in RuneAudio to your network first.
In the main page click on the cogwheel in the upper right corner. In menu ‘Addons’ Update RuneAudio+R e2 first. This didn’t work the first time and messages ended with a problem about Transmission, one of the addons you can install. I tried installing Transmission then, but that also failed. To make a long story short, after a few reboots and selecting previous pages to get out of the install page, updating of RuneAudio finally worked, but I don’t why. Maybe I missed something somewhere. So be warned and try and try again. After a reboot configure RuneAudio for your DAC: in ‘System’ under Audio choose RPi-DAC for the Elektor DAC (or the one you’re using) and under On-board devices turn Audio off. When leaving the menu a reboot is required. When this is done it’s recommended to make a backup of the micro-SD card using Win32DiskImager. Should the image you’re working on get corrupted you don’t have to go through the update exercise again.
Make a SSH connection to the RPi
Use Putty in Windows to make a SSH connection to the Rpi. You need the IP address of the Rpi on your network. One way is command ‘arp -a’ in a Command Prompt in Windows (this shows a list of IP addresses of all devices on the network) or connect a HDMI display to the Rasbperry Pi and click on the cogwheel in the upper right corner and select menu item ‘Network’. The IP address can be found here. Or check your router. In Putty use username ‘root’ and password ‘rune’.
Once the connection is made some packages must be installed. In Arch Linux a package manager called ‘pacman’ is used for this:
pacman -S xorg-server (may not be not necessary, on 15 December 2019 up to date)
pacman -S xf86-video-fbturbo
pacman -S xf86-input-evdev
pacman -S xf86-video-fbdev
pacman -S xinput_calibrator (I haven’t tried to use this)
pacman -S glibc
Copying driver files
Two files need to be copied to the micro-SD card. The driver from Waveshare for the 3.5” touchscreen LCD (waveshare35a-overlay.dtb or waveshare35b-overlay.dtb for the IPS version) and a fbturbo driver file fbturbo_drv.la (fbturbo_drv.so should already be present). The latter can be found in before mentioned project update in
https://www.elektormagazine.com/labs/audio-dac-for-rpi-networked-audio-player-using-volumio
The files waveshare35a-overlay.dtb and waveshare35b-overlay.dtb are often also copied to the /boot/overlays directory as waveshare35a.dtbo and waveshare35b.dtbo respectively but is maybe not necessary. There are 4 files starting with waveshare then.
The use of WinSCP to copy files is an easy way to do this. Install and run WinSCP. In a new session select SCP as File Protocol, the IP address of the RPi as Host name, default Port number is 22, User name is root. Then click on login. First the password is required (rune). Now you can drag and drop files from your computer to the directories on the RuneAudio micro-SD card and the other way around.
Editing and adding system files
Edit /boot/config.txt using text editor nano (nano /boot/config.txt)
Comment the line ‘gpu_mem=32’ (add # at the beginning of the line)
At the end add the following lines (content in bold)
gpu_mem=128
core_freq=250
sdram_freq=400
over_voltage=0
dtparam=spi=on
dtoverlay=waveshare35a
dtparam=i2c_arm=on
Add the following at the end of the line in /boot/cmdline.txt (nano /boot/cmdline.txt):
fbcon=map:10 fbcon=font:ProFont6x11 logo.nologo
(don’t forget to place a space first)
Create the file /etc/X11/xorg.conf.d/99-calibration.conf and insert the following
(nano /etc/X11/xorg.conf.d/99-calibration.conf):
Section "InputClass"
Identifier "calibration"
MatchProduct "ADS7846 Touchscreen"
Option "Calibration" "3932 300 294 3801"
Option "SwapAxes" "1"
EndSection
In /etc/X11/xorg.conf.d/99-fbturbo.conf, the following text should already be present except for one detail: change fb0 to fb1. Delete the empty line (Ctrl+K in nano). It should look like this:
(nano /etc/X11/xorg.conf.d/99-fbturbo.conf)
# This is a minimal sample config file, which can be copied to
# /etc/X11/xorg.conf in order to make the Xorg server pick up
# and load xf86-video-fbturbo driver installed in the system.
#
# When troubleshooting, check /var/log/Xorg.0.log for the debugging
# output and error messages.
#
# Run "man fbturbo" to get additional information about the extra
# configuration options for tuning the driver.
Section "Device"
Identifier "Allwinner A10/A13 FBDEV"
Driver "fbturbo"
Option "fbdev" "/dev/fb1"
Option "SwapbuffersWait" "true"
EndSection
Add the following to /etc/modules-load.d/raspberrypi.conf
(nano /etc/modules-load.d/raspberrypi.conf):
i2c-bcm2708
i2c-dev
flexfb width=320 height=480 regwidth=16 init=-1,0xb0,0x0,-1,0x11,-2,250,-1,0x3A,0x55,-1,0xC2,0x44,-1,0xC5,0x00,0x00,0x00,0x00,-1,0xE0,0x0F,0x1F,0x1C,0x0C,0x0F,0x08,0x48,0x98,0x37,0x0A,0x13,0x04,0x11,0x0D,0x00,-1,0xE1,0x0F,0x32,0x2E,0x0B,0x0D,0x05,0x47,0x75,0x37,0x06,0x10,0x03,0x24,0x20,0x00,-1,0xE2,0x0F,0x32,0x2E,0x0B,0x0D,0x05,0x47,0x75,0x37,0x06,0x10,0x03,0x24,0x20,0x00,-1,0x36,0x28,-1,0x11,-1,0x29,-3
fbtft_device debug=3 rotate=90 name=flexfb speed=16000000 gpios=reset:25,dc:24
ads7846_device model=7846 cs=1 gpio_pendown=17 keep_vref_on=1 swap_xy=1 pressure_max=255 x_plate_ohms=60 x_min=200 x_max=3900 y_min=200 y_max=3900
Add to file /etc/modules-load.d/fbtft.conf (nano /etc/modules-load.d/fbtft.conf)
spi-bcm2835
fbtft_device
To prevent the touch control being 90 degrees of, modify /usr/share/X11/xorg.conf.d/40-libinput.conf. In the before last section, change the driver from “libinput” to “evdev”. That section must look like the following:
(nano /usr/share/X11/xorg.conf.d/40-libinput.conf)
Section "InputClass"
Identifier "libinput touchscreen catchall"
MatchIsTouchscreen "on"
MatchDevicePath "/dev/input/event*"
Driver "evdev"
EndSection
Change the zoom factor in the local browser so all the controls are visible on the little 3.5” touchscreen LCD . This is done by changing the chromium command line switch ‘force-device-scale-factor’ from 1 to 0.5431. All controls and buttons are displayed. Some text and numbers become hard to read, a larger zoom factor however makes the buttons disappear. The file must look like this then:
(nano /etc/X11/xinit/xinitrc)
#!/bin/bash
export XDG_CACHE_HOME="/tmp/.cache" &
export DISPLAY=":0" &
xset dpms 0 0 0 &
xset s off &
xset -dpms &
matchbox-window-manager -use_cursor yes &
chromium --app=http://localhost --kiosk --incognito --disable-gpu --no-sandbox --force-device-scale-factor=0.5431
Reboot
Starting of the local browser takes a long time, be patient. Now, don’t forget to make a backup copy of config.txt in /root. You can also use WinSCP to copy that file to your computer. Instead of using the SSH connection and the text editor nano to add/change the system files you can create those files on your computer in a familiar text editor and use WinSCP to copy them to their respective directories, just a thought…
Attached is a photo showing RuneAudio+R e2 on the Waveshare 3.5" touchscreen LCD. A webradio channel is selected. Webradio channels can only be added manually. At power up or a reboot the player starts playing automatically by default (the last channel selected).
TonGiesberts 6 years ago
When using Ctrl - to zoom out in Chromium steps are rather large where it counts on the small 3.5” touchscreen LCD: 100, 90, 80, 75 but then 67 and 50 %. A zoom level of 50 % shows the full desktop but some of the text displayed becomes really hard to read. I already mentioned this in project update ‘From the lab - Volumio 2.282 + 3.5" touchscreen LCD + virtual keyboard’. I tested Midori to see if a full desktop with all text readable is possible with this lightweight web browser but ZoomOut as a command line switch first caused errors and Midori wouldn’t start. Well eventually I got it working but the result was even worse. Next I tried Vivaldi which is based on Chromium. Using the zoom slider (on the touchscreen) all steps are 10 %. But you can also click on the number next to the slider and enter a value. At 62 % the full desktop is visible and 63 % the desktop looks the same as 67 %. So somewhere between 62 and 63 % there’s a tipping point. At 62 % all text although still a bit small is now readable. Sadly the virtual matchbox keyboard isn’t working. An external USB keyboard works just fine. Also the slider on the right in the Queue menu to scroll through the playlist is almost impossible to get hold of. Despite being a few pixels wide it looks like only a column 1 pixel wide of the slider is working. Very strange. If you click too far left on the slider chance is you delete a track from your playlist. Rather frustrating and annoying. In Chromium this works as it should. Looking for a solution I found a remark about Vivaldi and a command line switch –force-device-scale-factor (https://forum.vivaldi.net/topic/22284/vivaldi-scaling-on-linux). This command line switch also works with Chromium and is described as: Overrides the device scale factor for the browser UI and the contents. When used there’s a nice surprise and that’s the resulting zoom factor: it is a combination of the zoom setting in Chromium and the value for the command line switch force-device-scale-factor. After some experimenting and rebooting quite a number of times I found the tipping point occurs at 62.5 %. Does anyone know why? A higher zoom level will only show part of the desktop. So if you want the entire desktop visible on the 3.5” touchscreen LCD much like the webUI on a smartphone, notebook or desktop computer and still have readable text the command line switch --force-device-scale-factor has to be set to 1.25 and the zoom level in Chromium to 50 %. If you’re using our latest image Elektor_Volumio2-389.zip the latter means entering once ‘Crtl -’ on the virtual keyboard, the zoom factor here is already 67 %. In Chromium the matchbox-keyboard is still working. The resulting total zoom factor is 62.5%. To start chromium with the additional command line switch in Volumio edit /opt/volumiokiosk.sh in a text editor. To do this open a SSH connection to the Raspberry Pi and in the terminal enter:
sudo nano /opt/volumiokiosk.sh
add at end of the line ‘/usr/bin/chromium-browser’ (before \ and use a space) --force-device-scale-factor=1.25
Then volumiokiosk.sh should look like the following (for clarity the change in bold):
#!/bin/bash
xset -dpms
xset s off
xset r off
matchbox-keyboard -d &
matchbox-window-manager -use_titlebar no &
openbox-session &
while true; do
rm -rf ~/.{config,cache}/chromium/
/usr/bin/chromium-browser --force-device-scale-factor=1.25 \
--no-touch-pinch \
--start-fullscreen \
--no-first-run \
--disable-3d-apis \
--disable-breakpad \
--disable-crash-reporter \
--disable-infobars \
--disable-session-crashed-bubble \
--disable-translate \
--user-data-dir='/data/volumiokiosk' --no-sandbox http://localhost:3000
done
After adding the text in nano: Ctrl-x → y →Enter to quit nano and save changes
sudo reboot
Doing this in the latest Volumio image, at the time of writing volumio-2.502-2018-10-31-pi.img.zip, something is different. After editing /opt/volumiokiosk.sh the command line switch --no-sandbox is not recognized at the end of volumiokiosk.sh. Moving this switch in between /usr/bin/chromium-browser and --force-device-scale-factor=1.25 \ makes it work…For testing I commented the other switches (# in front of each line) and used http://localhost:3000 as a start up page.
For those who would like to try Vivaldi the following describes a way how to install Vivaldi in Volumio. To do this open a SSH connection to the Raspberry Pi.
First create a directory to download the debian package in (here called download):
sudo mkdir ~/download
Go to this directory
cd ~/download
download the package
wget https://downloads.vivaldi.com/stable/vivaldi-stable_1.13.1008.34-1_armhf.deb
Before installing Vivaldi fonts are missing and have to be installed first
sudo apt-get update
sudo apt-get install fonts-liberation
sudo dpkg -i vivaldi-stable_1.13.1008.34-1_armhf.deb
If everything went well change /opt/volumiokiosk.sh to start Vivaldi instead of Chromium:
#!/bin/bash
xset -dpms
xset s off
xset s noblank
xset r off
matchbox-keyboard -d &
matchbox-window-manager -use_titlebar no &
openbox-session &
while true; do
vivaldi --no-sandbox --force-device-scale-factor=1.25 --start-fullscreen
# rm -rf ~/.{config,cache}/chromium/
# /usr/bin/chromium-browser \
# --no-touch-pinch \
# --start-fullscreen \
# --no-first-run \
# --disable-3d-apis \
# --disable-breakpad \
# --disable-crash-reporter \
# --disable-infobars \
# --disable-session-crashed-bubble \
# --disable-translate \
# --user-data-dir='/data/volumiokiosk' --no-sandbox http://localhost:3000
done
Of coarse the value of --force-device-scale-factor can be changed if a different zoom setting in Vivaldi is used.
Be sure there’s enough room on the micro SD card. Use at least an 8 GB micro SD card and increase third (last) partition to maximum using partition manager GParted (Linux utility). This needs to be done when using Elektor_Volumio2-389.zip.
Links of interest:
https://www.addictivetips.com/ubuntu-linux-tips/install-vivaldi-web-browser-on-linux/
chapterUbuntu/Debian
https://www.raspberrypi.org/forums/viewtopic.php?p=1271904
https://help.vivaldi.com/article/starting-vivaldi/
https://help.vivaldi.com/article/zooming-options-in-vivaldi/
https://forum.vivaldi.net/topic/22284/vivaldi-scaling-on-linux
TonGiesberts 6 years ago
In Volumio open the ‘PLAYBACK OPTIONS’ menu. Under ‘Audio Output’ select for the ‘DAC Model’ the ‘R-PI DAC’ and the ‘Output Device’ should change accordingly (if not select R-PI DAC also). Have a look at the screen dump. No re-sampling is needed now. I tested this setting with 16 bit, 24 bit and 32 bit encoded files and all played perfectly. Save and restart.
SiR 6 years ago
I testet the driver and I actually have both, no success AND success. All 16 bit sources work fine, no resampling needed, great! Only just sound from videos still not.
BUT: I then plugged the Dac on my old Rpi 3B, with a Volumio 2.368. Yet I was running it on a 3B+ . And what shall i say? All working flawlessly! Indeed the R-PI Dac driver is solving it on the older Rpi board. Sound from videos finally available.
Seemingly there is some kind of trouble with the 3B+. May it be about pcm1794 architecture or shairport Sync or Volumio on 3B+ or it all together, to be investigated tho'.
I'll test the Mamboberry on the 3B+ Board in the next days to see if issue is the same. I'll let you know so may be able to exclude wether or not it's about pcm1794 architecture.
Cheers guys and thanks for your contribution!
Happy now!
Simon
TonGiesberts 6 years ago
To test if it works first turn off ‘Audio Resampling’ in ‘PLAYBACK OPTIONS’.
Make a SSH connection to the RPi with Volumio. In Windows you can use PuTTY.
Go to the etc directory:
cd /etc
Open mpd.conf in a text editor:
nano mpd.config (or sudo nano mpd.config)
Add the following line (just before the line #replaygain “album”)
audio_output_format “*:24:2”
In nano the asterisk * is a command, you have to copy it from another text editor in Windows using copy/paste. Have a look at the screen dump I made of PuTTY.
Restart Volumio and if everything went well you should be able to listen to 16 bit encoded audio.
Paul van der Hulst 6 years ago
II just finished the dac and started by connecting the I2S bus to a scope.
Instead of volumio I run moode audio. I found that when the selected device is hifiberry and plain 16 bit CD audio is played, the I2S frame is only 16 bit for each channel 'word'. This is ok for hifiberry, but not compatible with the PCM1794 (the datasheet only shows 16 bit timing diagram for right aligned data, which is an implicit way of saying that 16 bit isn't supported in other modes like I2S)
A little googling found that a device called rpi-dac also uses the PCM1794. I don't know about volumio, but moode has a driver for that which is aware of the minimum word length limit of the PCM1794. With this driver the output word is now 32 bit, even for 16 bit data. This is more than the minimum of 24 bits, but that is great actually since it also complies with the limits of the clock multiplier (clock becomes 2.8MHz and the minimum is 2.5MHz). No resampling (processing power) is required, just a different driver.
My conclusion is that you should not aim to use the hifiberry driver as a first choice. It is no better than any other arbitrary I2S device. Instead try to find out which device in your distribution matches the elektor DAC closest and continue from there.
Paul
16 bit audio I2S output to hifiberry DAC (15kb)
TonGiesberts 6 years ago
TonGiesberts 6 years ago
The previous images we made available won’t work with this newer version. However a new version of Volumio is available that has Pi Kernel 4.14.29 and this means it supports the Raspberry Pi version 3 Model B+. The older images like Volumio v1.55 and Rune Audio don’t support this new version of the RPi. The only image that can be upgraded is the v2.282 of Volumio. This has to be done with an older version of the RPi 3. Using the WebUi on a remote computer is probably an easier way to do this. If you don’t know the IP Address of the RPi enter volumio.local in the address bar of the internet browser. Or if this doesn’t work click click on ‘Show Settings’ on the 3.5” touchscreen LCD (the cogwheel in the upper right corner) and next click on the menu item ‘NETWORK’. Under Network Status the IP Address is listed. Now click on ‘Show Settings’ again and select ‘SYSTEM’. In the menu item ‘System Updates’ click on ‘Check Updates’. It will show Update v2.389 is available and its change log. Click on ‘Update Now’. After the message appears ‘Successfully updated to "2.389" version. System restart required.’ click on ‘Restart System’. Volumio restarts but after restart the 3.5” LCD stays blank. The update has overwritten /boot/config.txt and two lines have to be added. Now config.txt has to be edited. Open a SSH connection to the RPi (in Windows you can use PuTTY). The rest of the changes like the virtual keyboard that has been added to the image of Volumio or the configuration for our DAC are all unaffected by the updating process.
In PuTTY in the Session menu enter volumio@192.168.1.20 (change the IP Address to the one your Rpi has been given) in the Host Name (or IP address) text entry field. Default port is 22. Click Open. Enter the default password volumio.
Now edit /boot/config.txt:
sudo nano /boot/config.txt
add the lines (after you entered the password again):
dtparam=spi=on
dtoverlay=waveshare35a:swapxy=1
If done correctly config.txt should look like:
initramfs volumio.initrd
gpu_mem=16
max_usb_current=1
dtparam=audio=on
audio_pwm_mode=2
dtparam=i2c_arm=on
disable_splash=1
hdmi_force_hotplug=1
dtparam=spi=on
dtoverlay=waveshare35a:swapxy=1
\n
#### Volumio i2s setting below: do not alter ####
dtoverlay=hifiberry-dac
You can restart the RPi from the terminal
sudo reboot
After restart the Volumio v2.389 should appear on the 3.5” touchscreen LCD . If the message ‘Restore pages? Chromium didn’t shut down correctly’ appears close it, don’t click on ‘Restore’ because that will open a new tab in the Chromium browser. Every time you click on Restore a new tab is added in the Chromium Browser. It’s a bug that still hasn’t been resolved. To see if there are more tabs click on F11 in the virtual keyboard. The virtual keyboard can be opened by clicking on the search box in the Browse Tab. There should only be one tab open in the Chromium browser. If there are more close them. Now this micro SD card can be used with a RPi 3 B+. Read project update ‘From the lab - Volumio 2.282 + 3.5" touchscreen LCD + virtual keyboard’ how to add the unallocated part of the micro SD card you’re using to make all memory of the microSD card available.
This new image replaces the 2.282 version of Volumio. Look for Elektor_Volumio2-389.zip under SOFTWARE.
There also is an image available with a different look. Some people may prefer the 90 degree rotated view of the v1.55 in the article. No virtual keyboard is added and a wizard will appear first to configure this v2.389 of Volumio. If text entries are needed use the WebUI on a remote computer, laptop, tablet or smart phone. Look for Elektor_Volumio2.389-vertical-layout.zip under SOFTWARE.
Johann Geyer 4 years ago
It would be nice to have an image with actual version
br
Johann
TonGiesberts 7 years ago
Show Settings > SYSTEM > i System Version:
System Version: 2.282 Released: Fri Oct 6 14:53:25 CEST 2017
Install this image on a Micro SD Card using Win32DiskImager or a similar program. Copy the latest waveshare35a-overlay.dtb from the waveshare driver to /boot/overlays. The latest version at time of writing was LCD-show-170703. Found here:
https://www.waveshare.com/wiki/3.5inch_RPi_LCD_(A)
Or choose the appropriate overlay file depending on the display used.
Put the card in the RPi (preferred is a version 3 but a Rpi 2 will do) and power-up. It will first create/re-size SD card partitions. This takes a few minutes. There are three partitions when this is done, boot, volumio and volumio_data. After Volumio has started the SSH service must be enabled. By default it is disabled for security reasons. In an internet browser type volumio.local/DEV in the address bar (or <IP ADDRESS>/DEV). Under SSH click the enable button.
Go back to the Volumio home page (volumio.local or IP Address). Click Show Settings > PLUGINS. This opens the Plugins Management menu. In tab Search plugins select miscellanea and install the Touch Display Plugin. Do not connect a keyboard and/or mouse when installing this plugin which should take about 5 to 7 minutes. Strangely, even after the installation finished, the progression bar halted at 70 percent. Simply click Playback to leave the setup menu if this happens. Go back to the Plugins Management menu and turn the Touch Display plugin On.
In Windows use PuTTY to modify and/or create files through a SSH connection. In the Session menu enter volumio@192.168.1.20 (change the IP Address to the one your Rpi has been given) in the Host Name (or IP address) text entry field. Default port is 22. Click Open. Enter the default password volumio.
First change /boot/config.txt:
sudo nano /boot/config.txt
add the lines
dtparam=spi=on
dtoverlay=waveshare35a:swapxy=1
Install evdev package
sudo apt-get install xserver-xorg-input-evdev
Only one new item is probably installed.
sudo nano /usr/share/X11/xorg.conf.d/40-libinput.conf
In following section (should be the last one) change Driver “libinput” to Driver “evdev”
Section "InputClass"
Identifier "libinput touchscreen catchall"
MatchIsTouchscreen "on"
MatchDevicePath "/dev/input/event*"
Driver "libinput"
EndSection
sudo nano /usr/share/X11/xorg.conf.d/99-fbturbo.conf
Change fb0 to fb1
Then it should look like:
Section "Device"
Identifier "Allwinner A10/A13 FBDEV"
Driver "fbturbo"
Option "fbdev" "/dev/fb1"
Option "SwapbuffersWait" "true"
EndSection
Add the following in /boot/cmdline.txt:
sudo nano /boot/cmdline.txt
add at the end of the line (don’t forget to put a space in front of this text first):
fbcon=map:10 fbcon=font:ProFont6x11 logo.nologo
Create directory /etc/X11/xorg.conf.d:
sudo mkdir /etc/X11/xorg.conf.d
A calibration file is necessary:
sudo nano /etc/X11/xorg.conf.d/99-calibration.conf
Add the following text in 99-calibration.conf:
Section "InputClass"
Identifier "calibration"
MatchProduct "ADS7846 Touchscreen"
(Option "Calibration" "3932 300 294 3801" original data)
Option "Calibration" "3919 254 236 3856"
Option "SwapAxes" "0"
EndSection
sudo reboot
Volumio should now start on the 3.5inch touchscreen LCD with calibrations for the touch control.
Connect a USB keyboard to change the zoom factor of the Chromium browser to your own preference. 67 % is a good start(press 'Ctrl' and '-' simultaneously to zoom out and 'Ctrl' and '+' to zoom in again). Only discrete steps are possible 25, 33, 50, 67, 75, 89, 90, 100 % etc.
After a new start (reboot) a rather annoying message appears every time, even if Volumio 2 is shut down correctly (Show Settings > SHUTDOWN > Power Off (or Restart):
Restore pages? Chromium didn't shut down correctly.
Just click the Restore button, but this doesn't do anything. The Volumio WebUI will be loaded anyway. A solution would be to add the command line switch –incognito to /opt/volumiokiosk.sh. But this would affect the loading of album arts. More about it here: https://volumio.org/forum/touchpanel-chromium-error-solution-avoid-t6203.html.
The screen saver is active, not always desirable.
sudo nano /opt/volumiokiosk.sh
To disable the screensaver change these lines in /opt/volumiokiosk.sh:
xset +dpms
xset s blank
xset 0 0 120
to these two lines (delete the third line)
xset -dpms
xset s off
At this point a virtual keyboard is still missing. To add it:
sudo apt-get install matchbox-window-manager matchbox-keyboard
To enable it modify the content of volumiokiosk.sh
sudo nano /opt/volumiokiosk.sh
to look like this:
#!/bin/bash
xset -dpms
xset s off
xset r off
matchbox-keyboard -d &
matchbox-window-manager -use_titlebar no &
openbox-session &
while true; do
rm -rf ~/.{config,cache}/chromium/
/usr/bin/chromium-browser \
--no-touch-pinch \
--kiosk \
--no-first-run \
--disable-3d-apis \
--disable-breakpad \
--disable-crash-reporter \
--disable-infobars \
--disable-session-crashed-bubble \
--disable-translate \
--user-data-dir='/data/volumiokiosk' --no-sandbox http://localhost:3000
done
The default layout of the virtual keyboard looked far from perfect. Keys were very small and on the right side of the display keys were repeated like there’s a second keyboard going off-screen. I tried to define width of the keys by adding for example width=”3000” to every key in the file keyboard.xml (in directory /usr/share/matchbox-keyboard). Before editing the original file I made a backup of it first:
sudo cp keyboard.xml keyboard.xml.org
Adding the width parameter worked for first rows but somewhere in the last (bottom) row or earlier suddenly all added widths had no influence anymore and key sizes depend on the number of keys in a row. A bug in the software or total width of keys and spaces in a row or rows is exceeding a maximum? Adding an extra space also reduces size of the keys in that specific row. Adding fill=”true” makes a key or space larger. If one key or space in a row has this parameter and the number of spaces and keys are equal in different rows then key sizes and spaces in all rows are the same. If less keys are used like in the last row keys and spaces are bigger. But I think this is not as it should be. The keyboard is pretty much symmetrical this way, works and the keys are not too small. If anyone knows how to remove the horizontal and vertical space between the keys to make them adjacent and thus as big as possible let us know.
To get an extended keyboard (not modified, it’s the one that comes with the installation of the matchbox-keyboard):
cd /usr/share/matchbox-keyboard
sudo cp keyboard.xml keyboard.xml.org
sudo cp keyboard-extended.xml keyboard.xml
Strangely the two menu bars have switched places. Now there’s a volume control button in the left corner of the bottom menu bar which opens a slider when touched. The window for the album art doesn’t scale. If zoom is reduced to 50 % then everything looks like the WebUI. But text in lot of places becomes unreadable. The virtual keyboard can also be used to zoom in or out. To reduce the zoom factor enter in succession Ctrl – and to increase the zoom factor enter in succession Ctrl Shift +. One way to open the keyboard is to touch the search box in the browse menu.
I noticed when the playlist consists of only radio stations previous and next don’t work. A warning: a next Volumio update (if applied) will probably remove most changes made to enable the 3.5” touchscreen LCD from Waveshare and the virtual keyboard. So again, before performing an update make an image file of the SD card first if there are settings you changed and don’t want to loose.
An alternative to the kiosk mode is the fullscreen mode. Change the line --kiosk to --start-fullscreen in /opt/volumiokiosk.sh (make sure \ is still at the end). Volumio will look the same but now F11 can be used to leave or restart the fullscreen mode. For this reason the function key F11 is the only one added to the virtual keyboard. A message will appear for a moment when fullscreen mode is entered, also after (re)boot: Press F11 to exit full screen. Leaving fullscreen mode gives access to settings of the Chromium browser (the 3 vertical dots in the upper right corner) or the possibility to surf the net. A lot of settings can be changed in the settings menu. But if you do make changes, backup the SD card first! Using the fullscreen mode I didn’t see the annoying message “Restore pages? Chromium didn't shut down correctly” appearing again. Although, when creating/augmenting the play list in the Chromium browser sometimes a second tab is open (or more). Very strange. Then the annoying message reappears again. Check by exiting full screen mode. Close the extra tabs. But sometimes this doesn’t help and with a second tab the message sometime doesn’t appear. If anyone knows the cause please let us know.
Some general information that can be of use:
https://peter.sh/experiments/chromium-command-line-switches/
To clear the terminal type clear.
To clear the history of all entered commands in this session in the terminal type history -c.
History -c clears the current session history, the -w option overwrites the history file.
df -h shows space used on the SD card.
sudo apt-get clean to reduce disk space used.
How to reduce image size of the (micro) SD card to save disk space for archiving or distribution:
https://www.raspberrypi.org/forums/viewtopic.php?f=29&t=111531
Use a linux operating system (e.g. Ubuntu).
Open GParted (if not installed: sudo apt-get install gparted). Depending on the number of drives, GParted will search for partitions first and this may take a while.
Select the last partition of the SD card. Unmount and click resize.
The New size should be 200 MB higher (or more if there’s an error) than the minimum size listed. The rest of the disk stays unallocated. Click Resize/Move. Then click Apply All operations. The partition will now be resized. Before quitting Gparted, calculate the sum of all partitions. In this case that’s 3 partitions in all (3440.24 MB). Also remember which device the SD card is. Here /dev/sdg. You’ll need it.
The DD command is a great way to copy the contents of the SD card to an image file because the image size can be specified. Add 50 MB or more to the sum of all partitions as a safety margin (this will ensure all data and their partitions will be copied).
After count= enter the sum of all partitions. Maybe round it to nice number.
Replace /dev/sdg to /dev/sd… as listed in your system.
In a terminal enter the following command:
sudo dd if=/dev/sdg of=Elektor_Volumio2.282.img bs=1M count=3500
This will create the image file in the home directory (if this is the working directory of the terminal).
While the image file is being written, there’s no reporting. When finished something like this is displayed in the terminal:
sudo dd if=/dev/sdg of=Elektor_volumio2.282.img bs=1M count=3500
3500+0 records in
3500+0 records out
3670016000 bytes (3,7 GB, 3,4 GiB) copied, 41,3648 s, 88,7 MB/s
The result is an image file of 3670016000 bytes (3.418 GB). So can be written to any SD card of 4 GB or larger. Not really necessary but use GParted again to maximize the third partition by adding the unallocated space at the end of the SD card used. There’s little free space on a 4 GB SD card, so use at least an 8 GB SD card.
The modified image of Volumio 2.282 is added under attachments/software: Elektor_Volumio2-282.zip
Main menu of Volumio 2.282 on 3.5" touchscreen LCD, zoom factor 67% (3673kb)
Volume slider of Volumio 2.282 on 3.5" touchscreen LCD, zoom factor 67% (3941kb)
Virtual keyboard in Volumio 2.282 on 3.5" touchscreen LCD, zoom factor 67% (4774kb)
Exit fullscreen in Volumio 2.282 on 3.5" touchscreen LCD, zoom factor 67% (4548kb)
Browser menu in Volumio 2.282 on 3.5" touchscreen LCD, zoom factor 67% (5370kb)
Browser settings in Volumio 2.282 on 3.5" touchscreen LCD, zoom factor 67% (6158kb)
Home page of Volumio 2.282 on 3.5" touchscreen LCD, zoom factor 50% (4772kb)
Jurrien 7 years ago
Next challenge was getting the touchscreen working using the base image of Volumio. Thanks to all the suggestions and links on this page I was able to get the touchscreen up and running.
Primary source I used, is the Gitlab page https://github.com/swkim01/waveshare-dtoverlays and by using the suggestions for calibration I've updated the /opt/volumiokiosk.sh script to do a calibration after boot. By default the calibration tool has a timeout so if you don't need to calibrate it will continue after a moment.
Attached to this message is the patch script to execute all the necessary steps for a base image. Hopefully this will help others to get everything up and running.
Setup with patch script and only one reboot
Flash with image volumio-2.323-2017-11-17-pi
Add empty file ssh and patch script to boot partition
Start wizard and leave I have an I2S DAC to no and audio output to Audio Jack in order to prevent an additional reboot.
Install plugin via the wizard: Plugins, Search Plugins, Miscellanea, Touch Display Plugin.
Next to the kiosk plugin, this will also install all the necessary packages for X Window System
When finished, go to Installed Plugins and switch Touch Display to On
Logon using ssh with username volumio and password volumio
Start the patch script
volumio@volumio:~$ bash /boot/patch-volumio-2.323-2017-11-17-pi.sh
The script will prompt for root access via sudo once so enter the password of user volumio, namely volumio
When the script is finished, you can enable the I2S DAC and select the HiFiBerry DAC
When saving, also restart as the popup suggests
rudimentaire4ever 6 years ago
TonGiesberts 7 years ago
A few days later I plugged the SD card in and tried one more time and Volumio started normally. I set up WLAN and to my surprise it worked, I got an IP address and the NAS mount added the previous time was accessible and also working. But booting after disabling ‘Wait for Network at Boot’ in the Raspberry Pi Software Configuration Tool (raspi-config), no LAN connected, is delayed by more than a minute (raise network interface). Adding the line ‘xserver-command=X –s 0 -dpms’ in /etc/lightdm/lightdm.conf to disable the screensaver makes the installation freeze. I have no confidence this image is working properly so luckily there’s an alternative solution: RuneAudio.
I made several attempts to get WLAN working in the installation of Volumio 1.55 but to no avail. WLAN works just fine in the the RuneAudio installation. If you want to install RuneAudio yourself look at Project Update ‘From the lab - using RuneAudio’. We added an 8 GB image with RuneAudio and the 3.5 inch Touch Screen TFT LCD from Waveshare working: Elektor_RuneAudio_8GB_Image.zip. See Attachments/Software. Setting up a WLAN connection in RuneAudio is easy.
After flashing the image to a SD card of at least 8 GB first connect the wired LAN and make the appropriate settings for WLAN (under MENU/NETWORK). Best way is to use the WebUI. Type the IP address of the RPi with RuneAudio in an internet explorer of your choice. The IP address of the LAN connection can be found in MENU/Network next to ETH0 under NETWORK INTERFACES. When trying to enter the Password on the 3.5”touchscreen LCD an almost full screen keyboard appears and you can’t see what your typing. Entering letters this way is challenging but not impossible. Sometimes not all letters get accepted. Using a USB keyboard worked for me. Strange thing happened when I selected the network menu. It will display ‘scanning for networks’, and a few seconds later several WiFi-networks from my neighborhood were listed, but my own WiFi network wasn’t. I unchecked the setting ‘Enable 20/40 MHz Coexistence’ in the Wireless Setup Menu of my Router and later my WiFi-network was listed also. Make sure new devices are allowed to connect to your router. Other security settings in your router or network configuration can also be the reason why connection fails and/or your SSID isn’t listed among the wireless networks found!
Disconnect the LAN Cable and reboot. RuneAudio should now connect through the WLAN interface. After power-up a short copyright screen is shown with a login. Just wait and be patient, this screen may be shown for more than a minute before continuing booting. RuneAudio has no menu for resampling and so all audio files and internet radio stations (Dirble) must be 24 or 32 bit encoded, otherwise there’s no sound.
In case you install the 3.5 inch Touch Screen TFT LCD yourself in the original RuneAudio image check the following configurations necessary for our DAC:
(in Elektor_RuneAudio_8GB_Image these settings are already set):
- In MENU/MPD/Audio Output select HiFiBerry DAC (I2S) as Audio output interface
- In MENU/MPD/Volume control select disabled
- In MENU/SETTINGS/Features management turn Local browser ON
- In MENU/SETTINGS/Features management turn USB Automount ON
Kl Thonke 7 years ago
I can confirm, that the WLAN is not working - I thought it had to do with the on-board WLAN chip present int the TasPi 3.
Also commands issued by hand like
ifconfig wlan0 up
iwlist wlan0 scan
do not solve the problem.
I also tried to let the RasPi update several software pieces, but in the end the LCD was not working again - so I now have to restart from your image again.
Overall, I find this project rather frustatrating for somebody with just fundamental Unix knowledge like me:
Obviously, you have to
- stick to a totally outdated version of Volumio (1.55) and of the hardware (RasPi 2),
- never update any piece of software, because the system might become unbootable
- use the RasPi exclusively over ethernet cable.
This is actually not what I was looking for!
Advices to solve the problems are welcome.
Klaus
Kl Thonke 7 years ago
When trying to configure WLAN via a putty-connection, also the WLAN is not found:
______
login as: root
root@192.168.178.47's password:
=============== RuneOS distribution ===============
____ _ _ _
| _ \ _ _ _ __ ___ / \ _ _ __| (_) ___
| |_) | | | | '_ \ / _ \ / _ \| | | |/ _` | |/ _ \
| _ <| |_| | | | | __// ___ \ |_| | (_| | | (_) |
|_| \_\\__,_|_| |_|\___/_/ \_\__,_|\__,_|_|\___/
================ www.runeaudio.com ================
RuneOs: 0.3-beta
RuneUI: 1.3-beta
Hw-env: RaspberryPi 2
[root@runeaudio ~]# ifconfig wlan0 up
wlan0: ERROR while getting interface flags: No such device
[root@runeaudio ~]#
______
Any solution?
Klaus
TonGiesberts 7 years ago
Kl Thonke 7 years ago
The LCD sold in the bundle seem to be not compatible because of driver problems.
It would be nice if somebody had a solution for that.
Klaus
TonGiesberts 7 years ago
You're certainly not the first to ask to get the 3.5 LCD (or similar) working in Volumio 2. Have a look at the Volumio forum:
https://volumio.org/forum/can-get-lcd-touchscreen-display-web-t6459.html
It will take some doing.
TonGiesberts 7 years ago
@/usr/bin/chromium-browser --kiosk --disable-restore-session-state http://localhost
Well Volumio started at boot but after installing the display driver of Waveshare LCD-show-170703.tar.gz (I’m not sure if this was the cause) dhcpcd failed to make a connection. So, no network. Also USB thumb drives failed to mount. After many hours it was time to use an older version of Raspbian, 2016-09-23-raspbian-jessie.img without upgrading and no rpi-update. This worked. Here is an updated description how to install Volumio 1.55.
Installing Volumio 1.55 on a raspberry pi 2 in combination with a 480x320 3.5” LCD to work as a stand-alone music player
First install 2016-09-23-raspbian-jessie.img image on a micro SD card of at least 8 GB.
You can find the image here:
http://downloads.raspberrypi.org/raspbian/images/raspbian-2016-09-28/
Connect a monitor (HDMI), keyboard and mouse to the RPi. Power up the RPi.
After start-up has finished open a terminal and run:
sudo apt-get update
sudo raspi-config
to extend the partition to the full size of the micro SD card and maybe change the keyboard layout, default is English UK. You can enable SSH here also. I strongly recommend it but change the default password for security reassons. After the LCD is configured working on a remote computer through a SSH connection is maybe an easier way to enter commands in a terminal. The letters on the 3.5” LCD are a bit small. Login by default is still pi/raspberry.
sudo reboot
sudo apt-get install midori (an internet browser we know how to start fullscreen)
sudo nano ~/.config/lxsession/LXDE-pi/autostart
add the following lines (don’t forget to put # in front the line xscreensaver…):
#@xscreensaver -no-splash
@xset s off #disable screensaver
@xset -dpms
@xset s noblank #disable screensaver blanking
@unclutter -idle 0 #disable mouse pointing
midori -e Fullscreen & ZoomOut & ZoomOut -a http://localhost
To disable the screensaver permanently:
sudo nano /etc/lightdm/lightdm.conf
and add in the [SeatDefaults] section (and nowhere else or it won’t work) the following command:
xserver-command=X –s 0 -dpms
sudo apt-get autoremove minecraft-pi
sudo apt-get autoremove wolfram-engine
sudo reboot
(alt-F4 to close midori after reboot)
sudo apt-get install alsa-utils mpd mpc minidlna usbmount ntfs-3g -y
sudo nano /etc/mpd.conf
comment the following line with #
bind_to_address "localhost"
this is the next line after # For network
sudo apt-get install nginx sqlite3 php5-fpm php5-curl php5-sqlite php5-cli php5-gd php5-imagick -y
sudo apt-get install samba samba-common-bin -y
sudo apt-get install autofs -y
sudo nano /etc/auto.master
add the following line at the end:
/media/ /etc/auto.ext-usb --timeout=10,defaults,user,exec,uid=1000
sudo mkdir /var/www
(already exists, check first with: ls /var/www)
sudo mkdir /mnt/disk1
sudo mkdir /mnt/disk2
sudo mkdir -p /mnt/NAS
sudo mkdir -p /mnt/USB
sudo ln -s /mnt/NAS /var/lib/mpd/music/NAS
sudo ln -s /mnt/USB /var/lib/mpd/music/USB
sudo rm -r /var/www
This deletes all contents in /var/www. To avoid error:
fatal: destination path ‘/var/www’ already exists and is not an empty directory.
sudo git clone https://github.com/volumio/Volumio-WebUI.git /var/www
sudo chmod 775 /var/www/_OS_SETTINGS/etc/rc.local
sudo chmod 755 /var/www/_OS_SETTINGS/etc/php5/mods-available/apc.ini
sudo chmod -R 777 /var/www/command/
sudo chmod -R 777 /var/www/db/
sudo chmod -R 777 /var/www/inc/
sudo cp -var /var/www/_OS_SETTINGS/etc /
cd /var/lib/mpd/music ; sudo ln -s /mnt/disk1/Music
sudo ln -s /mnt/NAS /var/lib/mpd/music/NAS
sudo ln -s /mnt/USB /var/lib/mpd/music/USB
sudo nano /etc/modules
Add the following lines to the file /etc/modules:
snd_soc_bcm2708
bcm2708_dmaengine
snd_soc_hifiberry_dac
Configure ALSA
sudo nano /etc/asound.conf
Create /etc/asound.conf with the following content:
pcm.!default {
type hw card 0
}
ctl.!default {
type hw card 0
}
sudo reboot
At this stage the LCD is still not used, just the HDMI output.
Volumio appears and asks to update. Updating the first time produces an error. Close Midori (Alt-F4) and start Midori again. Enter http:/localhost in the address bar and try again. Or right click on the error page and select back and try again. The second time shouldn’t produce an error and the main screen of Volumio should appear.
To use the 3.5” display from Waveshare copy the driver on the CD (in our case the file was called LCD-show-161112.tar.gz) to a directory on the Raspberry Pi. Easiest way to do this is the use of thumb drive. Follow the instruction in the user manual on the CD. It states to run ‘tar xvf LCD-show.tar.gz’.
Depending on the location you copied the driver file to (in our case to /home/pi/Documents) run:
tar xvf /home/pi/Documents/LCD-show-160520.tar.gz
and then run
cd /home/pi/LCD-show/
sudo ./LCD35-show
The system will reboot and Volumio should appear in fullscreen on the LCD. If you still want to use the Raspberry Pi for other purposes pressing F11 will leave fullscreen and the Desktop is accessible. Pressing F11 again will put Midori in fullscreen again (if it’s the active window). Adding a location to the library may require a reboot before it’s visible.
Because the installation of the LCD overwrites or changes /boot/config.txt we save enabling the AudioDAC to last.
sudo nano /boot/config.txt
To enable I2S in /boot/config.txt uncomment or add the line:
dtparam=i2s=on
and add line:
dtoverlay=hifiberry-dac
sudo reboot
Getting the AudioDac playing in Volumio a few settings need to be changed:
In Playback/Audio Output select ’sndrpihifiberry’.
In Playback/Volume control mixer/mixer type select ‘disabled’.
In System/I2S driver select ‘Hifiberry’.
In Library select UPDATE LIBRARY. Any changes in a disconnected/reconnected USB thumb drive or NAS require another update to make the changes visible in Volumio.
DucTom 7 years ago
l am not deep into Linux and i am not able to get the DAC running properly.
Tom the User
After a few tries i got the Volumio once running, volumio updatet, but after reboot the WiFi was gone, so the Volumio not apeares (With Lan Cable - funktion).
The Raspi has vorgotten the Wlan and not possible to connect - no device.
Whats about Volumio 2 ?
Tom
Kl Thonke 7 years ago
The available touch screen plugin does not work.
When I install Raspbian instead of Volumino, the LCD works.
I also tried under Volumino this version via putty:
- copied the file "LCD-show-161112.tar.gz " onto the SD card
- unpacked it
- tried "sudo raspi-config" --> command is not available!
- tried anyway to start the unpacked "./LCD35-show" --> raspberry hangs up; no new boot possible; only writing again Volumino image on SD card helps to restart the whole story.
What is the workaround?
Thank you for any advise!
TonGiesberts 7 years ago
TonGiesberts 7 years ago
Werner Jäger 7 years ago
I prepared a micro SD card 16 GB and got the software running on RASPI 2B. I took the raspi-image comming with the mini-dvd and followed all the instructions as described in the article above. Finally I did the settings in Volumio ... and many reboots. I got used to handle the audioplayer-GUI, especially with updating the "Library" ... finally there are some songs (16 bit, 24 bit) in the playlist and the playing-time is ticking. The DAC-module is powerd up too and the Amp of my stereo is waiting for analog-audio input - but there is none.
Do I have to change some of the Dip-switches or the jumpers ?
TonGiesberts 7 years ago
TonGiesberts 7 years ago
In ~/.config/lxsession/LXDE-pi/autostart change the line
midori -e Fullscreen -a http://localhost
to
midori -e Fullscreen & ZoomOut & ZoomOut -a http://localhost
It will make Midori zoom out twice. Once would be enough but the button Turn off isn’t completely visible then and maybe an option if some letters are getting to small. The photograph shows the result with zoom out twice.
TonGiesberts 7 years ago
I used the image RuneAudio_rpi2_rp3_0.4-beta_20160321_2GB.img, found here: http://www.runeaudio.com/download/
Write it to a microSD card and insert it into the Raspberry Pi. Make sure the RPi is connected to a network. A SSH connection from another computer connected on the same network to the RPi (PuTTY in Windows) must be made. Default username is root and password is rune. But before you start some files must be copied to a USB pendrive. Installing the driver for the display is done manually. A number of files have to be added and/or edited in the RuneAudio system.
First copy the waveshare driver waveshare35a-overlay.dtb from the WaveShare DVD that came with the display to the USB pendrive. The driver can also be obtained as part of the driver package on the Waveshare Wiki: http://www.waveshare.com/. In both cases it's inside an archive. On the DVD the archive is located in the Image folder. I used an older version of the display (v3). The archive is called LCD-show-160520.tar.gz.
Also copy the fbturbo driver files fbturbo_drv.la and fbturbo_drv.so (located in fbturbo_driver.zip) to the pendrive and insert it into a USB port of the Rpi. Execute the following in the PuTTY window:
cd /mnt/MPD/USB/<name pendrive>
(maybe first use command ls to see what the exact name of the pendrive is, Linux is case sensitive!)
cp waveshare35a-overlay.dtb /boot/overlays
cp fbturbo_drv.la /lib/xorg/modules/drivers
cp fbturbo_drv.so /lib/xorg/modules/drivers
4 files should now be located in the /lib/xorg/modules/drivers folder: also fbdev_drv.so and modesetting_drv.so (these are part of fbturbo_driver.zip but should't be needed).
(ls /lib/xorg/modules/drivers)
Now edit /boot/config.txt using text editor nano (nano /boot/config.txt).
To enable I2S and the AudioDAC uncomment the following lines (remove # at the beginning of each line):
#dtparam=i2s=on
#dtoverlay=hifiberry-dac
Comment these lines (put # at the beginning of each line):
gpu_mem=64
hdmi_drive=2
Add the following lines at the end to /boot/config.txt:
start_x=1
gpu_mem=128
core_freq=250
sdram_freq=400
over_voltage=0
dtparam=spi=on
dtoverlay=waveshare35a
dtoverlay=ads7846,cs=1,penirq=17,penirq_pull=2,speed=1000000,keep_vref_on=1,swapxy=1,pmax=255,xohms=60,xmin=200,xmax=3900,ymin=200,ymax=3900
dtparam=i2c_arm=on
dtoverlay=w1-gpio-pullup,gpiopin=4,extpullup=1
Add the following at the end of the line in /boot/cmdline.txt (nano /boot/cmdline.txt):
fbcon=map:10 fbcon=font:ProFont6x11 logo.nologo
Create the file /etc/X11/xorg.conf.d/99-calibration.conf and insert the following
(nano /etc/X11/xorg.conf.d/99-calibration.conf):
Section "InputClass"
Identifier "calibration"
MatchProduct "ADS7846 Touchscreen"
Option "Calibration" "3932 300 294 3801"
Option "SwapAxes" "1"
EndSection
In /etc/X11/xorg.conf.d/99-fbturbo.conf, add the following text:
(nano /etc/X11/xorg.conf.d/99-fbturbo.conf)
# This is a minimal sample config file, which can be copied to
# /etc/X11/xorg.conf in order to make the Xorg server pick up
# and load xf86-video-fbturbo driver installed in the system.
#
# When troubleshooting, check /var/log/Xorg.0.log for the debugging
# output and error messages.
#
# Run "man fbturbo" to get additional information about the extra
# configuration options for tuning the driver.
Section "Device"
Identifier "Allwinner A10/A13 FBDEV"
Driver "fbturbo"
Option "fbdev" "/dev/fb1"
Option "SwapbuffersWait" "true"
EndSection
Add the following to /etc/modules-load.d/raspberrypi.conf
(nano /etc/modules-load.d/raspberrypi.conf):
i2c-bcm2708
i2c-dev
flexfb width=320 height=480 regwidth=16 init=-1,0xb0,0x0,-1,0x11,-2,250,-1,0x3A,0x55,-1,0xC2,0x44,-1,0xC5,0x00,0x00,0x00,0x00,-1,0xE0,0x0F,0x1F,0x1C,0x0C,0x0F,0x08,0x48,0x98,0x37,0x0A,0x13,0x04,0x11,0x0D,0x00,-1,0xE1,0x0F,0x32,0x2E,0x0B,0x0D,0x05,0x47,0x75,0x37,0x06,0x10,0x03,0x24,0x20,0x00,-1,0xE2,0x0F,0x32,0x2E,0x0B,0x0D,0x05,0x47,0x75,0x37,0x06,0x10,0x03,0x24,0x20,0x00,-1,0x36,0x28,-1,0x11,-1,0x29,-3
fbtft_device debug=3 rotate=90 name=flexfb speed=16000000 gpios=reset:25,dc:24
ads7846_device model=7846 cs=1 gpio_pendown=17 keep_vref_on=1 swap_xy=1 pressure_max=255 x_plate_ohms=60 x_min=200 x_max=3900 y_min=200 y_max=3900
Now reboot. The RuneUI should appear on the 3.5" LCD with the touchscreen working. Advantage over Volumio 1.55 is the main MENU item 'Turn off' is now selectable on the LCD (standard orientation).
Source:
http://www.runeaudio.com/forum/waveshare-spotspear-3-5-touch-screen-working-with-rune-t3859.html
Fbturbo driver (60kb)
TonGiesberts 7 years ago
To make more items visible in the different menus do the following.
Edit /root/.config/midori/config.
(nano /root/.config/midori/config)
Change the line
zoom-level=0.7
to
zoom-level=0.5
But as always there’s a downside. The touch control gets more difficult. And maybe the zoom factor can be tweaked to produce more crisp letters.
TonGiesberts 7 years ago
After starting OpenELEC (version 6.03 is installed) first some configurations must be done like choosing your network. In ‘Sharing and Remote Access’ enable SSH also. You’ll need it. Next go to System/Settings/System/Audio output and you’ll will find no HifiBerry, just HDMI, Analogue and both as a choice. Now a modification of OpenELEC is necessary. To do this use putty to make a SSH connection to the RPi from a Windows computer. From a Linux computer it’s easier with the SSH command in a Terminal. After login (default username is root, password is openelec) enter the following in the PuTTY window:
mount -o remount,rw /flash
This will enable you to change config.txt in the /flash folder:
nano /flash/config.txt
change the line ‘dtoverlay=hifiberry-dacplus’ into ‘dtoverlay=hifiberry-dac’
also add the line ‘dtparam=i2s=on’
After this is done make the /flash folder read only again:
mount -o remount,ro /flash
reboot
After reboot goto the setting for the Audio output device and you will see a fourth choice:
ALSA: Default (snd_rpi_hifiberry_dac Analog)
Select it and play a song. It should work now.
Only the HDMI output is used in OpenELEC.
TonGiesberts 8 years ago
For the Waveshare display we used:
Change location to the driver: cd LCD-show/ (or to wherever the driver is located)
then run: ./LCD35-show 90
Initially this didn’t work, nothing changed. But then we still used the older version LCD-show-160520.tar.gz. Updating to the latest version (LCD-show-161112.tar.gz) and replacing the directory LCD-show and trying again proofed successful.
Installing the driver again will change /boot/config.txt again and maybe also /etc/modules. So there’s no audio after reboot (happens automatically). Look at the main project text and enable I2S and the Audio-DAC again (check enabling hifiberry at the end of the text, just before the measurements).
More detailed information can be found on the website of Waveshare: http://www.waveshare.com/wiki/3.5inch_RPi_LCD_(A)
Now the MENU item ‘Turn off’ is visible but on the Playlist page ‘Clear Queue’ is not visible. This is annoying because clearing a large playlist item by item is not exactly user friendly. So whatever you prefer, 0 or 90 degrees both are not perfect.
In the two photo’s the 90 degrees rotation is shown. In the first photo also the menu items Repeat, Random, Single and Consume Mode are visible. In the second photo MENU is open and item ‘Turn off’ is visible now.
Volumio MENU item Turn off visible (1183kb)