mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-12-01 17:10:11 +00:00
de1728ce4c
This adds support for partitions of the form "dev.hwpart:part" and "dev#partname". This allows one to flash to eMMC boot partitions without having to use CONFIG_FASTBOOT_MMC_BOOT1_SUPPORT. It also allows one to flash to an entire device without needing CONFIG_FASTBOOT_MMC_USER_NAME. Lastly, one can also flash MMC devices other than CONFIG_FASTBOOT_FLASH_MMC_DEV. Because devices can be specified explicitly, CONFIG_FASTBOOT_FLASH_MMC_DEV is used only when necessary for existing functionality. For those cases, fastboot_mmc_get_dev has been added as a helper function. This allows There should be no conflicts with the existing system, but just in case, I have ordered detection of these names after all existing names. The fastboot_mmc_part test has been updated for these new names. Signed-off-by: Sean Anderson <sean.anderson@seco.com> Reviewed-by: Simon Glass <sjg@chromium.org>
95 lines
3.1 KiB
C
95 lines
3.1 KiB
C
// SPDX-License-Identifier: GPL-2.0+
|
|
/*
|
|
* Copyright (C) 2015 Google, Inc
|
|
*/
|
|
|
|
#include <common.h>
|
|
#include <dm.h>
|
|
#include <fastboot.h>
|
|
#include <fb_mmc.h>
|
|
#include <mmc.h>
|
|
#include <part.h>
|
|
#include <part_efi.h>
|
|
#include <dm/test.h>
|
|
#include <test/ut.h>
|
|
#include <linux/stringify.h>
|
|
|
|
#define FB_ALIAS_PREFIX "fastboot_partition_alias_"
|
|
|
|
static int dm_test_fastboot_mmc_part(struct unit_test_state *uts)
|
|
{
|
|
char response[FASTBOOT_RESPONSE_LEN] = {0};
|
|
char str_disk_guid[UUID_STR_LEN + 1];
|
|
struct blk_desc *mmc_dev_desc, *fb_dev_desc;
|
|
struct disk_partition part_info;
|
|
struct disk_partition parts[2] = {
|
|
{
|
|
.start = 48, /* GPT data takes up the first 34 blocks or so */
|
|
.size = 1,
|
|
.name = "test1",
|
|
},
|
|
{
|
|
.start = 49,
|
|
.size = 1,
|
|
.name = "test2",
|
|
},
|
|
};
|
|
|
|
/*
|
|
* There are a lot of literal 0s I don't want to have to construct from
|
|
* MMC_DEV.
|
|
*/
|
|
ut_asserteq(0, CONFIG_FASTBOOT_FLASH_MMC_DEV);
|
|
ut_assertok(blk_get_device_by_str("mmc", "0", &mmc_dev_desc));
|
|
if (CONFIG_IS_ENABLED(RANDOM_UUID)) {
|
|
gen_rand_uuid_str(parts[0].uuid, UUID_STR_FORMAT_STD);
|
|
gen_rand_uuid_str(parts[1].uuid, UUID_STR_FORMAT_STD);
|
|
gen_rand_uuid_str(str_disk_guid, UUID_STR_FORMAT_STD);
|
|
}
|
|
ut_assertok(gpt_restore(mmc_dev_desc, str_disk_guid, parts,
|
|
ARRAY_SIZE(parts)));
|
|
|
|
/* "Classic" partition labels */
|
|
ut_asserteq(1, fastboot_mmc_get_part_info("test1", &fb_dev_desc,
|
|
&part_info, response));
|
|
ut_asserteq(2, fastboot_mmc_get_part_info("test2", &fb_dev_desc,
|
|
&part_info, response));
|
|
|
|
/* Test aliases */
|
|
ut_assertnull(env_get(FB_ALIAS_PREFIX "test3"));
|
|
ut_assertok(env_set(FB_ALIAS_PREFIX "test3", "test1"));
|
|
ut_asserteq(1, fastboot_mmc_get_part_info("test3", &fb_dev_desc,
|
|
&part_info, response));
|
|
ut_assertok(env_set(FB_ALIAS_PREFIX "test3", NULL));
|
|
|
|
/* "New" partition labels */
|
|
ut_asserteq(1, fastboot_mmc_get_part_info("#test1", &fb_dev_desc,
|
|
&part_info, response));
|
|
ut_asserteq(1, fastboot_mmc_get_part_info("0#test1", &fb_dev_desc,
|
|
&part_info, response));
|
|
ut_asserteq(1, fastboot_mmc_get_part_info("0.0#test1", &fb_dev_desc,
|
|
&part_info, response));
|
|
ut_asserteq(1, fastboot_mmc_get_part_info("0:1", &fb_dev_desc,
|
|
&part_info, response));
|
|
ut_asserteq(1, fastboot_mmc_get_part_info("0.0:1", &fb_dev_desc,
|
|
&part_info, response));
|
|
ut_asserteq(1, fastboot_mmc_get_part_info("0", &fb_dev_desc,
|
|
&part_info, response));
|
|
ut_asserteq(1, fastboot_mmc_get_part_info("0.0", &fb_dev_desc,
|
|
&part_info, response));
|
|
ut_asserteq(0, fastboot_mmc_get_part_info("0:0", &fb_dev_desc,
|
|
&part_info, response));
|
|
ut_asserteq(0, fastboot_mmc_get_part_info("0.0:0", &fb_dev_desc,
|
|
&part_info, response));
|
|
ut_asserteq(0, fastboot_mmc_get_part_info("1", &fb_dev_desc,
|
|
&part_info, response));
|
|
ut_asserteq(0, fastboot_mmc_get_part_info("1.0", &fb_dev_desc,
|
|
&part_info, response));
|
|
ut_asserteq(1, fastboot_mmc_get_part_info(":1", &fb_dev_desc,
|
|
&part_info, response));
|
|
ut_asserteq(0, fastboot_mmc_get_part_info(":0", &fb_dev_desc,
|
|
&part_info, response));
|
|
|
|
return 0;
|
|
}
|
|
DM_TEST(dm_test_fastboot_mmc_part, UT_TESTF_SCAN_PDATA | UT_TESTF_SCAN_FDT);
|