[rtems commit] fstests/fsbdpart01: New test
Sebastian Huber
sebh at rtems.org
Tue Mar 13 11:31:33 UTC 2012
Module: rtems
Branch: master
Commit: 113944fa634e792c78bf394989d710197bb722da
Changeset: http://git.rtems.org/rtems/commit/?id=113944fa634e792c78bf394989d710197bb722da
Author: Sebastian Huber <sebastian.huber at embedded-brains.de>
Date: Tue Feb 28 15:37:31 2012 +0100
fstests/fsbdpart01: New test
---
testsuites/fstests/Makefile.am | 1 +
testsuites/fstests/configure.ac | 1 +
testsuites/fstests/fsbdpart01/Makefile.am | 20 +++
testsuites/fstests/fsbdpart01/fsbdpart01.doc | 11 ++
testsuites/fstests/fsbdpart01/fsbdpart01.scn | 17 ++
testsuites/fstests/fsbdpart01/init.c | 231 ++++++++++++++++++++++++++
6 files changed, 281 insertions(+), 0 deletions(-)
diff --git a/testsuites/fstests/Makefile.am b/testsuites/fstests/Makefile.am
index d731eb6..f765a89 100644
--- a/testsuites/fstests/Makefile.am
+++ b/testsuites/fstests/Makefile.am
@@ -32,6 +32,7 @@ SUBDIRS += mrfs_fssymlink
SUBDIRS += mrfs_fstime
SUBDIRS += fsnofs01
SUBDIRS += fsimfsgeneric01
+SUBDIRS += fsbdpart01
EXTRA_DIST =
EXTRA_DIST += support/ramdisk_support.c
diff --git a/testsuites/fstests/configure.ac b/testsuites/fstests/configure.ac
index f2ca983..833a85c 100644
--- a/testsuites/fstests/configure.ac
+++ b/testsuites/fstests/configure.ac
@@ -106,6 +106,7 @@ mrfs_fssymlink/Makefile
mrfs_fstime/Makefile
fsnofs01/Makefile
fsimfsgeneric01/Makefile
+fsbdpart01/Makefile
])
AC_OUTPUT
diff --git a/testsuites/fstests/fsbdpart01/Makefile.am b/testsuites/fstests/fsbdpart01/Makefile.am
new file mode 100644
index 0000000..923e980
--- /dev/null
+++ b/testsuites/fstests/fsbdpart01/Makefile.am
@@ -0,0 +1,20 @@
+rtems_tests_PROGRAMS = fsbdpart01
+fsbdpart01_SOURCES = init.c
+
+dist_rtems_tests_DATA = fsbdpart01.scn fsbdpart01.doc
+
+include $(RTEMS_ROOT)/make/custom/@RTEMS_BSP at .cfg
+include $(top_srcdir)/../automake/compile.am
+include $(top_srcdir)/../automake/leaf.am
+
+
+AM_CPPFLAGS += -I$(top_srcdir)/../support/include
+
+LINK_OBJS = $(fsbdpart01_OBJECTS)
+LINK_LIBS = $(fsbdpart01_LDLIBS)
+
+fsbdpart01$(EXEEXT): $(fsbdpart01_OBJECTS) $(fsbdpart01_DEPENDENCIES)
+ @rm -f fsbdpart01$(EXEEXT)
+ $(make-exe)
+
+include $(top_srcdir)/../automake/local.am
diff --git a/testsuites/fstests/fsbdpart01/fsbdpart01.doc b/testsuites/fstests/fsbdpart01/fsbdpart01.doc
new file mode 100644
index 0000000..56da2eb
--- /dev/null
+++ b/testsuites/fstests/fsbdpart01/fsbdpart01.doc
@@ -0,0 +1,11 @@
+This file describes the directives and concepts tested by this test set.
+
+test set name: fsbdpart01
+
+directives:
+
+ TBD
+
+concepts:
+
+ TBD
diff --git a/testsuites/fstests/fsbdpart01/fsbdpart01.scn b/testsuites/fstests/fsbdpart01/fsbdpart01.scn
new file mode 100644
index 0000000..33efd2c
--- /dev/null
+++ b/testsuites/fstests/fsbdpart01/fsbdpart01.scn
@@ -0,0 +1,17 @@
+*** TEST FSBDPART 1 ***
+-------------------------------------------------------------------------------
+ PARTITION TABLE
+------------+------------+-----------------------------------------------------
+ BEGIN | END | TYPE
+------------+------------+-----------------------------------------------------
+ 63 | 126 | FAT 32
+ 126 | 189 | FAT 32
+ 189 | 252 | FAT 32
+ 315 | 378 | FAT 32
+ 441 | 504 | FAT 32
+ 567 | 630 | FAT 32
+ 693 | 756 | FAT 32
+ 819 | 882 | FAT 32
+ 945 | 1008 | FAT 32
+------------+------------+-----------------------------------------------------
+*** END OF TEST FSBDPART 1 ***
diff --git a/testsuites/fstests/fsbdpart01/init.c b/testsuites/fstests/fsbdpart01/init.c
new file mode 100644
index 0000000..69fe071
--- /dev/null
+++ b/testsuites/fstests/fsbdpart01/init.c
@@ -0,0 +1,231 @@
+/*
+ * Copyright (c) 2012 embedded brains GmbH. All rights reserved.
+ *
+ * embedded brains GmbH
+ * Obere Lagerstr. 30
+ * 82178 Puchheim
+ * Germany
+ * <rtems at 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 "tmacros.h"
+
+#include <sys/stat.h>
+#include <fcntl.h>
+
+#include <rtems/bdpart.h>
+#include <rtems/blkdev.h>
+#include <rtems/ide_part_table.h>
+#include <rtems/ramdisk.h>
+
+#define ASSERT_SC(sc) rtems_test_assert((sc) == RTEMS_SUCCESSFUL)
+
+#define PARTITION_COUNT 9
+
+static const char rda [] = "/dev/rda";
+
+static const char *const bdpart_rdax [PARTITION_COUNT] = {
+ "/dev/rda1",
+ "/dev/rda2",
+ "/dev/rda3",
+ "/dev/rda4",
+ "/dev/rda5",
+ "/dev/rda6",
+ "/dev/rda7",
+ "/dev/rda8",
+ "/dev/rda9"
+};
+
+static const char *const ide_part_table_rdax [PARTITION_COUNT] = {
+ "/dev/rda1",
+ "/dev/rda2",
+ "/dev/rda3",
+ "/dev/rda5",
+ "/dev/rda6",
+ "/dev/rda7",
+ "/dev/rda8",
+ "/dev/rda9",
+ "/dev/rda10"
+};
+
+static const rtems_blkdev_bnum starts [PARTITION_COUNT] = {
+ 63, 126, 189, 315, 441, 567, 693, 819, 945
+};
+
+static const rtems_bdpart_format format = {
+ .mbr = {
+ .type = RTEMS_BDPART_FORMAT_MBR,
+ .disk_id = 0xdeadbeef,
+ .dos_compatibility = true
+ }
+};
+
+static const unsigned distribution [PARTITION_COUNT] = {
+ 1, 1, 1, 1, 1, 1, 1, 1, 1
+};
+
+static void test_logical_disks(const char *const *rdax, bool exists)
+{
+ size_t i = 0;
+
+ for (i = 0; i < PARTITION_COUNT; ++i) {
+ int fd = open(rdax [i], O_RDONLY);
+
+ if (exists) {
+ const rtems_disk_device *dd = NULL;
+ int rv = 0;
+
+ rtems_test_assert(fd >= 0);
+
+ rv = rtems_disk_fd_get_disk_device(fd, &dd);
+ rtems_test_assert(rv == 0);
+
+ rtems_test_assert(dd->start == starts [i]);
+ rtems_test_assert(dd->size == 63);
+
+ rv = close(fd);
+ rtems_test_assert(rv == 0);
+ } else {
+ rtems_test_assert(fd == -1);
+ }
+ }
+}
+
+static void test_bdpart(void)
+{
+ rtems_status_code sc = RTEMS_SUCCESSFUL;
+ rtems_bdpart_partition created_partitions [PARTITION_COUNT];
+ rtems_bdpart_format actual_format;
+ rtems_bdpart_partition actual_partitions [PARTITION_COUNT];
+ size_t actual_count = PARTITION_COUNT;
+ size_t i = 0;
+
+ memset(&created_partitions [0], 0, sizeof(created_partitions));
+ memset(&actual_format, 0, sizeof(actual_format));
+ memset(&actual_partitions [0], 0, sizeof(actual_partitions));
+
+ for (i = 0; i < PARTITION_COUNT; ++i) {
+ rtems_bdpart_to_partition_type(
+ RTEMS_BDPART_MBR_FAT_32,
+ created_partitions [i].type
+ );
+ }
+
+ sc = rtems_bdpart_create(
+ rda,
+ &format,
+ &created_partitions [0],
+ &distribution [0],
+ PARTITION_COUNT
+ );
+ ASSERT_SC(sc);
+
+ sc = rtems_bdpart_write(
+ rda,
+ &format,
+ &created_partitions [0],
+ PARTITION_COUNT
+ );
+ ASSERT_SC(sc);
+
+ sc = rtems_bdpart_read(
+ rda,
+ &actual_format,
+ &actual_partitions [0],
+ &actual_count
+ );
+ ASSERT_SC(sc);
+ rtems_test_assert(actual_format.mbr.disk_id == format.mbr.disk_id);
+ rtems_test_assert(
+ memcmp(
+ &actual_partitions [0],
+ &created_partitions [0],
+ PARTITION_COUNT
+ ) == 0
+ );
+
+ sc = rtems_bdpart_register(
+ rda,
+ actual_partitions,
+ actual_count
+ );
+ ASSERT_SC(sc);
+ test_logical_disks(&bdpart_rdax [0], true);
+
+ sc = rtems_bdpart_unregister(
+ rda,
+ actual_partitions,
+ actual_count
+ );
+ ASSERT_SC(sc);
+ test_logical_disks(&bdpart_rdax [0], false);
+
+ sc = rtems_bdpart_register_from_disk(rda);
+ ASSERT_SC(sc);
+ test_logical_disks(&bdpart_rdax [0], true);
+
+ sc = rtems_bdpart_unregister(
+ rda,
+ actual_partitions,
+ actual_count
+ );
+ ASSERT_SC(sc);
+ test_logical_disks(&bdpart_rdax [0], false);
+
+ rtems_bdpart_dump(&actual_partitions [0], actual_count);
+}
+
+static void test_ide_part_table(void)
+{
+ rtems_status_code sc = RTEMS_SUCCESSFUL;
+
+ test_logical_disks(&ide_part_table_rdax [0], false);
+ sc = rtems_ide_part_table_initialize(rda);
+ ASSERT_SC(sc);
+ test_logical_disks(&ide_part_table_rdax [0], true);
+}
+
+static void Init(rtems_task_argument arg)
+{
+ printf("\n\n*** TEST FSBDPART 1 ***\n");
+
+ test_bdpart();
+ test_ide_part_table();
+
+ printf("*** END OF TEST FSBDPART 1 ***\n");
+
+ rtems_test_exit(0);
+}
+
+rtems_ramdisk_config rtems_ramdisk_configuration [] = {
+ { .block_size = 512, .block_num = 1024 }
+};
+
+size_t rtems_ramdisk_configuration_size = 1;
+
+#define CONFIGURE_APPLICATION_NEEDS_CLOCK_DRIVER
+#define CONFIGURE_APPLICATION_NEEDS_CONSOLE_DRIVER
+#define CONFIGURE_APPLICATION_EXTRA_DRIVERS RAMDISK_DRIVER_TABLE_ENTRY
+#define CONFIGURE_APPLICATION_NEEDS_LIBBLOCK
+
+#define CONFIGURE_LIBIO_MAXIMUM_FILE_DESCRIPTORS 4
+
+#define CONFIGURE_USE_IMFS_AS_BASE_FILESYSTEM
+
+#define CONFIGURE_MAXIMUM_TASKS 2
+
+#define CONFIGURE_EXTRA_TASK_STACKS (8 * 1024)
+
+#define CONFIGURE_RTEMS_INIT_TASKS_TABLE
+
+#define CONFIGURE_INIT
+
+#include <rtems/confdefs.h>
More information about the vc
mailing list