"Después del juego es antes del juego"
Sepp Herberger

lunes, 25 de abril de 2016

Printer Wars II: Resetear contador de consumibles OKI B45XX.

Bueno, pues ahora vamos a por una OKI B4525/B45XX. La encontramos en la basura sin tóner pero con un tambor al que todavía le quedaba bastante vida útil, así que compré un cartucho de tóner reciclado de 6000 copias.

Por lo visto había que resetear los datos de contabilidad de consumibles, así que me puse a buscar por todo el menú de su panel táctil sin éxito. Parece ser que OKI no quiere que nadie resetee fácilmente sus impresoras y no tiene la información muy visible.

Afortunadamente en este foro daban la pista, primero hay que entrar en "modo admin":

  • Tecla down (flecha abajo), tecla "*" y tecla "#".
  • El menú cambia y muestra un menú oculto : ahora es "SOS1", "SOS2", ... o algo similar, dependiendo del idioma.
  • Entramos en SOS1, aparece un número de 8 bits, por ejemplo "00100001".
  • Cambiamos el primer bit a "1", quedando algo así como "10100001". Volvemos al menú inicial.
  • Reiniciamos la impresora apagando y volviendo a encender.

Una vez reiniciada ya estamos en modo admin, lo cual nos da una serie de funcionalidades para resetear, borrar y hacer muchas más cosas con la impresora. Esas funcionalidades las encontré en la página 23 y sucesivas de este manual de servicio. Adjunto capturas de pantalla:


A mi me interesaba resetear los contadores de consumibles, en ese caso la opción es entrar en Menú (pulsando la tecla de bajar,por ejemplo)-> pulsar "#" -> pulsar "4". Bueno, pues nada, no se resetea nada. Y no es que esté mal el manual, el resto de opciones si funciona, simplemente sucede que OKI no deja que se reseteen esos datos ni siquiera con el "modo admin", aunque el manual de servicio sugiera que es posible.

¿Y como se resetean entonces?. Pues comprando aparte una "tarjeta de reseteo" que se supone solo fabrica OKI y distribuye con sus tóner "originales", aunque se pueden encontrar tarjetas clónicas en AliExpress:


Y en esas estoy, compuesto y sin tóner. ¿Compro la tarjeta al lejano oriente?. Ya veremos.

Adelantando un post que tengo en la recámara, lanzo la siguiente pregunta: Señor OKI, ¿usted qué fabrica? ¿impresoras? ¿cartuchos de tóner? ¿tarjetas chip?. Sepan que han perdido un cliente por su forma estrambótica de controlar el mercado de consumibles. Yo pensaba que eran una empresa seria y resulta que no.

sábado, 23 de abril de 2016

Recopilar mediante puppet de forma masiva las claves de licencia de Windows 7/8/10.

Si en nuestra base de equipos instalados tenemos un buen número de instalaciones duales de Ubuntu+Windows no viene mal poder recopilar las claves de licencia de todos ellos. Es importante tener un inventario de licencias actualizado, así que vamos a ver como hacerlo de forma automática usando un facter de puppet.

La clave de licencia se almacena en una tabla de la BIOS del equipo y se puede mostrar con el comando:
~# hexdump -s 56 -e '"MSDM key: " /29 "%s\n"' /sys/firmware/acpi/tables/MSDM
Con un facter de puppet tendremos el sistema ideal para recoger el dato de forma automatizada:
~# cat /usr/lib/ruby/vendor_ruby/facter/windows_key.rb

# Archivo /usr/lib/ruby/vendor_ruby/facter/windows_key.rb
# Se utiliza para obtener, si es posible, la licencia del windows de la máquina donde se ejecuta.
# 

if File.exist?('/sys/firmware/acpi/tables/MSDM') and key = Facter::Util::Resolution.exec(%Q(hexdump -s 56 -e '/29 "%s"' /sys/firmware/acpi/tables/MSDM))
   Facter.add("WINDOWSKEY") do
            setcode { key }
   end
end

####
Para distribuirlo a todos los clientes usamos esta regla puppet desde una clase que llamaremos "nombre_clase":
.....
#Facter puppet para sacar la clave de Windows OEM de siatics/infolabs y (por probar) portatiles HP

file {"/usr/lib/ruby/vendor_ruby/facter/windows_key.rb":
                                owner => root, group => root, mode => 644,
                                source => "puppet:///modules/nombre_clase/windows_key.rb",
}
.....
Una vez distribuida a todos los clientes, obtendremos en cada cliente la clave con:
 ~# facter windowskey
7WNG2-PXY6F-XXXXX-YYYYY-ZZZZZ
Y, lo mas importante, todos los facter se guardan en el servidor puppet, en los ficheros de facts con formato yaml. De esta forma tendremos centralizado en un sitio todas las claves de licencia recopiladas:
~# grep -ir windowskey /var/lib/puppet/yaml/facts/* 
pc-o23.vguadalupe.yaml:    windowskey: "7WNG2-PXY6F-XXXXX-YYYYY-ZZZZZ"
..........................
Como guinda al pastel solo falta desvelar como recopilar las licencias de nuestros Linux:



lunes, 18 de abril de 2016

Printer Wars I: Re-Animator

Empiezo una serie de posts sobre aventuras y desventuras con impresoras variadas. La primera es mi Epson DX3800, una impresora de inyección que tiene varias características avanzadísimas:

  • Gasta tinta de color incluso cuando imprimes solo en blanco y negro.
  • Si se gasta un cartucho de tinta de color hay que reponerlo sí o sí, aunque solo quieras imprimir en "grayscale".
  • Tiene en la parte baja de sus entrañas una esponja increíble que absorbe todos los mililitros de tinta que no es capaz de hacer llegar al papel. Hay un dineral en tinta perdido para siempre allí abajo.

Tras una época sin usar, me encontré con que ya no imprimía. Puse cartuchos nuevos y tampoco: se habían "secado los inyectores", taponándose con tinta seca. El problema es que todavía tenía varios cartuchos sin abrir y no me parecía razonable tirarlos, así que empecé a buscar una solución. Y encontré ésta:



Parece broma, pero si bombeas dentro del cabezal y extraes lo que te arrastre la succión (coloreado con la tinta correspondiente) varias veces, dejando a continuación secar todo un par de días al poner el cartucho la impresora imprime de nuevo.

Como en la película Re-Animator necesitamos un líquido para hacer revivir los inyectores; en mi caso el líquido que ha funcionado ha sido el Cristasol de toda la vida (nada de marcas blancas), rebajado con un poco de agua:


Las otras herramientas usadas han sido un par de jeringas grandotas: una con un tubo de goma que me ha dejado el profesor de Tecnología y otra una jeringa de repostería comprada en una tienda de chinos (la impresionante aguja no sirve de nada en esta tarea, la uso para meter miedo a los niños). Lo mas sencillo para no dejarlo todo empantanado es que el tubo se acople lo mejor posible al "pitoche" del inyector y así poder bombear metiendo y sacando líquido varias veces con ayuda del vacío.


Detalle de los inyectores:


No se ve bien, pero los "pitoches" de los inyectores tienen unos agujeritos en su superficio que es por dónde entra la tinta del cartucho hacia abajo. Seguramente esos agujeritos son los que se taponan con la tinta seca y al meter el cristasol a presión se disuelve todo.

Después del tratamiento, dejé secar la impresora un par de días y puse los cartuchos. Y ¡voilá! imprimiendo de nuevo a la perfección. Toma ya, Epson.

Epílogo I: aun así no todo ha sido feliz. Los rodillos no siempre cogían el papel (era un problema que ya tenía de antes) así que desmonté toda la impresora siguiendo el "Service Manual" para echar un vistazo y limpiar un poco. Al final del todo, en la parte mas profunda encontré entre los rodillos un trozo de mina de lápiz naranja (#!@@!"&) ... la quité, limpié los rodillos con alcohol y los sometí un par de pasadas con lija de grano grueso:



Monté todo de nuevo sin que me sobrara un tornillo y ¡ajá!, ya coge todo el papel sin problema.

Epílogo II: Epson me odia por alargar la vida de sus trastos. Al apagar la impresora y volverla a encender ha empezado a dar error de fallo general (todos los led se ponen a parpadear compulsivamente). Una de cada diez veces se enciende bien, la cual aprovecharé para imprimir hasta agotar los cartuchos y luego procederé a desmontarla para piezas.

Me encantaría desmontar la parte de escáner y seguir usándo eso sin el resto de impresora, pero me huelo que va a ser imposible. Malditos capitalistas, con esta impresora tan poco aprovechable Mark Watney hubiera muerto en Marte.

jueves, 14 de abril de 2016

Configurando la VGA en los HP ProDesk 600 G2 SFF (Parte I)

Los equipos que hemos recibido para los laboratorios de informática son HP ProDesk 600 G2 SFF. Aunque en la licitación se supone que los equipos deberían ser compatibles 100% con Ubuntu y venir preparados para ello, lo cierto es que hemos tenido que resolver varias "features" por nuestra parte para hacerlos funcionales, estables y sin cuelgues.

Estos equipos traen 2 tarjetas VGA:
00:02.0 8086:1912 VGA compatible controller: Intel Corporation Sky Lake Integrated Graphics (rev 06) 
01:00.0 10de:1287 VGA compatible controller: NVIDIA Corporation GK208 [GeForce GT 730] (rev a1)  
La tarjeta Intel está en la placa y la nVidia está pinchada en un bus.

En el aspecto gráfico hemos tenido 2 problemas:

  • Si encendemos el PC conectado por una salida DisplayPort al monitor (un HP ProDisplay P232) con éste apagado, al encender el monitor a posteriori resulta que permanece "fundido en negro" y no hay manera de ver nada, aunque el PC sea accesible por ssh.
  • El uso o la simple presencia del driver xorg y/o el módulo del kernel "nouveau" provoca cuelgues aleatorios, en los que la pantalla se apaga y el equipo no es accesible por ssh.

Vamos a ver como resolver estos problemillas.

1) Solución al monitor que no muestra imagen al encenderse a posteriori.

Como este problema no aparecía con cables VGA estaba a punto de tirar la toalla y conectar todos los PC con cable VGA, pero afortunadamente mi compañero Francis Paniagua dió con la solución:

"He estado buscando información y he leído que desactivando DDC/CI Support en el propio monitor funcionaba ... pero nada, me he puesto a hacer mas pruebas y entrando en la configuración del monitor en "Input Control": desactivando "Auto Switch Input" (poner a valor Off) y poniendo "DP Hot-Plug Detection" a Always Active, sí funciona."

Pues nada, nos toca ir monitor a monitor haciendo esto, lástima de no tener un alumno castigado y aburrido para ayudarnos.

2) Solución 1 a los problemas provocados por el driver/módulo nouveau.

Esta consiste en instalar el driver propietario de nvidia, que anula el nouveau y usar la tarjeta nvidia para conectar la pantalla. Para ello me guié en este enlace.

En esta solución, usada para el PC del profesor, quiero además que el monitor esté conectado a la salida DisplayPort y tener un cañon de video con la imagen del principal clonada en la salida DVI/VGA. Veamos los pasos:

1) Asegurarnos de que no se carga el módulo nouveau del kernel, metemos este fichero y reiniciamos:
# cat /etc/modprobe.d/nvidia-installer-disable-nouveau.conf 
# generated by nvidia-installer
blacklist nouveau
options nouveau modeset=0
2) Paramos el lightdm desde consola.
# service lightdm stop
3) Entramos en consola y ejecutamos el fichero:
# ./NVIDIA-Linux-x86_64-361.28.run
que hemos descargado de la página de drivers de nvidia y hecho ejecutable con "chmod +x". Si se queja por algo le decimos que si una y otra vez, lo importante es que continúe. Después de quejarse por todo llegamos al final y resulta que lo ha instalado. nVidia debería contratar a otra gente para hacer los instaladores: los que tiene ahora parecen una gincana.

