gpt

package
v0.0.0-...-7eb602e Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jan 6, 2018 License: BSD-3-Clause Imports: 8 Imported by: 0

Documentation

Overview

gpt implements reading and writing of GUID Partition tables. GPTs are dumped in JSON format and written in same. One complication is that we frequently only want to write a very small subset of a GPT. For example, we might only want to change the GUID. As it happens it is simpler (and more useful) just to read and write the whole thing. In for a penny, in for a pound.

Index

Constants

View Source
const (
	BlockSize         = 512
	HeaderOff         = 0x200
	HeaderSize        = 0x5c               // They claim it can vary. Give me a break.
	Signature  uint64 = 0x5452415020494645 // ("EFI PART", 45h 46h 49h 20h 50h 41h 52h 54h on little-endian machines)
	Revision          = 0x10000
	MaxNPart          = 0x80
)

Variables

This section is empty.

Functions

func EqualHeader

func EqualHeader(p, b Header) error

EqualHeader compares two headers and returns true if they match. Those fields which by definition must differ are ignored.

func EqualPart

func EqualPart(p, b Part) (err error)

func EqualParts

func EqualParts(p, b *GPT) (err error)

EqualParts compares the Parts arrays from two GPTs and returns an error if they differ. If they length differs we just give up, since there's no way to know which should have matched. Otherwise, we do a 1:1 comparison.

func New

func New(r io.ReaderAt) (*GPT, *GPT, error)

New reads in the primary and backup GPT from a disk and returns a pointer to them. There are some checks it can apply. It can return with a one or more headers AND an error. Sorry. Experience with some real USB sticks is showing that we need to return data even if there are some things wrong.

func Write

func Write(w io.WriterAt, g *GPT) error

Write writes the GPT to w, both primary and backup. It generates the CRCs before writing. It takes an io.Writer and assumes that you are correctly positioned in the output stream. This means we must adjust partition numbers by subtracting one from them.

Types

type GPT

type GPT struct {
	Header
	Parts []Part
}

func Table

func Table(r io.ReaderAt, off int64) (*GPT, error)

Table reads a GPT table at the given offset. It checks that the Signature, Revision, HeaderSize, and MaxPart are reasonable. It also verifies the header and partition table CRC32 values.

func (*GPT) String

func (g *GPT) String() string
type Header struct {
	Signature  uint64
	Revision   uint32    // (for GPT version 1.0 (through at least UEFI version 2.7 (May 2017)), the value is 00h 00h 01h 00h)
	HeaderSize uint32    // size in little endian (in bytes, usually 5Ch 00h 00h 00h or 92 bytes)
	CRC        uint32    // CRC32/zlib of header (offset +0 up to header size) in little endian, with this field zeroed during calculation
	Reserved   uint32    // ; must be zero
	CurrentLBA uint64    // (location of this header copy)
	BackupLBA  uint64    // (location of the other header copy)
	FirstLBA   uint64    // usable LBA for partitions (primary partition table last LBA + 1)
	LastLBA    uint64    // usable LBA (secondary partition table first LBA - 1)
	DiskGUID   uuid.UUID // (also referred as UUID on UNIXes)
	PartStart  uint64    // LBA of array of partition entries (always 2 in primary copy)
	NPart      uint32    // Number of partition entries in array
	PartSize   uint32    // Size of a single partition entry (usually 80h or 128)
	PartCRC    uint32    // CRC32/zlib of partition array in little endian
}

type Part

type Part struct {
	PartGUID   uuid.UUID // Partition type GUID
	UniqueGUID uuid.UUID // Unique partition GUID
	FirstLBA   uint64    // LBA (little endian)
	LastLBA    uint64    // LBA (inclusive, usually odd)
	Attribute  PartAttr  // flags (e.g. bit 60 denotes read-only)
	Name       PartName  // Partition name (36 UTF-16LE code units)
}

type PartAttr

type PartAttr uint64

type PartName

type PartName [72]byte

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL