hc
2023-11-06 15ade055295d13f95d49e3d99b09f3bbfb4a43e7
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef _HAL_FWOFFLOADC2HFORMAT_H2C_C2H_NIC_H_
#define _HAL_FWOFFLOADC2HFORMAT_H2C_C2H_NIC_H_
#define C2H_SUB_CMD_ID_C2H_DBG  0X00
#define C2H_SUB_CMD_ID_BT_COEX_INFO  0X02
#define C2H_SUB_CMD_ID_SCAN_STATUS_RPT  0X03
#define C2H_SUB_CMD_ID_H2C_ACK_HDR  0X01
#define C2H_SUB_CMD_ID_CFG_PARAMETER_ACK  0X01
#define C2H_SUB_CMD_ID_BT_COEX_ACK  0X01
#define C2H_SUB_CMD_ID_DUMP_PHYSICAL_EFUSE_ACK  0X01
#define C2H_SUB_CMD_ID_UPDATE_PACKET_ACK  0X01
#define C2H_SUB_CMD_ID_UPDATE_DATAPACK_ACK  0X01
#define C2H_SUB_CMD_ID_RUN_DATAPACK_ACK  0X01
#define C2H_SUB_CMD_ID_CHANNEL_SWITCH_ACK  0X01
#define C2H_SUB_CMD_ID_IQK_ACK  0X01
#define C2H_SUB_CMD_ID_POWER_TRACKING_ACK  0X01
#define C2H_SUB_CMD_ID_PSD_ACK  0X01
#define C2H_SUB_CMD_ID_PSD_DATA  0X04
#define C2H_SUB_CMD_ID_EFUSE_DATA  0X05
#define H2C_SUB_CMD_ID_CFG_PARAMETER_ACK SUB_CMD_ID_CFG_PARAMETER
#define H2C_SUB_CMD_ID_BT_COEX_ACK SUB_CMD_ID_BT_COEX
#define H2C_SUB_CMD_ID_DUMP_PHYSICAL_EFUSE_ACK SUB_CMD_ID_DUMP_PHYSICAL_EFUSE
#define H2C_SUB_CMD_ID_UPDATE_PACKET_ACK SUB_CMD_ID_UPDATE_PACKET
#define H2C_SUB_CMD_ID_UPDATE_DATAPACK_ACK SUB_CMD_ID_UPDATE_DATAPACK
#define H2C_SUB_CMD_ID_RUN_DATAPACK_ACK SUB_CMD_ID_RUN_DATAPACK
#define H2C_SUB_CMD_ID_CHANNEL_SWITCH_ACK SUB_CMD_ID_CHANNEL_SWITCH
#define H2C_SUB_CMD_ID_IQK_ACK SUB_CMD_ID_IQK
#define H2C_SUB_CMD_ID_POWER_TRACKING_ACK SUB_CMD_ID_POWER_TRACKING
#define H2C_SUB_CMD_ID_PSD_ACK SUB_CMD_ID_PSD
#define H2C_CMD_ID_CFG_PARAMETER_ACK  0XFF
#define H2C_CMD_ID_BT_COEX_ACK  0XFF
#define H2C_CMD_ID_DUMP_PHYSICAL_EFUSE_ACK  0XFF
#define H2C_CMD_ID_UPDATE_PACKET_ACK  0XFF
#define H2C_CMD_ID_UPDATE_DATAPACK_ACK  0XFF
#define H2C_CMD_ID_RUN_DATAPACK_ACK  0XFF
#define H2C_CMD_ID_CHANNEL_SWITCH_ACK  0XFF
#define H2C_CMD_ID_IQK_ACK  0XFF
#define H2C_CMD_ID_POWER_TRACKING_ACK  0XFF
#define H2C_CMD_ID_PSD_ACK  0XFF
#define C2H_HDR_GET_CMD_ID(__pC2H)    LE_BITS_TO_4BYTE(__pC2H + 0X00, 0, 8)
#define C2H_HDR_SET_CMD_ID(__pC2H, __Value)    SET_BITS_TO_LE_4BYTE(__pC2H + 0X00, 0, 8, __Value)
#define C2H_HDR_GET_SEQ(__pC2H)    LE_BITS_TO_4BYTE(__pC2H + 0X00, 8, 8)
#define C2H_HDR_SET_SEQ(__pC2H, __Value)    SET_BITS_TO_LE_4BYTE(__pC2H + 0X00, 8, 8, __Value)
#define C2H_HDR_GET_C2H_SUB_CMD_ID(__pC2H)    LE_BITS_TO_4BYTE(__pC2H + 0X00, 16, 8)
#define C2H_HDR_SET_C2H_SUB_CMD_ID(__pC2H, __Value)    SET_BITS_TO_LE_4BYTE(__pC2H + 0X00, 16, 8, __Value)
#define C2H_HDR_GET_LEN(__pC2H)    LE_BITS_TO_4BYTE(__pC2H + 0X00, 24, 8)
#define C2H_HDR_SET_LEN(__pC2H, __Value)    SET_BITS_TO_LE_4BYTE(__pC2H + 0X00, 24, 8, __Value)
#define C2H_DBG_GET_DBG_MSG(__pC2H)    LE_BITS_TO_4BYTE(__pC2H + 0X04, 0, 8)
#define C2H_DBG_SET_DBG_MSG(__pC2H, __Value)    SET_BITS_TO_LE_4BYTE(__pC2H + 0X04, 0, 8, __Value)
#define BT_COEX_INFO_GET_DATA_START(__pC2H)    LE_BITS_TO_4BYTE(__pC2H + 0X04, 0, 8)
#define BT_COEX_INFO_SET_DATA_START(__pC2H, __Value)    SET_BITS_TO_LE_4BYTE(__pC2H + 0X04, 0, 8, __Value)
#define SCAN_STATUS_RPT_GET_H2C_RETURN_CODE(__pC2H)    LE_BITS_TO_4BYTE(__pC2H + 0X04, 0, 8)
#define SCAN_STATUS_RPT_SET_H2C_RETURN_CODE(__pC2H, __Value)    SET_BITS_TO_LE_4BYTE(__pC2H + 0X04, 0, 8, __Value)
#define SCAN_STATUS_RPT_GET_H2C_SEQ(__pC2H)    LE_BITS_TO_4BYTE(__pC2H + 0X04, 16, 16)
#define SCAN_STATUS_RPT_SET_H2C_SEQ(__pC2H, __Value)    SET_BITS_TO_LE_4BYTE(__pC2H + 0X04, 16, 16, __Value)
#define H2C_ACK_HDR_GET_H2C_RETURN_CODE(__pC2H)    LE_BITS_TO_4BYTE(__pC2H + 0X04, 0, 8)
#define H2C_ACK_HDR_SET_H2C_RETURN_CODE(__pC2H, __Value)    SET_BITS_TO_LE_4BYTE(__pC2H + 0X04, 0, 8, __Value)
#define H2C_ACK_HDR_GET_H2C_CMD_ID(__pC2H)    LE_BITS_TO_4BYTE(__pC2H + 0X04, 8, 8)
#define H2C_ACK_HDR_SET_H2C_CMD_ID(__pC2H, __Value)    SET_BITS_TO_LE_4BYTE(__pC2H + 0X04, 8, 8, __Value)
#define H2C_ACK_HDR_GET_H2C_SUB_CMD_ID(__pC2H)    LE_BITS_TO_4BYTE(__pC2H + 0X04, 16, 16)
#define H2C_ACK_HDR_SET_H2C_SUB_CMD_ID(__pC2H, __Value)    SET_BITS_TO_LE_4BYTE(__pC2H + 0X04, 16, 16, __Value)
#define H2C_ACK_HDR_GET_H2C_SEQ(__pC2H)    LE_BITS_TO_4BYTE(__pC2H + 0X08, 0, 16)
#define H2C_ACK_HDR_SET_H2C_SEQ(__pC2H, __Value)    SET_BITS_TO_LE_4BYTE(__pC2H + 0X08, 0, 16, __Value)
#define CFG_PARAMETER_ACK_GET_OFFSET_ACCUMULATION(__pC2H)    LE_BITS_TO_4BYTE(__pC2H + 0XC, 0, 32)
#define CFG_PARAMETER_ACK_SET_OFFSET_ACCUMULATION(__pC2H, __Value)    SET_BITS_TO_LE_4BYTE(__pC2H + 0XC, 0, 32, __Value)
#define CFG_PARAMETER_ACK_GET_VALUE_ACCUMULATION(__pC2H)    LE_BITS_TO_4BYTE(__pC2H + 0X10, 0, 32)
#define CFG_PARAMETER_ACK_SET_VALUE_ACCUMULATION(__pC2H, __Value)    SET_BITS_TO_LE_4BYTE(__pC2H + 0X10, 0, 32, __Value)
#define BT_COEX_ACK_GET_DATA_START(__pC2H)    LE_BITS_TO_4BYTE(__pC2H + 0XC, 0, 8)
#define BT_COEX_ACK_SET_DATA_START(__pC2H, __Value)    SET_BITS_TO_LE_4BYTE(__pC2H + 0XC, 0, 8, __Value)
#define PSD_DATA_GET_SEGMENT_ID(__pC2H)    LE_BITS_TO_4BYTE(__pC2H + 0X04, 0, 7)
#define PSD_DATA_SET_SEGMENT_ID(__pC2H, __Value)    SET_BITS_TO_LE_4BYTE(__pC2H + 0X04, 0, 7, __Value)
#define PSD_DATA_GET_END_SEGMENT(__pC2H)    LE_BITS_TO_4BYTE(__pC2H + 0X04, 7, 1)
#define PSD_DATA_SET_END_SEGMENT(__pC2H, __Value)    SET_BITS_TO_LE_4BYTE(__pC2H + 0X04, 7, 1, __Value)
#define PSD_DATA_GET_SEGMENT_SIZE(__pC2H)    LE_BITS_TO_4BYTE(__pC2H + 0X04, 8, 8)
#define PSD_DATA_SET_SEGMENT_SIZE(__pC2H, __Value)    SET_BITS_TO_LE_4BYTE(__pC2H + 0X04, 8, 8, __Value)
#define PSD_DATA_GET_TOTAL_SIZE(__pC2H)    LE_BITS_TO_4BYTE(__pC2H + 0X04, 16, 16)
#define PSD_DATA_SET_TOTAL_SIZE(__pC2H, __Value)    SET_BITS_TO_LE_4BYTE(__pC2H + 0X04, 16, 16, __Value)
#define PSD_DATA_GET_H2C_SEQ(__pC2H)    LE_BITS_TO_4BYTE(__pC2H + 0X8, 0, 16)
#define PSD_DATA_SET_H2C_SEQ(__pC2H, __Value)    SET_BITS_TO_LE_4BYTE(__pC2H + 0X8, 0, 16, __Value)
#define PSD_DATA_GET_DATA_START(__pC2H)    LE_BITS_TO_4BYTE(__pC2H + 0X8, 16, 8)
#define PSD_DATA_SET_DATA_START(__pC2H, __Value)    SET_BITS_TO_LE_4BYTE(__pC2H + 0X8, 16, 8, __Value)
#define EFUSE_DATA_GET_SEGMENT_ID(__pC2H)    LE_BITS_TO_4BYTE(__pC2H + 0X04, 0, 7)
#define EFUSE_DATA_SET_SEGMENT_ID(__pC2H, __Value)    SET_BITS_TO_LE_4BYTE(__pC2H + 0X04, 0, 7, __Value)
#define EFUSE_DATA_GET_END_SEGMENT(__pC2H)    LE_BITS_TO_4BYTE(__pC2H + 0X04, 7, 1)
#define EFUSE_DATA_SET_END_SEGMENT(__pC2H, __Value)    SET_BITS_TO_LE_4BYTE(__pC2H + 0X04, 7, 1, __Value)
#define EFUSE_DATA_GET_SEGMENT_SIZE(__pC2H)    LE_BITS_TO_4BYTE(__pC2H + 0X04, 8, 8)
#define EFUSE_DATA_SET_SEGMENT_SIZE(__pC2H, __Value)    SET_BITS_TO_LE_4BYTE(__pC2H + 0X04, 8, 8, __Value)
#define EFUSE_DATA_GET_TOTAL_SIZE(__pC2H)    LE_BITS_TO_4BYTE(__pC2H + 0X04, 16, 16)
#define EFUSE_DATA_SET_TOTAL_SIZE(__pC2H, __Value)    SET_BITS_TO_LE_4BYTE(__pC2H + 0X04, 16, 16, __Value)
#define EFUSE_DATA_GET_H2C_SEQ(__pC2H)    LE_BITS_TO_4BYTE(__pC2H + 0X8, 0, 16)
#define EFUSE_DATA_SET_H2C_SEQ(__pC2H, __Value)    SET_BITS_TO_LE_4BYTE(__pC2H + 0X8, 0, 16, __Value)
#define EFUSE_DATA_GET_DATA_START(__pC2H)    LE_BITS_TO_4BYTE(__pC2H + 0X8, 16, 8)
#define EFUSE_DATA_SET_DATA_START(__pC2H, __Value)    SET_BITS_TO_LE_4BYTE(__pC2H + 0X8, 16, 8, __Value)
#endif