Wiki Ubuntu-it

Indice
Partecipa
FAQ
Wiki Blog
------------------
Ubuntu-it.org
Forum
Chiedi
Chat
Cerca
Planet
  • Pagina non alterabile
  • Informazioni
  • Allegati

Versione 13 del 07/06/2021 17.03.39

Nascondi questo messaggio

Messaggio: «error: sparse file not allowed»

Questo errore può verificarsi su file system Btrfs o ZFS quando nel file /etc/default/grub sono state specificate le seguenti opzioni:

GRUB_DEFAULT=saved
GRUB_SAVEDEFAULT=true

Queste opzioni specificano che Grub deve memorizzare la voce scelta dall'utente nel menù di avvio per poi riproporla al successivo avvio come valore di default. Grub scrive questo dato nel file grubenv, un file speciale della dimensione fissa di 1024 byte la cui posizione predefinita è nel percorso /boot/grub/. Tuttavia se il file grubenv si trova in una partizione con file system Btrfs o ZFS, Grub non può modificarlo e visualizza il messaggio error: sparse file not allowed.

Per risolvere questo errore è necessario spostare il file grubenv in una partizione che rispetti i seguenti requisiti:

  • Deve risiedere in un disco GPT o MBR, non RAID, LVM o altro.

  • Deve avere un file system come ext4, FAT32, NTFS o un altro file system che non implementi il checksum a livello di blocco.

A tal scopo nei sistemi UEFI può essere sfrutta la partizione EFI, che utilizza il file system FAT32. Se nel sistema non è presente una partizione che soddisfi questi requisiti, sarà necessario crearne una e montarla.

Procedere come segue:

  1. Spostare il file grubenv nella partizione designata digitando nel terminale il seguente comando::

    sudo mv /boot/grub/grubenv <puntodimontaggio>

    Sostituire <puntodimontaggio> con il punto di montaggio della partizione. Se si intende utilizzare la partizione EFI, il suo punto di montaggio predefinito è /boot/efi/.

  2. Aprire con i privilegi di amministrazione e con un editor di testo il file /etc/grub.d/00_header.

  3. All'inizio del file, subito dopo le note di copyright e di licenza, inserire una riga di questo tipo:

    GRUBENV="(hd0,gpt1)/grubenv"
    • hd0 si riferisce al primo disco fisso. Se la partizione si trova nel secondo disco scrivere hd1, per il terzo hd2, ecc...
      gpt1 si riferisce alla prima partizione del disco, se questo è partizionato in GPT. Se invece è partizionato in MBR, usare la forma msdos1. Per riferirsi alla seconda partizione scrivere gpt2 o msdos2, per la terza gpt3 o msdos3, ecc...

    L'indice usato da Grub per identificare le partizioni si basa sull'ordine in cui queste sono collocate sul disco, mentre l'indice usato dal sistema è in ordine cronologico, ovvero in basa a quale partizione è stata creata prima. Ciò significa che la partizione sda1 potrebbe non corrispondere a gpt1 o msdos1.

  4. Utilizzare la funzione Trova e sostituisci dell'editor di testo per sostituire l'espressione

    load_env

    con

    load_env --file "\${grubenv}"
  5. Utilizzare la funzione Trova e sostituisci dell'editor di testo per sostituire tutte le occorrenze dell'espressione

    `save_env`

    con

    save_env --file "\${grubenv}"
  6. Individuare la function initrdfail, che è preceduta dalla riga cat <<"EOF" e termina al successivo EOF.

  7. All'interno di questa funzione sostituire tutte le occorrenze dell'espressione

    "\${grubenv}"

    con

    "${grubenv}"

    Notare l'assenza del carattere \.

  8. Salvare il file e chiudere l'editor di testo.
  9. Aggiornare la configurazione di Grub digitando nel terminale il seguente comando:

    sudo update-grub