mirror of
git://nv-tegra.nvidia.com/linux-nvgpu.git
synced 2025-12-23 09:57:08 +03:00
gpu: nvgpu: add UT for timers unit
Add unit test cases for timers unit. Jira NVGPU-2655 Change-Id: Ie3f3001dc8b89cdd13cde3d4c326f2481dabd425 Signed-off-by: ajesh <akv@nvidia.com> Reviewed-on: https://git-master.nvidia.com/r/2179108 GVS: Gerrit_Virtual_Submit Reviewed-by: Alex Waterman <alexw@nvidia.com> Reviewed-by: Vaibhav Kachore <vkachore@nvidia.com> Reviewed-by: mobile promotions <svcmobile_promotions@nvidia.com> Tested-by: mobile promotions <svcmobile_promotions@nvidia.com>
This commit is contained in:
260
userspace/units/posix/timers/posix-timers.h
Normal file
260
userspace/units/posix/timers/posix-timers.h
Normal file
@@ -0,0 +1,260 @@
|
||||
/*
|
||||
* Copyright (c) 2019, NVIDIA CORPORATION. All rights reserved.
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||
* copy of this software and associated documentation files (the "Software"),
|
||||
* to deal in the Software without restriction, including without limitation
|
||||
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||
* and/or sell copies of the Software, and to permit persons to whom the
|
||||
* Software is furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in
|
||||
* all copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||
* DEALINGS IN THE SOFTWARE.
|
||||
*/
|
||||
|
||||
/**
|
||||
* @addtogroup SWUTS-posix-timers
|
||||
* @{
|
||||
*
|
||||
* Software Unit Test Specification for posix-timers
|
||||
*/
|
||||
#ifndef __UNIT_POSIX_TIMERS_H__
|
||||
#define __UNIT_POSIX_TIMERS_H__
|
||||
|
||||
/**
|
||||
* Test specification for test_timer_init
|
||||
*
|
||||
* Description: Test the timer initialization routine.
|
||||
*
|
||||
* Test Type: Feature based.
|
||||
*
|
||||
* Inputs:
|
||||
* 1) The type of timer to be tested is passed as an argument to the test.
|
||||
* 2) Global defines for flag and duration values.
|
||||
* 3) Global nvgpu_timeout structure instance.
|
||||
*
|
||||
* Steps:
|
||||
* 1) Check for the type of timer to be tested.
|
||||
* 2) Populate the flags and duration values depending on the timer type.
|
||||
* 3) Invoke the timer init function.
|
||||
* 4) Check the return value for errors.
|
||||
* 5) Check the internal parameters in nvgpu_timeout structure to ensure
|
||||
* proper initialisation.
|
||||
*
|
||||
* Output:
|
||||
* The test returns PASS if the return value from timer init function
|
||||
* indicates success and the internal parameter values in nvgpu_timeout
|
||||
* structure is initialised as per the passed arguments.
|
||||
* Test returns FAIL if timer init function fails or if any of the
|
||||
* parameters inside the nvgpu_timeout struct is not initialised properly.
|
||||
*
|
||||
*/
|
||||
int test_timer_init(struct unit_module *m,
|
||||
struct gk20a *g, void *args);
|
||||
|
||||
/**
|
||||
* Test specification for test_timer_init_err
|
||||
*
|
||||
* Description: Test the timer initialisation routine error path.
|
||||
*
|
||||
* Test Type: Boundary Value analysis.
|
||||
*
|
||||
* Inputs:
|
||||
* 1) Global nvgpu_timeout structure instance.
|
||||
*
|
||||
* Steps:
|
||||
* 1) Invoke timer initialisation routine in loop with different value for
|
||||
* flags parameter for each invocation.
|
||||
* 2) Check for the corresponding return value. The timer initialisation
|
||||
* function should return error for invalid flag values and return success
|
||||
* for valid flag values.
|
||||
*
|
||||
* Output:
|
||||
* The test returns PASS if the initialisation routine returns an appropriate
|
||||
* return value as per the flag value passed for each invocation.
|
||||
* The test returns FAIL if the initialisation routine does not return the
|
||||
* expected value for a particular flag for any of the invocation.
|
||||
*
|
||||
*/
|
||||
int test_timer_init_err(struct unit_module *m,
|
||||
struct gk20a *g, void *args);
|
||||
|
||||
/**
|
||||
* Test specification for test_timer_counter
|
||||
*
|
||||
* Description: Test the counter based timer functionality.
|
||||
*
|
||||
* Test Type: Feature based.
|
||||
*
|
||||
* Input:
|
||||
* 1) Global nvgpu_timeout structure instance.
|
||||
* 2) Global defines for flag and duration parameters.
|
||||
*
|
||||
* Steps:
|
||||
* 1) Reset the global nvgpu_timeout structure with all 0s.
|
||||
* 2) Initialise the timeout structure.
|
||||
* 3) Check the return value for error.
|
||||
* 4) Loop and check for the timer expiry. Sleep is introduced
|
||||
* between each loop.
|
||||
* 5) Confirm the status of the timer expiry by verifying the
|
||||
* counter value.
|
||||
*
|
||||
* Output:
|
||||
* Test returns PASS if the timer expires after the programmed
|
||||
* counter value.
|
||||
* Test returns FAIL if the initialisation routine returns error or
|
||||
* timer expires before the programmed counter value is reached.
|
||||
*
|
||||
*/
|
||||
int test_timer_counter(struct unit_module *m,
|
||||
struct gk20a *g, void *args);
|
||||
|
||||
/**
|
||||
* Test specification for test_timer_duration
|
||||
*
|
||||
* Description: Test the duration based timer functionality.
|
||||
*
|
||||
* Test Type: Feature based.
|
||||
*
|
||||
* Input:
|
||||
* 1) Global nvgpu_timeout structure instance.
|
||||
* 2) Global defines for flag and duration parameters.
|
||||
*
|
||||
* Steps:
|
||||
* 1) Reset the global nvgpu_timeout structure to all 0s.
|
||||
* 2) Initialise the timeout structure.
|
||||
* 3) Check the return value for error.
|
||||
* 4) Sleep for the required duration + 500ms to ensure the timer expires.
|
||||
* 5) Check for the timer status.
|
||||
* 6) Reconfirm the timer status.
|
||||
*
|
||||
* Output:
|
||||
* Test returns PASS if the timer expires after the programmed
|
||||
* duration.
|
||||
* Test returns FAIL if the initialisation routine returns error or if
|
||||
* the timer does not expire even after the programmed duration.
|
||||
*
|
||||
*/
|
||||
int test_timer_duration(struct unit_module *m,
|
||||
struct gk20a *g, void *args);
|
||||
|
||||
/**
|
||||
* Test specification for test_timer_delay
|
||||
*
|
||||
* Description: Test the delay functionality.
|
||||
*
|
||||
* Test Type: Feature based.
|
||||
*
|
||||
* Input: None.
|
||||
*
|
||||
* Steps:
|
||||
* 1) Get the current time in us.
|
||||
* 2) Delay the execution using nvpgu_udelay function.
|
||||
* 3) Get the time after the delay function is executed.
|
||||
* 4) Calculate the difference between both timestamps.
|
||||
* 5) Convert it into msec.
|
||||
* 6) If the difference is less than the duration for which the
|
||||
* delay was requested, return fail.
|
||||
* 7) Continue steps 1-6 for the wrapper api nvgpu_usleep_range
|
||||
* which internally uses nvgpu_udelay itself.
|
||||
*
|
||||
* Output:
|
||||
* Test returns PASS if the delay function actually delays the execution
|
||||
* for required amount of time. It also returns PASS if there is a
|
||||
* reordering of instructions resulting in the test check being invalid
|
||||
* and the test is skipped by returning PASS.
|
||||
* Test returns FAIL if the delay function returns before the required
|
||||
* duration.
|
||||
*
|
||||
*/
|
||||
int test_timer_delay(struct unit_module *m,
|
||||
struct gk20a *g, void *args);
|
||||
|
||||
/**
|
||||
* Test specification for test_timer_msleep
|
||||
*
|
||||
* Description: Test the sleep functionality.
|
||||
*
|
||||
* Test Type: Feature based.
|
||||
*
|
||||
* Input: None.
|
||||
*
|
||||
* Steps:
|
||||
* 1) Get the current time in ms.
|
||||
* 2) Call sleep function for 5ms.
|
||||
* 3) Get the time after the sleep call.
|
||||
* 4) Calculate the difference between both the timestamps.
|
||||
* 5) Compare the difference to deduce the test result.
|
||||
*
|
||||
* Output:
|
||||
* Test returns PASS if the sleep function is completed for required duration.
|
||||
* Test returns FAIL if the sleep function returns before the requested
|
||||
* duration.
|
||||
*
|
||||
*/
|
||||
int test_timer_msleep(struct unit_module *m,
|
||||
struct gk20a *g, void *args);
|
||||
|
||||
/**
|
||||
* Test specification for test_timer_hrtimestamp
|
||||
*
|
||||
* Description: Test the high resolution counter based functionalities.
|
||||
*
|
||||
* Test Type: Feature based.
|
||||
*
|
||||
* Input: None.
|
||||
*
|
||||
* Steps:
|
||||
* 1) Initialise two counter variables to 0.
|
||||
* 2) Read the value of HR counter into one of the counter variables.
|
||||
* 3) Compare the value of read counter value with the bkp counter value.
|
||||
* 4) If read counter variable is less than the previously read counter value
|
||||
* return fail.
|
||||
* 5) Store the read counter value in bkp counter value.
|
||||
* 6) Suspend execution by calling usleep.
|
||||
* 7) Loop steps 1 - 6 for multiple times.
|
||||
*
|
||||
* Output:
|
||||
* Test returns PASS if for every read of HR counter, the value returned is
|
||||
* either greater than or equal to the previous value.
|
||||
* Test returns FAIL if any of the subsequent read of HR counter returns
|
||||
* a value less than the previous value.
|
||||
*
|
||||
*/
|
||||
int test_timer_hrtimestamp(struct unit_module *m,
|
||||
struct gk20a *g, void *args);
|
||||
|
||||
/**
|
||||
* Test specification for test_timer_compare
|
||||
*
|
||||
* Description: Compare the timers in various resoutions.
|
||||
*
|
||||
* Test Type: Feature based.
|
||||
*
|
||||
* Input: None.
|
||||
*
|
||||
* Steps:
|
||||
* 1) Initialise two timestamp variables.
|
||||
* 2) Read the time in ms and store in one timestamp variable.
|
||||
* 3) Read the time in ns and store in the second timestamp variable.
|
||||
* 4) Do the necessary conversion to make both timers in same resolution.
|
||||
* 5) Compare the timer values to determine the test results.
|
||||
*
|
||||
* Output:
|
||||
* Test returns PASS if various timer resolutions match each other.
|
||||
* Test returns FAIL if various timer resolutions does not match with
|
||||
* each other.
|
||||
*
|
||||
*/
|
||||
int test_timer_compare(struct unit_module *m,
|
||||
struct gk20a *g, void *args);
|
||||
|
||||
#endif /* __UNIT_POSIX_TIMERS_H__ */
|
||||
Reference in New Issue
Block a user