From ae2f350dd2b6c6bce07f4c8f5a43b23b3aaf2c5e Mon Sep 17 00:00:00 2001 From: lucianom Date: Mon, 9 May 2022 13:08:38 +0100 Subject: [PATCH 1/7] Add support for XVF3510-UA --- CHANGELOG.md | 5 +++++ README.md | 4 ++-- setup.sh | 2 +- 3 files changed, 8 insertions(+), 3 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index b0cd13e..39c8324 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,10 @@ # VocalFusion Raspberry Pi Setup Change Log +## 5.1.0 + + * Added support for xvf3510-ua + * Renamed xvf3510 device as xvf3510-int + ## 5.0.0 * Added support for xvf3610-ua and xvf3615-ua diff --git a/README.md b/README.md index 23a88d5..40bd3c8 100644 --- a/README.md +++ b/README.md @@ -14,7 +14,7 @@ This setup will perform the following operations: - update the asoundrc file to support I2S devices - add a cron job to load the I2S drivers at boot up -For XVF3510 devices these actions will be done as well: +For XVF3510-INT devices these actions will be done as well: - configure MCLK at 24576kHz from pin 7 (BCM 4) - configure I2S BCLK at 3072kHz from pin 12 (BCM18) @@ -32,7 +32,7 @@ For XVF361x-INT devices these actions will be done as well: - add a cron job to reset the device at boot up - add a cron job to configure the DAC at boot up -For XVF361x-UA devices these actions will be done as well: +For XVF3510-UA and XVF361x-UA devices these actions will be done as well: - update the asoundrc file to support USB devices - update udev rules so that root privileges are not needed to access USB control interface diff --git a/setup.sh b/setup.sh index 888365b..acf3613 100755 --- a/setup.sh +++ b/setup.sh @@ -6,7 +6,7 @@ I2S_MODE= XMOS_DEVICE= # Valid values for XMOS device -VALID_XMOS_DEVICES="xvf3100 xvf3500 xvf3510 xvf3600-slave xvf3600-master xvf3610-int xvf3610-ua xvf3615-int xvf3615-ua" +VALID_XMOS_DEVICES="xvf3100 xvf3500 xvf3510-int xvf3510-ua xvf3600-slave xvf3600-master xvf3610-int xvf3610-ua xvf3615-int xvf3615-ua" usage() { local VALID_XMOS_DEVICES_DISPLAY_STRING= From 39fedcf31f815f776bb98483e0542ead6bceb39a Mon Sep 17 00:00:00 2001 From: lucianom Date: Mon, 16 May 2022 17:03:41 +0100 Subject: [PATCH 2/7] Install Debian packages one at the time --- CHANGELOG.md | 1 + setup.sh | 52 +++++++++++++++++++++++++++++----------------------- 2 files changed, 30 insertions(+), 23 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 39c8324..91d022c 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -4,6 +4,7 @@ * Added support for xvf3510-ua * Renamed xvf3510 device as xvf3510-int + * Install one Debian package at the time ## 5.0.0 diff --git a/setup.sh b/setup.sh index acf3613..dc04067 100755 --- a/setup.sh +++ b/setup.sh @@ -116,17 +116,23 @@ sudo raspi-config nonint do_spi 0 # been tested and verified. KERNEL_HEADERS_PACKAGE=raspberrypi-kernel-headers if ! dpkg -s $KERNEL_HEADERS_PACKAGE &> /dev/null; then - echo "Installing Raspberry Pi kernel headers" - sudo apt-get install -y $KERNEL_HEADERS_PACKAGE + echo "Installing Raspberry Pi kernel headers" + sudo apt-get install -y $KERNEL_HEADERS_PACKAGE fi echo "Installing the Python3 packages and related libs" -sudo apt-get install -y python3-matplotlib -sudo apt-get install -y python3-numpy -sudo apt-get install -y libatlas-base-dev +sudo apt-get install -y python3-matplotlib || echo "Package Iinstallation failed" && exit 1 +sudo apt-get install -y python3-numpy|| echo "Package Iinstallation failed" && exit 1 +sudo apt-get install -y libatlas-base-dev || echo "Package Iinstallation failed" && exit 1 echo "Installing necessary packages for dev kit" -sudo apt-get install -y libusb-1.0-0-dev libreadline-dev libncurses-dev libevdev-dev libudev-dev +sudo apt-get install -y libusb-1.0-0-dev || echo "Package Iinstallation failed" && exit 1 +sudo apt-get install -y libreadline-dev || echo "Package Iinstallation failed" && exit 1 +sudo apt-get install -y libncurses-dev || echo "Package Iinstallation failed" && exit 1 +if [[ -n "$UA_MODE" ]]; then + sudo apt-get install -y libevdev-dev || echo "Package Iinstallation failed" && exit 1 + sudo apt-get install -y libudev-dev || echo "Package Iinstallation failed" && exit 1 +fi # Build I2S kernel module PI_MODEL=$(cat /proc/device-tree/model | awk '{print $3}') @@ -197,23 +203,23 @@ chmod a-w ~/.asoundrc sudo /etc/init.d/alsa-utils restart if [[ -n "$I2S_MODE" ]]; then - # Create the script to run after each reboot and make the soundcard available - i2s_driver_script=$RPI_SETUP_DIR/resources/load_i2s_driver.sh - rm -f $i2s_driver_script - - # Sometimes with Buster on RPi3 the SYNC bit in the I2S_CS_A_REG register is not set before the drivers are loaded - # According to section 8.8 of https://cs140e.sergio.bz/docs/BCM2837-ARM-Peripherals.pdf - # this bit is set after 2 PCM clocks have occurred. - # To avoid this issue we add a 1-second delay before the drivers are loaded - echo "sleep 1" >> $i2s_driver_script - - I2S_NAME=i2s_$I2S_MODE - I2S_MODULE=$RPI_SETUP_DIR/loader/$I2S_NAME/${I2S_NAME}_loader.ko - echo "sudo insmod $I2S_MODULE" >> $i2s_driver_script - - echo "# Run Alsa at startup so that alsamixer configures" >> $i2s_driver_script - echo "arecord -d 1 > /dev/null 2>&1" >> $i2s_driver_script - echo "aplay dummy > /dev/null 2>&1" >> $i2s_driver_script + # Create the script to run after each reboot and make the soundcard available + i2s_driver_script=$RPI_SETUP_DIR/resources/load_i2s_driver.sh + rm -f $i2s_driver_script + + # Sometimes with Buster on RPi3 the SYNC bit in the I2S_CS_A_REG register is not set before the drivers are loaded + # According to section 8.8 of https://cs140e.sergio.bz/docs/BCM2837-ARM-Peripherals.pdf + # this bit is set after 2 PCM clocks have occurred. + # To avoid this issue we add a 1-second delay before the drivers are loaded + echo "sleep 1" >> $i2s_driver_script + + I2S_NAME=i2s_$I2S_MODE + I2S_MODULE=$RPI_SETUP_DIR/loader/$I2S_NAME/${I2S_NAME}_loader.ko + echo "sudo insmod $I2S_MODULE" >> $i2s_driver_script + + echo "# Run Alsa at startup so that alsamixer configures" >> $i2s_driver_script + echo "arecord -d 1 > /dev/null 2>&1" >> $i2s_driver_script + echo "aplay dummy > /dev/null 2>&1" >> $i2s_driver_script fi if [[ -n "$DAC_SETUP" ]]; then From 6bb50c0d2729f8c5bbe1efe66cc6ccc466b86036 Mon Sep 17 00:00:00 2001 From: lucianom Date: Mon, 16 May 2022 17:26:03 +0100 Subject: [PATCH 3/7] Fix typos --- setup.sh | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/setup.sh b/setup.sh index dc04067..73000a4 100755 --- a/setup.sh +++ b/setup.sh @@ -121,17 +121,18 @@ if ! dpkg -s $KERNEL_HEADERS_PACKAGE &> /dev/null; then fi echo "Installing the Python3 packages and related libs" -sudo apt-get install -y python3-matplotlib || echo "Package Iinstallation failed" && exit 1 -sudo apt-get install -y python3-numpy|| echo "Package Iinstallation failed" && exit 1 -sudo apt-get install -y libatlas-base-dev || echo "Package Iinstallation failed" && exit 1 +sudo apt-get install -y python3-matplotlib || echo "Package installation failed" && exit 1 +sudo apt-get install -y python3-numpy || echo "Package installation failed" && exit 1 +sudo apt-get install -y libatlas-base-dev || echo "Package installation failed" && exit 1 echo "Installing necessary packages for dev kit" -sudo apt-get install -y libusb-1.0-0-dev || echo "Package Iinstallation failed" && exit 1 -sudo apt-get install -y libreadline-dev || echo "Package Iinstallation failed" && exit 1 -sudo apt-get install -y libncurses-dev || echo "Package Iinstallation failed" && exit 1 +sudo apt-get install -y audacity || echo "Package installation failed" && exit 1 +sudo apt-get install -y libreadline-dev || echo "Package installation failed" && exit 1 +sudo apt-get install -y libncurses-dev || echo "Package installation failed" && exit 1 if [[ -n "$UA_MODE" ]]; then - sudo apt-get install -y libevdev-dev || echo "Package Iinstallation failed" && exit 1 - sudo apt-get install -y libudev-dev || echo "Package Iinstallation failed" && exit 1 + sudo apt-get install -y libusb-1.0-0-dev || echo "Package installation failed" && exit 1 + sudo apt-get install -y libevdev-dev || echo "Package installation failed" && exit 1 + sudo apt-get install -y libudev-dev || echo "Package installation failed" && exit 1 fi # Build I2S kernel module @@ -238,7 +239,6 @@ if [[ -n "$DAC_SETUP" ]]; then echo "python $RPI_SETUP_DIR/resources/clk_dac_setup/reset_xvf.py $(echo $XMOS_DEVICE | cut -c1-7)" >> $dac_and_clks_script fi -sudo apt-get install -y audacity if [[ -n "$DAC_SETUP" ]]; then audacity_script=$RPI_SETUP_DIR/resources/run_audacity.sh rm -f $audacity_script From 0f408714a4289cbd4e852579392e02256c3e8b01 Mon Sep 17 00:00:00 2001 From: lucianom Date: Mon, 16 May 2022 20:06:11 +0100 Subject: [PATCH 4/7] Use correct syntax --- setup.sh | 19 ++++++++++--------- 1 file changed, 10 insertions(+), 9 deletions(-) diff --git a/setup.sh b/setup.sh index 73000a4..62e21d5 100755 --- a/setup.sh +++ b/setup.sh @@ -121,18 +121,18 @@ if ! dpkg -s $KERNEL_HEADERS_PACKAGE &> /dev/null; then fi echo "Installing the Python3 packages and related libs" -sudo apt-get install -y python3-matplotlib || echo "Package installation failed" && exit 1 -sudo apt-get install -y python3-numpy || echo "Package installation failed" && exit 1 -sudo apt-get install -y libatlas-base-dev || echo "Package installation failed" && exit 1 +sudo apt-get install -y python3-matplotlib || ( echo "Package installation failed" ; exit 1) +sudo apt-get install -y python3-numpy || ( echo "Package installation failed" ; exit 1) +sudo apt-get install -y libatlas-base-dev || ( echo "Package installation failed" ; exit 1) echo "Installing necessary packages for dev kit" -sudo apt-get install -y audacity || echo "Package installation failed" && exit 1 -sudo apt-get install -y libreadline-dev || echo "Package installation failed" && exit 1 -sudo apt-get install -y libncurses-dev || echo "Package installation failed" && exit 1 +sudo apt-get install -y audacity || ( echo "Package installation failed" ; exit 1) +sudo apt-get install -y libreadline-dev || ( echo "Package installation failed" ; exit 1) +sudo apt-get install -y libncurses-dev || ( echo "Package installation failed" ; exit 1) if [[ -n "$UA_MODE" ]]; then - sudo apt-get install -y libusb-1.0-0-dev || echo "Package installation failed" && exit 1 - sudo apt-get install -y libevdev-dev || echo "Package installation failed" && exit 1 - sudo apt-get install -y libudev-dev || echo "Package installation failed" && exit 1 + sudo apt-get install -y libusb-1.0-0-dev || ( echo "Package installation failed" ; exit 1) + sudo apt-get install -y libevdev-dev || ( echo "Package installation failed" ; exit 1) + sudo apt-get install -y libudev-dev || ( echo "Package installation failed" ; exit 1) fi # Build I2S kernel module @@ -177,6 +177,7 @@ popd > /dev/null # Copy the udev rules files if device is UA if [[ -n "$UA_MODE" ]]; then + echo "Add UDEV rules for XMOS devices" sudo cp $RPI_SETUP_DIR/resources/99-xmos.rules /etc/udev/rules.d/ fi From 545f6deb95d263f4dd1c154d735c7279a7775f17 Mon Sep 17 00:00:00 2001 From: lucianom Date: Tue, 17 May 2022 08:07:37 +0100 Subject: [PATCH 5/7] Update printouts --- setup.sh | 19 +++++++++---------- 1 file changed, 9 insertions(+), 10 deletions(-) diff --git a/setup.sh b/setup.sh index 62e21d5..b358989 100755 --- a/setup.sh +++ b/setup.sh @@ -121,18 +121,18 @@ if ! dpkg -s $KERNEL_HEADERS_PACKAGE &> /dev/null; then fi echo "Installing the Python3 packages and related libs" -sudo apt-get install -y python3-matplotlib || ( echo "Package installation failed" ; exit 1) -sudo apt-get install -y python3-numpy || ( echo "Package installation failed" ; exit 1) -sudo apt-get install -y libatlas-base-dev || ( echo "Package installation failed" ; exit 1) +sudo apt-get install -y python3-matplotlib || ( echo "Error: Package installation failed" ; exit 1 ) +sudo apt-get install -y python3-numpy || ( echo "Error: Package installation failed" ; exit 1 ) +sudo apt-get install -y libatlas-base-dev || ( echo "Error: Package installation failed" ; exit 1 ) echo "Installing necessary packages for dev kit" -sudo apt-get install -y audacity || ( echo "Package installation failed" ; exit 1) -sudo apt-get install -y libreadline-dev || ( echo "Package installation failed" ; exit 1) -sudo apt-get install -y libncurses-dev || ( echo "Package installation failed" ; exit 1) +sudo apt-get install -y audacity || ( echo "Error: Package installation failed" ; exit 1 ) +sudo apt-get install -y libreadline-dev || ( echo "Error: Package installation failed" ; exit 1 ) +sudo apt-get install -y libncurses-dev || ( echo "Error: Package installation failed" ; exit 1 ) if [[ -n "$UA_MODE" ]]; then - sudo apt-get install -y libusb-1.0-0-dev || ( echo "Package installation failed" ; exit 1) - sudo apt-get install -y libevdev-dev || ( echo "Package installation failed" ; exit 1) - sudo apt-get install -y libudev-dev || ( echo "Package installation failed" ; exit 1) + sudo apt-get install -y libusb-1.0-0-dev || ( echo "Error: Package installation failed" ; exit 1 ) + sudo apt-get install -y libevdev-dev || ( echo "Error: Package installation failed" ; exit 1 ) + sudo apt-get install -y libudev-dev || ( echo "Error: Package installation failed" ; exit 1 ) fi # Build I2S kernel module @@ -269,4 +269,3 @@ popd > /dev/null fi echo "To enable all interfaces, this Raspberry Pi must be rebooted." - From 55fd506058dfd4c691b2745382a9bc9104287328 Mon Sep 17 00:00:00 2001 From: lucianom Date: Tue, 17 May 2022 09:00:14 +0100 Subject: [PATCH 6/7] Fix device name parsing --- CHANGELOG.md | 1 + setup.sh | 14 +++++++------- 2 files changed, 8 insertions(+), 7 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 91d022c..c602b86 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -4,6 +4,7 @@ * Added support for xvf3510-ua * Renamed xvf3510 device as xvf3510-int + * Fix bug in parsing of device names * Install one Debian package at the time ## 5.0.0 diff --git a/setup.sh b/setup.sh index b358989..86dfb0b 100755 --- a/setup.sh +++ b/setup.sh @@ -56,13 +56,13 @@ else fi # Configure device-specific settings -case $XMOS_DEVICE in - xvf3[56]10-ua) +case $XMOS_DEVICE in + xvf3510-ua|xvf3610-ua|xvf615-ua) UA_MODE=y ASOUNDRC_TEMPLATE=$RPI_SETUP_DIR/resources/asoundrc_vf_xvf3510_ua ;; - xvf3[56]10-int) + xvf3510-int|xvf3610-int|xvf3615-int) I2S_MODE=master DAC_SETUP=y ASOUNDRC_TEMPLATE=$RPI_SETUP_DIR/resources/asoundrc_vf_xvf3510_int @@ -71,7 +71,7 @@ case $XMOS_DEVICE in I2S_MODE=slave ASOUNDRC_TEMPLATE=$RPI_SETUP_DIR/resources/asoundrc_vf_stereo ;; - xvf3100) + xvf3[01]00) I2S_MODE=slave ASOUNDRC_TEMPLATE=$RPI_SETUP_DIR/resources/asoundrc_vf ;; @@ -86,7 +86,7 @@ case $XMOS_DEVICE in ASOUNDRC_TEMPLATE=$RPI_SETUP_DIR/resources/asoundrc_vf ;; *) - echo error: unknown XMOS device type $XMOS_DEVICE. + echo Error: unknown XMOS device type $XMOS_DEVICE. exit 1 ;; esac @@ -154,7 +154,7 @@ if [[ -n "$I2S_MODE" ]]; then # no flags needed for I2S slave compilation ;; *) - echo error: I2S mode not known for XMOS device $XMOS_DEVICE. + echo Error: I2S mode not known for XMOS device $XMOS_DEVICE. exit 1 ;; esac @@ -192,7 +192,7 @@ fi # Check XMOS device for asoundrc selection. if [[ -z "$ASOUNDRC_TEMPLATE" ]]; then - echo error: sound card config not known for XMOS device $XMOS_DEVICE. + echo Error: sound card config not known for XMOS device $XMOS_DEVICE. exit 1 fi cp $ASOUNDRC_TEMPLATE ~/.asoundrc From 250519ce630cc574c377d4d779f8d138c6fc1aa7 Mon Sep 17 00:00:00 2001 From: lucianom Date: Wed, 18 May 2022 14:22:55 +0100 Subject: [PATCH 7/7] Improve printouts and fix error in case --- setup.sh | 23 +++++++++++------------ 1 file changed, 11 insertions(+), 12 deletions(-) diff --git a/setup.sh b/setup.sh index 86dfb0b..abceb81 100755 --- a/setup.sh +++ b/setup.sh @@ -8,6 +8,9 @@ XMOS_DEVICE= # Valid values for XMOS device VALID_XMOS_DEVICES="xvf3100 xvf3500 xvf3510-int xvf3510-ua xvf3600-slave xvf3600-master xvf3610-int xvf3610-ua xvf3615-int xvf3615-ua" +PACKAGES_TO_INSTALL="python3-matplotlib python3-numpy libatlas-base-dev audacity libreadline-dev libncurses-dev" +PACKAGES_TO_INSTALL_ONLY_FOR_UA="libusb-1.0-0-dev libevdev-dev libudev-dev" + usage() { local VALID_XMOS_DEVICES_DISPLAY_STRING= local NUMBER_OF_VALID_DEVICES=$(echo $VALID_XMOS_DEVICES | wc -w) @@ -57,7 +60,7 @@ fi # Configure device-specific settings case $XMOS_DEVICE in - xvf3510-ua|xvf3610-ua|xvf615-ua) + xvf3510-ua|xvf3610-ua|xvf3615-ua) UA_MODE=y ASOUNDRC_TEMPLATE=$RPI_SETUP_DIR/resources/asoundrc_vf_xvf3510_ua ;; @@ -120,20 +123,15 @@ if ! dpkg -s $KERNEL_HEADERS_PACKAGE &> /dev/null; then sudo apt-get install -y $KERNEL_HEADERS_PACKAGE fi -echo "Installing the Python3 packages and related libs" -sudo apt-get install -y python3-matplotlib || ( echo "Error: Package installation failed" ; exit 1 ) -sudo apt-get install -y python3-numpy || ( echo "Error: Package installation failed" ; exit 1 ) -sudo apt-get install -y libatlas-base-dev || ( echo "Error: Package installation failed" ; exit 1 ) - echo "Installing necessary packages for dev kit" -sudo apt-get install -y audacity || ( echo "Error: Package installation failed" ; exit 1 ) -sudo apt-get install -y libreadline-dev || ( echo "Error: Package installation failed" ; exit 1 ) -sudo apt-get install -y libncurses-dev || ( echo "Error: Package installation failed" ; exit 1 ) +packages=$PACKAGES_TO_INSTALL +# Add packages for UA mode if [[ -n "$UA_MODE" ]]; then - sudo apt-get install -y libusb-1.0-0-dev || ( echo "Error: Package installation failed" ; exit 1 ) - sudo apt-get install -y libevdev-dev || ( echo "Error: Package installation failed" ; exit 1 ) - sudo apt-get install -y libudev-dev || ( echo "Error: Package installation failed" ; exit 1 ) + packages="$packages $PACKAGES_TO_INSTALL_ONLY_FOR_UA" fi +for package in $packages; do + sudo apt-get install -y $package || ( echo "Error: installation of package $package failed" ; exit 1 ) +done # Build I2S kernel module PI_MODEL=$(cat /proc/device-tree/model | awk '{print $3}') @@ -269,3 +267,4 @@ popd > /dev/null fi echo "To enable all interfaces, this Raspberry Pi must be rebooted." +