#!/bin/sh # Ensure that printing a GPT partition table does not modify the pMBR. # Much like t0205, but with the addition of a corrupt PTE in primary table, # "parted $device print" would modify $device. # Copyright (C) 2010-2014, 2019-2022 Free Software Foundation, Inc. # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 3 of the License, or # (at your option) any later version. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # You should have received a copy of the GNU General Public License # along with this program. If not, see . . "${srcdir=.}/init.sh"; path_prepend_ ../parted ss=$sector_size_ n_sectors=400 dev=dev-file dd if=/dev/null of=$dev bs=$ss seek=$n_sectors || fail=1 parted -s $dev mklabel gpt || fail=1 parted -s $dev mkpart p1 128s 255s || fail=1 parted -m -s $dev u s p || fail=1 # Write non-NUL bytes all over the MBR, so we're likely to see any change. # However, be careful to leave the type of the first partition, 0xEE, # as well as the final two magic bytes. printf '%0450d\xee%059d\x55\xaa' 0 0 | dd of=$dev count=1 conv=notrunc || fail=1 dd if=$dev of=before count=1 || fail=1 orig_byte=$(gpt_corrupt_primary_table_ $dev $ss) || fail=1 parted -m -s $dev u s p || fail=1 dd if=$dev of=after count=1 || fail=1 cmp before after || fail=1 Exit $fail