4) Ajuste de resolución para cañón y pantalla:

Hemos dicho que queremos tener clonados monitor (salida DIRECTPORT) y cañon de vídeo (salida DVI). Si no es tu caso, olvida este apartado o adáptalo a tus circunstancias. Por experiencia puedo decir que lo mas sencillo es crear un script de inicio que use xrandr.
# cat /usr/bin/resolucion_infolab_nvidia 

#!/bin/bash

test -e  $HOME/.config/xfce4/xfconf/xfce-perchannel-xml/displays.xml  &&  rm  $HOME/.config/xfce4/xfconf/xfce-perchannel-xml/displays.xml

DVI=$(xrandr | grep " connected" | grep DVI | cut -d" " -f1)
DIRECTPORT=$(xrandr | grep " connected" | grep DP | cut -d" " -f1)

xrandr --output $DIRECTPORT --mode 1440x900 --pos 0x0 --rotate normal \
       --output $DVI --mode 1024x768 --pos 0x0 --rotate normal \
       --same-as $DIRECTPORT --scale-from 1440x900

exit 0
Que ejecutamos con:
# cat /etc/xdg/autostart/Resolucion.desktop 

#!/usr/bin/env xdg-open

[Desktop Entry]
Version=1.0
Type=Application
Terminal=false
Icon[zh_CN]=
Exec=/usr/bin/resolucion_infolab_nvidia
Name[zh_CN]=Resolución
Name=Resolución
Icon=/usr/share/icons/gmusicbrowser.png 
En plan maniático además añadimos un xorg.conf hecho a medida para la nvidia con la herramienta nvidia-settings que instala el driver propietario::
# cat /etc/X11/xorg.conf 

# nvidia-settings: X configuration file generated by nvidia-settings
# nvidia-settings:  version 361.28  (buildmeister@swio-display-x64-rhel04-04)  Wed Feb  3 16:26:48 PST 2016

Section "ServerLayout"
    Identifier     "Layout0"
    Screen      0  "Screen0" 0 0
    InputDevice    "Keyboard0" "CoreKeyboard"
    InputDevice    "Mouse0" "CorePointer"
    Option         "Xinerama" "0"
EndSection

Section "Files"
EndSection

Section "InputDevice"
    # generated from default
    Identifier     "Mouse0"
    Driver         "mouse"
    Option         "Protocol" "auto"
    Option         "Device" "/dev/psaux"
    Option         "Emulate3Buttons" "no"
    Option         "ZAxisMapping" "4 5"
EndSection

Section "InputDevice"
    # generated from default
    Identifier     "Keyboard0"
    Driver         "kbd"
EndSection

Section "Monitor"
    # HorizSync source: edid, VertRefresh source: edid
    Identifier     "Monitor0"
    VendorName     "Unknown"
    ModelName      "HP P232"
    HorizSync       24.0 - 80.0
    VertRefresh     50.0 - 60.0
    Option         "DPMS"
EndSection

Section "Device"
    Identifier     "Device0"
    Driver         "nvidia"
    VendorName     "NVIDIA Corporation"
    BoardName      "GeForce GT 730" 
    Option         "TwinViewOrientation" "Clone"
    Option         "TwinView"

EndSection

Section "Screen"
    Identifier     "Screen0"
    Device         "Device0"
    Monitor        "Monitor0"
    DefaultDepth    24
    Option         "Stereo" "0"
    Option         "nvidiaXineramaInfoOrder" "DFP-2"
    Option         "metamodes" "DP-1: 1440x900 +0+0, DVI-I-0: 1024x768 +0+0"
    Option         "SLI" "Off"
    Option         "MultiGPU" "Off"
    Option         "BaseMosaic" "off"
    SubSection     "Display"
        Depth       24
    EndSubSection
