hc
2024-08-12 233ab1bd4c5697f5cdec94e60206e8c6ac609b4c
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
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
/*
 *  Copyright (c) 2017 Rockchip Electronics Co. Ltd.
 *  Author: Bin Yang <yangbin@rock-chips.com>
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
 
#ifndef __COMMON_H__
#define __COMMON_H__
#include <stdio.h>
 
#ifdef PCBA_PX3SE
#define   PCBA_TEST_PLATFORM            "PX3SE"
#endif
 
#ifdef PCBA_ECHO
#define   PCBA_TEST_PLATFORM            "ECHO"
#endif
 
#ifdef PCBA_CVR
#define   PCBA_TEST_PLATFORM            "CVR"
#endif
 
#ifdef PCBA_3308
#define   PCBA_TEST_PLATFORM            "3308"
#endif
 
#ifdef PCBA_3229GVA
#define   PCBA_TEST_PLATFORM            "GVA"
#endif
 
#ifdef PCBA_1808
#define   PCBA_TEST_PLATFORM            "1808"
#endif
 
#ifdef PCBA_3326
#define   PCBA_TEST_PLATFORM            "3326"
#endif
 
#ifdef PCBA_PX30
#define   PCBA_TEST_PLATFORM            "PX30"
#endif
 
#ifdef PCBA_3288
#define   PCBA_TEST_PLATFORM            "3288"
#endif
 
#ifdef PCBA_312X
#define   PCBA_TEST_PLATFORM            "312X"
#endif
 
#ifdef PCBA_3328
#define   PCBA_TEST_PLATFORM            "3328"
#endif
 
#ifdef PCBA_3399
#define   PCBA_TEST_PLATFORM            "3399"
#endif
 
#ifdef PCBA_3399PRO
#define   PCBA_TEST_PLATFORM            "3399PRO"
#endif
 
#ifdef PCBA_1126_1109
#define   PCBA_TEST_PLATFORM            "1126_1109"
#endif
 
#ifdef PCBA_356X
#define   PCBA_TEST_PLATFORM            "356X"
#endif
 
#ifdef PCBA_3588
#define   PCBA_TEST_PLATFORM            "3588"
#endif
 
 
#define   PCBA_VERSION                  "1.2.0"
 
typedef enum {
   /* format parse*/
   CMD_CHK_OK              =  0,
   CMD_TYPE_ERR            = -1,
   TEST_ITEM_ERR           = -2,
   CMD_ERR                 = -3,
   MSG_ERR                 = -4,
   SEND_FORMAT_ERR         = -5,
   TCP_SEND_ERR            = -6,
   QUERY_RESULT_ERR        = -7,
   RECV_FORMAT_ERR         = -8,
   CMD_OVERLONG            = -9,
 
   /* process  parse */
   TEST_MODE_ERR           = -10,
   ENTER_TEST_ERR          = -11,
   EXIT_TEST_ERR           = -12,
   TEST_ITEM_BUSY          = -13,
   STOP_TEST_ERR           = -14,
   SAVE_RESULE_ERR         = -15,
   TEST_FORK_ERR           = -16,
   TEST_RESULT_EXIST       = -17,
 
   /* write storage */
   WRITE_VENDOR_ERR        = -20,
   READ_VENDOR_ERR         = -21,
   /* ptz  test */
   PTZ_TEST_ERR            = -30,
   /* key test */
   KEY_OPEN_FAIL           = -40,
   KEY_EVENT_TIMEOUT       = -41,
   KEY_PROC_ERR            = -42,
   KEY_QUERY_FAIL          = -43,
   /* ROTARY test */
   ROTARY_OPEN_FAIL        = -50,
   ROTARY_EVENT_TIMEOUT    = -51,
   ROTARY_QUERY_FAIL       = -52,
   ROTARY_PROC_ERR         = -53,
