gpu: nvgpu: cast bvec test

Add BVEC tests for following functions:
nvgpu_safe_cast_u64_to_u32, nvgpu_safe_cast_u64_to_u16,
nvgpu_safe_cast_u64_to_u8, nvgpu_safe_cast_u64_to_s64,
nvgpu_safe_cast_u64_to_s32, nvgpu_safe_cast_s64_to_u64,
nvgpu_safe_cast_s64_to_u32, nvgpu_safe_cast_s64_to_s32,
nvgpu_safe_cast_u32_to_u16, nvgpu_safe_cast_u32_to_u8,
nvgpu_safe_cast_u32_to_s32, nvgpu_safe_cast_u32_to_s8,
nvgpu_safe_cast_s32_to_u64, nvgpu_safe_cast_s32_to_u32,
nvgpu_safe_cast_s8_to_u8, nvgpu_safe_cast_bool_to_u32

JIRA NVGPU-6412

Change-Id: Ic97e45051570a7133045de6cb4345c5f935cf9f6
Signed-off-by: Sagar Kamble <skamble@nvidia.com>
Reviewed-on: https://git-master.nvidia.com/r/c/linux-nvgpu/+/2555469
(cherry picked from commit be2ba5f1a7ead4c062eab74c7587c32797a651df)
Reviewed-on: https://git-master.nvidia.com/r/c/linux-nvgpu/+/2623637
Reviewed-by: Vaibhav Kachore <vkachore@nvidia.com>
Reviewed-by: mobile promotions <svcmobile_promotions@nvidia.com>
Tested-by: mobile promotions <svcmobile_promotions@nvidia.com>
GVS: Gerrit_Virtual_Submit
This commit is contained in:
Sagar Kamble
2021-07-07 15:51:49 +05:30
committed by mobile promotions
parent a1e75fe9bc
commit 0394aef90d
3 changed files with 232 additions and 80 deletions

View File

@@ -1,5 +1,5 @@
/*
* Copyright (c) 2017-2020, NVIDIA CORPORATION. All rights reserved.
* Copyright (c) 2017-2021, 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"),
@@ -135,6 +135,11 @@ NVGPU_COV_WHITELIST_BLOCK_BEGIN(false_positive, 2, NVGPU_MISRA(Rule, 21_1), "Bug
* Maximum value for signed char.
*/
#define SCHAR_MAX (U8_MAX/2)
/**
* Minimum value for signed char.
*/
#define SCHAR_MIN (-SCHAR_MAX - 1)
#endif
NVGPU_COV_WHITELIST_BLOCK_END(NVGPU_MISRA(Rule, 21_1))

View File

