2019-06-25 11:12:58 +00:00
|
|
|
/* SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
* Copyright(c) 2010-2014 Intel Corporation
|
2018-05-15 09:49:22 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
|
|
|
|
#include "test.h"
|
|
|
|
|
|
|
|
#include <rte_cycles.h>
|
|
|
|
#include <rte_meter.h>
|
|
|
|
|
|
|
|
#define mlog(format, ...) do{\
|
|
|
|
printf("Line %d:",__LINE__);\
|
|
|
|
printf(format, ##__VA_ARGS__);\
|
|
|
|
printf("\n");\
|
|
|
|
}while(0);
|
|
|
|
|
|
|
|
#define melog(format, ...) do{\
|
|
|
|
printf("Line %d:",__LINE__);\
|
|
|
|
printf(format, ##__VA_ARGS__);\
|
|
|
|
printf(" failed!\n");\
|
|
|
|
return -1;\
|
|
|
|
}while(0);
|
|
|
|
|
|
|
|
#define TM_TEST_SRTCM_CIR_DF 46000000
|
|
|
|
#define TM_TEST_SRTCM_CBS_DF 2048
|
|
|
|
#define TM_TEST_SRTCM_EBS_DF 4096
|
|
|
|
|
|
|
|
#define TM_TEST_TRTCM_CIR_DF 46000000
|
|
|
|
#define TM_TEST_TRTCM_PIR_DF 69000000
|
2020-06-18 16:55:50 +00:00
|
|
|
#define TM_TEST_TRTCM_EIR_DF 69000000
|
2018-05-15 09:49:22 +00:00
|
|
|
#define TM_TEST_TRTCM_CBS_DF 2048
|
|
|
|
#define TM_TEST_TRTCM_PBS_DF 4096
|
2020-06-18 16:55:50 +00:00
|
|
|
#define TM_TEST_TRTCM_EBS_DF 4096
|
2018-05-15 09:49:22 +00:00
|
|
|
|
|
|
|
static struct rte_meter_srtcm_params sparams =
|
|
|
|
{.cir = TM_TEST_SRTCM_CIR_DF,
|
|
|
|
.cbs = TM_TEST_SRTCM_CBS_DF,
|
|
|
|
.ebs = TM_TEST_SRTCM_EBS_DF,};
|
|
|
|
|
|
|
|
static struct rte_meter_trtcm_params tparams=
|
|
|
|
{.cir = TM_TEST_TRTCM_CIR_DF,
|
|
|
|
.pir = TM_TEST_TRTCM_PIR_DF,
|
|
|
|
.cbs = TM_TEST_TRTCM_CBS_DF,
|
|
|
|
.pbs = TM_TEST_TRTCM_PBS_DF,};
|
|
|
|
|
2020-06-18 16:55:50 +00:00
|
|
|
static struct rte_meter_trtcm_rfc4115_params rfc4115params =
|
|
|
|
{.cir = TM_TEST_TRTCM_CIR_DF,
|
|
|
|
.eir = TM_TEST_TRTCM_EIR_DF,
|
|
|
|
.cbs = TM_TEST_TRTCM_CBS_DF,
|
|
|
|
.ebs = TM_TEST_TRTCM_EBS_DF,};
|
|
|
|
|
2018-05-15 09:49:22 +00:00
|
|
|
/**
|
|
|
|
* functional test for rte_meter_srtcm_config
|
|
|
|
*/
|
|
|
|
static inline int
|
|
|
|
tm_test_srtcm_config(void)
|
|
|
|
{
|
|
|
|
#define SRTCM_CFG_MSG "srtcm_config"
|
2019-06-25 11:12:58 +00:00
|
|
|
struct rte_meter_srtcm_profile sp;
|
2018-05-15 09:49:22 +00:00
|
|
|
struct rte_meter_srtcm_params sparams1;
|
|
|
|
|
|
|
|
/* invalid parameter test */
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_srtcm_profile_config(NULL, NULL) == 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(SRTCM_CFG_MSG);
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_srtcm_profile_config(&sp, NULL) == 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(SRTCM_CFG_MSG);
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_srtcm_profile_config(NULL, &sparams) == 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(SRTCM_CFG_MSG);
|
|
|
|
|
|
|
|
/* cbs and ebs can't both be zero */
|
|
|
|
sparams1 = sparams;
|
|
|
|
sparams1.cbs = 0;
|
|
|
|
sparams1.ebs = 0;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_srtcm_profile_config(&sp, &sparams1) == 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(SRTCM_CFG_MSG);
|
|
|
|
|
|
|
|
/* cir should never be 0 */
|
|
|
|
sparams1 = sparams;
|
|
|
|
sparams1.cir = 0;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_srtcm_profile_config(&sp, &sparams1) == 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(SRTCM_CFG_MSG);
|
|
|
|
|
|
|
|
/* one of ebs and cbs can be zero, should be successful */
|
|
|
|
sparams1 = sparams;
|
|
|
|
sparams1.ebs = 0;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_srtcm_profile_config(&sp, &sparams1) != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(SRTCM_CFG_MSG);
|
|
|
|
|
|
|
|
sparams1 = sparams;
|
|
|
|
sparams1.cbs = 0;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_srtcm_profile_config(&sp, &sparams1) != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(SRTCM_CFG_MSG);
|
|
|
|
|
|
|
|
/* usual parameter, should be successful */
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_srtcm_profile_config(&sp, &sparams) != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(SRTCM_CFG_MSG);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* functional test for rte_meter_trtcm_config
|
|
|
|
*/
|
|
|
|
static inline int
|
|
|
|
tm_test_trtcm_config(void)
|
|
|
|
{
|
2019-06-25 11:12:58 +00:00
|
|
|
struct rte_meter_trtcm_profile tp;
|
2018-05-15 09:49:22 +00:00
|
|
|
struct rte_meter_trtcm_params tparams1;
|
|
|
|
#define TRTCM_CFG_MSG "trtcm_config"
|
|
|
|
|
|
|
|
/* invalid parameter test */
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_trtcm_profile_config(NULL, NULL) == 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(TRTCM_CFG_MSG);
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_trtcm_profile_config(&tp, NULL) == 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(TRTCM_CFG_MSG);
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_trtcm_profile_config(NULL, &tparams) == 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(TRTCM_CFG_MSG);
|
|
|
|
|
|
|
|
/* cir, cbs, pir and pbs never be zero */
|
|
|
|
tparams1 = tparams;
|
|
|
|
tparams1.cir = 0;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_trtcm_profile_config(&tp, &tparams1) == 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(TRTCM_CFG_MSG);
|
|
|
|
|
|
|
|
tparams1 = tparams;
|
|
|
|
tparams1.cbs = 0;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_trtcm_profile_config(&tp, &tparams1) == 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(TRTCM_CFG_MSG);
|
|
|
|
|
|
|
|
tparams1 = tparams;
|
|
|
|
tparams1.pbs = 0;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_trtcm_profile_config(&tp, &tparams1) == 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(TRTCM_CFG_MSG);
|
|
|
|
|
|
|
|
tparams1 = tparams;
|
|
|
|
tparams1.pir = 0;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_trtcm_profile_config(&tp, &tparams1) == 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(TRTCM_CFG_MSG);
|
|
|
|
|
|
|
|
/* pir should be greater or equal to cir */
|
|
|
|
tparams1 = tparams;
|
|
|
|
tparams1.pir = tparams1.cir - 1;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_trtcm_profile_config(&tp, &tparams1) == 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(TRTCM_CFG_MSG" pir < cir test");
|
|
|
|
|
|
|
|
/* usual parameter, should be successful */
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_trtcm_profile_config(&tp, &tparams) != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(TRTCM_CFG_MSG);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2020-06-18 16:55:50 +00:00
|
|
|
/**
|
|
|
|
* functional test for rte_meter_trtcm_rfc4115_config
|
|
|
|
*/
|
|
|
|
static inline int
|
|
|
|
tm_test_trtcm_rfc4115_config(void)
|
|
|
|
{
|
|
|
|
struct rte_meter_trtcm_rfc4115_profile tp;
|
|
|
|
struct rte_meter_trtcm_rfc4115_params rfc4115params1;
|
|
|
|
#define TRTCM_RFC4115_CFG_MSG "trtcm_rfc4115_config"
|
|
|
|
|
|
|
|
/* invalid parameter test */
|
|
|
|
if (rte_meter_trtcm_rfc4115_profile_config(NULL, NULL) == 0)
|
|
|
|
melog(TRTCM_RFC4115_CFG_MSG);
|
|
|
|
if (rte_meter_trtcm_rfc4115_profile_config(&tp, NULL) == 0)
|
|
|
|
melog(TRTCM_RFC4115_CFG_MSG);
|
|
|
|
if (rte_meter_trtcm_rfc4115_profile_config(NULL, &rfc4115params) == 0)
|
|
|
|
melog(TRTCM_RFC4115_CFG_MSG);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* cbs and pbs should be none-zero if cir and eir are none-zero
|
|
|
|
* respectively
|
|
|
|
*/
|
|
|
|
rfc4115params1 = rfc4115params;
|
|
|
|
rfc4115params1.cbs = 0;
|
|
|
|
if (rte_meter_trtcm_rfc4115_profile_config(&tp, &rfc4115params1) == 0)
|
|
|
|
melog(TRTCM_RFC4115_CFG_MSG);
|
|
|
|
|
|
|
|
rfc4115params1 = rfc4115params;
|
|
|
|
rfc4115params1.ebs = 0;
|
|
|
|
if (rte_meter_trtcm_rfc4115_profile_config(&tp, &rfc4115params1) == 0)
|
|
|
|
melog(TRTCM_RFC4115_CFG_MSG);
|
|
|
|
|
|
|
|
/* usual parameter, should be successful */
|
|
|
|
if (rte_meter_trtcm_rfc4115_profile_config(&tp, &rfc4115params) != 0)
|
|
|
|
melog(TRTCM_RFC4115_CFG_MSG);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2018-05-15 09:49:22 +00:00
|
|
|
/**
|
|
|
|
* functional test for rte_meter_srtcm_color_blind_check
|
|
|
|
*/
|
|
|
|
static inline int
|
|
|
|
tm_test_srtcm_color_blind_check(void)
|
|
|
|
{
|
|
|
|
#define SRTCM_BLIND_CHECK_MSG "srtcm_blind_check"
|
2019-06-25 11:12:58 +00:00
|
|
|
struct rte_meter_srtcm_profile sp;
|
2018-05-15 09:49:22 +00:00
|
|
|
struct rte_meter_srtcm sm;
|
|
|
|
uint64_t time;
|
|
|
|
uint64_t hz = rte_get_tsc_hz();
|
|
|
|
|
|
|
|
/* Test green */
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_srtcm_profile_config(&sp, &sparams) != 0)
|
|
|
|
melog(SRTCM_BLIND_CHECK_MSG);
|
|
|
|
if (rte_meter_srtcm_config(&sm, &sp) != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(SRTCM_BLIND_CHECK_MSG);
|
|
|
|
time = rte_get_tsc_cycles() + hz;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_srtcm_color_blind_check(
|
|
|
|
&sm, &sp, time, TM_TEST_SRTCM_CBS_DF - 1)
|
2020-06-18 16:55:50 +00:00
|
|
|
!= RTE_COLOR_GREEN)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(SRTCM_BLIND_CHECK_MSG" GREEN");
|
|
|
|
|
|
|
|
/* Test yellow */
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_srtcm_profile_config(&sp, &sparams) != 0)
|
|
|
|
melog(SRTCM_BLIND_CHECK_MSG);
|
|
|
|
if (rte_meter_srtcm_config(&sm, &sp) != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(SRTCM_BLIND_CHECK_MSG);
|
|
|
|
time = rte_get_tsc_cycles() + hz;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_srtcm_color_blind_check(
|
|
|
|
&sm, &sp, time, TM_TEST_SRTCM_CBS_DF + 1)
|
2020-06-18 16:55:50 +00:00
|
|
|
!= RTE_COLOR_YELLOW)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(SRTCM_BLIND_CHECK_MSG" YELLOW");
|
|
|
|
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_srtcm_profile_config(&sp, &sparams) != 0)
|
|
|
|
melog(SRTCM_BLIND_CHECK_MSG);
|
|
|
|
if (rte_meter_srtcm_config(&sm, &sp) != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(SRTCM_BLIND_CHECK_MSG);
|
|
|
|
time = rte_get_tsc_cycles() + hz;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_srtcm_color_blind_check(
|
2020-06-18 16:55:50 +00:00
|
|
|
&sm, &sp, time, (uint32_t)sp.ebs - 1) != RTE_COLOR_YELLOW)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(SRTCM_BLIND_CHECK_MSG" YELLOW");
|
|
|
|
|
|
|
|
/* Test red */
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_srtcm_profile_config(&sp, &sparams) != 0)
|
|
|
|
melog(SRTCM_BLIND_CHECK_MSG);
|
|
|
|
if (rte_meter_srtcm_config(&sm, &sp) != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(SRTCM_BLIND_CHECK_MSG);
|
|
|
|
time = rte_get_tsc_cycles() + hz;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_srtcm_color_blind_check(
|
|
|
|
&sm, &sp, time, TM_TEST_SRTCM_EBS_DF + 1)
|
2020-06-18 16:55:50 +00:00
|
|
|
!= RTE_COLOR_RED)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(SRTCM_BLIND_CHECK_MSG" RED");
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* functional test for rte_meter_trtcm_color_blind_check
|
|
|
|
*/
|
|
|
|
static inline int
|
|
|
|
tm_test_trtcm_color_blind_check(void)
|
|
|
|
{
|
|
|
|
#define TRTCM_BLIND_CHECK_MSG "trtcm_blind_check"
|
|
|
|
|
|
|
|
uint64_t time;
|
2019-06-25 11:12:58 +00:00
|
|
|
struct rte_meter_trtcm_profile tp;
|
2018-05-15 09:49:22 +00:00
|
|
|
struct rte_meter_trtcm tm;
|
|
|
|
uint64_t hz = rte_get_tsc_hz();
|
|
|
|
|
|
|
|
/* Test green */
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_trtcm_profile_config(&tp, &tparams) != 0)
|
|
|
|
melog(TRTCM_BLIND_CHECK_MSG);
|
|
|
|
if (rte_meter_trtcm_config(&tm, &tp) != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(TRTCM_BLIND_CHECK_MSG);
|
|
|
|
time = rte_get_tsc_cycles() + hz;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_trtcm_color_blind_check(
|
|
|
|
&tm, &tp, time, TM_TEST_TRTCM_CBS_DF - 1)
|
2020-06-18 16:55:50 +00:00
|
|
|
!= RTE_COLOR_GREEN)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(TRTCM_BLIND_CHECK_MSG" GREEN");
|
|
|
|
|
|
|
|
/* Test yellow */
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_trtcm_profile_config(&tp, &tparams) != 0)
|
|
|
|
melog(TRTCM_BLIND_CHECK_MSG);
|
|
|
|
if (rte_meter_trtcm_config(&tm, &tp) != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(TRTCM_BLIND_CHECK_MSG);
|
|
|
|
time = rte_get_tsc_cycles() + hz;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_trtcm_color_blind_check(
|
|
|
|
&tm, &tp, time, TM_TEST_TRTCM_CBS_DF + 1)
|
2020-06-18 16:55:50 +00:00
|
|
|
!= RTE_COLOR_YELLOW)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(TRTCM_BLIND_CHECK_MSG" YELLOW");
|
|
|
|
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_trtcm_profile_config(&tp, &tparams) != 0)
|
|
|
|
melog(TRTCM_BLIND_CHECK_MSG);
|
|
|
|
if (rte_meter_trtcm_config(&tm, &tp) != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(TRTCM_BLIND_CHECK_MSG);
|
|
|
|
time = rte_get_tsc_cycles() + hz;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_trtcm_color_blind_check(
|
|
|
|
&tm, &tp, time, TM_TEST_TRTCM_PBS_DF - 1)
|
2020-06-18 16:55:50 +00:00
|
|
|
!= RTE_COLOR_YELLOW)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(TRTCM_BLIND_CHECK_MSG" YELLOW");
|
|
|
|
|
|
|
|
/* Test red */
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_trtcm_profile_config(&tp, &tparams) != 0)
|
|
|
|
melog(TRTCM_BLIND_CHECK_MSG);
|
|
|
|
if (rte_meter_trtcm_config(&tm, &tp) != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(TRTCM_BLIND_CHECK_MSG);
|
|
|
|
time = rte_get_tsc_cycles() + hz;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_trtcm_color_blind_check(
|
|
|
|
&tm, &tp, time, TM_TEST_TRTCM_PBS_DF + 1)
|
2020-06-18 16:55:50 +00:00
|
|
|
!= RTE_COLOR_RED)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(TRTCM_BLIND_CHECK_MSG" RED");
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2020-06-18 16:55:50 +00:00
|
|
|
/**
|
|
|
|
* functional test for rte_meter_trtcm_rfc4115_color_blind_check
|
|
|
|
*/
|
|
|
|
static inline int
|
|
|
|
tm_test_trtcm_rfc4115_color_blind_check(void)
|
|
|
|
{
|
|
|
|
#define TRTCM_RFC4115_BLIND_CHECK_MSG "trtcm_rfc4115_blind_check"
|
|
|
|
|
|
|
|
uint64_t time;
|
|
|
|
struct rte_meter_trtcm_rfc4115_profile tp;
|
|
|
|
struct rte_meter_trtcm_rfc4115 tm;
|
|
|
|
uint64_t hz = rte_get_tsc_hz();
|
|
|
|
|
|
|
|
/* Test green */
|
|
|
|
if (rte_meter_trtcm_rfc4115_profile_config(&tp, &rfc4115params) != 0)
|
|
|
|
melog(TRTCM_RFC4115_BLIND_CHECK_MSG);
|
|
|
|
if (rte_meter_trtcm_rfc4115_config(&tm, &tp) != 0)
|
|
|
|
melog(TRTCM_RFC4115_BLIND_CHECK_MSG);
|
|
|
|
time = rte_get_tsc_cycles() + hz;
|
|
|
|
if (rte_meter_trtcm_rfc4115_color_blind_check(
|
|
|
|
&tm, &tp, time, TM_TEST_TRTCM_CBS_DF - 1)
|
|
|
|
!= RTE_COLOR_GREEN)
|
|
|
|
melog(TRTCM_RFC4115_BLIND_CHECK_MSG" GREEN");
|
|
|
|
|
|
|
|
/* Test yellow */
|
|
|
|
if (rte_meter_trtcm_rfc4115_profile_config(&tp, &rfc4115params) != 0)
|
|
|
|
melog(TRTCM_RFC4115_BLIND_CHECK_MSG);
|
|
|
|
if (rte_meter_trtcm_rfc4115_config(&tm, &tp) != 0)
|
|
|
|
melog(TRTCM_RFC4115_BLIND_CHECK_MSG);
|
|
|
|
time = rte_get_tsc_cycles() + hz;
|
|
|
|
if (rte_meter_trtcm_rfc4115_color_blind_check(
|
|
|
|
&tm, &tp, time, TM_TEST_TRTCM_CBS_DF + 1)
|
|
|
|
!= RTE_COLOR_YELLOW)
|
|
|
|
melog(TRTCM_RFC4115_BLIND_CHECK_MSG" YELLOW");
|
|
|
|
|
|
|
|
if (rte_meter_trtcm_rfc4115_profile_config(&tp, &rfc4115params) != 0)
|
|
|
|
melog(TRTCM_RFC4115_BLIND_CHECK_MSG);
|
|
|
|
if (rte_meter_trtcm_rfc4115_config(&tm, &tp) != 0)
|
|
|
|
melog(TRTCM_RFC4115_BLIND_CHECK_MSG);
|
|
|
|
time = rte_get_tsc_cycles() + hz;
|
|
|
|
if (rte_meter_trtcm_rfc4115_color_blind_check(
|
|
|
|
&tm, &tp, time, TM_TEST_TRTCM_EBS_DF - 1)
|
|
|
|
!= RTE_COLOR_YELLOW)
|
|
|
|
melog(TRTCM_RFC4115_BLIND_CHECK_MSG" YELLOW");
|
|
|
|
|
|
|
|
/* Test red */
|
|
|
|
if (rte_meter_trtcm_rfc4115_profile_config(&tp, &rfc4115params) != 0)
|
|
|
|
melog(TRTCM_RFC4115_BLIND_CHECK_MSG);
|
|
|
|
if (rte_meter_trtcm_rfc4115_config(&tm, &tp) != 0)
|
|
|
|
melog(TRTCM_RFC4115_BLIND_CHECK_MSG);
|
|
|
|
time = rte_get_tsc_cycles() + hz;
|
|
|
|
if (rte_meter_trtcm_rfc4115_color_blind_check(
|
|
|
|
&tm, &tp, time, TM_TEST_TRTCM_EBS_DF + 1)
|
|
|
|
!= RTE_COLOR_RED)
|
|
|
|
melog(TRTCM_RFC4115_BLIND_CHECK_MSG" RED");
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2018-05-15 09:49:22 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @in[4] : the flags packets carries.
|
|
|
|
* @in[4] : the flags function expect to return.
|
|
|
|
* It will do blind check at the time of 1 second from beginning.
|
|
|
|
* At the time, it will use packets length of cbs -1, cbs + 1,
|
|
|
|
* ebs -1 and ebs +1 with flag in[0], in[1], in[2] and in[3] to do
|
|
|
|
* aware check, expect flag out[0], out[1], out[2] and out[3]
|
|
|
|
*/
|
|
|
|
|
|
|
|
static inline int
|
|
|
|
tm_test_srtcm_aware_check
|
2020-06-18 16:55:50 +00:00
|
|
|
(enum rte_color in[4], enum rte_color out[4])
|
2018-05-15 09:49:22 +00:00
|
|
|
{
|
|
|
|
#define SRTCM_AWARE_CHECK_MSG "srtcm_aware_check"
|
2019-06-25 11:12:58 +00:00
|
|
|
struct rte_meter_srtcm_profile sp;
|
2018-05-15 09:49:22 +00:00
|
|
|
struct rte_meter_srtcm sm;
|
|
|
|
uint64_t time;
|
|
|
|
uint64_t hz = rte_get_tsc_hz();
|
|
|
|
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_srtcm_profile_config(&sp, &sparams) != 0)
|
|
|
|
melog(SRTCM_AWARE_CHECK_MSG);
|
|
|
|
if (rte_meter_srtcm_config(&sm, &sp) != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(SRTCM_AWARE_CHECK_MSG);
|
|
|
|
time = rte_get_tsc_cycles() + hz;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_srtcm_color_aware_check(
|
|
|
|
&sm, &sp, time, TM_TEST_SRTCM_CBS_DF - 1, in[0]) != out[0])
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(SRTCM_AWARE_CHECK_MSG" %u:%u", in[0], out[0]);
|
|
|
|
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_srtcm_profile_config(&sp, &sparams) != 0)
|
|
|
|
melog(SRTCM_AWARE_CHECK_MSG);
|
|
|
|
if (rte_meter_srtcm_config(&sm, &sp) != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(SRTCM_AWARE_CHECK_MSG);
|
|
|
|
time = rte_get_tsc_cycles() + hz;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_srtcm_color_aware_check(
|
|
|
|
&sm, &sp, time, TM_TEST_SRTCM_CBS_DF + 1, in[1]) != out[1])
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(SRTCM_AWARE_CHECK_MSG" %u:%u", in[1], out[1]);
|
|
|
|
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_srtcm_profile_config(&sp, &sparams) != 0)
|
|
|
|
melog(SRTCM_AWARE_CHECK_MSG);
|
|
|
|
if (rte_meter_srtcm_config(&sm, &sp) != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(SRTCM_AWARE_CHECK_MSG);
|
|
|
|
time = rte_get_tsc_cycles() + hz;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_srtcm_color_aware_check(
|
|
|
|
&sm, &sp, time, TM_TEST_SRTCM_EBS_DF - 1, in[2]) != out[2])
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(SRTCM_AWARE_CHECK_MSG" %u:%u", in[2], out[2]);
|
|
|
|
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_srtcm_profile_config(&sp, &sparams) != 0)
|
|
|
|
melog(SRTCM_AWARE_CHECK_MSG);
|
|
|
|
if (rte_meter_srtcm_config(&sm, &sp) != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(SRTCM_AWARE_CHECK_MSG);
|
|
|
|
time = rte_get_tsc_cycles() + hz;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_srtcm_color_aware_check(
|
|
|
|
&sm, &sp, time, TM_TEST_SRTCM_EBS_DF + 1, in[3]) != out[3])
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(SRTCM_AWARE_CHECK_MSG" %u:%u", in[3], out[3]);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* functional test for rte_meter_srtcm_color_aware_check
|
|
|
|
*/
|
|
|
|
static inline int
|
|
|
|
tm_test_srtcm_color_aware_check(void)
|
|
|
|
{
|
2020-06-18 16:55:50 +00:00
|
|
|
enum rte_color in[4], out[4];
|
2018-05-15 09:49:22 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* test 4 points that will produce green, yellow, yellow, red flag
|
|
|
|
* if using blind check
|
|
|
|
*/
|
|
|
|
|
2022-09-02 07:34:10 +00:00
|
|
|
/* previously have a green, test points should keep unchanged */
|
2020-06-18 16:55:50 +00:00
|
|
|
in[0] = in[1] = in[2] = in[3] = RTE_COLOR_GREEN;
|
|
|
|
out[0] = RTE_COLOR_GREEN;
|
|
|
|
out[1] = RTE_COLOR_YELLOW;
|
|
|
|
out[2] = RTE_COLOR_YELLOW;
|
|
|
|
out[3] = RTE_COLOR_RED;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (tm_test_srtcm_aware_check(in, out) != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
return -1;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* previously have a yellow, green & yellow = yellow
|
|
|
|
* yellow & red = red
|
|
|
|
*/
|
2020-06-18 16:55:50 +00:00
|
|
|
in[0] = in[1] = in[2] = in[3] = RTE_COLOR_YELLOW;
|
|
|
|
out[0] = RTE_COLOR_YELLOW;
|
|
|
|
out[1] = RTE_COLOR_YELLOW;
|
|
|
|
out[2] = RTE_COLOR_YELLOW;
|
|
|
|
out[3] = RTE_COLOR_RED;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (tm_test_srtcm_aware_check(in, out) != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
return -1;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* previously have a red, red & green = red
|
|
|
|
* red & yellow = red
|
|
|
|
*/
|
2020-06-18 16:55:50 +00:00
|
|
|
in[0] = in[1] = in[2] = in[3] = RTE_COLOR_RED;
|
|
|
|
out[0] = RTE_COLOR_RED;
|
|
|
|
out[1] = RTE_COLOR_RED;
|
|
|
|
out[2] = RTE_COLOR_RED;
|
|
|
|
out[3] = RTE_COLOR_RED;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (tm_test_srtcm_aware_check(in, out) != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
return -1;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @in[4] : the flags packets carries.
|
|
|
|
* @in[4] : the flags function expect to return.
|
|
|
|
* It will do blind check at the time of 1 second from beginning.
|
|
|
|
* At the time, it will use packets length of cbs -1, cbs + 1,
|
|
|
|
* ebs -1 and ebs +1 with flag in[0], in[1], in[2] and in[3] to do
|
|
|
|
* aware check, expect flag out[0], out[1], out[2] and out[3]
|
|
|
|
*/
|
|
|
|
static inline int
|
|
|
|
tm_test_trtcm_aware_check
|
2020-06-18 16:55:50 +00:00
|
|
|
(enum rte_color in[4], enum rte_color out[4])
|
2018-05-15 09:49:22 +00:00
|
|
|
{
|
|
|
|
#define TRTCM_AWARE_CHECK_MSG "trtcm_aware_check"
|
2019-06-25 11:12:58 +00:00
|
|
|
struct rte_meter_trtcm_profile tp;
|
2018-05-15 09:49:22 +00:00
|
|
|
struct rte_meter_trtcm tm;
|
|
|
|
uint64_t time;
|
|
|
|
uint64_t hz = rte_get_tsc_hz();
|
|
|
|
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_trtcm_profile_config(&tp, &tparams) != 0)
|
|
|
|
melog(TRTCM_AWARE_CHECK_MSG);
|
|
|
|
if (rte_meter_trtcm_config(&tm, &tp) != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(TRTCM_AWARE_CHECK_MSG);
|
|
|
|
time = rte_get_tsc_cycles() + hz;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_trtcm_color_aware_check(
|
|
|
|
&tm, &tp, time, TM_TEST_TRTCM_CBS_DF - 1, in[0]) != out[0])
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(TRTCM_AWARE_CHECK_MSG" %u:%u", in[0], out[0]);
|
|
|
|
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_trtcm_profile_config(&tp, &tparams) != 0)
|
|
|
|
melog(TRTCM_AWARE_CHECK_MSG);
|
|
|
|
if (rte_meter_trtcm_config(&tm, &tp) != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(TRTCM_AWARE_CHECK_MSG);
|
|
|
|
time = rte_get_tsc_cycles() + hz;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_trtcm_color_aware_check(
|
|
|
|
&tm, &tp, time, TM_TEST_TRTCM_CBS_DF + 1, in[1]) != out[1])
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(TRTCM_AWARE_CHECK_MSG" %u:%u", in[1], out[1]);
|
|
|
|
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_trtcm_profile_config(&tp, &tparams) != 0)
|
|
|
|
melog(TRTCM_AWARE_CHECK_MSG);
|
|
|
|
if (rte_meter_trtcm_config(&tm, &tp) != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(TRTCM_AWARE_CHECK_MSG);
|
|
|
|
time = rte_get_tsc_cycles() + hz;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_trtcm_color_aware_check(
|
|
|
|
&tm, &tp, time, TM_TEST_TRTCM_PBS_DF - 1, in[2]) != out[2])
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(TRTCM_AWARE_CHECK_MSG" %u:%u", in[2], out[2]);
|
|
|
|
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_trtcm_profile_config(&tp, &tparams) != 0)
|
|
|
|
melog(TRTCM_AWARE_CHECK_MSG);
|
|
|
|
if (rte_meter_trtcm_config(&tm, &tp) != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(TRTCM_AWARE_CHECK_MSG);
|
|
|
|
time = rte_get_tsc_cycles() + hz;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (rte_meter_trtcm_color_aware_check(
|
|
|
|
&tm, &tp, time, TM_TEST_TRTCM_PBS_DF + 1, in[3]) != out[3])
|
2018-05-15 09:49:22 +00:00
|
|
|
melog(TRTCM_AWARE_CHECK_MSG" %u:%u", in[3], out[3]);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* functional test for rte_meter_trtcm_color_aware_check
|
|
|
|
*/
|
|
|
|
|
|
|
|
static inline int
|
|
|
|
tm_test_trtcm_color_aware_check(void)
|
|
|
|
{
|
2020-06-18 16:55:50 +00:00
|
|
|
enum rte_color in[4], out[4];
|
2018-05-15 09:49:22 +00:00
|
|
|
/**
|
|
|
|
* test 4 points that will produce green, yellow, yellow, red flag
|
|
|
|
* if using blind check
|
|
|
|
*/
|
|
|
|
|
2022-09-02 07:34:10 +00:00
|
|
|
/* previously have a green, test points should keep unchanged */
|
2020-06-18 16:55:50 +00:00
|
|
|
in[0] = in[1] = in[2] = in[3] = RTE_COLOR_GREEN;
|
|
|
|
out[0] = RTE_COLOR_GREEN;
|
|
|
|
out[1] = RTE_COLOR_YELLOW;
|
|
|
|
out[2] = RTE_COLOR_YELLOW;
|
|
|
|
out[3] = RTE_COLOR_RED;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (tm_test_trtcm_aware_check(in, out) != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
return -1;
|
|
|
|
|
2020-06-18 16:55:50 +00:00
|
|
|
in[0] = in[1] = in[2] = in[3] = RTE_COLOR_YELLOW;
|
|
|
|
out[0] = RTE_COLOR_YELLOW;
|
|
|
|
out[1] = RTE_COLOR_YELLOW;
|
|
|
|
out[2] = RTE_COLOR_YELLOW;
|
|
|
|
out[3] = RTE_COLOR_RED;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (tm_test_trtcm_aware_check(in, out) != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
return -1;
|
|
|
|
|
2020-06-18 16:55:50 +00:00
|
|
|
in[0] = in[1] = in[2] = in[3] = RTE_COLOR_RED;
|
|
|
|
out[0] = RTE_COLOR_RED;
|
|
|
|
out[1] = RTE_COLOR_RED;
|
|
|
|
out[2] = RTE_COLOR_RED;
|
|
|
|
out[3] = RTE_COLOR_RED;
|
2019-06-25 11:12:58 +00:00
|
|
|
if (tm_test_trtcm_aware_check(in, out) != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
return -1;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2020-06-18 16:55:50 +00:00
|
|
|
/**
|
|
|
|
* @in[4] : the flags packets carries.
|
|
|
|
* @in[4] : the flags function expect to return.
|
|
|
|
* It will do blind check at the time of 1 second from beginning.
|
|
|
|
* At the time, it will use packets length of cbs -1, cbs + 1,
|
|
|
|
* ebs -1 and ebs +1 with flag in[0], in[1], in[2] and in[3] to do
|
|
|
|
* aware check, expect flag out[0], out[1], out[2] and out[3]
|
|
|
|
*/
|
|
|
|
static inline int
|
|
|
|
tm_test_trtcm_rfc4115_aware_check
|
|
|
|
(enum rte_color in[4], enum rte_color out[4])
|
|
|
|
{
|
|
|
|
#define TRTCM_RFC4115_AWARE_CHECK_MSG "trtcm_rfc4115_aware_check"
|
|
|
|
struct rte_meter_trtcm_rfc4115_profile tp;
|
|
|
|
struct rte_meter_trtcm_rfc4115 tm;
|
|
|
|
uint64_t time;
|
|
|
|
uint64_t hz = rte_get_tsc_hz();
|
|
|
|
|
|
|
|
if (rte_meter_trtcm_rfc4115_profile_config(&tp, &rfc4115params) != 0)
|
|
|
|
melog(TRTCM_AWARE_CHECK_MSG);
|
|
|
|
if (rte_meter_trtcm_rfc4115_config(&tm, &tp) != 0)
|
|
|
|
melog(TRTCM_RFC4115_AWARE_CHECK_MSG);
|
|
|
|
time = rte_get_tsc_cycles() + hz;
|
|
|
|
if (rte_meter_trtcm_rfc4115_color_aware_check(
|
|
|
|
&tm, &tp, time, TM_TEST_TRTCM_CBS_DF - 1, in[0]) != out[0])
|
|
|
|
melog(TRTCM_RFC4115_AWARE_CHECK_MSG" %u:%u", in[0], out[0]);
|
|
|
|
|
|
|
|
if (rte_meter_trtcm_rfc4115_profile_config(&tp, &rfc4115params) != 0)
|
|
|
|
melog(TRTCM_RFC4115_AWARE_CHECK_MSG);
|
|
|
|
if (rte_meter_trtcm_rfc4115_config(&tm, &tp) != 0)
|
|
|
|
melog(TRTCM_RFC4115_AWARE_CHECK_MSG);
|
|
|
|
time = rte_get_tsc_cycles() + hz;
|
|
|
|
if (rte_meter_trtcm_rfc4115_color_aware_check(
|
|
|
|
&tm, &tp, time, TM_TEST_TRTCM_CBS_DF + 1, in[1]) != out[1])
|
|
|
|
melog(TRTCM_RFC4115_AWARE_CHECK_MSG" %u:%u", in[1], out[1]);
|
|
|
|
|
|
|
|
if (rte_meter_trtcm_rfc4115_profile_config(&tp, &rfc4115params) != 0)
|
|
|
|
melog(TRTCM_RFC4115_AWARE_CHECK_MSG);
|
|
|
|
if (rte_meter_trtcm_rfc4115_config(&tm, &tp) != 0)
|
|
|
|
melog(TRTCM_RFC4115_AWARE_CHECK_MSG);
|
|
|
|
time = rte_get_tsc_cycles() + hz;
|
|
|
|
if (rte_meter_trtcm_rfc4115_color_aware_check(
|
|
|
|
&tm, &tp, time, TM_TEST_TRTCM_EBS_DF - 1, in[2]) != out[2])
|
|
|
|
melog(TRTCM_RFC4115_AWARE_CHECK_MSG" %u:%u", in[2], out[2]);
|
|
|
|
|
|
|
|
if (rte_meter_trtcm_rfc4115_profile_config(&tp, &rfc4115params) != 0)
|
|
|
|
melog(TRTCM_RFC4115_AWARE_CHECK_MSG);
|
|
|
|
if (rte_meter_trtcm_rfc4115_config(&tm, &tp) != 0)
|
|
|
|
melog(TRTCM_RFC4115_AWARE_CHECK_MSG);
|
|
|
|
time = rte_get_tsc_cycles() + hz;
|
|
|
|
if (rte_meter_trtcm_rfc4115_color_aware_check(
|
|
|
|
&tm, &tp, time, TM_TEST_TRTCM_EBS_DF + 1, in[3]) != out[3])
|
|
|
|
melog(TRTCM_RFC4115_AWARE_CHECK_MSG" %u:%u", in[3], out[3]);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* functional test for rte_meter_trtcm_rfc4115_color_aware_check
|
|
|
|
*/
|
|
|
|
static inline int
|
|
|
|
tm_test_trtcm_rfc4115_color_aware_check(void)
|
|
|
|
{
|
|
|
|
enum rte_color in[4], out[4];
|
|
|
|
/**
|
|
|
|
* test 4 points that will produce green, yellow, yellow, red flag
|
|
|
|
* if using blind check
|
|
|
|
*/
|
|
|
|
|
2022-09-02 07:34:10 +00:00
|
|
|
/* previously have a green, test points should keep unchanged */
|
2020-06-18 16:55:50 +00:00
|
|
|
in[0] = in[1] = in[2] = in[3] = RTE_COLOR_GREEN;
|
|
|
|
out[0] = RTE_COLOR_GREEN;
|
|
|
|
out[1] = RTE_COLOR_YELLOW;
|
|
|
|
out[2] = RTE_COLOR_YELLOW;
|
|
|
|
out[3] = RTE_COLOR_RED;
|
|
|
|
if (tm_test_trtcm_rfc4115_aware_check(in, out) != 0)
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
in[0] = in[1] = in[2] = in[3] = RTE_COLOR_YELLOW;
|
|
|
|
out[0] = RTE_COLOR_YELLOW;
|
|
|
|
out[1] = RTE_COLOR_YELLOW;
|
|
|
|
out[2] = RTE_COLOR_YELLOW;
|
|
|
|
out[3] = RTE_COLOR_RED;
|
|
|
|
if (tm_test_trtcm_rfc4115_aware_check(in, out) != 0)
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
in[0] = in[1] = in[2] = in[3] = RTE_COLOR_RED;
|
|
|
|
out[0] = RTE_COLOR_RED;
|
|
|
|
out[1] = RTE_COLOR_RED;
|
|
|
|
out[2] = RTE_COLOR_RED;
|
|
|
|
out[3] = RTE_COLOR_RED;
|
|
|
|
if (tm_test_trtcm_rfc4115_aware_check(in, out) != 0)
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2018-05-15 09:49:22 +00:00
|
|
|
/**
|
|
|
|
* test main entrance for library meter
|
|
|
|
*/
|
|
|
|
static int
|
|
|
|
test_meter(void)
|
|
|
|
{
|
2019-06-25 11:12:58 +00:00
|
|
|
if (tm_test_srtcm_config() != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
return -1;
|
|
|
|
|
2019-06-25 11:12:58 +00:00
|
|
|
if (tm_test_trtcm_config() != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
return -1;
|
|
|
|
|
2020-06-18 16:55:50 +00:00
|
|
|
if (tm_test_trtcm_rfc4115_config() != 0)
|
|
|
|
return -1;
|
|
|
|
|
2019-06-25 11:12:58 +00:00
|
|
|
if (tm_test_srtcm_color_blind_check() != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
return -1;
|
|
|
|
|
2019-06-25 11:12:58 +00:00
|
|
|
if (tm_test_trtcm_color_blind_check() != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
return -1;
|
|
|
|
|
2020-06-18 16:55:50 +00:00
|
|
|
if (tm_test_trtcm_rfc4115_color_blind_check() != 0)
|
|
|
|
return -1;
|
|
|
|
|
2019-06-25 11:12:58 +00:00
|
|
|
if (tm_test_srtcm_color_aware_check() != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
return -1;
|
|
|
|
|
2019-06-25 11:12:58 +00:00
|
|
|
if (tm_test_trtcm_color_aware_check() != 0)
|
2018-05-15 09:49:22 +00:00
|
|
|
return -1;
|
|
|
|
|
2020-06-18 16:55:50 +00:00
|
|
|
if (tm_test_trtcm_rfc4115_color_aware_check() != 0)
|
|
|
|
return -1;
|
|
|
|
|
2018-05-15 09:49:22 +00:00
|
|
|
return 0;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
REGISTER_TEST_COMMAND(meter_autotest, test_meter);
|