diff options
author | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2010-04-30 08:42:13 +0000 |
---|---|---|
committer | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2010-04-30 08:42:13 +0000 |
commit | 67808290370e184f5a4fb7e1bff0402e5104d016 (patch) | |
tree | 59733050629d923611f226d2a5c49ff1f9b0f2fa /cpukit/libblock/src/bdpart-dump.c | |
parent | 2010-04-30 Sebastian Huber <sebastian.huber@embedded-brains.de> (diff) | |
download | rtems-67808290370e184f5a4fb7e1bff0402e5104d016.tar.bz2 |
2010-04-30 Sebastian Huber <sebastian.huber@embedded-brains.de>
* libblock/src/bdpart.c: Removed file.
* libblock/src/bdpart-create.c, libblock/src/bdpart-dump.c,
libblock/src/bdpart-mount.c, libblock/src/bdpart-read.c,
libblock/src/bdpart-register.c, libblock/src/bdpart-sort.c,
libblock/src/bdpart-write.c: New files.
* libblock/include/rtems/bdpart.h: Moved some definitions from bdpart.c.
* libblock/Makefile.am: Update for file changes.
Diffstat (limited to 'cpukit/libblock/src/bdpart-dump.c')
-rw-r--r-- | cpukit/libblock/src/bdpart-dump.c | 97 |
1 files changed, 97 insertions, 0 deletions
diff --git a/cpukit/libblock/src/bdpart-dump.c b/cpukit/libblock/src/bdpart-dump.c new file mode 100644 index 0000000000..abd85b6037 --- /dev/null +++ b/cpukit/libblock/src/bdpart-dump.c @@ -0,0 +1,97 @@ +/** + * @file + * + * @ingroup rtems_bdpart + * + * Block device partition management. + */ + +/* + * Copyright (c) 2009, 2010 + * embedded brains GmbH + * Obere Lagerstr. 30 + * D-82178 Puchheim + * Germany + * <rtems@embedded-brains.de> + * + * The license and distribution terms for this file may be + * found in the file LICENSE in this distribution or at + * http://www.rtems.com/license/LICENSE. + */ + +#ifdef HAVE_CONFIG_H +#include "config.h" +#endif + +#include <stdio.h> +#include <inttypes.h> + +#include <rtems.h> +#include <rtems/bdpart.h> + +static void rtems_bdpart_type_to_string( + const uuid_t type, + char str [37] +) +{ + uuid_unparse_lower( type, str); +} + +void rtems_bdpart_dump( const rtems_bdpart_partition *pt, size_t count) +{ + size_t i = 0; + + printf( + "-------------------------------------------------------------------------------\n" + " PARTITION TABLE\n" + "------------+------------+-----------------------------------------------------\n" + " BEGIN | END | TYPE\n" + "------------+------------+-----------------------------------------------------\n" + ); + + for (i = 0; i < count; ++i) { + const rtems_bdpart_partition *p = pt + i; + const char *type = NULL; + char type_buffer [52]; + uint8_t type_mbr = 0; + + if (rtems_bdpart_to_mbr_partition_type( p->type, &type_mbr)) { + switch (type_mbr) { + case RTEMS_BDPART_MBR_FAT_12: + type = "FAT 12"; + break; + case RTEMS_BDPART_MBR_FAT_16: + type = "FAT 16"; + break; + case RTEMS_BDPART_MBR_FAT_16_LBA: + type = "FAT 16 LBA"; + break; + case RTEMS_BDPART_MBR_FAT_32: + type = "FAT 32"; + break; + case RTEMS_BDPART_MBR_FAT_32_LBA: + type = "FAT 32 LBA"; + break; + case RTEMS_BDPART_MBR_DATA: + type = "DATA"; + break; + default: + snprintf( type_buffer, sizeof( type_buffer), "0x%02" PRIx8, type_mbr); + type = type_buffer; + break; + } + } else { + rtems_bdpart_type_to_string( p->type, type_buffer); + type = type_buffer; + } + + printf( + " %10" PRIu32 " | %10" PRIu32 " |%52s\n", + p->begin, + p->end, + type + ); + } + + puts( "------------+------------+-----------------------------------------------------"); +} |