sábado, 15 de diciembre de 2007

Scripts para saber cuando pasa cada hora:

Suele suceder que gracias a la gran estabilidad de los sistemas que usamos y la adictividad las terminales gráficas, virtuales, de texto algunos perdemos la noción del tiempo.

Como suelo usar varias veces la compu con los parlantes encendidos para escuchar música de vez en cuando lo que se me ocurrió hacer es un conjunto de scripts que combinados con crontab, un reproductor de sonido y un archivo de audio al inicio de cada hora hicieran un toque horario parecido al de las radioemisoras AM.

La idea es que no se interrumpa la música ni lo que se oye sino que se "pise" el sonido de los beeps con lo que corre. Esto lo he logrado gracias a los drivers ALSA para mi placa de sonido, mi placa de sonido y otras cosas que desconozco que permiten que dos programas salgan al mismo tiempo (mixer por hardware debería ser).

Lo primero que se me ocurrió hacer fue el sonido de Beep, después de instalar audacity y probar varias cosas noté que lo mejor era aprender a usar bien el programa y luego grabar de un buzzer que tengo guardado por ahí. Lo que quedó fueron tres toques: uno por canal derecho el otro por el izquierdo y al final el más largo por los dos canales, de paso el archivo me sirve para probar las conexiones de sonido. Naturalmente lo exporté a Ogg Vorbis.

Pensé en un script que verificara si el usuario dueño del proceso estuviera logueado, que leyera un archivo de configuración que evitase la ejecucióon en determinadas ocasiones y que en sí mismo tuviera la información del archivo de sonido y el programa para escucharlo. Luego se me ocurrió que el programa y el archivo podrían ser enviados como argumentos. Y luego le agregué como escribir el archivo de configuración.

Agregué las lineas correspondientes a crontab que ejecutasen el escript a los 00 minutos de cada hora. Y queda una cosa más o menos:

00 * * * * nice -n10 sh /home/MAbeeTT/myFilesystem/my_usr/my_share/my_bin/beep_horario.sh \
/usr/bin/ogg123 /home/MAbeeTT/myFilesystem/my_usr/my_share/beeper/Beeper.ogg \
2>/dev/null 1>/dev/null

TOdo en una linea, claro. Como se puede apreciar el script se ejecuta amablemente con un valor nice 10, llama a ogg123 que leerá el archivo Beeper.ogg. Esa aparentemente extraña organización del directorio myFilesystem es una forma personal de evitar ensuciar /usr/local con programas y scripts que solo correrá mi usuario.

En definitiva la ejecución del sript sería:

sh beep_horario.sh programa archivo [Valor_permiso_permiso_escritura]
donde Valor_permiso_permiso_escritura podría ser un 1 o cualuier otra cosa para escribir el archivo de configuración ~/.beep_horario y habilitar o deshabilitar la emisión del sonido.

Pero luego se me ocurríó que sería más interesante hacer un script que agregase las sentencias por sí solo y lo agregué, al mismo se le entrega:

sh instalar_cron.sh programa archivo_audio archivo_temporal valor_nice

Donde programa podría ser ogg123, archivo_audio algún archivo de sonido (poque tal vez no les guste mi Beeper.ogg), archivo_temporal un archivo temporal para que no se pierda la informacion de crontab y valor_nice deber ser el valor nice del proceso, está forzado a ser mayor 4.

Todo esto está disponible en el archivo de descarga

Después de algnos días me econtré en Debian con algunos paquetes parecidos:

  • saytime: speaks the current time through your sound card. Say the current time through your sound card. Requires you have a sound output device available.
  • grandfatherclock: a clock that tolls time acoustically grandfatherclock plays audio files to report the time. The default configuration emulates a grandfather clock with Westminster chimes. Cuckoo clock and Close Encounters of the Third Kind files are included as well...

sábado, 8 de diciembre de 2007

Escuchando múscica con MPD III - Ahora icecast

Antes les expliqué Cómo instalar mpd, y luego algo de usarlo en modo usuario. Ahora les muestro lo que encontré y configuré probando un poco: icecast.