@@ -390,105 +390,202 @@ int test_arithmetic(struct unit_module *m, struct gk20a *g, void *args)
return UNIT_SUCCESS;
}
/**
* unsigned to unsigned cast tests
*
* parameters:
* type1: type to cast from (u32, u64)
* type2: type to cast to (u8, u16, u32)
* type1_max: Maximum value of the type1.
* type2_max : Maximum value of the type2.
*
* Boundary values: (0, type2 max, type1 max)
*
* Valid tests: Cast result within range for each valid boundary value and
* random value.
* Invalid tests: Cast result out of range if possible for each invalid
* boundary and random value.
*/
#define GENERATE_UNSIGNED_CAST_TESTS(type1, type2, type1_max, type2_max) { \
type1 temp; \
type1 valid_##type2[] = {0, 1, (temp = rand() % type2_max) > 1 ? temp : 2, type2_max - 1, type2_max}; \
type1 invalid_##type2[] = {(type1)type2_max + 1, (type1)type2_max + 2,\
(type1)type2_max + ((temp = rand() % (type1_max - type2_max)) > 2 ? temp : 3),\
type1_max - 1, type1_max}; \
for (i = 0; i < ARRAY_SIZE(valid_##type2); i++) { \
unit_assert(nvgpu_safe_cast_##type1##_to_##type2(valid_##type2[i]) == (type2)valid_##type2[i], return UNIT_FAIL); \
} \
for (i = 0; i < ARRAY_SIZE(invalid_##type2); i++) { \
err = EXPECT_BUG((void)nvgpu_safe_cast_##type1##_to_##type2(invalid_##type2[i])); \
unit_assert(err != 0, return UNIT_FAIL); \
} \
}
/**
* unsigned to signed cast tests
*
* parameters:
* type1: type to cast from (u32, u64)
* type2: type to cast to (s8, s32, s64)
* type1_max: Maximum value of the type1.
* type2_min : Minimum value of the type2.
* type2_max : Maximum value of the type2.
*
* Boundary values: (type2 min, 0, type2 max, type1 max)
*
* Valid tests: Cast result within range for each valid boundary value and
* random value.
* Invalid tests: Cast result out of range if possible for each invalid
* boundary and random value.
*/
#define GENERATE_SIGNED_CAST_TESTS(type1, type2, type1_max, type2_min, type2_max) { \
type2 temp; \
type1 valid_##type2[] = {0, 1, (temp = rand() % type2_max) > 1 ? temp : 2, type2_max - 1, type2_max}; \
type1 invalid_##type2[] = {(type1)type2_min, (type1)type2_min + 1, \
(type1)type2_min + ((temp = rand() % type2_min) > 1 ? temp : 2), -1, \
(type1)type2_max + 1, (type1)type2_max + 2, \
(type1)type2_max + ((temp = rand() % (type1_max - type2_max)) > 2 ? temp : 3), \
type1_max - 1, type1_max}; \
for (i = 0; i < ARRAY_SIZE(valid_##type2); i++) { \
unit_assert(nvgpu_safe_cast_##type1##_to_##type2(valid_##type2[i]) == (type2)valid_##type2[i], return UNIT_FAIL); \
} \
for (i = 0; i < ARRAY_SIZE(invalid_##type2); i++) { \
err = EXPECT_BUG((void)nvgpu_safe_cast_##type1##_to_##type2(invalid_##type2[i])); \
unit_assert(err != 0, return UNIT_FAIL); \
} \
}
/**
* signed to unsigned cast tests
*
* parameters:
* type1: type to cast to (s8, s32, s64)
* type2: type to cast from (u8, u32, u64)
* type1_min : Minimum value of the type1.
* type1_max : Maximum value of the type1.
*
* Boundary values: (type1 min, 0, type1 max)
*
* Assumption: the range of non-negative values from type1 are subset of those
* from type2.
*
* Valid tests: Cast result within range for each valid boundary value and
* random value.
* Invalid tests: Cast result out of range if possible for each invalid
* boundary and random value.
*/
#define GENERATE_SIGNED_TO_UNSIGNED_CAST_TESTS(type1, type2, type1_min, type1_max) { \
type1 temp;\
type1 valid_##type2[] = {0, 1, (temp = rand() % type1_max) > 1 ? temp : 2, type1_max - 1, type1_max}; \
type1 invalid_##type2[] = {type1_min, type1_min + 1, type1_min + ((temp = rand() % type1_min) > 1 ? temp : 2), -1}; \
for (i = 0; i < ARRAY_SIZE(valid_##type2); i++) { \
unit_assert(nvgpu_safe_cast_##type1##_to_##type2(valid_##type2[i]) == (type2)valid_##type2[i], return UNIT_FAIL); \
} \
for (i = 0; i < ARRAY_SIZE(invalid_##type2); i++) { \
err = EXPECT_BUG((void)nvgpu_safe_cast_##type1##_to_##type2(invalid_##type2[i])); \
unit_assert(err != 0, return UNIT_FAIL); \
} \
}
int test_cast(struct unit_module *m, struct gk20a *g, void *args)
{
s64 random_s64;
/**
* s64 to u32 cast tests
*
* Boundary values: (LONG_MIN, 0, U32_MAX, LONG_MAX)
*
* Valid tests: Cast result within range for each valid boundary value and
* random value.
* Invalid tests: Cast result out of range if possible for each invalid
* boundary and random value.
*/
s64 valid_s64_u32[] = {0, 1, (random_s64 = rand() % U32_MAX) > 1 ? random_s64 : 2, U32_MAX - 1, U32_MAX};
s64 invalid_s64_u32[] = {LONG_MIN, LONG_MIN + 1,
LONG_MIN + ((random_s64 = rand() % LONG_MIN) > 1 ? random_s64 : 2), -1,
(s64)U32_MAX + 1, (s64)U32_MAX + 2,
(s64)U32_MAX + ((random_s64 = rand() % LONG_MAX) > 1 ? random_s64 : 3),
LONG_MAX - 1, LONG_MAX};
/**
* s64 to s32 cast tests
*
* Boundary values: (LONG_MIN, INT_MIN, 0, INT_MAX, LONG_MAX)
*
* Valid tests: Cast result within range for each valid boundary value and
* random value.
* Invalid tests: Cast result out of range if possible for each invalid
* boundary and random value.
*/
s64 valid_s64_s32[] = {INT_MIN, INT_MIN + 1,
INT_MIN + ((random_s64 = rand() % INT_MIN) > 1 ? random_s64 : 2), -1, 0,
1, (random_s64 = rand() % INT_MAX) > 1 ? random_s64 : 2, INT_MAX - 1, INT_MAX};
s64 invalid_s64_s32[] = {LONG_MIN, LONG_MIN + 1,
LONG_MIN + ((random_s64 = rand() % (INT_MIN - LONG_MIN)) > 1 ? random_s64 : 2),
(s64)INT_MIN - 2, (s64)INT_MIN - 1, (s64)INT_MAX + 1, (s64)INT_MAX + 2,
(s64)INT_MAX + ((random_s64 = rand() % (LONG_MAX - INT_MAX)) > 1 ? random_s64 : 3),
LONG_MAX - 1, LONG_MAX};
int err;
u32 i;
/* U64 to U32 */
unit_assert(nvgpu_safe_cast_u64_to_u32(U32_MAX) == U32_MAX,
return UNIT_FAIL);
err = EXPECT_BUG((void)nvgpu_safe_cast_u64_to_u32(U64(U32_MAX)+1));
unit_assert(err != 0, return UNIT_FAIL);
GENERATE_UNSIGNED_CAST_TESTS(u64, u32, U64_MAX, U32_MAX);
/* U64 to U16 */
unit_assert(nvgpu_safe_cast_u64_to_u16(U16_MAX) == U16_MAX,
return UNIT_FAIL);
err = EXPECT_BUG((void)nvgpu_safe_cast_u64_to_u16(U64(U16_MAX)+1));
unit_assert(err != 0, return UNIT_FAIL);
GENERATE_UNSIGNED_CAST_TESTS(u64, u16, U64_MAX, U16_MAX);
/* U64 to U8 */
unit_assert(nvgpu_safe_cast_u64_to_u8(U8_MAX) == U8_MAX,
return UNIT_FAIL);
err = EXPECT_BUG((void)nvgpu_safe_cast_u64_to_u8(U64(U8_MAX)+1));
unit_assert(err != 0, return UNIT_FAIL);
/* U64 to S64 */
unit_assert(nvgpu_safe_cast_u64_to_s64(LONG_MAX) == LONG_MAX,
return UNIT_FAIL);
err = EXPECT_BUG((void)nvgpu_safe_cast_u64_to_s64(U64(LONG_MAX)+1));
unit_assert(err != 0, return UNIT_FAIL);
/* U64 to S32 */
unit_assert(nvgpu_safe_cast_u64_to_s32(INT_MAX) == INT_MAX,
return UNIT_FAIL);
err = EXPECT_BUG((void)nvgpu_safe_cast_u64_to_s32(U64(INT_MAX)+1));
unit_assert(err != 0, return UNIT_FAIL);
/* S64 to U64 */
unit_assert(nvgpu_safe_cast_s64_to_u64(LONG_MAX) == LONG_MAX,
return UNIT_FAIL);
err = EXPECT_BUG((void)nvgpu_safe_cast_s64_to_u64(-1));
unit_assert(err != 0, return UNIT_FAIL);
/* S64 to U32 */
unit_assert(nvgpu_safe_cast_s64_to_u32(U32_MAX) == U32_MAX,
return UNIT_FAIL);
err = EXPECT_BUG((void)nvgpu_safe_cast_s64_to_u32(-1));
unit_assert(err != 0, return UNIT_FAIL);
err = EXPECT_BUG((void)nvgpu_safe_cast_s64_to_u32(U64(U32_MAX)+1));
unit_assert(err != 0, return UNIT_FAIL);
/* S64 to S32 */
unit_assert(nvgpu_safe_cast_s64_to_s32(INT_MAX) == INT_MAX,
return UNIT_FAIL);
unit_assert(nvgpu_safe_cast_s64_to_s32(INT_MIN) == INT_MIN,
return UNIT_FAIL);
err = EXPECT_BUG((void)nvgpu_safe_cast_s64_to_s32(S64(INT_MIN)-1));
unit_assert(err != 0, return UNIT_FAIL);
err = EXPECT_BUG((void)nvgpu_safe_cast_s64_to_s32(S64(INT_MAX)+1));
unit_assert(err != 0, return UNIT_FAIL);
GENERATE_UNSIGNED_CAST_TESTS(u64, u8, U64_MAX, U8_MAX);
/* U32 to U16 */
unit_assert(nvgpu_safe_cast_u32_to_u16(U16_MAX) == U16_MAX,
return UNIT_FAIL);
err = EXPECT_BUG((void)nvgpu_safe_cast_u32_to_u16(U64(U16_MAX)+1));
unit_assert(err != 0, return UNIT_FAIL);
GENERATE_UNSIGNED_CAST_TESTS(u32, u16, U32_MAX, U16_MAX);
/* U32 to U8 */
unit_assert(nvgpu_safe_cast_u32_to_u8(U8_MAX) == U8_MAX,
return UNIT_FAIL);
err = EXPECT_BUG((void)nvgpu_safe_cast_u32_to_u8(U64(U8_MAX)+1));
unit_assert(err != 0, return UNIT_FAIL);
GENERATE_UNSIGNED_CAST_TESTS(u32, u8, U32_MAX, U8_MAX);
/* U64 to S64 */
GENERATE_SIGNED_CAST_TESTS(u64, s64, U64_MAX, LONG_MIN, LONG_MAX);
/* U64 to S32 */
GENERATE_SIGNED_CAST_TESTS(u64, s32, U64_MAX, INT_MIN, INT_MAX);
/* U32 to S32 */
unit_assert(nvgpu_safe_cast_u32_to_s32(INT_MAX) == INT_MAX,
return UNIT_FAIL);
err = EXPECT_BUG((void)nvgpu_safe_cast_u32_to_s32(U32(INT_MAX)+1));
unit_assert(err != 0, return UNIT_FAIL);
GENERATE_SIGNED_CAST_TESTS(u32, s32, U32_MAX, INT_MIN, INT_MAX);
/* U32 to S8 */
unit_assert(nvgpu_safe_cast_u32_to_s8(SCHAR_MAX) == SCHAR_MAX,
return UNIT_FAIL);
err = EXPECT_BUG((void)nvgpu_safe_cast_u32_to_s8(U32(SCHAR_MAX)+1));
unit_assert(err != 0, return UNIT_FAIL);
GENERATE_SIGNED_CAST_TESTS(u32, s8, U32_MAX, SCHAR_MIN, SCHAR_MAX);
/* S64 to U64 */
GENERATE_SIGNED_TO_UNSIGNED_CAST_TESTS(s64, u64, LONG_MIN, LONG_MAX);
/* S32 to U64 */
unit_assert(nvgpu_safe_cast_s32_to_u64(INT_MAX) == INT_MAX,
return UNIT_FAIL);
err = EXPECT_BUG((void)nvgpu_safe_cast_s32_to_u64(-1));
unit_assert(err != 0, return UNIT_FAIL);
GENERATE_SIGNED_TO_UNSIGNED_CAST_TESTS(s32, u64, INT_MIN, INT_MAX);
/* S32 to U32 */
unit_assert(nvgpu_safe_cast_s32_to_u32(INT_MAX) == INT_MAX,
return UNIT_FAIL);
err = EXPECT_BUG((void)nvgpu_safe_cast_s32_to_u32(-1));
unit_assert(err != 0, return UNIT_FAIL);
GENERATE_SIGNED_TO_UNSIGNED_CAST_TESTS(s32, u32, INT_MIN, INT_MAX);
/* S8 to U8 */
unit_assert(nvgpu_safe_cast_s8_to_u8(SCHAR_MAX) == SCHAR_MAX,
return UNIT_FAIL);
err = EXPECT_BUG((void)nvgpu_safe_cast_s8_to_u8(-1));
unit_assert(err != 0, return UNIT_FAIL);
GENERATE_SIGNED_TO_UNSIGNED_CAST_TESTS(s8, u8, SCHAR_MIN, SCHAR_MAX);
/* S64 to U32 */
for (i = 0; i < ARRAY_SIZE(valid_s64_u32); i++) {
unit_assert(nvgpu_safe_cast_s64_to_u32(valid_s64_u32[i]) == (u32)valid_s64_u32[i], return UNIT_FAIL);
}
for (i = 0; i < ARRAY_SIZE(invalid_s64_u32); i++) {
err = EXPECT_BUG((void)nvgpu_safe_cast_s64_to_u32(invalid_s64_u32[i]));
unit_assert(err != 0, return UNIT_FAIL);
}
/* S64 to S32 */
for (i = 0; i < ARRAY_SIZE(valid_s64_s32); i++) {
unit_assert(nvgpu_safe_cast_s64_to_s32(valid_s64_s32[i]) == (s32)valid_s64_s32[i], return UNIT_FAIL);
}
for (i = 0; i < ARRAY_SIZE(invalid_s64_s32); i++) {
err = EXPECT_BUG((void)nvgpu_safe_cast_s64_to_s32(invalid_s64_s32[i]));
unit_assert(err != 0, return UNIT_FAIL);
}
/* bool to U32 */
unit_assert(nvgpu_safe_cast_bool_to_u32(false) == 0, return UNIT_FAIL);

View File

@@ -122,7 +122,7 @@ int test_arithmetic(struct unit_module *m, struct gk20a *g, void *args);
*
* Description: Verify functionality of static analysis safe cast APIs.
*
* Test Type: Feature, Error guessing
* Test Type: Feature, Error guessing, Boundary Value
*
* Targets: nvgpu_safe_cast_u64_to_u32, nvgpu_safe_cast_u64_to_u16,
* nvgpu_safe_cast_u64_to_u8, nvgpu_safe_cast_u64_to_s64,
@@ -135,10 +135,60 @@ int test_arithmetic(struct unit_module *m, struct gk20a *g, void *args);
*
* Input: None
*
* -# unsigned to unsigned cast tests:
* Boundary values: {0, type2 max, type1 max}
*
* Equivalence classes:
* Variable: Cast input value.
* - Valid tests: Cast result within range for each valid boundary value and
* random value [0, type2 max].
* - Invalid tests: Cast result out of range if possible for each invalid
* boundary and random value [type2 max + 1, type1 max].
*
* -# unsigned to signed cast tests:
* Boundary values: {type2 min, 0, type2 max, type1 max}
*
* Equivalence classes:
* Variable: Cast input value.
* - Valid tests: Cast result within range for each valid boundary value and
* random value. [0, type2 max]
* - Invalid tests: Cast result out of range if possible for each invalid
* boundary and random value. {[type2 min, -1], [type2 max + 1, type1 max]}
*
* -# signed to unsigned cast tests:
* Boundary values: {type1 min, 0, type1 max}
*
* Equivalence classes:
* Variable: Cast input value.
* - Valid tests: Cast result within range for each valid boundary value and
* random value. [0, type1 max]
* - Invalid tests: Cast result out of range if possible for each invalid
* boundary and random value. [type1 min, -1]
*
* -# s64 to u32 cast tests:
* Boundary values: {LONG_MIN, 0, U32_MAX, LONG_MAX}
*
* Equivalence classes:
* Variable: Cast input value.
* - Valid tests: Cast result within range for each valid boundary value and
* random value. [0, U32_MAX]
* - Invalid tests: Cast result out of range if possible for each invalid
* boundary and random value. {[LONG_MIN, -1], [U32_MAX + 1, LONG_MAX]}
*
* -# s64 to s32 cast tests:
* Boundary values: {LONG_MIN, INT_MIN, 0, INT_MAX, LONG_MAX}
*
* Equivalence classes:
* Variable: Cast input value.
* - Valid tests: Cast result within range for each valid boundary value and
* random value. [INT_MIN, INT_MAX]
* - Invalid tests: Cast result out of range if possible for each invalid
* boundary and random value. {[LONG_MIN, INT_MIN - 1], [INT_MAX + 1, LONG_MAX]}
*
* Steps:
* - Call the static analysis arithmetic APIs. Pass in valid values and verify
* - Call the static analysis cast APIs. Pass in valid values and verify
* correct return.
* - Call the static analysis arithmetic APIs. Pass in values beyond type range
* - Call the static analysis cast APIs. Pass in values beyond type range
* and use EXPECT_BUG() to verify BUG() is called.
*
* Output: Returns PASS if expected result is met, FAIL otherwise.