Problemas de latencia

marcelu80
#1 por marcelu80 el 29/11/2007
Hola a todos,

ya llevo casi 10 meses en Ubuntu y la verdad es que ya me manejo bastante bién en general pero el tema del sonido todavía se me resiste. Tras tener problemas con el Kernel de Ubuntu opté por canviar a Studio con el kernel rt. Ahora empiezo a entrar de verdad en el tema de sonido en Linux.

Lo primero que quiero probar es reproducir y hacer sonar Aeolus (estupendo sintetizador de organo, por otra parte) pero Jack me llena el registro de xrun de color rosa o rojo, lo cual significa que tengo problemas de latencia. He configurado las preferencias de jack de mil formas pero siempre tengo xrun y, claro está, un sonido absolutamente inaudible y lleno de distorsiones. Cierto es que trabajo con la tarjeta de sonido de placa, pero en Win2 reproduzco hasta 12 pistas de VST en Cubase sin ningún problema.

¿Hay algo más que deba mirar? ¿És normal que a pesar de tener el kernel rt todavía tenga problemas de latencia?


Saludos amigos.
Subir
OFERTASVer todas
  • -21%
    Zoom H4n Pro Black
    158 €
    Ver oferta
  • beyerdynamic DT-770 Pro
    138 €
    Ver oferta
  • -8%
    Behringer X Air XR18
    645 €
    Ver oferta
Ismael Valladolid Torres
#2 por Ismael Valladolid Torres el 29/11/2007
La experiencia habitual es que ALSA se porta mejor, incluso con las tarjetas de sonido embutidas en las placas base, que los drivers de audio de Windows, así que me extraña lo tuyo.

Arranca qjackctl (JACK Control) y pulsa Setup. Haz clic en Realtime y en Force 16bit. Ahora te sugiero jugar con los valores Frames/Period y Periods/Buffer. Prueba con valores conservadores como 2048/16. Si consigues que funcione establemente, ve bajando los valores. Cuanto más bajos, menor la latencia. Con la tarjeta de la placa base de mi portátil funciona con 256/2 para 11,6 ms. de latencia. Prueba también a poner en Audio Playback only si no vas a grabar con la tarjeta. En el peor de los casos puedes probar a activar No Memory Lock y Unlock Memory pero si y sólo si tienes más de un giga de memoria.

Ya nos cuentas...
Subir
marcelu80
#3 por marcelu80 el 29/11/2007
Gracias por tu consejo:

Nada. He probado estos valores una y otra vez pero sólo consigo peores resultados. Lo bueno es que con los valores 256/2 que dices me marca la misma latencia de 11.6ms, que además deberia de ser imperceptible, pero luego me encuentro que el sonido es pésimo. No se cual problema, pero lo que es seguro es que el registro de jack se llena de xrun en rosa o rojo, y de vez en cuando un skipped.
Me da mucha pena no poder ni empezar con sonido en Linux porque es una cuestión de orgullo el demostrar que LInux sirve también para profesionales de escritorio, pero no puedo ni tan sólo cruzar el umbral de la puerta.
Subir
guitman
#4 por guitman el 29/11/2007
¿ Qué hay en /etc/security/limits.conf?
Subir
marcelu80
#5 por marcelu80 el 29/11/2007
Esto es:

marcel@ubuntu:~$ cat /etc/security/limits.conf
# /etc/security/limits.conf
#
#Each line describes a limit for a user in the form:
#
#
#
#Where:
# can be:
# - an user name
# - a group name, with @group syntax
# - the wildcard *, for default entry
# - the wildcard %, can be also used with %group syntax,
# for maxlogin limit
#
# can have the two values:
# - "soft" for enforcing the soft limits
# - "hard" for enforcing hard limits
#
# can be one of the following:
# - core - limits the core file size (KB)
# - data - max data size (KB)
# - fsize - maximum filesize (KB)
# - memlock - max locked-in-memory address space (KB)
# - nofile - max number of open files
# - rss - max resident set size (KB)
# - stack - max stack size (KB)
# - cpu - max CPU time (MIN)
# - nproc - max number of processes
# - as - address space limit
# - maxlogins - max number of logins for this user
# - maxsyslogins - max number of logins on the system
# - priority - the priority to run user process with
# - locks - max number of file locks the user can hold
# - sigpending - max number of pending signals
# - msgqueue - max memory used by POSIX message queues (bytes)
# - nice - max nice priority allowed to raise to
# - rtprio - max realtime priority
# - chroot - change root to directory (Debian-specific)
#
#
#

#* soft core 0
#* hard rss 10000
#@student hard nproc 20
#@faculty soft nproc 20
#@faculty hard nproc 50
#ftp hard nproc 0
#ftp - chroot /ftp
#@student - maxlogins 4

# End of file
@audio - rtprio 99
@audio - memlock 512000


Espero que veas algo que pueda cambiar.

Saludos.
Subir
guitman
#6 por guitman el 30/11/2007
Es algo diferente a lo que hay en el mío , a ver si te vale :

[code] @audio - rtprio 99
@audio - nice 10
@audio - memlock 4000000
[/code]

Es de suponer que tu usuario estará adscrito al grupo audio .

Prueba a cambiarle los parámetros por esos que puse y reinicia tu sesión .

Ya nos contarás .
Subir
Ismael Valladolid Torres
#7 por Ismael Valladolid Torres el 30/11/2007
Insisto, es muy razonable que tu tarjeta tenga tamaños de buffer fijos y que sólo te funcione con un valor de Frames/Period. Mi RME --¡una RME, nada menos!-- sólo funciona a 32 bits con 1024 y 256. Prueba con todos los valores, no te dejes ni uno.

