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
|
#include "sapp_api.h"
#include "sapp_private_api.h"
#ifdef __cplusplus
extern "C" {
#endif
static const unsigned char MESA_art_log[] =
{
0x50, 0x72, 0x6F, 0x64, 0x75, 0x63, 0x65, 0x64, 0x20, 0x62, 0x79, 0x0D, 0x0A, 0x20, 0x20, 0x20,
0x20, 0x5F, 0x5F, 0x20, 0x20, 0x5F, 0x5F, 0x5F, 0x5F, 0x5F, 0x5F, 0x5F, 0x5F, 0x5F, 0x5F, 0x5F,
0x5F, 0x5F, 0x5F, 0x20, 0x5F, 0x5F, 0x5F, 0x0D, 0x0A, 0x20, 0x20, 0x20, 0x2F, 0x20, 0x20, 0x7C,
0x2F, 0x20, 0x20, 0x2F, 0x20, 0x5F, 0x5F, 0x5F, 0x5F, 0x2F, 0x20, 0x5F, 0x5F, 0x5F, 0x2F, 0x2F,
0x20, 0x20, 0x20, 0x7C, 0x0D, 0x0A, 0x20, 0x20, 0x2F, 0x20, 0x2F, 0x7C, 0x5F, 0x2F, 0x20, 0x2F,
0x20, 0x5F, 0x5F, 0x2F, 0x20, 0x20, 0x5C, 0x5F, 0x5F, 0x20, 0x5C, 0x2F, 0x20, 0x2F, 0x7C, 0x20,
0x7C, 0x0D, 0x0A, 0x20, 0x2F, 0x20, 0x2F, 0x20, 0x20, 0x2F, 0x20, 0x2F, 0x20, 0x2F, 0x5F, 0x5F,
0x5F, 0x20, 0x5F, 0x5F, 0x5F, 0x2F, 0x20, 0x2F, 0x20, 0x5F, 0x5F, 0x5F, 0x20, 0x7C, 0x0D, 0x0A,
0x2F, 0x5F, 0x2F, 0x20, 0x20, 0x2F, 0x5F, 0x2F, 0x5F, 0x5F, 0x5F, 0x5F, 0x5F, 0x2F ,0x2F, 0x5F,
0x5F, 0x5F, 0x5F, 0x2F, 0x5F, 0x2F, 0x20, 0x20, 0x7C, 0x5F, 0x7C, 0x0D, 0x0A, 0x00/* EOF */
};
int MESA_platform_init(int argc, char *argv[]);
void MESA_platform_run(void);
extern int sapp_args_v;
int dpdk_init(int argc, char **argv);
static void signal_user_handler(int signo)
{
//time_t last_time = time(NULL);
//while(time(NULL) < last_time + 10); /* wait 10 second, for DPDK IO module detect this process is not running */
signal(signo, SIG_DFL);
kill(getpid(), signo);
}
static void signal_hup_handler(int signo)
{
printf("SIGHUP recviced!\n");
MESA_handle_runtime_log_reconstruction(NULL);
}
static void signal_take_over(void)
{
sapp_config_t *pconfig = &sapp_global_val->config;
signal(SIGHUP, signal_hup_handler);
if (0 == sapp_global_single.signal_take_over_sw && 0 == pconfig->tools.signal_handler.signal)
{
return;
}
signal(SIGUSR1, signal_user_handler);
signal(SIGUSR2, signal_user_handler);
//signal(pconfig->tools.signal_handler.signal, signal_handler);
}
static void show_mesa_log(void)
{
int i;
for(i = 0; (i < sizeof(MESA_art_log)) && (MESA_art_log[i] != 0); i ++){
//putchar(MESA_log[i]);
printf("%c", MESA_art_log[i]);
}
printf("\n");
sapp_runtime_log(30, "\n\n%s", MESA_art_log);
}
int main(int argc, char *argv[])
{
int ret;
sapp_gval_init();
sapp_set_current_state(SAPP_STATE_JUST_START);
sapp_set_current_state(SAPP_STATE_CONFIG_PARSE);
if(argc >= 2){
/* ����������в���, �Ƚ���cla, ��Ϊ����ʹ��-h, -v�Ȱ�����Ϣ */
if(sapp_parse_cmd_args(argc, argv) < 0){
return -1;
}
ret = sapp_parse_config();
}else{
ret = sapp_parse_config();
}
if(ret < 0){
return -1;
}
sapp_cla_override_cfg_file();
show_mesa_log();
#if SAPP_INSECTICIDE
printf("\033[33m[Warning]This sapp is a temp version for solve confounded bug!\033[0m\n");
#endif
#if COMPAT_PAPP_FOR_BENCHMARK
printf("\033[33m[Warning]This sapp is a emasculate version for compare with papp, in other word, it's papp!\033[0m\n");
sleep(1);
#endif
sapp_init_breakpad_mini();
signal_take_over();
if(MESA_platform_init(argc, argv) < 0){
exit(1);
}
MESA_platform_run();
return 0;
}
#ifdef __cplusplus
}
#endif
|