mirror of
https://gitlab.rtems.org/rtems/rtos/rtems.git
synced 2025-12-05 15:15:44 +00:00
364 lines
9.8 KiB
C
364 lines
9.8 KiB
C
/* SPDX-License-Identifier: BSD-2-Clause */
|
|
|
|
/**
|
|
* @file
|
|
*
|
|
* @ingroup RtemsModeValModes
|
|
*/
|
|
|
|
/*
|
|
* Copyright (C) 2020 embedded brains GmbH & Co. KG
|
|
*
|
|
* 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://www.rtems.org/bugs.html
|
|
*
|
|
* For information on updating and regenerating please refer to the How-To
|
|
* section in the Software Requirements Engineering chapter of the
|
|
* RTEMS Software Engineering manual. The manual is provided as a part of
|
|
* a release. For development sources please refer to the online
|
|
* documentation at:
|
|
*
|
|
* https://docs.rtems.org
|
|
*/
|
|
|
|
#ifdef HAVE_CONFIG_H
|
|
#include "config.h"
|
|
#endif
|
|
|
|
#include <rtems.h>
|
|
|
|
#include <rtems/test.h>
|
|
|
|
/**
|
|
* @defgroup RtemsModeValModes spec:/rtems/mode/val/modes
|
|
*
|
|
* @ingroup TestsuitesValidationNoClock0
|
|
*
|
|
* @brief Tests the task mode constants and function-like macros of the Classic
|
|
* API.
|
|
*
|
|
* This test case performs the following actions:
|
|
*
|
|
* - Validate the non-default task mode constants.
|
|
*
|
|
* - Check that RTEMS_NO_ASR is a power of two representable as an integer of
|
|
* type rtems_mode.
|
|
*
|
|
* - Check that RTEMS_NO_PREEMPT is a power of two representable as an
|
|
* integer of type rtems_mode.
|
|
*
|
|
* - Check that RTEMS_TIMESLICE is a power of two representable as an integer
|
|
* of type rtems_mode.
|
|
*
|
|
* - Validate the default task mode constants.
|
|
*
|
|
* - Check that RTEMS_ASR is equal to zero.
|
|
*
|
|
* - Check that RTEMS_DEFAULT_MODES is equal to zero.
|
|
*
|
|
* - Check that RTEMS_NO_TIMESLICE is equal to zero.
|
|
*
|
|
* - Check that RTEMS_PREEMPT is equal to zero.
|
|
*
|
|
* - Validate RTEMS_ALL_MODE_MASKS.
|
|
*
|
|
* - Check that the bitwise and of RTEMS_ASR_MASK and RTEMS_ALL_MODE_MASKS is
|
|
* equal to RTEMS_ASR_MASK.
|
|
*
|
|
* - Check that the bitwise and of RTEMS_PREEMPT_MASK and
|
|
* RTEMS_ALL_MODE_MASKS is equal to RTEMS_PREEMPT_MASK.
|
|
*
|
|
* - Check that the bitwise and of RTEMS_TIMESLICE_MASK and
|
|
* RTEMS_ALL_MODE_MASKS is equal to RTEMS_TIMESLICE_MASK.
|
|
*
|
|
* - Check that the bitwise and of RTEMS_INTERRUPT_MASK and
|
|
* RTEMS_ALL_MODE_MASKS is equal to RTEMS_INTERRUPT_MASK.
|
|
*
|
|
* - Validate the task mode mask constants except RTEMS_INTERRUPT_MASK.
|
|
*
|
|
* - Check that RTEMS_ASR_MASK is a power of two representable as an integer
|
|
* of type rtems_mode.
|
|
*
|
|
* - Check that RTEMS_PREEMPT_MASK is a power of two representable as an
|
|
* integer of type rtems_mode.
|
|
*
|
|
* - Check that RTEMS_TIMESLICE_MASK is a power of two representable as an
|
|
* integer of type rtems_mode.
|
|
*
|
|
* - Calculate the bitwise or of all task mode mask constants and 0xff.
|
|
*
|
|
* - Check that the count of set bits in the calculated value is equal to the
|
|
* count of task mode mask constants except RTEMS_INTERRUPT_MASK plus
|
|
* eight. Since each task mode mask constants except RTEMS_INTERRUPT_MASK
|
|
* is a power of two and the bitwise and of 0xff and RTEMS_INTERRUPT_MASK
|
|
* is equal to RTEMS_INTERRUPT_MASK this proves that each constant and 0xff
|
|
* has a unique value.
|
|
*
|
|
* - Calculate the bitwise or of all non-default task mode constants.
|
|
*
|
|
* - Check that the count of set bits in the calculated value is equal to the
|
|
* count of non-default task mode constants. Since each non-default task
|
|
* mode constants except is a power of this proves that each constant has a
|
|
* unique value.
|
|
*
|
|
* - Validate RTEMS_INTERRUPT_LEVEL().
|
|
*
|
|
* - Check the result of RTEMS_INTERRUPT_LEVEL() for a sample value.
|
|
*
|
|
* @{
|
|
*/
|
|
|
|
static bool IsPowerOfTwo( rtems_mode mode )
|
|
{
|
|
return mode != 0 && ( mode & ( mode - 1 ) ) == 0;
|
|
}
|
|
|
|
static int PopCount( rtems_mode modes )
|
|
{
|
|
int count;
|
|
|
|
count = 0;
|
|
|
|
while ( modes != 0 ) {
|
|
++count;
|
|
modes &= modes - 1;
|
|
}
|
|
|
|
return count;
|
|
}
|
|
|
|
/**
|
|
* @brief Validate the non-default task mode constants.
|
|
*/
|
|
static void RtemsModeValModes_Action_0( void )
|
|
{
|
|
/* No action */
|
|
|
|
/*
|
|
* Check that RTEMS_NO_ASR is a power of two representable as an integer of
|
|
* type rtems_mode.
|
|
*/
|
|
T_step_true( 0, IsPowerOfTwo( RTEMS_NO_ASR ) );
|
|
|
|
/*
|
|
* Check that RTEMS_NO_PREEMPT is a power of two representable as an integer
|
|
* of type rtems_mode.
|
|
*/
|
|
T_step_true( 1, IsPowerOfTwo( RTEMS_NO_PREEMPT ) );
|
|
|
|
/*
|
|
* Check that RTEMS_TIMESLICE is a power of two representable as an integer
|
|
* of type rtems_mode.
|
|
*/
|
|
T_step_true( 2, IsPowerOfTwo( RTEMS_TIMESLICE ) );
|
|
}
|
|
|
|
/**
|
|
* @brief Validate the default task mode constants.
|
|
*/
|
|
static void RtemsModeValModes_Action_1( void )
|
|
{
|
|
/* No action */
|
|
|
|
/*
|
|
* Check that RTEMS_ASR is equal to zero.
|
|
*/
|
|
T_step_eq_u32( 3, RTEMS_ASR, 0 );
|
|
|
|
/*
|
|
* Check that RTEMS_DEFAULT_MODES is equal to zero.
|
|
*/
|
|
T_step_eq_u32( 4, RTEMS_DEFAULT_MODES, 0 );
|
|
|
|
/*
|
|
* Check that RTEMS_NO_TIMESLICE is equal to zero.
|
|
*/
|
|
T_step_eq_u32( 5, RTEMS_NO_TIMESLICE, 0 );
|
|
|
|
/*
|
|
* Check that RTEMS_PREEMPT is equal to zero.
|
|
*/
|
|
T_step_eq_u32( 6, RTEMS_PREEMPT, 0 );
|
|
}
|
|
|
|
/**
|
|
* @brief Validate RTEMS_ALL_MODE_MASKS.
|
|
*/
|
|
static void RtemsModeValModes_Action_2( void )
|
|
{
|
|
/* No action */
|
|
|
|
/*
|
|
* Check that the bitwise and of RTEMS_ASR_MASK and RTEMS_ALL_MODE_MASKS is
|
|
* equal to RTEMS_ASR_MASK.
|
|
*/
|
|
T_step_eq_u32(
|
|
7,
|
|
RTEMS_ASR_MASK & RTEMS_ALL_MODE_MASKS,
|
|
RTEMS_ASR_MASK
|
|
);
|
|
|
|
/*
|
|
* Check that the bitwise and of RTEMS_PREEMPT_MASK and RTEMS_ALL_MODE_MASKS
|
|
* is equal to RTEMS_PREEMPT_MASK.
|
|
*/
|
|
T_step_eq_u32(
|
|
8,
|
|
RTEMS_PREEMPT_MASK & RTEMS_ALL_MODE_MASKS,
|
|
RTEMS_PREEMPT_MASK
|
|
);
|
|
|
|
/*
|
|
* Check that the bitwise and of RTEMS_TIMESLICE_MASK and
|
|
* RTEMS_ALL_MODE_MASKS is equal to RTEMS_TIMESLICE_MASK.
|
|
*/
|
|
T_step_eq_u32(
|
|
9,
|
|
RTEMS_TIMESLICE_MASK & RTEMS_ALL_MODE_MASKS,
|
|
RTEMS_TIMESLICE_MASK
|
|
);
|
|
|
|
/*
|
|
* Check that the bitwise and of RTEMS_INTERRUPT_MASK and
|
|
* RTEMS_ALL_MODE_MASKS is equal to RTEMS_INTERRUPT_MASK.
|
|
*/
|
|
T_step_eq_u32(
|
|
10,
|
|
RTEMS_INTERRUPT_MASK & RTEMS_ALL_MODE_MASKS,
|
|
RTEMS_INTERRUPT_MASK
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @brief Validate the task mode mask constants except RTEMS_INTERRUPT_MASK.
|
|
*/
|
|
static void RtemsModeValModes_Action_3( void )
|
|
{
|
|
/* No action */
|
|
|
|
/*
|
|
* Check that RTEMS_ASR_MASK is a power of two representable as an integer of
|
|
* type rtems_mode.
|
|
*/
|
|
T_step_true( 11, IsPowerOfTwo( RTEMS_ASR_MASK ) );
|
|
|
|
/*
|
|
* Check that RTEMS_PREEMPT_MASK is a power of two representable as an
|
|
* integer of type rtems_mode.
|
|
*/
|
|
T_step_true( 12, IsPowerOfTwo( RTEMS_PREEMPT_MASK ) );
|
|
|
|
/*
|
|
* Check that RTEMS_TIMESLICE_MASK is a power of two representable as an
|
|
* integer of type rtems_mode.
|
|
*/
|
|
T_step_true( 13, IsPowerOfTwo( RTEMS_TIMESLICE_MASK ) );
|
|
}
|
|
|
|
/**
|
|
* @brief Calculate the bitwise or of all task mode mask constants and 0xff.
|
|
*/
|
|
static void RtemsModeValModes_Action_4( void )
|
|
{
|
|
rtems_mode modes;
|
|
|
|
modes = 0;
|
|
modes |= 0xff;
|
|
modes |= RTEMS_ASR_MASK;
|
|
modes |= RTEMS_PREEMPT_MASK;
|
|
modes |= RTEMS_TIMESLICE_MASK;
|
|
|
|
/*
|
|
* Check that the count of set bits in the calculated value is equal to the
|
|
* count of task mode mask constants except RTEMS_INTERRUPT_MASK plus eight.
|
|
* Since each task mode mask constants except RTEMS_INTERRUPT_MASK is a power
|
|
* of two and the bitwise and of 0xff and RTEMS_INTERRUPT_MASK is equal to
|
|
* RTEMS_INTERRUPT_MASK this proves that each constant and 0xff has a unique
|
|
* value.
|
|
*/
|
|
T_step_eq_int( 14, PopCount( modes ), 11 );
|
|
}
|
|
|
|
/**
|
|
* @brief Calculate the bitwise or of all non-default task mode constants.
|
|
*/
|
|
static void RtemsModeValModes_Action_5( void )
|
|
{
|
|
rtems_mode modes;
|
|
|
|
modes = 0;
|
|
modes |= RTEMS_NO_ASR;
|
|
modes |= RTEMS_NO_PREEMPT;
|
|
modes |= RTEMS_TIMESLICE;
|
|
|
|
/*
|
|
* Check that the count of set bits in the calculated value is equal to the
|
|
* count of non-default task mode constants. Since each non-default task
|
|
* mode constants except is a power of this proves that each constant has a
|
|
* unique value.
|
|
*/
|
|
T_step_eq_int( 15, PopCount( modes ), 3 );
|
|
}
|
|
|
|
/**
|
|
* @brief Validate RTEMS_INTERRUPT_LEVEL().
|
|
*/
|
|
static void RtemsModeValModes_Action_6( void )
|
|
{
|
|
/* Nothing to do */
|
|
|
|
/*
|
|
* Check the result of RTEMS_INTERRUPT_LEVEL() for a sample value.
|
|
*/
|
|
T_step_eq_u32(
|
|
16,
|
|
RTEMS_INTERRUPT_LEVEL( UINT32_MAX ),
|
|
RTEMS_INTERRUPT_MASK
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @fn void T_case_body_RtemsModeValModes( void )
|
|
*/
|
|
T_TEST_CASE( RtemsModeValModes )
|
|
{
|
|
T_plan( 17 );
|
|
|
|
RtemsModeValModes_Action_0();
|
|
RtemsModeValModes_Action_1();
|
|
RtemsModeValModes_Action_2();
|
|
RtemsModeValModes_Action_3();
|
|
RtemsModeValModes_Action_4();
|
|
RtemsModeValModes_Action_5();
|
|
RtemsModeValModes_Action_6();
|
|
}
|
|
|
|
/** @} */
|