Files
linux-nvgpu/userspace/include/unit/unit.h
Nicolas Benech 819921c543 gpu: nvgpu: unit: init empty JAMA strings
When JAMA-related data is not being used, make sure
that the corresponding strings are still initialized
otherwise it could cause issues in QNX.

JIRA NVGPU-2937

Change-Id: I73cecf2e056820177e8973992f3b1c34f4d65d8f
Signed-off-by: Nicolas Benech <nbenech@nvidia.com>
Reviewed-on: https://git-master.nvidia.com/r/2074038
Reviewed-by: Automatic_Commit_Validation_User
GVS: Gerrit_Virtual_Submit
Reviewed-by: Alex Waterman <alexw@nvidia.com>
Reviewed-by: mobile promotions <svcmobile_promotions@nvidia.com>
Tested-by: mobile promotions <svcmobile_promotions@nvidia.com>
2019-03-18 10:04:31 -07:00

176 lines
4.4 KiB
C

/*
* Copyright (c) 2018-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.
*/
#ifndef __UNIT_UNIT_H__
#define __UNIT_UNIT_H__
#include <pthread.h>
struct gk20a;
struct unit_module;
typedef int (*module_test_fn)(struct unit_module *m,
struct gk20a *g, void *args);
#define UNIT_SUCCESS 0
#define UNIT_FAIL -1
struct unit_module_test {
/*
* Name of the test.
*/
const char *name;
/*
* Function to call to execute the test.
*/
module_test_fn fn;
/*
* A void pointer to arbitrary arguments. Lets the same unit test
* function perform multiple tests. This gets passed into the
* module_test_fn as @args.
*/
void *args;
/*
* Linkage to JAMA test specification. An example would be:
*
* .requirement = "NVGPU-RQCD-68"
* .verification_criteria = "C1"
*
* This would link to C1 verification criteria of the pd_cache
* requirement NVGPU-RQCD-68.
*
* This is an optional field for any given unit test. But a unit
* test module must satisfy the necessary VC for all requirements
* within that unit.
*/
struct {
/*
* Requirement linkage: this should point to the unique ID
* of the test specification.
*/
const char *unique_id;
/*
* The particular verification criteria that this is
* satisfying.
*/
const char *verification_criteria;
/*
* Specific requirement this test provides coverage for.
*/
const char *requirement;
} jama;
};
/*
* Interface to the unit test framework module loader. Each unit test module
* will have exactly one of these.
*/
struct unit_module {
/*
* Name of the module.
*/
const char *name;
/*
* NULL terminated list of tests within the module.
*/
struct unit_module_test *tests;
unsigned long nr_tests;
/*
* Run priority. Currently 3 defined:
*
* UNIT_PRIO_SELF_TEST
* UNIT_PRIO_POSIX_TEST
* UNIT_PRIO_NVGPU_TEST
*
* These let us run environment and POSIX API wrapper tests before the
* rest of the unit tests run.
*/
unsigned int prio;
/*
* For the core FW to use. Not for modules!!!
*/
void *lib_handle;
struct unit_fw *fw;
pthread_t thread;
};
/*
* Zero is the higest priority. Increasing the prio value decreases priority to
* run.
*/
#define UNIT_PRIO_SELF_TEST 0U
#define UNIT_PRIO_POSIX_TEST 50U
#define UNIT_PRIO_NVGPU_TEST 100U
#define UNIT_MODULE(__name, __tests, __prio) \
struct unit_module __unit_module__ = { \
.name = #__name, \
.tests = __tests, \
.nr_tests = (sizeof(__tests) / \
sizeof(struct unit_module_test)), \
.prio = __prio, \
.lib_handle = NULL, \
.fw = NULL, \
}
#define UNIT_TEST(__name, __fn, __args) \
{ \
.name = #__name, \
.fn = __fn, \
.args = __args, \
.jama.requirement = "", \
.jama.unique_id = "", \
.jama.verification_criteria = "", \
}
/*
* Use this for a unit test that satisfies or contributes to satisfying a
* verification criteria for a given requirement.
*/
#define UNIT_TEST_REQ(__req, __uid, __vc, __name, __fn, __args) \
{ \
.name = #__name, \
.fn = __fn, \
.args = __args, \
.jama.requirement = __req, \
.jama.unique_id = __uid, \
.jama.verification_criteria = __vc, \
}
#define unit_return_fail(m, msg, ...) \
do { \
unit_err(m, "%s():%d " msg, \
__func__, __LINE__, ##__VA_ARGS__); \
return UNIT_FAIL; \
} while (0)
#endif