La idea:

Icecast es un servidor de streamings que soporta Ogg Vorbis y Mp3. Mi idea es usarlo como un elemento de interfaz entre la supuesta computadora del armario y un cliente que dispondría del los parlantitos, que podría ser un laptop o un desktop, que podría estar dentro una red local o bien Internet. Para Icecast mpd sería un cliente fuente (source client) y el programa que corre en la computadora laptop sería un oyente (listener), que puede ser mplayer, xmms, rhythmbox, winamp.

Debo agregar unos parámetros al archivo de configuración de mpd:


################# SHOUT STREAMING ########################
#
# Set this to allow mpd to stream its output to icecast2
# (i.e. mpd is a icecast2 source)
#
audio_output {
        type            "shout"
        name            "my cool stream"
        host            "localhost"
        port            "8000"
        mount           "mpd.ogg"
        password        "hackme"
#       quality         "5.0"
        bitrate         "128"
        format          "44100:16:2"

# Optional Paramters
        description     "here's my long descriptiion"
} # end of audio_output

De los parámetros:

  • type: es el tipo de salida DEBE ser shout.
  • name: es el nombre que tendrá el stream
  • port: puerto que usará icecast, yo escogí el 8000 porque tengo un apache para experimentos, pero podría tenerlo andando en el 80 o cualquier otro.
  • mount: es el punto de montaje del streaming, para acceder al streaming se usará luego ip_del_servidor:puerto/mounto_montaje.ogg. Escogí ponerle extensión .ogg al punto de montaje porque algunos programas clientes se atontan sin la extensión.
  • password: para que icecast no le de lugar a cualquier persona.
  • quality: calidad de codificación del stream Ogg es valido cualquier vvalor con un decimal entre 0 y 10. Solo vale poner el parámetro quality o bitrate; pero no ambos.
  • bitrate: el bitrate de encodeo en kbps.
  • format: usa la forma sample_rate:bits:channels donde sample_rate es el nivel de muestreo, bits los bits por muestreo y channels el número de canales.
  • description: la descripción del streaming.

Hasta ahora los datos colocados en description y name sólo se ven en la interfaz web de icecast.

Como es lógico mientras mayor es la calidad de salida más ancho de banda consumido, más recarga de la red y más uso de CPU.

Icecast

Por otro lado hay que instalar icecast:

apt-get install icecast2

La configuración de icecast es sencilla, el archivo de configutación es /etc/icecast2/icecast.xml, al menos se puede dejar algo andando sin tocar demasiadas cosas, me basé en el archivo que viene en el paquete Debian icecast_minimal.xml:

<!-- This config file contains a minimal set of configurable parameters,
     and mostly just contains the things you need to change.  We created
     this for those who got scared away from the rather large and heavily
     commented icecast.xml.dist file. -->
<icecast>
    <limits>
        <sources>2</sources>
    </limits>
    <authentication>
       
<source-password>hackme</source-password>
       
<relay-password>hackme</relay-password>
        <admin-user>admin</admin-user>
       
<admin-password>hackme</admin-password>
    </authentication>
    <directory>
       
<!--  <yp-url-timeout>15</yp-url-timeout> -->
       
<!-- <yp-url>http://dir.xiph.org/cgi-bin/yp-cgi</yp-url> -->

    </directory>
    <hostname>localhost</hostname>
    <listen-socket>
        <port>8000</port>
    </listen-socket>
    <fileserve>1</fileserve>
    <paths>
        <logdir>./log</logdir>
        <webroot>./web</webroot>
        <adminroot>./admin</adminroot>
        <alias source="/"
dest="/status.xsl"/>
    </paths>
    <logging>
       
<accesslog>access.log</accesslog>
        <errorlog>error.log</errorlog>
        <loglevel>3</loglevel>
<!-- 4 Debug, 3 Info, 2 Warn, 1 Error -->
    </logging>
     <security>
        <chroot>0</chroot>
        <changeowner>
            <user>icecast2</user>
            <group>icecast</group>
        </changeowner>
    </security>
