153 lines
5.0 KiB
C
Raw Normal View History

2025-05-10 21:58:58 +08:00
/******************************************************************************
*
* Copyright(c) 2019 Realtek Corporation.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of version 2 of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
*****************************************************************************/
#ifndef _TEST_MODULE_DEF_H_
#define _TEST_MODULE_DEF_H_
#ifdef CONFIG_PHL_TEST_SUITE
#define TEST_NAME_LEN 32
#define TEST_RPT_RSN_LEN 32
#define TEST_LVL_LOW_TO 1000
#define TEST_LVL_NORMAL_TO 50
#define TEST_LVL_HIGH_TO 20
/*add cusstomized BP types in the following enum,
and hanle them in corresponding bp handler*/
enum TEST_BP_INFO_TYPE{
BP_INFO_TYPE_NONE = 0,
BP_INFO_TYPE_WAIT_BEACON_JOIN = 0x1,
BP_INFO_TYPE_SEND_AUTH_ODD = 0x2,
BP_INFO_TYPE_SEND_ASOC_REQ = 0x3,
BP_INFO_TYPE_SEND_DISASSOC = 0x4,
BP_INFO_TYPE_FILL_DISASSOC_RSN = 0x5,
BP_INFO_TYPE_SEND_PROBE_REQ = 0x6,
BP_INFO_TYPE_MP_CMD_EVENT = 0x7,
BP_INFO_TYPE_RX_TEST_WPRPT = 0x8,
BP_INFO_TYPE_RX_TEST_PATTERN = 0x9,
BP_INFO_TYPE_MP_RX_PHYSTS = 0xA,
BP_INFO_TYPE_TX_4_WAY = 0xB,
BP_INFO_TYPE_RX_4_WAY = 0xC,
BP_INFO_TYPE_MAX
};
enum TEST_RUN_LVL{
TEST_LVL_NONE = 0,
TEST_LVL_LOW,
TEST_LVL_NORMAL,
TEST_LVL_HIGH,
TEST_LVL_MAX
};
enum TEST_BP_RETURN_TYPE{
BP_RET_SKIP_SECTION = 0,
BP_RET_RUN_ORIGIN_SEC,
BP_RET_LEAVE_FUNC,
BP_RET_MAX
};
enum TEST_SUB_MODULE {
TEST_SUB_MODULE_MP = 0,
TEST_SUB_MODULE_FPGA = 1,
TEST_SUB_MODULE_VERIFY = 2,
TEST_SUB_MODULE_TOOL = 3,
TEST_SUB_MODULE_TRX = 4,
TEST_SUB_MODULE_UNKNOWN,
};
enum TEST_MODULE_MODE_TYPE {
UNIT_TEST_MODE = 0,
INTGR_TEST_MODE = 1,
FUNC_TEST_MODE = 2
};
struct test_bp_info{
enum TEST_BP_INFO_TYPE type;
u32 len;
void* ptr;
};
/**
* test_obj_ctrl_interface - basic test control methods for generic management.
* @start_test: test entry, initiate & run a test
* @is_test_end: return true when test ends.
* NOTE: Do not use evt/lock inside this method for sync.
* @is_test_pass: return true when test passed.
* @get_fail_rsn: if test fails, construct a reasonable string as fail description,
* not just a status code.
* @bp_handler: handle break point which is currently being hit,
* use rtw_phl_test_setup_bp to add new break point in source code
* and add customized BP type in TEST_BP_INFO_TYPE for recognition.
*/
struct test_obj_ctrl_interface{
u8 (*start_test)(void *priv);
u8 (*is_test_end)(void *priv);
u8 (*is_test_pass)(void *priv);
u8 (*get_fail_rsn)(void *priv,char* rsn, u32 max_len);
u8 (*bp_handler)(void *priv, struct test_bp_info* bp_info);
};
struct test_object {
_os_list list;
void* priv;
enum TEST_RUN_LVL run_lvl;
char name[TEST_NAME_LEN];
struct test_obj_ctrl_interface ctrl;
s32 total_time_ms; // optional, set 0 to use default see TEST_LVL_LOW_TO
};
struct test_rpt {
char name[TEST_NAME_LEN];
u8 status;
char rsn[TEST_RPT_RSN_LEN];
u32 total_time; // in ms
};
void rtw_phl_test_submodule_init(struct rtw_phl_com_t* phl_com, void *buf);
void rtw_phl_test_submodule_deinit(struct rtw_phl_com_t* phl_com, void *buf);
void rtw_phl_test_submodule_cmd_process(struct rtw_phl_com_t* phl_com, void *buf, u32 buf_len);
void rtw_phl_test_submodule_get_rpt(struct rtw_phl_com_t* phl_com, void *buf, u32 buf_len);
u8 rtw_phl_test_add_new_test_obj(struct rtw_phl_com_t* phl_com,
char *name,
void* priv,
enum TEST_RUN_LVL lvl,
struct test_obj_ctrl_interface* ctrl_intf,
s32 total_time_ms,
u8 objid,
u8 test_mode);
u8 rtw_phl_test_setup_bp(struct rtw_phl_com_t* phl_com,
struct test_bp_info* bp_info,
u8 submdid);
u8 rtw_phl_test_is_test_complete(struct rtw_phl_com_t* phl_com);
u8 rtw_phl_test_get_rpt(struct rtw_phl_com_t* phl_com, u8* buf, u32 len);
u8 rtw_phl_test_set_max_run_time(struct rtw_phl_com_t* phl_com, enum TEST_RUN_LVL lvl, u32 timeout_ms);
enum rtw_phl_status rtw_phl_reset(void *phl);
#else
#define rtw_phl_test_submodule_init(phl_com, buf)
#define rtw_phl_test_submodule_deinit(phl_com, buf)
#define rtw_phl_test_submodule_cmd_process(phl_com, buf, buf_len)
#define rtw_phl_test_submodule_get_rpt(phl_com, buf, buf_len)
#define rtw_phl_test_add_new_test_obj(phl_com, name, priv, lvl, ctrl_intf, total_time_ms, objid, test_mode) true
#define rtw_phl_test_setup_bp(phl_com, bp_info, submdid) true
#define rtw_phl_test_is_test_complete(phl_com) true
#define rtw_phl_test_get_rpt(phl_com, buf, len) true
#define rtw_phl_test_set_max_run_time(phl_com, lvl, timeout_ms) true
#endif /*CONFIG_PHL_TEST_SUITE*/
#endif /* _TEST_MODULE_DEF_H_ */