EndSection
Y ya como buen dobleplusparanoico he desactivado la tarjeta VGA intel (la que viene en la placa) en la BIOS del PC, de tal forma que al hacer "lspci | grep -i vga" sale solo la nVidia.

Con esto tenemos un sistema muy estable que no nos dará problemas.

3) Solución 2 a los problemas provocados por el driver/módulo nouveau.

Esta es la solución opuesta: ignorar la tarjeta nvidia y usar la Intel embebida en la placa base. Es la solución empleada para los PC de los alumnos, a los que conecto el monitor por el puerto Display Port 1 de esta tarjeta (que sorpresivamente tiene 3 salidas: 2 DisplayPort y 1 VGA).

Como son muchos PC lo he automatizado con estos recursos puppet:
# cat /etc/puppet/modules/infolab_ajustes/manifests/init.pp 

import "/etc/puppet/defines/*.pp"

class infolab_ajustes {

        ......
        ......

        #Los alumnos van con la tarjeta VGA intel, desactivamos nvidia y nouveau para evitar cuelgues innecesarios
        file {"/etc/modprobe.d/disable-nouveau.conf":
               owner => root , group => root , mode => 644 ,
               source => "puppet:///modules/infolab_ajustes/disable-nouveau.conf",
        }
        #Añade a rc.local (si no está ya) el código que desactiva en el arranque la tarjeta VGA nvidia
        add_line_above { desactiva_nvdia_vga_infolab:
              file=> "/etc/rc.local",
              line=> 'bus=$(lspci | grep "VGA compatible controller: NVIDIA" | cut -d" " -f1) ; test -n $bus && echo 1 > "/sys/bus/pci/devices/0000:$bus/remove"',
              search=> "VGA compatible controller: NVIDIA",
              above=> "^exit 0$"
        }
        #Desactivamos el DPMS en las X.
        file {"/usr/share/X11/xorg.conf.d/10-monitor.conf":
               owner => root , group => root , mode => 644 ,
               source => "puppet:///modules/infolab_ajustes/10-monitor.conf",

        ......
        ......

}
El fichero que quita el módulo nouveau:
# cat /etc/puppet/modules/infolab_ajustes/files/disable-nouveau.conf 
# generated by nvidia-installer
blacklist nouveau
options nouveau modeset=0
El que desactiva DPMS en la salida DP1 (adáptalo a tu caso):
# cat /etc/puppet/modules/infolab_ajustes/files/10-monitor.conf 
Section "Monitor"
 #Los monitores están en la salida DP1. Eso se averigua con xrandr si quieres adaptarlo a otro caso.
 Identifier "DP1"  
 Option "DPMS" "false"
EndSection

Section "ServerLayout"
 Identifier "ServerLayout0"
 Option "StandbyTime" "0"
 Option "SuspendTime" "0"
 Option "OffTime"  "0"
 Option "BlankTime"   "0"
EndSection

Y el rc.local que vaporiza la tarjeta VGA nvidia de los PC de los alumnos debe quedar:
# cat /etc/rc.local
#!/bin/sh -e
#
# rc.local
#
............
bus=$(lspci | grep "VGA compatible controller: NVIDIA" | cut -d" " -f1) ; test -n $bus && echo 1 >  "/sys/bus/pci/devices/0000:$bus/remove"
............

exit 0

Y con esto tenemos estables los PC de los alumnos. Vaya trabajito nos ha costado llegar aquí...

martes, 5 de abril de 2016

Configurando el sonido los HP ProDesk 600 G2/G1 SFF con Ubuntu

Bueno, nos han llegado 2 modelos de HP ProDesk 600: el G1 SFF y el G2 SFF. Ambos tienen tarjetas de sonido analógicas en placa y en la tarjeta gráfica HDMI. Vamos a ver como:

1) Vaporizar las tarjetas de sonido HDMI.

