[Date Prev][Date Next] [Thread Prev][Thread Next] [Date Index] [Thread Index]

Sound card not detected by the incoming Debian installer for Debian 10



Hello,

root[/home/didier]# lspci -knn|grep -A2 Audio
00:1b.0 Audio device [0403]: Intel Corporation 6 Series/C200 Series Chipset Family High Definition Audio Controller [8086:1c20] (rev 04)
	Subsystem: Lenovo 6 Series/C200 Series Chipset Family High Definition Audio Controller [17aa:21cf]
	Kernel driver in use: snd_hda_intel
	Kernel modules: snd_hda_intel

Weekly image ISO: debian-testing-amd64-DVD-1.iso (dated 14 June IIRC).

I would expect that /lib/debian-installer-startup.d/S38espeakup detects
one sound card, so just starts espeakup.

Instead, it is stuck in the 30 seconds loop then give up.

I attach S38espeakup and the Slint script probe_sound_cars with the same
purpose but that does detect the card.

However I don't know if the difference comes from the script or on how
/sys is populated or from any other reason.

I will provide additional information upon request.

Best regards,

Didier

PS additionally the 'sleep' from BusyBox doesn't accept a 0.1 argument, but that's minor.
BASE=/sys/class/sound

strip () {
	cardid=${1#$BASE/card}
	echo ${cardid%/id}
}

if lsmod | grep -q speakup_soft; then
	# Give drivers some time to detect boards :/
	sleep 1
	S=1
	while true
	do
		IDS=$(echo $BASE/card*/id)
		if [ "$IDS" = "$BASE/card*/id" ]; then
			if [ "$S" -ge 3 ]; then
				echo "No sound card detected after $S seconds..."
			fi
			if [ "$S" -lt 30 ]; then
				# We have seen cards taking as much as 12s to get initialized...
				sleep 1
				S=$((S+1))
				continue
			else
				echo "Can not do software speech synthesis... Press enter to continue anyway."
				read
				break
			fi
		fi

		# Sleep again as much, in case more cards are to come :/
		echo "Waiting for $S more seconds for any other card..."
		sleep $S

		. /usr/share/alsa/utils.sh
		preinit_levels all
		sanify_levels all

		IDS=$(echo $BASE/card*/id)
		N=$(echo $IDS | wc -w)

		case $N in
		1)
			# Just one card, can not be wrong
			echo $(strip $IDS) > /var/run/espeakup.card
			/usr/bin/espeakup -V en > /var/log/espeakup.log 2>&1
			;;
		*)
			# Several cards, make the user choose
			CARD=none
			while [ "$CARD" = none ]
			do
				for ID in $IDS
				do
					i=$(strip $ID)
					ALSA_CARD=$(cat /sys/class/sound/card$i/id) /usr/bin/espeakup -V en >> /var/log/espeakup.log 2>&1
					while ! [ -r /var/run/espeakup.pid ]
					do
						sleep 0.1
					done
					pid=$(cat /var/run/espeakup.pid)
					answer=none
					echo Please type enter to use this sound board
					read -t 5 answer
					kill $pid
					while [ -r /var/run/espeakup.pid ]
					do
						sleep 0.1
					done
					if [ "$answer" != none ]
					then
						CARD=$i
						break
					fi
				done
			done
			echo "$CARD" > /var/run/espeakup.card
			ALSA_CARD=$(cat /sys/class/sound/card$CARD/id) /usr/bin/espeakup -V en >> /var/log/espeakup.log 2>&1
		esac

		break
	done
fi
BASE=/sys/class/sound

if [ ! -d /sys/class/sound ]; then
	touch /tmp/noespeakup
	exit
fi

strip () {
	cardid=${1#$BASE/card}
	echo ${cardid%/id}
}

if ! grep -q speakup /proc/cmdline; then
	# Give drivers some time to detect boards :/
	sleep 2
	IDS=$(echo $BASE/card*/id)
	N=$(echo $IDS | wc -w)
	case $N in
		0)
			touch /tmp/noespeakup
			exit
			;;
		1)
			# Just one card, can not be wrong
			/usr/bin/espeakup -V $(cat /tmp/speech) > /tmp/espeakup.log 2>&1
			echo "/usr/bin/espeakup -V $(cat /tmp/speech)" >> /tmp/report
			;;
		*)
			# Several cards, make the user choose
			CARD=none
			while [ "$CARD" = none ]; do
				for ID in $IDS; do
					i=$(strip $ID)
					ALSA_CARD=$(cat /sys/class/sound/card$i/id)
					ALSA_CARD=$ALSA_CARD /usr/bin/espeakup -V $(cat /tmp/speech) >> /tmp/espeakup.log 2>&1
					echo "ALSA_CARD=$ALSA_CARD /usr/bin/espeakup -V $(cat /tmp/speech)" >> /tmp/report
					echo $ALSA_CARD >/tmp/alsacard
					echo "defaults.pcm.card $i" >/tmp/asound.conf
					echo "defaults.ctl.card $i" >>/tmp/asound.conf
					answer=none
					echo "Please type enter to use the sound board $ALSA_CARD"
					echo
					read -t 7 dummy
					answer=$?
					if [ $answer -eq 0 ]; then
						CARD=$i
						echo "Card chosen: $i" >> /tmp/cards 
						break
					fi
					PID=$(ps -C espeakup --noheaders -o pid)
					kill -s 9 $PID
					sleep 1
				done
				if [ "$CARD" = none ]; then
					echo "No card was selected. Speech will not be provided."
					touch /tmp/noespeakup
					rm /tmp/alsacard
					rm /tmp/asound.conf
					echo "No sound card selected" >> /tmp/report
					exit
				fi
			done
	esac
fi

Reply to: