[PATCH 8/8] validation/ts-performance-0: Add partition tests

Sebastian Huber sebastian.huber at embedded-brains.de
Fri Nov 13 10:07:57 UTC 2020


---
 .../testsuites/validation/performance-0.yml   |   1 +
 testsuites/validation/tc-part-performance.c   | 437 ++++++++++++++++++
 2 files changed, 438 insertions(+)
 create mode 100644 testsuites/validation/tc-part-performance.c

diff --git a/spec/build/testsuites/validation/performance-0.yml b/spec/build/testsuites/validation/performance-0.yml
index ba14066dd3..711edb0c75 100644
--- a/spec/build/testsuites/validation/performance-0.yml
+++ b/spec/build/testsuites/validation/performance-0.yml
@@ -11,6 +11,7 @@ includes: []
 ldflags: []
 links: []
 source:
+- testsuites/validation/tc-part-performance.c
 - testsuites/validation/ts-performance-0.c
 stlib: []
 target: testsuites/validation/ts-performance-0.exe
diff --git a/testsuites/validation/tc-part-performance.c b/testsuites/validation/tc-part-performance.c
new file mode 100644
index 0000000000..46f48c7bf5
--- /dev/null
+++ b/testsuites/validation/tc-part-performance.c
@@ -0,0 +1,437 @@
+/* SPDX-License-Identifier: BSD-2-Clause */
+
+/**
+ * @file
+ *
+ * @ingroup RTEMSTestCaseRtemsPartValPerformance
+ */
+
+/*
+ * Copyright (C) 2020 embedded brains GmbH (http://www.embedded-brains.de)
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
+ * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ * POSSIBILITY OF SUCH DAMAGE.
+ */
+
+/*
+ * This file is part of the RTEMS quality process and was automatically
+ * generated.  If you find something that needs to be fixed or
+ * worded better please post a report or patch to an RTEMS mailing list
+ * or raise a bug report:
+ *
+ * https://docs.rtems.org/branches/master/user/support/bugs.html
+ *
+ * For information on updating and regenerating please refer to:
+ *
+ * https://docs.rtems.org/branches/master/eng/req/howto.html
+ */
+
+#ifdef HAVE_CONFIG_H
+#include "config.h"
+#endif
+
+#include <rtems.h>
+#include <rtems/chain.h>
+
+#include <rtems/test.h>
+
+/**
+ * @defgroup RTEMSTestCaseRtemsPartValPerformance \
+ *   spec:/rtems/part/val/performance
+ *
+ * @ingroup RTEMSTestSuiteTestsuitesPerformance0
+ *
+ * @brief This test case provides a context to run Partition Manager
+ *   performance tests.
+ *
+ * @{
+ */
+
+/**
+ * @brief Test context for spec:/rtems/part/val/performance test case.
+ */
+typedef struct {
+  /**
+   * @brief This member provides a partition with exactly one free buffer.
+   */
+  rtems_id part_one;
+
+  /**
+   * @brief This member provides a partition with exactly
+   *   ${.:/params/buffer-count} free buffers.
+   */
+  rtems_id part_many;
+
+  /**
+   * @brief This member provides a status code.
+   */
+  rtems_status_code status;
+
+  /**
+   * @brief This member provides a buffer pointer.
+   */
+  void *buffer;
+
+  /**
+   * @brief This member provides a second buffer pointer.
+   */
+  void *buffer_2;
+
+  /**
+   * @brief This member references the measure runtime context.
+   */
+  T_measure_runtime_context *context;
+
+  /**
+   * @brief This member provides the measure runtime request.
+   */
+  T_measure_runtime_request request;
+} RtemsPartValPerformance_Context;
+
+static RtemsPartValPerformance_Context
+  RtemsPartValPerformance_Instance;
+
+static void RtemsPartValPerformance_Setup_Context(
+  RtemsPartValPerformance_Context *ctx
+)
+{
+  T_measure_runtime_config config;
+
+  memset( &config, 0, sizeof( config ) );
+  config.sample_count = 1000;
+  ctx->request.arg = ctx;
+  ctx->context = T_measure_runtime_create( &config );
+  T_assert_not_null( ctx->context );
+}
+
+/**
+ * @brief Creates the test partition.
+ */
+static void RtemsPartValPerformance_Setup(
+  RtemsPartValPerformance_Context *ctx
+)
+{
+  rtems_status_code sc;
+  size_t            size;
+  void             *area;
+  uintptr_t         length;
+
+  size = sizeof( rtems_chain_node );
+
+  area = T_malloc( size );
+  sc = rtems_partition_create(
+    rtems_build_name( ' ', 'O', 'N', 'E' ),
+    area,
+    size,
+    size,
+    RTEMS_DEFAULT_ATTRIBUTES,
+    &ctx->part_one
+  );
+  T_assert_rsc_success( sc );
+
+  length = 100 * size;
+  area = T_malloc( length );
+  sc = rtems_partition_create(
+    rtems_build_name( 'M', 'A', 'N', 'Y' ),
+    area,
+    length,
+    size,
+    RTEMS_DEFAULT_ATTRIBUTES,
+    &ctx->part_many
+  );
+  T_assert_rsc_success( sc );
+}
+
+static void RtemsPartValPerformance_Setup_Wrap( void *arg )
+{
+  RtemsPartValPerformance_Context *ctx;
+
+  ctx = arg;
+  RtemsPartValPerformance_Setup_Context( ctx );
+  RtemsPartValPerformance_Setup( ctx );
+}
+
+/**
+ * @brief Deletes the test partition.
+ */
+static void RtemsPartValPerformance_Teardown(
+  RtemsPartValPerformance_Context *ctx
+)
+{
+  rtems_status_code sc;
+
+  if ( ctx->part_one != 0 ) {
+    sc = rtems_partition_delete( ctx->part_one );
+    T_rsc_success( sc );
+  }
+
+  if ( ctx->part_many != 0 ) {
+    sc = rtems_partition_delete( ctx->part_many );
+    T_rsc_success( sc );
+  }
+}
+
+static void RtemsPartValPerformance_Teardown_Wrap( void *arg )
+{
+  RtemsPartValPerformance_Context *ctx;
+
+  ctx = arg;
+  RtemsPartValPerformance_Teardown( ctx );
+}
+
+static T_fixture RtemsPartValPerformance_Fixture = {
+  .setup = RtemsPartValPerformance_Setup_Wrap,
+  .stop = NULL,
+  .teardown = RtemsPartValPerformance_Teardown_Wrap,
+  .scope = NULL,
+  .initial_context = &RtemsPartValPerformance_Instance
+};
+
+/**
+ * @brief Get a buffer.
+ */
+static void RtemsPartReqPerfGetBuffer_Body(
+  RtemsPartValPerformance_Context *ctx
+)
+{
+  ctx->status = rtems_partition_get_buffer( ctx->part_many, &ctx->buffer );
+}
+
+static void RtemsPartReqPerfGetBuffer_Body_Wrap( void *arg )
+{
+  RtemsPartValPerformance_Context *ctx;
+
+  ctx = arg;
+  RtemsPartReqPerfGetBuffer_Body( ctx );
+}
+
+/**
+ * @brief Return the buffer.
+ */
+static bool RtemsPartReqPerfGetBuffer_Teardown(
+  RtemsPartValPerformance_Context *ctx,
+  T_ticks                         *delta,
+  uint32_t                         tic,
+  uint32_t                         toc,
+  unsigned int                     retry
+)
+{
+  rtems_status_code sc;
+
+  T_quiet_rsc_success( ctx->status );
+
+  sc = rtems_partition_return_buffer( ctx->part_many, ctx->buffer );
+  T_quiet_rsc_success( sc );
+
+  return tic == toc;
+}
+
+static bool RtemsPartReqPerfGetBuffer_Teardown_Wrap(
+  void        *arg,
+  T_ticks     *delta,
+  uint32_t     tic,
+  uint32_t     toc,
+  unsigned int retry
+)
+{
+  RtemsPartValPerformance_Context *ctx;
+
+  ctx = arg;
+  return RtemsPartReqPerfGetBuffer_Teardown( ctx, delta, tic, toc, retry );
+}
+
+/**
+ * @brief Get the buffer.
+ */
+static void RtemsPartReqPerfGetNoBuffer_Prepare(
+  RtemsPartValPerformance_Context *ctx
+)
+{
+  rtems_status_code sc;
+
+  sc = rtems_partition_get_buffer( ctx->part_one, &ctx->buffer_2 );
+  T_rsc_success( sc );
+}
+
+/**
+ * @brief Try to get a buffer.
+ */
+static void RtemsPartReqPerfGetNoBuffer_Body(
+  RtemsPartValPerformance_Context *ctx
+)
+{
+  ctx->status = rtems_partition_get_buffer( ctx->part_one, &ctx->buffer );
+}
+
+static void RtemsPartReqPerfGetNoBuffer_Body_Wrap( void *arg )
+{
+  RtemsPartValPerformance_Context *ctx;
+
+  ctx = arg;
+  RtemsPartReqPerfGetNoBuffer_Body( ctx );
+}
+
+/**
+ * @brief Check the status code.
+ */
+static bool RtemsPartReqPerfGetNoBuffer_Teardown(
+  RtemsPartValPerformance_Context *ctx,
+  T_ticks                         *delta,
+  uint32_t                         tic,
+  uint32_t                         toc,
+  unsigned int                     retry
+)
+{
+  T_quiet_rsc( ctx->status, RTEMS_UNSATISFIED );
+
+  return tic == toc;
+}
+
+static bool RtemsPartReqPerfGetNoBuffer_Teardown_Wrap(
+  void        *arg,
+  T_ticks     *delta,
+  uint32_t     tic,
+  uint32_t     toc,
+  unsigned int retry
+)
+{
+  RtemsPartValPerformance_Context *ctx;
+
+  ctx = arg;
+  return RtemsPartReqPerfGetNoBuffer_Teardown( ctx, delta, tic, toc, retry );
+}
+
+/**
+ * @brief Return the buffer.
+ */
+static void RtemsPartReqPerfGetNoBuffer_Cleanup(
+  RtemsPartValPerformance_Context *ctx
+)
+{
+  rtems_status_code sc;
+
+  sc = rtems_partition_return_buffer( ctx->part_one, ctx->buffer_2 );
+  T_rsc_success( sc );
+}
+
+/**
+ * @brief Get the buffer.
+ */
+static void RtemsPartReqPerfReturnBuffer_Setup(
+  RtemsPartValPerformance_Context *ctx
+)
+{
+  rtems_status_code sc;
+
+  sc = rtems_partition_get_buffer( ctx->part_many, &ctx->buffer );
+  T_quiet_rsc_success( sc );
+}
+
+static void RtemsPartReqPerfReturnBuffer_Setup_Wrap( void *arg )
+{
+  RtemsPartValPerformance_Context *ctx;
+
+  ctx = arg;
+  RtemsPartReqPerfReturnBuffer_Setup( ctx );
+}
+
+/**
+ * @brief Return the buffer.
+ */
+static void RtemsPartReqPerfReturnBuffer_Body(
+  RtemsPartValPerformance_Context *ctx
+)
+{
+  ctx->status = rtems_partition_return_buffer( ctx->part_many, ctx->buffer );
+}
+
+static void RtemsPartReqPerfReturnBuffer_Body_Wrap( void *arg )
+{
+  RtemsPartValPerformance_Context *ctx;
+
+  ctx = arg;
+  RtemsPartReqPerfReturnBuffer_Body( ctx );
+}
+
+/**
+ * @brief Check the status code.
+ */
+static bool RtemsPartReqPerfReturnBuffer_Teardown(
+  RtemsPartValPerformance_Context *ctx,
+  T_ticks                         *delta,
+  uint32_t                         tic,
+  uint32_t                         toc,
+  unsigned int                     retry
+)
+{
+  T_quiet_rsc( ctx->status, RTEMS_SUCCESSFUL );
+
+  return tic == toc;
+}
+
+static bool RtemsPartReqPerfReturnBuffer_Teardown_Wrap(
+  void        *arg,
+  T_ticks     *delta,
+  uint32_t     tic,
+  uint32_t     toc,
+  unsigned int retry
+)
+{
+  RtemsPartValPerformance_Context *ctx;
+
+  ctx = arg;
+  return RtemsPartReqPerfReturnBuffer_Teardown( ctx, delta, tic, toc, retry );
+}
+
+/**
+ * @fn void T_case_body_RtemsPartValPerformance( void )
+ */
+T_TEST_CASE_FIXTURE(
+  RtemsPartValPerformance,
+  &RtemsPartValPerformance_Fixture
+)
+{
+  RtemsPartValPerformance_Context *ctx;
+
+  ctx = T_fixture_context();
+
+  ctx->request.name = "RtemsPartReqPerfGetBuffer";
+  ctx->request.setup = NULL;
+  ctx->request.body = RtemsPartReqPerfGetBuffer_Body_Wrap;
+  ctx->request.teardown = RtemsPartReqPerfGetBuffer_Teardown_Wrap;
+  T_measure_runtime( ctx->context, &ctx->request );
+
+  RtemsPartReqPerfGetNoBuffer_Prepare( ctx );
+  ctx->request.name = "RtemsPartReqPerfGetNoBuffer";
+  ctx->request.setup = NULL;
+  ctx->request.body = RtemsPartReqPerfGetNoBuffer_Body_Wrap;
+  ctx->request.teardown = RtemsPartReqPerfGetNoBuffer_Teardown_Wrap;
+  T_measure_runtime( ctx->context, &ctx->request );
+  RtemsPartReqPerfGetNoBuffer_Cleanup( ctx );
+
+  ctx->request.name = "RtemsPartReqPerfReturnBuffer";
+  ctx->request.setup = RtemsPartReqPerfReturnBuffer_Setup_Wrap;
+  ctx->request.body = RtemsPartReqPerfReturnBuffer_Body_Wrap;
+  ctx->request.teardown = RtemsPartReqPerfReturnBuffer_Teardown_Wrap;
+  T_measure_runtime( ctx->context, &ctx->request );
+}
+
+/** @} */
-- 
2.26.2



More information about the devel mailing list