El HP ProDesk 600 G2 SFF (el que usamos en los laboratorios de informática) tiene:
 # lspci de las tarjetas de sonido:
00:1f.3 Audio device: Intel Corporation Sunrise Point-H HD Audio (rev 31)
01:00.0 VGA compatible controller: NVIDIA Corporation GK208 [GeForce GT 730] (rev a1)
01:00.1 Audio device: NVIDIA Corporation GK208 HDMI/DP Audio Controller (rev a1)

# cat /proc/asound/cards
 0 [PCH            ]: HDA-Intel - HDA Intel PCH
                      HDA Intel PCH at 0xbc440000 irq 131
 1 [NVidia         ]: HDA-Intel - HDA NVidia
                      HDA NVidia at 0xbc000000 irq 17

El HP ProDesk 600 G1 SFF (el que usamos con las pizarras digitales) tiene:
 # lspci de las tarjetas de sonido:
00:03.0 Audio device: Intel Corporation Xeon E3-1200 v3/4th Gen Core Processor HD Audio Controller (rev 06)
00:1b.0 Audio device: Intel Corporation 8 Series/C220 Series Chipset High Definition Audio Controller (rev 04)
01:00.0 VGA compatible controller: NVIDIA Corporation GT218 [GeForce 210] (rev a2)
01:00.1 Audio device: VIDIA Corporation High Definition Audio Controller (rev a1)

# cat /proc/asound/cards 
 0 [HDMI           ]: HDA-Intel - HDA Intel HDMI
                      HDA Intel HDMI at 0xf7b34000 irq 36
 1 [PCH            ]: HDA-Intel - HDA Intel PCH
                      HDA Intel PCH at 0xf7b30000 irq 34
 2 [NVidia         ]: HDA-Intel - HDA NVidia

Está muy bien eso de tener varias tarjetas de sonido en PC... si eres de los que te gustan tener varias tarjetas de sonido en el PC. Yo, que solo tengo dos oídos, me conformo con una y por una vez y sin que sirva de precedente estoy de acuerdo con la mayoría: mejor una tarjeta de sonido y que el audio salga por el conector jack, lo simple es bello. Nada mas horrible que abrir el control de sonido y encontrarse con varias tarjetas y controles de volumen si lo único que quieres es escuchar a Metallica un rato.

Ya hicimos esto antes y lo contamos aqui. Veamos ahora como hacerlo para estos dos modelos de PC, usando una tarea puppet que añade el código en cuestión al arranque en rc.local:

En el HP ProDesk 600 G2 SFF:
#============================================================================================================================
#Añade a rc.local (si no está ya) el código que desactiva en el arranque la tarjeta de audio HDMI de la tarjeta gráfica

add_line_above { desactiva_audio_hdmi_siatic:
              file=> "/etc/rc.local",
              line=> 'bus=$(lspci | grep "Audio device: NVIDIA Corporation" | cut -d" " -f1) ; test -n $bus && echo 1 > "/sys/bus/pci/devices/0000:$bus/remove"',
              search=> "NVIDIA Corporation",
              above=> "^exit 0$"
}
Para HP ProDesk 600 G1 SFF:
#============================================================================================================================
#Añade a rc.local (si no está ya) el código que desactiva en el arranque la tarjeta de audio HDMI de la tarjeta gráfica
add_line_above { desactiva_audio_hdmi_infolab:
              file=> "/etc/rc.local",
              line=> 'bus=$(lspci | grep "Audio device: NVIDIA Corporation GK208" | cut -d" " -f1) ; test -n $bus && echo 1 > "/sys/bus/pci/devices/0000:$bus/remove"',
              search=> "GK208",
              above=> "^exit 0$"
}
Con esto el audio HDMI desaparece el PC y no se carga el driver ni el control PulseAudio, quedando solamente la tarjeta de sonido analógico, mas o menos así:
# cat /proc/asound/cards
 0 [PCH            ]: HDA-Intel - HDA Intel PCH
                      HDA Intel PCH at 0xbc440000 irq 131

2) Fijar la tarjeta de sonido analógica

Otra cuestión que me pasaba con los HP ProDesk 600 G2 SFF es el driver la tarjeta de sonido analógica fallaba aleatoriamente durante el arranque, impidiendo manejarla desde el control de sonido. Es decir, salía esto:
# cat /proc/asound/cards
 1 [NVidia         ]: HDA-Intel - HDA NVidia
                      HDA NVidia at 0xbc000000 irq 17
Como se puede ver, la "0 [PCH ]: HDA-Intel - HDA Intel PCH" no estaba. Como consecuencia no salía sonido por el jack y nuestros altavoces analógicos permanecían enmudecidos.

Tras investigar un poco vi que cuando el driver fallaba esta línea aparecía en el syslog:
# dmesg | grep i915
[   10.966853] snd_hda_intel 0000:00:1f.3:
failed to add i915_bpo component master (-19)
Buscando encontré este enlace en el cual vienen a decir que la solución es actualizar al driver ALSA mas moderno que puedas encontrar. Eso se cuenta en esta página. Son dos pasos:

Uno: Instalar dkms con "apt-get install dkms" para permitir recompilar drivers al actualizar el kernel.
Dos: Bajar e instalar la última versión del driver alsa para mi sistema operativo concreto, que a fecha de hoy está en este enlace. Los comandos son:
# wget https://launchpad.net/~ubuntu-audio-dev/+archive/ubuntu/alsa-daily/+files/oem-audio-hda-daily-lts-vivid-dkms_0.201603231016~ubuntu14.04.1_all.deb
# dpkg -i oem-audio-hda-daily-lts-vivid-dkms_0.201603231016~ubuntu14.04.1_all.deb
# apt-get -f install
# ...
# dpkg -l | grep oem-audio-hda
ii  oem-audio-hda-daily-lts-vivid-dkms 0.201603231016~ubuntu14.04.1    

Tras esto reiniciamos y el driver de la tarjeta analógica siempre estará cargado.

Y con esto acabamos por hoy, de todas maneras seguiremos hablando de estos equipos y los problemas que dan con Ubuntu pese a que el contrato exigía que se entregasen totalmente compatibles. La empresa ganadora se piensa que si instalas y arrancas sin problemas ya va todo bien.... en fin, como siempre me recuerda Noo-Noo, mi Roomba:



Ampliación 21/09/2016: me comenta mi compañero Ismael que el enlace al driver ya no va, que hay que buscar en Internet "oem-audio-hda-daily-dkms" y luego descargar el paquete mas adecuado para nuestra versión. Otro compañero, Francis, da la solución definitiva: instalar mediante un PPA el paquete, asi siempre estará actualizado.
# add-apt-repository ppa:ubuntu-audio-dev/alsa-daily
# apt-get update
# apt-get install oem-audio-hda-daily-lts-vivid-dkms
¡Gracias, compañeros!.

lunes, 4 de abril de 2016

Remontar sistema de ficheros root como de lectura-escritura tras arrancar en modo rescate

El título lo dice todo: arranco un Ubuntu en modo rescate y accedo a la shell como root. Quiero modificar un fichero pero me dice que el sistema de ficheros / está montado en modo de solo lectura. No puedo desmontarlo ya que estoy dentro de él, ¿qué hacer?, pues remontarlo "al vuelo" con el siguiente comando:

# mount -o remount,rw /

Me imagino al sistema operativo dando un saltito y mientras que está en el aire el sistema de archivos pasa de "ro" a "rw" antes de que vuelva a pisar el suelo.

Por cierto, no estoy muerto ni estoy de parranda. Si no escribo últimamente es porque estoy mas atareado que un gato en una matanza. A ver si esta semana puedo escribir alguna cosilla interesante, porque últimamente me dedico más a apretar tornillos que a otra cosa.