A localização da tabela de partições (GPT) muda ao passar de USB3 para SATA?

2

Acabei de abrir um gabinete externo de disco rígido USB 3.0 e o disco foi montado internamente em um PC via SATA. Agora, o sistema Linux pára de encontrar o GPT que certamente estava lá. Como já existem 2 TB de dados no disco, seria bom encontrar a tabela de partições que já está lá.

A localização da GPT pode mudar ao usar uma interface diferente (USB, SATA)? Como pode ser corrigido?

Aqui está a saída do gdisk montada no PC (SATA):

# gdisk /dev/disk/by-id/ata-TOSHIBA_DT01ABA300_123456890
GPT fdisk (gdisk) version 1.0.1

Partition table scan:
  MBR: protective
  BSD: not present
  APM: not present
  GPT: not present

Creating new GPT entries.

Command (? for help): q

O disco é um TOSHIBA DT01ABA300 (como você pode ver acima) e estava em um gabinete Toshiba Canvio USB3.

Aqui está a parte relevante de dmesg :

[    1.618441] scsi host9: ahci
[    1.618485] ata9: SATA max UDMA/133 abar m512@0xfd1ff000 port 0xfd1ff100 irq 42
[    2.106001] ata9: SATA link up 6.0 Gbps (SStatus 133 SControl 300)
[    2.107329] ata9.00: ATA-8: TOSHIBA DT01ACA300, MX6OABB0, max UDMA/133
[    2.107332] ata9.00: 5860533168 sectors, multi 0: LBA48 NCQ (depth 31/32), AA
[    2.108712] ata9.00: configured for UDMA/133
[    2.609553] scsi 9:0:0:0: Direct-Access     ATA      TOSHIBA DT01ABA3 ABB0 PQ: 0 ANSI: 5
[    2.609699] sd 9:0:0:0: [sdg] 5860533168 512-byte logical blocks: (3.00 TB/2.72 TiB)
[    2.609703] sd 9:0:0:0: [sdg] 4096-byte physical blocks
[    2.609785] sd 9:0:0:0: [sdg] Write Protect is off
[    2.609788] sd 9:0:0:0: [sdg] Mode Sense: 00 3a 00 00
[    2.609825] sd 9:0:0:0: [sdg] Write cache: enabled, read cache: enabled, doesn't support DPO or FUA
[    2.637653] sd 9:0:0:0: [sdg] Attached SCSI disk

Aqui é onde encontrei a assinatura EFI (GPT ?!) no disco bruto:

dd if=/dev/sdg bs=2M count=32 | hexdump -C | grep -w EFI
32+0 records in
32+0 records out
67108864 bytes (67 MB) copied, 0.447864 s, 150 MB/s
00001000  45 46 49 20 50 41 52 54  00 00 01 00 5c 00 00 00  |EFI PART....\...|

Não encontrei um parâmetro gdisk para ler o GPT de um determinado deslocamento. Como posso ler isso?

# parted /dev/sdg
GNU Parted 3.2
Using /dev/sdg
Welcome to GNU Parted! Type 'help' to view a list of commands.
(parted) unit b                                                           
(parted) print                                                            
Error: /dev/sdg: unrecognised disk label
Model: ATA TOSHIBA DT01ABA3 (scsi)                                        
Disk /dev/sdg: 3000592982016B
Sector size (logical/physical): 512B/4096B
Partition Table: unknown
Disk Flags: 
(parted) q

E:

# losetup --find --show /dev/sdg
/dev/loop0
# parted /dev/loop0
GNU Parted 3.2
Using /dev/loop0
Welcome to GNU Parted! Type 'help' to view a list of commands.
(parted) unit b                                                           
(parted) print                                                            
Error: /dev/loop0: unrecognised disk label
Model: Loopback device (loopback)                                         
Disk /dev/loop0: 3000592982016B
Sector size (logical/physical): 512B/512B
Partition Table: unknown
Disk Flags: 
(parted)
    
por Ned64 29.10.2015 / 14:51

1 resposta

2

Can the location of the GPT change when using a different interface (USB, SATA)?

Sim, porque o GPT é estúpido e depende do tamanho do setor, e alguns gabinetes USB reivindicam 512b setores quando são realmente 4096b setores ou vice-versa.

Sim, porque o Linux é estúpido e não suporta GPT para tamanhos de bloco diferentes, embora seja possível detectar isso automaticamente.

Você pode ter que recriar a tabela de partições para converter da GPT-512 para a GPT-4096 e esperar que as partições sejam alinhadas com MiB para permitir tais conversões em primeiro lugar.

    
por 29.10.2015 / 15:34