//    /* light test */
//    LIGHT_PATH_ERR          = -50,
//    LIGHT_DEV_ERR           = -51,
//    /* ircut test */
//    IRCUT_STATE_ERR         = -60,
//    IRCUT_OPEN_ERR            = -61,
//    IRCUT_SET_ERR            = -62,
   /* sdcard test */
   SDCARD_SIZE_ERR         = -70,
   SDCARD_WRITE_ERR        = -71,
   SDCARD_READ_ERR         = -72,
   SDCARD_UNKNOWN_ERR      = -73,
   SDCARD_TIMEOUT_ERR      = -74,
   SDCARD_MOUNT_ERR        = -75,
   /* audio test */
   AUDIO_PLAY_ERR          = -80,
   AUDIO_RECORD_ERR        = -81,
   AUDIO_TYPE_ERR          = -82,
   /* wifi test */
   WIFI_RES_FILE_ERR       = -90,
   WIFI_RUN_ERR            = -91,
   WIFI_PROC_ERR           = -92,
   WIFI_UNKNOWN_ERR        = -93,
 
   /* ddr test */
   DDR_PROC_ERR            = -100,
   /* emmc test*/
   EMMC_PROC_ERR           = -110,
 
   /*usb host test*/
   USBHOST_UNKNOWN_ERR     = -120,
   USBHOST_TIMEOUT_ERR     = -121,
   USBHOST_MOUNT_ERR       = -122,
 
   /*infrard ray test*/
   IR_OPEN_FAIL            = -130,
   IR_EVENT_TIMEOUT        = -131,
   IR_QUERY_FAIL           = -132,
 
   /* camera test */
   CAMERA_PROC_ERR         = -200,
   CAMERA_DATA_ERR         = -201,
} RET_STA;
 
typedef enum _SDCARD_EVENT_ID {
   SDCARD_NOT_EVENT        = 0,
   SDCARD_UNMOUNT_EVENT    = 1,
   SDCARD_MOUNT_EVENT      = 2,
   SDCARD_MOUNT_NOTFIT     = 3,
   SDCARD_MOUNT_FAIL       = 4,
}SDCARD_EVENT_ID;
 
typedef enum _HDMI_EVENT_ID {
   HDMI_NOT_EVENT          = 0,
   HDMI_IN_EVENT           = 1,
   HDMI_OUT_EVENT          = 2,
}HDMI_EVENT_ID;
 
#define COMMAND_NAMESIZE        20
#define COMMAND_VALUESIZE       100
 
#define SDCARD_PATH             "/mnt/sdcard"
#define TEST_RESULT_SAVE_PATH   "/tmp"
 
//#define TEST_RESULT_SAVE_PATH "/data/cfg/rk_pcba_test"
 
 
//#define PCBA_TEST_PATH "/tmp"
//#define PCBA_TEST_PATH "/data/cfg/rk_pcba_test"
 
#define PCBA_TEST_PATH          "/data/"
#define MANUAL_TEST_TIMEOUT     60000000
#define RESULT_TESTING          "TESTING"
#define RESULT_PASS             "PASS"
#define RESULT_FAIL             "FAIL"
#define RESULT_VERIFY           "VERIFY"
#define RESULT_KEY_PRESS        "PRESS"
 
#define TESTITEM_SEND_PARSE        "%*[^<]<%[^>]>,<%[^>]>,<%d>"
#define TESTITEM_SEND_PARSE_NOMSG "%*[^<]<>,<%[^>]>,<%d>"
#define TESTITEM_SEND_HEAD      "[tcp_server]"
#define TESTITEM_SEND_FORMAT    "%s<%s>,<%s>,<%d>\n"
 
#define send_msg_to_server(msg, result, err_code) \
   printf(TESTITEM_SEND_FORMAT, TESTITEM_SEND_HEAD, msg, result, err_code)
#define send_msg_to_buf(buf, msg, result, err_code) \
   snprintf(buf, COMMAND_VALUESIZE, TESTITEM_SEND_FORMAT, TESTITEM_SEND_HEAD, msg, result, err_code)
 
 
#define LOG_DEBUG_LEVEL         (1)
#define LOG_ERROR_FLAG          (4)
#define LOG_WARING_FLAG         (3)
#define LOG_INFO_FLAG           (2)
#define LOG_DEBUG_FLAG          (1)
 
#define LOG_PRINTF(level, format, ...) \
   do { \
       if (level > LOG_DEBUG_LEVEL) { \
           printf("[%s]: "format, LOG_TAG, ##__VA_ARGS__); \
       } \
   } while(0)
#define log_info(format, ...) LOG_PRINTF(LOG_INFO_FLAG, format, ##__VA_ARGS__)
#define log_dbg(format, ...) LOG_PRINTF(LOG_DEBUG_FLAG, format, ##__VA_ARGS__)
#define log_warn(format, ...) LOG_PRINTF(LOG_WARING_FLAG, format, ##__VA_ARGS__)
#define log_err(format, ...) LOG_PRINTF(LOG_ERROR_FLAG, format, ##__VA_ARGS__)
 
#endif