part: show efi partition name when print out partition info
Previous output: Marvell>> mmc part Partition Map for MMC device 1 -- Partition Type: EFI Part Start LBA End LBA gpt1 0x8C00 0xCBFF gpt2 0xCC00 0x57BFF gpt3 0x57C00 0xA2BFF gpt4 0xA2C00 0xECBFDE With the patch, the output becomes: Marvell>> mmc part Partition Map for MMC device 1 -- Partition Type: EFI Part Name Start LBA End LBA 1 ramdisk 0x00008C00 0x0000CBFF 2 system 0x0000CC00 0x00057BFF 3 userdata 0x00057C00 0x000A2BFF 4 remaining 0x000A2C00 0x00ECBFDE Signed-off-by: Lei Wen <leiwen@marvell.com>
This commit is contained in:
parent
9f87658054
commit
6eecc03079
@ -35,6 +35,7 @@
|
|||||||
#include <ide.h>
|
#include <ide.h>
|
||||||
#include <malloc.h>
|
#include <malloc.h>
|
||||||
#include "part_efi.h"
|
#include "part_efi.h"
|
||||||
|
#include <linux/ctype.h>
|
||||||
|
|
||||||
#if defined(CONFIG_CMD_IDE) || \
|
#if defined(CONFIG_CMD_IDE) || \
|
||||||
defined(CONFIG_CMD_MG_DISK) || \
|
defined(CONFIG_CMD_MG_DISK) || \
|
||||||
@ -99,6 +100,20 @@ static gpt_entry *alloc_read_gpt_entries(block_dev_desc_t * dev_desc,
|
|||||||
|
|
||||||
static int is_pte_valid(gpt_entry * pte);
|
static int is_pte_valid(gpt_entry * pte);
|
||||||
|
|
||||||
|
static char *print_efiname(gpt_entry *pte)
|
||||||
|
{
|
||||||
|
static char name[PARTNAME_SZ + 1];
|
||||||
|
int i;
|
||||||
|
for (i = 0; i < PARTNAME_SZ; i++) {
|
||||||
|
u8 c;
|
||||||
|
c = pte->partition_name[i] & 0xff;
|
||||||
|
c = (c && !isprint(c)) ? '.' : c;
|
||||||
|
name[i] = c;
|
||||||
|
}
|
||||||
|
name[PARTNAME_SZ] = 0;
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Public Functions (include/part.h)
|
* Public Functions (include/part.h)
|
||||||
*/
|
*/
|
||||||
@ -122,12 +137,12 @@ void print_part_efi(block_dev_desc_t * dev_desc)
|
|||||||
|
|
||||||
debug("%s: gpt-entry at 0x%08X\n", __FUNCTION__, (unsigned int)*pgpt_pte);
|
debug("%s: gpt-entry at 0x%08X\n", __FUNCTION__, (unsigned int)*pgpt_pte);
|
||||||
|
|
||||||
printf("Part Start LBA End LBA\n");
|
printf("Part\tName\t\t\tStart LBA\tEnd LBA\n");
|
||||||
for (i = 0; i < le32_to_int(gpt_head.num_partition_entries); i++) {
|
for (i = 0; i < le32_to_int(gpt_head.num_partition_entries); i++) {
|
||||||
|
|
||||||
if (is_pte_valid(&(*pgpt_pte)[i])) {
|
if (is_pte_valid(&(*pgpt_pte)[i])) {
|
||||||
printf("%s%d 0x%llX 0x%llX\n", GPT_ENTRY_NAME,
|
printf("%3d\t%-18s\t0x%08llX\t0x%08llX\n", (i + 1),
|
||||||
(i + 1),
|
print_efiname(&(*pgpt_pte)[i]),
|
||||||
le64_to_int((*pgpt_pte)[i].starting_lba),
|
le64_to_int((*pgpt_pte)[i].starting_lba),
|
||||||
le64_to_int((*pgpt_pte)[i].ending_lba));
|
le64_to_int((*pgpt_pte)[i].ending_lba));
|
||||||
} else {
|
} else {
|
||||||
@ -169,7 +184,8 @@ int get_partition_info_efi(block_dev_desc_t * dev_desc, int part,
|
|||||||
- info->start;
|
- info->start;
|
||||||
info->blksz = GPT_BLOCK_SIZE;
|
info->blksz = GPT_BLOCK_SIZE;
|
||||||
|
|
||||||
sprintf((char *)info->name, "%s%d", GPT_ENTRY_NAME, part);
|
sprintf((char *)info->name, "%s",
|
||||||
|
print_efiname(&(*pgpt_pte)[part - 1]));
|
||||||
sprintf((char *)info->type, "U-Boot");
|
sprintf((char *)info->type, "U-Boot");
|
||||||
|
|
||||||
debug("%s: start 0x%lX, size 0x%lX, name %s", __FUNCTION__,
|
debug("%s: start 0x%lX, size 0x%lX, name %s", __FUNCTION__,
|
||||||
|
@ -117,13 +117,14 @@ typedef struct _gpt_entry_attributes {
|
|||||||
unsigned long long type_guid_specific:16;
|
unsigned long long type_guid_specific:16;
|
||||||
} __attribute__ ((packed)) gpt_entry_attributes;
|
} __attribute__ ((packed)) gpt_entry_attributes;
|
||||||
|
|
||||||
|
#define PARTNAME_SZ (72 / sizeof(efi_char16_t))
|
||||||
typedef struct _gpt_entry {
|
typedef struct _gpt_entry {
|
||||||
efi_guid_t partition_type_guid;
|
efi_guid_t partition_type_guid;
|
||||||
efi_guid_t unique_partition_guid;
|
efi_guid_t unique_partition_guid;
|
||||||
unsigned char starting_lba[8];
|
unsigned char starting_lba[8];
|
||||||
unsigned char ending_lba[8];
|
unsigned char ending_lba[8];
|
||||||
gpt_entry_attributes attributes;
|
gpt_entry_attributes attributes;
|
||||||
efi_char16_t partition_name[72 / sizeof(efi_char16_t)];
|
efi_char16_t partition_name[PARTNAME_SZ];
|
||||||
}
|
}
|
||||||
__attribute__ ((packed)) gpt_entry;
|
__attribute__ ((packed)) gpt_entry;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user