</icecast>

Se puede hacer una configuración más completa: con una contraseña por cliente fuente, limitar la cantidad de oyentes por fuente, etc.

Como se puede ver está la misma contraseña para el server y como pueden apreciar también no me tomé la seguridad en serio ya que sólo estoy experimentando.

Icecast tiene una interfaz web cuyo usuario y contraseña están en el archivi de configuración, a través de ella se puede ver las estadísticas del servidor, echar clientes, cambiarlos de canal

Para que cada vez que arranque la computadora del armario corra todo esto automáticamente al inicio del sistema alcanza con tocar los archivos /etc/default de los paquetes correspondientes.

Para elegir la lista, cambiar de temas, etc alcanza con cualquier cliente de mpd y con la configuración que permita al cliente acceder al comando de la lista

Varias salidas al mismo tiempo.

Una cosa interesante es que se pueden tener activas más de una salida al mismo tiempo; por ejemplo se puede tener la salida ALSA lista y al mismo tiempo la salida para icecast. Algunos clientes como gmpc permiten activar o desactivar cada una de las salidas

Referencias:

viernes, 30 de noviembre de 2007

Escuchando múscica con MPD II

Ateriormente les conté de mpd y un cliente ncmpc, ahora les cuento cómo es que escogí mi configuración para poder ejecutarlo como usuario:

Cree un directorio ~/.mpd que alojara a los archivos "errors.log" "mpd.log" "state" "tag_cache" y al directorio "playlists". Cambié los parámetros apropiados:

 music_directory         "/var/lib/mpd/music"
 playlist_directory      "/home/MAbeeTT/.mpd/playlists"

 db_file                 "/home/MAbeeTT/.mpd/tag_cache"
 log_file                "/home/MAbeeTT/.mpd/mpd.log"
 error_file              "/home/MAbeeTT/.mpd//errors.log"
 pid_file                "/var/run/mpd/pid"

Del directorio de la sumidero de la música no toqué nada y tampoco del archivo pid, como al archivo del pid solo accede root o el grupo de mpd le cambio permisos al archivo o me agrego al grupo.

Fuerzo a usar salida Alsa:

audio_output {
        type            "alsa"
        name            "my ALSA device"
#       device          "hw:0,0" # optional
        format          "44100:16:2" #optional
}

Agrego normalización de volumen, para achatar un poco la diferencia de columenes de grabación:

 volume_normalization  yes

Mezclador:

mixer_type              "alsa"
mixer_device            "default"
mixer_control           "PCM"

Archivo de estado

state_file         "/home/matias01/.mpd/state"

Éste es sirve para recrear el estado de la sesión al volver a ejecutar el programa.

bind_to_address "localhost" ya que aún no me compro la notebook :-P.

Con esta sencilla configuración al apagar el sistema se ejecutará /etc/init.d/mpd stop y cerrará el programa ordenadamente "pausando" el tema en reproducción para continuar luego en el punto que estaba. Esto es muy útil con esos temas que son extracciones en bruto de los CDs que duran como 75 minutos. Si se inicia a mpd desde /etc/init.d/mpd start se inicia el programa según /etc/mpd.conf indique.

El lector atento notará que no he mostrado parámetros de configuración de uso de puertos no habituales para el cliente ni contraseña de acceso límite de conexiones, pero eso se deja a criterio de quien lee.

Referencias

Página man de ncmpc: man ncmpc

Página man de mpd: man mpd

Página man de mpd.conf: man mpd.conf

viernes, 16 de noviembre de 2007

Escuchando múscica con MPD

Introducción
Cuando me inicié con Mandrake Linux (Sí: tenemos algo obscuro en nuestro pasado), una de las primeras cosas que me propuse hacer de las habituales fue escuchar música y empecé con xmms.

El inconveniente de este reproductor era que es dependiente de la interfaz gráfica, si se cae la interfaz gráfica (no es que me suceda a menudo sino que ocasionalmente presiono Ctrl+Alt+Backspace :-P) se cae xmms, la lista de reproducción vuelve al principio etc. A veces es irrisorio levantar la interfaz gráfica para escuchar música.