También ayudará que nos pongas los mensajes que te devuelve jackd, por si algo se nos escapa.
Subir
marcelu80
#8 por marcelu80 el 30/11/2007
Pongo una muestra del registro de jack. Los valores son:
Priority: 0 (creo que es lo mejor, no?)
Frames: 256
sample rate: 44100
periods buffer: 2
Force 16 bit: enabled
el resto está por defecto. La latencia estimada es de 11.6msec.
________________________

22:57:22.227 Patchbay deactivated.
22:57:22.256 Statistics reset.
22:57:22.371 MIDI connection graph change.
JACK tmpdir identified as [/dev/shm]
22:57:22.478 MIDI connection change.
22:57:25.891 Startup script...
22:57:25.891 artsshell -q terminate
JACK tmpdir identified as [/dev/shm]
can't create mcop directory
Link points to "/tmp/ksocket-marcel"
22:57:26.498 Startup script terminated with exit status=256.
22:57:26.499 JACK is starting...
22:57:26.500 /usr/bin/jackd -R -p128 -u -dalsa -dhw:0 -r44100 -p256 -n2 -s -S
22:57:26.502 JACK was started with PID=5979 (0x175b).
jackd 0.103.0
Copyright 2001-2005 Paul Davis and others.
jackd comes with ABSOLUTELY NO WARRANTY
This is free software, and you are welcome to redistribute it
under certain conditions; see the file COPYING for details
JACK compiled with System V SHM support.
loading driver ..
apparent rate = 44100
creating alsa driver ... hw:0|hw:0|256|2|44100|0|0|nomon|swmeter|soft-mode|16bit
control device hw:0
configuring for 44100Hz, period = 256 frames, buffer = 2 periods
ALSA: final selected sample format for capture: 16bit little-endian
ALSA: use 2 periods for capture
ALSA: final selected sample format for playback: 16bit little-endian
ALSA: use 2 periods for playback
22:57:28.521 Server configuration saved to "/home/marcel/.jackdrc".
22:57:28.522 Statistics reset.
22:57:28.763 Client activated.
22:57:28.767 Audio connection change.
22:57:28.773 Audio connection graph change.
JACK tmpdir identified as [/dev/shm]
22:57:48.340 Audio connection graph change.
22:57:48.376 MIDI connection graph change.
22:57:48.480 Audio connection change.
22:57:48.481 MIDI connection change.
delay of 11443.000 usecs exceeds estimated spare time of 5598.000; restart ...
22:58:03.342 XRUN callback (1).
delay of 5622.000 usecs exceeds estimated spare time of 5444.000; restart ...
22:58:04.969 XRUN callback (1 skipped).
delay of 5417.000 usecs exceeds estimated spare time of 3725.000; restart ...
22:58:06.871 XRUN callback (3).
delay of 5459.000 usecs exceeds estimated spare time of 3725.000; restart ...
delay of 5462.000 usecs exceeds estimated spare time of 3725.000; restart ...
22:58:06.981 XRUN callback (2 skipped).
________________________________
...i mientras tanto el sonido es horrible, claro.
Subir
marcelu80
#9 por marcelu80 el 01/12/2007
También he probado a añadir la linea con valor nice 10 e incluso -19 para forzar prioridad de cpu pero no ha cambiado nada después de reiniciar el ordenador. También he arrancado jack y mientras funcionaba he probado a modificar la prioridad en el registro de procesos del monitor de gnome pero tampoco cambia nada. Está claro que no tiene que ver con problema de capacidad de proceso del sistema.
Hay algo más y por lo que veo no es algo raro ya que más usuarios se quejan de lo mismo.

Saludos.
Subir
marcelu80
#10 por marcelu80 el 02/12/2007
Sólo decíros que he probado a poner 3 en buffer con 256 frames y no me ha dado problemas de sonido aunque los xrun van saliendo de vez en cuando. No quisiera cantar victoria antes de tiempo pero creo que ya veo por donde van los tiros. Gracias ivalladt y guitman por vuestros consejos.

Un saludo.
Subir
Ismael Valladolid Torres
#11 por Ismael Valladolid Torres el 04/12/2007
Lo vuelvo a escribir: Es muy habitual que una tarjeta de sonido tenga un tamaño de buffer fijo así que sólo funcione con un valor de Frames específico. En cuanto al buffer, con independencia del valor que pongas las últimas versiones de ALSA van al menor tamaño soportado, para dar la menor latencia posible. Aún así, sigue probando valores altos de buffer y cuéntanos cómo sigue el tema.

Si tienes un giga de memoria, cosas como activar el no memory lock también podría ayudar...
Subir
marcelu80
#12 por marcelu80 el 04/12/2007
OK. Para que lo entienda, ¿cuales son los valores que exigen más rendimiento del ordenador pero que dan mejor calidad de sonido?... ¿cuanto más altos o cuanto más bajos?. Porque subiendo a 4 buffers va incluso mejor. Pero no puedo subir a 1024 frames. sólo puedo hasta 512. Veo que tengo varias opciones (no entiendo entonces porque no funcionó al principio cuando juraria haberlas probado todas) y no sé cual es la ideal.

Gracias Ivalladt por tu ayuda. Saludos.
Subir
Ismael Valladolid Torres
#13 por Ismael Valladolid Torres el 04/12/2007
Cuanto menor la latencia, mayor la exigencia al sistema. Es decir, en efecto con más buffers el sistema debería ir más suelto, y con más frames lo mismo, solo que si la tarjeta tiene un tamaño fijo de buffer, con este último parámetro no puedes jugar.

Me alegra que lo vayas viendo más claro. :shock:
Subir
Hilos similares
Nuevo post

Regístrate o para poder postear en este hilo