|
Packit |
da863b |
/* vim: set tabstop=8 shiftwidth=4 softtabstop=4 expandtab smarttab colorcolumn=80: */
|
|
Packit |
da863b |
/*
|
|
Packit |
da863b |
* Copyright (c) 2016 Red Hat, Inc.
|
|
Packit |
da863b |
* Author: Nathaniel McCallum <npmccallum@redhat.com>
|
|
Packit |
da863b |
*
|
|
Packit |
da863b |
* This program is free software: you can redistribute it and/or modify it
|
|
Packit |
da863b |
* under the terms of the GNU Lesser General Public License as published by
|
|
Packit |
da863b |
* the Free Software Foundation, either version 2.1 of the License, or
|
|
Packit |
da863b |
* (at your option) any later version.
|
|
Packit |
da863b |
*
|
|
Packit |
da863b |
* This program is distributed in the hope that it will be useful,
|
|
Packit |
da863b |
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
Packit |
da863b |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
Packit |
da863b |
* GNU Lesser General Public License for more details.
|
|
Packit |
da863b |
*
|
|
Packit |
da863b |
* You should have received a copy of the GNU Lesser General Public License
|
|
Packit |
da863b |
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
Packit |
da863b |
*/
|
|
Packit |
da863b |
|
|
Packit |
da863b |
#include "test.h"
|
|
Packit |
da863b |
#include <error.h>
|
|
Packit |
da863b |
#include <stdlib.h>
|
|
Packit |
da863b |
#include <string.h>
|
|
Packit |
da863b |
|
|
Packit |
da863b |
static const luksmeta_uuid_t UUID0 = {
|
|
Packit |
da863b |
0x35, 0x08, 0x50, 0xc3, 0x25, 0xc9, 0x85, 0xea,
|
|
Packit |
da863b |
0x1b, 0x55, 0x93, 0x56, 0x36, 0x2a, 0xd9, 0x85
|
|
Packit |
da863b |
};
|
|
Packit |
da863b |
|
|
Packit |
da863b |
static const luksmeta_uuid_t UUID1 = {
|
|
Packit |
da863b |
0xb4, 0xcb, 0x8c, 0x1c, 0x34, 0xea, 0xcc, 0x21,
|
|
Packit |
da863b |
0x0b, 0x9c, 0xc3, 0x9c, 0x9a, 0x09, 0xc0, 0x0f
|
|
Packit |
da863b |
};
|
|
Packit |
da863b |
|
|
Packit |
da863b |
int
|
|
Packit |
da863b |
main(int argc, char *argv[])
|
|
Packit |
da863b |
{
|
|
Packit |
da863b |
uint8_t data[sizeof(UUID0)] = {};
|
|
Packit |
da863b |
struct crypt_device *cd = NULL;
|
|
Packit |
da863b |
luksmeta_uuid_t uuid = {};
|
|
Packit |
da863b |
uint32_t offset = 0;
|
|
Packit |
da863b |
uint32_t length = 0;
|
|
Packit |
da863b |
int r;
|
|
Packit |
da863b |
|
|
Packit |
da863b |
crypt_free(test_format());
|
|
Packit |
da863b |
cd = test_init();
|
|
Packit |
da863b |
test_hole(cd, &offset, &length);
|
|
Packit |
da863b |
|
|
Packit |
da863b |
/* Add one metadata. */
|
|
Packit |
da863b |
r = luksmeta_save(cd, 0, UUID0, UUID0, sizeof(UUID0));
|
|
Packit |
da863b |
if (r < 0)
|
|
Packit |
da863b |
error(EXIT_FAILURE, -r, "luksmeta_save()");
|
|
Packit |
da863b |
|
|
Packit |
da863b |
assert(test_layout((range_t[]) {
|
|
Packit |
da863b |
{ 0, 1024 }, /* LUKS header */
|
|
Packit Service |
b4924e |
{ 1024, 3072, true }, /* Keyslot Area */
|
|
Packit |
da863b |
{ offset, 4096 }, /* luksmeta header */
|
|
Packit |
da863b |
{ offset + 4096, 4096 }, /* luksmeta slot 0 */
|
|
Packit |
da863b |
END(offset + 8192), /* Rest of the file */
|
|
Packit |
da863b |
}));
|
|
Packit |
da863b |
|
|
Packit |
da863b |
assert(luksmeta_load(cd, 0, uuid, data, sizeof(data)) == sizeof(data));
|
|
Packit |
da863b |
assert(memcmp(uuid, UUID0, sizeof(UUID0)) == 0);
|
|
Packit |
da863b |
assert(memcmp(data, UUID0, sizeof(UUID0)) == 0);
|
|
Packit |
da863b |
|
|
Packit |
da863b |
/* Add a second metadata. */
|
|
Packit |
da863b |
r = luksmeta_save(cd, 1, UUID1, UUID1, sizeof(UUID1));
|
|
Packit |
da863b |
if (r < 0)
|
|
Packit |
da863b |
error(EXIT_FAILURE, -r, "luksmeta_save()");
|
|
Packit |
da863b |
|
|
Packit |
da863b |
assert(test_layout((range_t[]) {
|
|
Packit |
da863b |
{ 0, 1024 }, /* LUKS header */
|
|
Packit Service |
b4924e |
{ 1024, 3072, true }, /* Keyslot Area */
|
|
Packit |
da863b |
{ offset, 4096 }, /* luksmeta header */
|
|
Packit |
da863b |
{ offset + 4096, 4096 }, /* luksmeta slot 0 */
|
|
Packit |
da863b |
{ offset + 8192, 4096 }, /* luksmeta slot 1 */
|
|
Packit |
da863b |
END(offset + 12288), /* Rest of the file */
|
|
Packit |
da863b |
}));
|
|
Packit |
da863b |
|
|
Packit |
da863b |
assert(luksmeta_load(cd, 0, uuid, data, sizeof(data)) == sizeof(data));
|
|
Packit |
da863b |
assert(memcmp(uuid, UUID0, sizeof(UUID0)) == 0);
|
|
Packit |
da863b |
assert(memcmp(data, UUID0, sizeof(UUID0)) == 0);
|
|
Packit |
da863b |
assert(luksmeta_load(cd, 1, uuid, data, sizeof(data)) == sizeof(data));
|
|
Packit |
da863b |
assert(memcmp(uuid, UUID1, sizeof(UUID1)) == 0);
|
|
Packit |
da863b |
assert(memcmp(data, UUID1, sizeof(UUID1)) == 0);
|
|
Packit |
da863b |
|
|
Packit |
da863b |
/* Delete the first metadata. */
|
|
Packit |
da863b |
assert(luksmeta_wipe(cd, 0, UUID0) == 0);
|
|
Packit |
da863b |
assert(test_layout((range_t[]) {
|
|
Packit |
da863b |
{ 0, 1024 }, /* LUKS header */
|
|
Packit Service |
b4924e |
{ 1024, 3072, true }, /* Keyslot Area */
|
|
Packit |
da863b |
{ offset, 4096 }, /* luksmeta header */
|
|
Packit |
da863b |
{ offset + 4096, 4096, true }, /* luksmeta slot 0 */
|
|
Packit |
da863b |
{ offset + 8192, 4096 }, /* luksmeta slot 1 */
|
|
Packit |
da863b |
END(offset + 12288), /* Rest of the file */
|
|
Packit |
da863b |
}));
|
|
Packit |
da863b |
|
|
Packit |
da863b |
/* Delete the second metadata. */
|
|
Packit |
da863b |
assert(luksmeta_wipe(cd, 1, UUID1) == 0);
|
|
Packit |
da863b |
assert(test_layout((range_t[]) {
|
|
Packit |
da863b |
{ 0, 1024 }, /* LUKS header */
|
|
Packit Service |
b4924e |
{ 1024, 3072, true }, /* Keyslot Area */
|
|
Packit |
da863b |
{ offset, 4096 }, /* luksmeta header */
|
|
Packit |
da863b |
END(offset + 4096), /* Rest of the file */
|
|
Packit |
da863b |
}));
|
|
Packit |
da863b |
|
|
Packit |
da863b |
crypt_free(cd);
|
|
Packit |
da863b |
unlink(filename);
|
|
Packit |
da863b |
return 0;
|
|
Packit |
da863b |
}
|