Duas soluções aqui: uma é rápida de aplicar, embora resolva o problema apenas parcialmente, a outra é a completa, mas requer que você compile seu próprio kernel.
A resposta correta é um patch do kernel.
Robin H. Johnson escreveu um patch para o driver do kernel SATA ( encontra-o no site de troca de pilha Unix / Linux ) que esconde completamente o drive.
Update O patch agora é upstream (pelo menos no 3.12.7 kernel estável), veja o repositório git . Eu pedi por backport na barra de lançamento do Ubuntu .
Quando o patch estiver instalado, adicione
libata.force=2.00:disable
para os parâmetros de inicialização do kernel irá esconder o disco do kernel do Linux. Verifique novamente se o número está correto; pesquisar pelo nome do dispositivo pode ajudar:
(0)samsung-romano:~% dmesg | grep iSSD
[ 1.493279] ata2.00: ATA-8: SanDisk iSSD P4 8GB, SSD 9.14, max UDMA/133
[ 1.494236] scsi 1:0:0:0: Direct-Access ATA SanDisk iSSD P4 SSD PQ: 0 ANSI: 5
Solução alternativa
Respondida pelo usuário Emmanuel do Unix StackExchange em link
Você pode pelo menos resolver o problema de suspensão emitindo o comando
echo 1 > /sys/block/sdb/device/delete
antes de suspender.
Para automatizá-lo, adicionei o seguinte arquivo: (observe os sinalizadores, ele deve ser executável)
-rwxr-xr-x 1 root root 204 Dec 6 16:03 99_delete_sdb
no diretório /etc/pm/sleep.d/
#!/bin/sh
# Tell grub that resume was successful
case "$1" in
suspend|hibernate)
if [ -d /sys/block/sdb ]; then
echo Deleting device sdb
echo 1 > /sys/block/sdb/device/delete
fi
;;
esac
... e agora o sistema suspende (e continua) corretamente. Eu adicionei o trecho
if [ -d /sys/block/sdb ]; then
echo Deleting device sdb
echo 1 > /sys/block/sdb/device/delete
fi
para /etc/rc.local
também, para uma boa medida.