summaryrefslogtreecommitdiffstats
path: root/testsuites/libtests/block07/init.c
diff options
context:
space:
mode:
authorThomas Doerfler <Thomas.Doerfler@embedded-brains.de>2009-11-09 16:27:42 +0000
committerThomas Doerfler <Thomas.Doerfler@embedded-brains.de>2009-11-09 16:27:42 +0000
commite6000760b27091647dc13bc763e0b37875ef4bd9 (patch)
tree13d9ddc5d4b62d2a363efd05a86ebe0dc1a6a83a /testsuites/libtests/block07/init.c
parent2009-11-09 Joel Sherrill <joel.sherrill@oarcorp.com> (diff)
downloadrtems-e6000760b27091647dc13bc763e0b37875ef4bd9.tar.bz2
Added block05, block06 and block07
Diffstat (limited to 'testsuites/libtests/block07/init.c')
-rw-r--r--testsuites/libtests/block07/init.c224
1 files changed, 224 insertions, 0 deletions
diff --git a/testsuites/libtests/block07/init.c b/testsuites/libtests/block07/init.c
new file mode 100644
index 0000000000..f7845d47a9
--- /dev/null
+++ b/testsuites/libtests/block07/init.c
@@ -0,0 +1,224 @@
+/**
+ * @file
+ *
+ * @ingroup test_bdbuf
+ *
+ * @brief Bdbuf test for block size change event.
+ */
+
+/*
+ * Copyright (c) 2009
+ * 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.
+ */
+
+#include <sys/ioctl.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <fcntl.h>
+#include <assert.h>
+
+#include <rtems.h>
+#include <rtems/ramdisk.h>
+#include <rtems/bdbuf.h>
+#include <rtems/diskdevs.h>
+
+#define ASSERT_SC(sc) assert((sc) == RTEMS_SUCCESSFUL)
+
+#define PRIORITY_INIT 1
+
+#define PRIORITY_HIGH 2
+
+#define PRIORITY_LOW 3
+
+#define PRIORITY_SWAPOUT 4
+
+#define PRIORITY_IDLE 5
+
+#define BLOCK_SIZE_A 1
+
+#define BLOCK_SIZE_B 2
+
+#define BLOCK_COUNT 2
+
+static dev_t dev;
+
+static rtems_id task_id_low;
+
+static rtems_id task_id_high;
+
+static void change_block_size(void)
+{
+ int rv = 0;
+ uint32_t new_block_size = BLOCK_SIZE_B;
+ int fd = open("/dev/rda", O_RDWR);
+
+ assert(fd >= 0);
+
+ rv = ioctl(fd, RTEMS_BLKIO_SETBLKSIZE, &new_block_size);
+ assert(rv == 0);
+
+ rv = close(fd);
+ assert(rv == 0);
+}
+
+static void task_low(rtems_task_argument arg)
+{
+ rtems_status_code sc = RTEMS_SUCCESSFUL;
+ rtems_bdbuf_buffer *bd = NULL;
+
+ printk("L: try access: 0\n");
+
+ sc = rtems_bdbuf_get(dev, 0, &bd);
+ ASSERT_SC(sc);
+
+ printk("L: access: 0\n");
+
+ assert(bd->group->bds_per_group == 2);
+
+ printk("L: release: 0\n");
+
+ sc = rtems_bdbuf_release(bd);
+ ASSERT_SC(sc);
+
+ printk("L: release done: 0\n");
+
+ rtems_task_delete(RTEMS_SELF);
+}
+
+static void task_high(rtems_task_argument arg)
+{
+ rtems_status_code sc = RTEMS_SUCCESSFUL;
+ rtems_bdbuf_buffer *bd = NULL;
+
+ change_block_size();
+
+ printk("H: try access: 0\n");
+
+ sc = rtems_bdbuf_get(dev, 0, &bd);
+ ASSERT_SC(sc);
+
+ printk("H: access: 0\n");
+
+ assert(bd->group->bds_per_group == 1);
+
+ printk("H: release: 0\n");
+
+ sc = rtems_bdbuf_release(bd);
+ ASSERT_SC(sc);
+
+ printk("H: release done: 0\n");
+
+ printk("*** END OF TEST BLOCK 7 ***\n");
+
+ exit(0);
+}
+
+static rtems_task Init(rtems_task_argument argument)
+{
+ rtems_status_code sc = RTEMS_SUCCESSFUL;
+ rtems_task_priority cur_prio = 0;
+ rtems_bdbuf_buffer *bd = NULL;
+
+ printk("\n\n*** TEST BLOCK 7 ***\n");
+
+ sc = rtems_disk_io_initialize();
+ ASSERT_SC(sc);
+
+ sc = ramdisk_register(BLOCK_SIZE_A, BLOCK_COUNT, false, "/dev/rda", &dev);
+ ASSERT_SC(sc);
+
+ sc = rtems_task_create(
+ rtems_build_name(' ', 'L', 'O', 'W'),
+ PRIORITY_LOW,
+ 0,
+ RTEMS_DEFAULT_MODES,
+ RTEMS_DEFAULT_ATTRIBUTES,
+ &task_id_low
+ );
+ ASSERT_SC(sc);
+
+ sc = rtems_task_start(task_id_low, task_low, 0);
+ ASSERT_SC(sc);
+
+ sc = rtems_task_create(
+ rtems_build_name('H', 'I', 'G', 'H'),
+ PRIORITY_HIGH,
+ 0,
+ RTEMS_DEFAULT_MODES,
+ RTEMS_DEFAULT_ATTRIBUTES,
+ &task_id_high
+ );
+ ASSERT_SC(sc);
+
+ sc = rtems_task_start(task_id_high, task_high, 0);
+ ASSERT_SC(sc);
+
+ sc = rtems_task_suspend(task_id_high);
+ ASSERT_SC(sc);
+
+ sc = rtems_bdbuf_get(dev, 1, &bd);
+ ASSERT_SC(sc);
+
+ sc = rtems_bdbuf_release(bd);
+ ASSERT_SC(sc);
+
+ printk("I: try access: 0\n");
+
+ sc = rtems_bdbuf_get(dev, 0, &bd);
+ ASSERT_SC(sc);
+
+ printk("I: access: 0\n");
+
+ sc = rtems_task_set_priority(RTEMS_SELF, PRIORITY_IDLE, &cur_prio);
+ ASSERT_SC(sc);
+
+ sc = rtems_task_resume(task_id_high);
+ ASSERT_SC(sc);
+
+ sc = rtems_task_set_priority(RTEMS_SELF, PRIORITY_INIT, &cur_prio);
+ ASSERT_SC(sc);
+
+ printk("I: release: 0\n");
+
+ sc = rtems_bdbuf_release(bd);
+ ASSERT_SC(sc);
+
+ printk("I: release done: 0\n");
+
+ rtems_task_delete(RTEMS_SELF);
+}
+
+#define CONFIGURE_INIT
+
+#define CONFIGURE_APPLICATION_DOES_NOT_NEED_CLOCK_DRIVER
+#define CONFIGURE_APPLICATION_NEEDS_CONSOLE_DRIVER
+#define CONFIGURE_APPLICATION_NEEDS_LIBBLOCK
+
+#define CONFIGURE_USE_IMFS_AS_BASE_FILESYSTEM
+#define CONFIGURE_LIBIO_MAXIMUM_FILE_DESCRIPTORS 4
+
+#define CONFIGURE_MAXIMUM_TASKS 5
+#define CONFIGURE_MAXIMUM_DRIVERS 2
+#define CONFIGURE_MAXIMUM_SEMAPHORES 5
+
+#define CONFIGURE_RTEMS_INIT_TASKS_TABLE
+
+#define CONFIGURE_INIT_TASK_PRIORITY PRIORITY_INIT
+#define CONFIGURE_INIT_TASK_ATTRIBUTES RTEMS_DEFAULT_ATTRIBUTES
+#define CONFIGURE_INIT_TASK_INITIAL_MODES RTEMS_DEFAULT_MODES
+
+#define CONFIGURE_SWAPOUT_TASK_PRIORITY PRIORITY_SWAPOUT
+
+#define CONFIGURE_BDBUF_BUFFER_MIN_SIZE BLOCK_SIZE_A
+#define CONFIGURE_BDBUF_BUFFER_MAX_SIZE BLOCK_SIZE_B
+#define CONFIGURE_BDBUF_CACHE_MEMORY_SIZE (BLOCK_SIZE_A * BLOCK_COUNT)
+
+#include <rtems/confdefs.h>