Di varias vueltas hasta llegar a dos reproductores de audio: cplay que muy sencillo que usa python y es un frontend de otros programas. El que voy a tratar ahora es mpd que es un tanto más completo que cplay.

La idea:
Imaginemos que tenemos una computadora en un armario; llena de música, pero en un armario, sin teclado, sin monitor, pero con Debian y un juego de parlantes o amplificador conectado.

MPD trabaja como cualquier otro reproductor de audio pero de una manera un poco más ambiciosa: es un demonio, indexa la música y luego ella puede ser buscada para ser reproducida, claro que esa parte del manejo de la lista y la reproducción puede ser comandada remotamente.

Instalación y configuración
Alcanza con escribir como root: apt-get install mpd El archivo de configuración de mpd para andar como servicio es /etc/mpd.conf y si lo ejecuta el usuario será ~/.mpdconf o /etc/mpd.conf La sitaxis del archivo es sencilla: alcanza con leer los comentarios en inglés. Un parámetro importante es "bind_to_address" que Debian trae por defecto seteao a escuchar solo a localhost.

Es importante también elegir audio_output, mixer_type, mixer_device, y mixer_control para que salga por alsa que en mi caso se escucha mucho mejor.

Lo que hice en primer término para no tocar demasiado la configuración fue colocar enlaces sinbólicos que apuntan a los directorios que contienen música en /var/lib/mpd/music/. Una cosa interesante es que se pueden configurar varios dispositivos de salida, cuando tenga varias placas de sonido les cuento :-(

Clientes
Hay varios clientes para mpd, inclusive que corren bajo windows ( pueden buscar en el sitio web de mpd); en mi debian estaban disponibles:
  • mpc: bueno; interfaz de linea de comando.
  • gmpc: GNOME/GTK 2.2, bueno, el de interfaz grafica que más me gustó.
  • mpdcon.app: a controller for GNUstep (MPDCon). No me gustó en absoluto.
  • glurp: a GTK 2.4 graphical client. Bueno pero no le encunetro nada intersante; le encontre para activarle/desactivarle las salidas.
  • ncmpc: an ncurses-based console interface. Bueno, parecido al cplay, este es que terminé usando.
  • pympd: python, con plugins interesante solamente.
El que más me gustó fue ncmpc, es bastante parecido a cplay, teclas de comando son:
  • 2: lista de reproducción;
  • 3: Navegador de archivos;
  • [espacio]: agregar a la lista de reproducción;
  • P: pausa
  • Tema anterior/siguiente
  • Ctrl-U: actualizar la base de datos;
  • / buscar;
  • h ayuda.

En ncmpc se puede configurar las teclas de comando, los colores, la presentación de los temas y otras cosas, para sarber más man ncmpc.

Retirar el modo server
Si es que no tienen la máquina en el armario como me pasa a mí notarán que al iniciarse se ejecutará mpd y continuará con la lista en curso, esto es algo muy bueno para no tener que escoger música y no repetirla; pero no es útil tener corriendo al demonio si uno no desea escuchar. Para no iniciar mpd en el init alcanza con configurar /etc/default/mpd.

Si luego el usuario levanta mpd se ejecutará leyendo el archivo de configuración citado antes y tal vez quejándose de algo, para detener la ejecución del programa mpd --kill.

Bueno, en las que sigue les cuento como ejecutar como usuario y cómo cantarle a la red

Referencias

sábado, 3 de noviembre de 2007

Resucitando mi pendrive

[Este era un post de mi anterior Blog (http://mabett.wordpress.com) , lo transcribo ahora...] Introducción:

Hace más de un año que se me murió pendrive (o llavero USB, o memory key, o dispositivo USB provisto de una memoria Flash). Aparentemente lo conecté a alguna PC en un ciber con puerto frontal y los cables mal conectados al motherboard; lo que lo llevó a mejor vida por algún tiempo. Ni bien me percaté de la desgracia continué utilizando, otro que me regalaron (gracias caraé :-D).

Fui parcialmente feliz "con el sustituto" hasta que un ¿buen? día lo extravié en un ciber de la Calle Paso de los Andes cuya desatención al preguntar por mi pertenencia me obliga a recomendarles que si pueden no asistir...

Así me vi en la disyuntiva de volver a utilizar disquetes de 1.44" o intentar arreglar mis inmóviles 512MB. La duda duró unos 0.112 segundos:

El aparato es un Memorex TravelDrive 512 (Rev 1.0B P/N:32507751):

Síntomas:

  • Un día lo conecté en algún lugar del planeta y no anduvo;
  • En mi computadora de ese entonces andaba, pero en la de la mayoría de los cibers no;
  • El comportamiento en las otras computadoras era una intermitencia de la luz que indica la lectura/escritura en la memoria, bajo windows "Error código 10", que no es más que "no se reconoce dispositivo" y bajo GNU/Linux error en el router USB.

Diagnóstico:

  • Está roto :-D.

Lo que tenían en común todas las otras computadoras que no la mía de ese entonces era el puerto USB 2.0, así que había "algo" en el USB 2.0 que en mi pendrive no.

Con mi computadora actual que sí tiene USB 2.0 algo tenía que hacer para emular las condiciones de la anterior. Lo necesario fue "desmontar" los drivers USB 2.0: en mi Debian:

root@nowhere someplace/ # rmmod ehci_hcd
y probablemente también retiré algún otro módulo. Al conectarlo /var/log/kern dice:
usb 1-5.2: new full speed USB device using ohci_hcd and address 12
usb 1-5.2: not running at top speed; connect to a high speed hub
scsi11 : SCSI emulation for USB Mass Storage devices
usb-storage: device found at 12
usb-storage: waiting for device to settle before scanningJun 14 14:39localhost kernel:   Vendor:           Model: Memorex TD 2B     Rev: PMAP
Type:   Direct-Access                      ANSI SCSI revision: 00
SCSI device sdb: 1015808 512-byte hdwr sectors (520 MB)
sdb: Write Protect is off
sdb: Mode Sense: 03 00 00 00
sdb: assuming drive cache: write through

A pesar del quejido de la velocidad de escritura el dispositivo trabajó correctamente, para probar si funciona lo monté de la manera usual y nos coloqué en el punto de montaje hice:

MAbeeTT@nowhere someplace/ $: while ((1)); do dd if=/dev/zero of=archivo_nulo.dmp; rm -f archivo_nulo.dmp ; done
y cada dd arrojó:
dd: escribiendo en «archivo_nulo.dmp»: No queda espacio en el dispositivo
551889+0 records in
551888+0 records out
282566656 bytes (283 MB) copied, 3,02966 seconds, 93,3 MB/s
con los 496 MB en vez de 283, si es que el dispositivo está vacío.

Desmonté el sistema de archivos desconecté el dispositivo, cargué el driver ehci y los que retiré junto a él y /var/log/kern arrojó:

usb-storage: device found at 103
usb-storage: waiting for device to settle before scanning
kernel: usb 1-6: USB disconnect, address 103
usb 1-5: new full speed USB device using ohci_hcd and address 16
hub 1-5:1.0: USB hub found
hub 1-5:1.0: 4 ports detected
hub 1-5:1.0: hub_port_status failed (err = -110)
hub 1-5:1.0: cannot reset port 1 (err = -110)
last message repeated 3 times
hub 1-5:1.0: Cannot enable port 1.  Maybe the USB cable is bad?
hub 1-5:1.0: cannot disable port 1 (err = -110)

El cable NO estaba mal. Lo que vemos es que la computadora vé algo pero ese algo se desconecta y luego lo vuelve a ver, se desconecta y pregunta por el cable.

Este comportamiento es similar bajo windows pero no se leer los logs de ese sitema.

Noté que había uno de los 8 conectores USB de mi gabinete que me daba más tiempo en ese lazo infinito así que conecté el pendrive ahí y usé usbview (GTK1), copié la descripción de dispositivo a un archivo de texto e hice lo mismo en USB 1.1; la diferencia es:

MAbeeTT@nowhere someplace/ $: diff -u memorex1.1.txt memorex2.0.txt
--- memorex1.1.txt      2007-06-02 18:09:22.000000000 -0300
+++ memorex2.0.txt      2007-06-02 15:54:00.000000000 -0300
@@ -1,7 +1,7 @@
Memorex TD 2B
Manufacturer:
Serial Number: 074C0C020739
-Speed: 12Mb/s (full)
+Speed: 480Mb/s (high)
USB Version:  2.00
Device Class: 00(>ifc )
Device Subclass: 00
@@ -29,12 +29,12 @@
Direction: in
Attribute: 2
Type: Bulk
-                       Max Packet Size: 64
+                       Max Packet Size: 512
Interval: 0ms
Endpoint Address: 02 Direction: out Attribute: 2 Type: Bulk - Max Packet Size: 64 + Max Packet Size: 512 Interval: 0ms Como era de esperar no hay nada relevante.

Fue entonces cuando me decidí a destriparlo:

Como se puede apreciar en la foto el controlador USB-Flash es un Phison, así que buscando en mi buscador favorito y en la wikipedia dí con la página del fabricante del integrado. Como era de esperar también la hoja de datos no estaba disponible on-line; así que lo solicité en el feedback de la empresa; por fortuna me lo enviaron.

Con el datasheet ya supe que patas no tocar; así que empecé por medir con mi multímetro todas las patas de alimentacion respecto a masa con el aparato funcionando correcta e intermitentemente.

Las patas que trabajaban a la par de la intermitencia eran las 1, 33 y 35. Según la hoja de datos debe trabajar entre 3 y 3,6Volt. El dispositivo que se conecta es "AH33 316GB". Preguntando en la lug-electronica me supieron desburrar de qué regulador se trata.

Con la hoja de datos del regulador no me quedó más que buscar uno y esperar no destruir todo el resto de los dispositivos de montaje superficial.

Las fiambrerías de electrónica de Mendoza no tienen reguladores de 3,3Volt así que la solución aparente era armar un regulador con un LM317L y apretar todo lo más que se pueda. Otra hoja de datos.

Armado una vez el circuito del regulador hay que calibrarlo para que entregue entre 3 y 3,6Volt; yo cometí la torpeza de colocarle un preset de 5k en vez de una R de 3K y un preset de 2K (para oscilar entre 2 y 5v y NO entre 0 y 5V que resta precisión, cualquier ínfimo movimiento al preset cambia notablemente el voltaje de salida). En realidad después de unas semanas el preset me empezó a molestar así que tomé la iniciativa de colocar el su lugar una resisencia cercana al valor de ajuste del preset.

Probando el circuito en el pendrive, con y sin el regulador. Cama arriba, cama abajo como Homero Simpson y todo bien.

Me quedaba qué hacer para integrar el circuito al pendrive; naturalmente dentro de la carcaza no cabría así que se me ocurrió perforarla para pasar los cables y apoyarla parte plana con parte plana. Se me ocurrió cubrir todo con cinta aisladora (PVC negro), y por sugerencia de mi viejo protegí el circuito con plástico de envase descartable de gaseosa (PET), y calentandolo para moldearlo. Cinta aisladora y a ser feliz.

Para hacer pruebas de lectura escritura, conectar montar y:

MAbeeTT@nowhere someplace/ $: while ((1)); do dd if=/dev/zero of=archivo_nulo.dmp; dd if=archivo_nulo.dmp of=/dev/null ; rm -f archivo_nulo.dmp ; done

y lo dejé un rato largo.

Agradecimientos

  • Phison: por la hoja de datos.
  • Memorex: por no borrar Phison del integrado :-D .
  • Hector Armando Maza, por el aporte con la hoja de datos, a la Lugmen por la lista de correo lug-electronica y a los chicos que participaron con el thread.
  • mi viejo, por la idea del plástico.

Algunas fotos de como quedó:

Testing.. Post.

testing....