main_mod.c 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556
  1. /******************************************************************************
  2. 版权所有:
  3. 文件名称: main_mod.c
  4. 文件版本: 01.01
  5. 创建作者: sunxi
  6. 创建日期: 2025-06-09
  7. 功能说明: 实时微系统。
  8. 其它说明:
  9. 修改记录:
  10. */
  11. #include <linux/fs.h>
  12. #include <linux/sched.h>
  13. #include <linux/wait.h>
  14. #include "bsp.h"
  15. #include "rt.h"
  16. #include "app.h"
  17. #include "head.h"
  18. #include "tmp/bsp_share/bsp_ustimer.h"
  19. #include <sys/prctl.h>
  20. #include <sys/types.h>
  21. #include <sys/syscall.h>
  22. #include <signal.h>
  23. #include <stdbool.h>
  24. #include <errno.h>
  25. #include <stdio.h>
  26. // #define __USE_GNU
  27. #define _GNU_SOURCE
  28. #include <sched.h>
  29. #include <pthread.h>
  30. static int m_reset; //看门狗复位变量
  31. struct completion *g_exit_completion_gprs_net_IEC_proc;
  32. static int g_exit_flag;
  33. bool SystemInit_finish_flag __attribute__((aligned(8))) = false;
  34. static int sync_cnt = 0;
  35. static pthread_t sync_tid = 0;
  36. enum
  37. {
  38. PTHREAD_MQ=0, // 消息队列
  39. PTHREAD_C0NSOLE, // 控制台
  40. PTHREAD_PRINTF, // 打印信息
  41. PTHREAD_MAIN_LOOP, // 主循环
  42. PTHREAD_MAIN_APP,
  43. PTHREAD_MAIN_DIDO_ADC,
  44. PTHREAD_RCD, // 录波
  45. PTHREAD_CAL_SAMPLE,
  46. PTHREAD_MAX_NUM
  47. };
  48. pthread_t AW_DTU_PTHREAD_TAB[PTHREAD_MAX_NUM]; //线程表
  49. struct rt_stat g_stat_periodus_5ms;
  50. int app_main (void *arg);
  51. int di_do_adc (void *arg);
  52. #ifdef ENCRYPT_SM2
  53. int gh_sm2_dev_init(void);
  54. void gh_sm2_dev_exit(void);
  55. #endif
  56. int console_init(void);
  57. void console_exit(void);
  58. int encrypt_test(void);
  59. int snprintf_test(void);
  60. extern void uart_putchar (int channel, char ch);
  61. extern int net_if_test(void);
  62. extern int clk_test(void);
  63. extern int ac_e2prom_test(void);
  64. void watchdog_m_reset(int flag){}
  65. extern int printf_e907_exit(void);
  66. int kernel_callback(void);
  67. static void main_mod_exit(int signo);
  68. // static DECLARE_WAIT_QUEUE_HEAD(wq);
  69. static int g_soft_irq_flag = 0;
  70. static struct proc_dir_entry *corp_info_proc_entry;
  71. int corp_info_read_proc(char *buf, char **start, off_t offset, int len, int *eof, void *data)
  72. {
  73. sprintf(buf, "XXXXXX XXXXXX XXXXXXX XXXXX XXXXXXX Co.,Ltd(XXXXXXXXXX) 2025\r\n");
  74. len = strlen(buf);
  75. return len;
  76. }
  77. pid_t gettid()
  78. {
  79. return syscall(SYS_gettid);
  80. }
  81. int mainloop_soft_isr(int irq, void *dev_id)
  82. {
  83. // int offset=0,tmp,count=1,count2=1,count3=0;
  84. // struct timespec ts;
  85. // struct rtc_time_t rtcs;
  86. struct sched_param sch_par;
  87. sch_par.sched_priority = 6;
  88. pthread_setschedparam(pthread_self(), SCHED_RR, &sch_par); // 设置当前线程优先级
  89. prctl(PR_SET_NAME, "mainloop_soft_isr_thread");
  90. #ifdef RT_THREAD_DEBUG
  91. rt_printf("Thread created successfully: %s,PID: %d LWP: %d\r\n",
  92. "mainloop_soft_isr_thread", (int)getpid(), (int)syscall(SYS_gettid));
  93. #endif
  94. while(1)
  95. {
  96. msleep(100);// 延时100ms
  97. kernel_callback();
  98. #if 0
  99. if(count++>=40)
  100. {
  101. //gps_get_time(&ts);
  102. //timespec_to_rtc(ts, &rtcs, 0);
  103. //tmp=GetUsCounterValue();
  104. //offset=tmp-offset;
  105. //rt_printf("%d---%d-%d-%d,%d:%d:%d mainloop=%d,offset=%d\r\n",ts.tv_sec,rtcs.year,rtcs.month,rtcs.day,rtcs.hour,rtcs.min,rtcs.ms,tmp,offset);
  106. //offset=tmp;
  107. //rt_printf("di=0x%08X\r\n",gpio_get_di());
  108. if(count3==0)
  109. gpio_kout_do(0,DO_OUT7);
  110. else
  111. {
  112. if((count3-1)!=DO_OUT4)
  113. gpio_kout_do(0,count3-1);
  114. }
  115. gpio_kout_do(1,count3);
  116. rt_printf("count=%d\r\n",count3);
  117. ++count3;
  118. if(count3>=DO_NUM)
  119. count3=0;
  120. gpio_kout_do(1,DO_PWM0);
  121. count=1;
  122. }
  123. #endif
  124. }
  125. }
  126. void mainloop_wakeup(void)
  127. {
  128. //rt_sirq_force(11);
  129. }
  130. int kernel_callback(void)
  131. {
  132. static unsigned char init_end_flag = 0; // sunxi 20190416 added
  133. // 延时100ms
  134. //wait_event_interruptible_timeout(wq,g_soft_irq_flag,HZ/10);
  135. g_soft_irq_flag = 0;
  136. // sunxi 20190416 added start
  137. if(!init_end_flag)
  138. {
  139. //corp_info_proc_entry = create_proc_entry("corp_info", 0400, NULL);
  140. if (corp_info_proc_entry)
  141. {
  142. //corp_info_proc_entry->read_proc = corp_info_read_proc;
  143. //corp_info_proc_entry->write_proc = NULL;
  144. }
  145. init_end_flag = 1;
  146. }
  147. // sunxi 20190416 added end
  148. // 检查是否需要退出。
  149. if(g_exit_flag)
  150. {
  151. hzk_exit();
  152. led_exit();
  153. net_debug_exit();
  154. net_debug_s_exit();
  155. if(g_exit_completion_gprs_net_IEC_proc)
  156. {
  157. ;//wait_for_completion(g_exit_completion_gprs_net_IEC_proc);
  158. }
  159. printf_e907_exit();
  160. //complete_and_exit(&exit_completion, 1);
  161. }
  162. return 0;
  163. }
  164. int cal_thread (void *arg)
  165. {
  166. uint32_t us0;
  167. int ms;
  168. struct sched_param sch_par;
  169. sch_par.sched_priority = 8;
  170. pthread_setschedparam(pthread_self(), SCHED_RR, &sch_par); // 设置当前线程优先级暂定 20200910
  171. while(SystemInit_finish_flag == false)
  172. {
  173. msleep(10);
  174. }
  175. uint32_t wdt_id;
  176. int rc = watchdog_add_item("cal_thread", &wdt_id,120);
  177. if(rc != 0) {
  178. printf("can not add cal_thread task to wdt\r\n");
  179. return -1;
  180. }
  181. ms = 50;
  182. us0 = ustimer_get_origin();
  183. prctl(PR_SET_NAME, "cal_thread");
  184. #ifdef RT_THREAD_DEBUG
  185. rt_printf("Thread created successfully: %s, PID: %d LWP: %d\r\n",
  186. "cal_thread", (int)getpid(), (int)syscall(SYS_gettid));
  187. #endif
  188. while(1)
  189. {
  190. watchdog_feed(wdt_id);
  191. // 100ms执行一次
  192. ms = 50 - (ustimer_get_duration(us0)/USTIMER_US+ 500)/1000;
  193. if(ms < 0)
  194. {
  195. ms = 0;
  196. }
  197. msleep(ms);
  198. us0 = ustimer_get_origin();
  199. // 检查是否需要退出。
  200. if(g_exit_flag)
  201. {
  202. //complete_and_exit(&exit_completion2, 1);
  203. break;
  204. }
  205. sw_cal_app();
  206. hisory_file_app();
  207. //pw_quality_app();
  208. }
  209. watchdog_remove_item(wdt_id);
  210. return 0;
  211. }
  212. int main_mod_is_exit(void)
  213. {
  214. return g_exit_flag;
  215. }
  216. // sunxi 20190417 added start
  217. /*
  218. * 该接口在模块装载时调用,防止我们的模块在之前的内核版本中能被轻易使用。函数名称不要定义跟功能一样。
  219. */
  220. int mod_init(void)
  221. {
  222. char buf[256] = {0x00};
  223. int fd = rt_file_open("/proc/version", O_RDONLY, 0);
  224. if(fd < 0)
  225. return -1;
  226. rt_file_read(fd, buf, 256, NULL);
  227. rt_file_close(fd, 0);
  228. if(strstr(buf, "root@Ubuntu") && strstr(buf, "-LYQ"))
  229. return 0;
  230. return -3;
  231. }
  232. int di_do_adc (void *unused)
  233. {
  234. pid_t tid;
  235. cpu_set_t set;
  236. struct sched_param sch_par;
  237. sch_par.sched_priority = 99;
  238. // Set CPU affinity [T536-CPU-3]
  239. tid = gettid();
  240. CPU_ZERO(&set);
  241. CPU_SET(3, &set);
  242. sched_setaffinity(tid, sizeof(cpu_set_t), &set);
  243. while(SystemInit_finish_flag == false)
  244. {
  245. msleep(10);
  246. }
  247. uint32_t wdt_id;
  248. int rc = watchdog_add_item("di_do_adc", &wdt_id,120);
  249. if(rc != 0) {
  250. printf("can not add di_do_adc task to wdt\r\n");
  251. return -1;
  252. }
  253. //adc_init();
  254. dido_init();
  255. rt_stat_init(&g_stat_periodus_5ms, "pit_5ms_priod(1us)");
  256. pthread_setschedparam(pthread_self(), SCHED_FIFO, &sch_par); // 设置当前线程优先级
  257. prctl(PR_SET_NAME, "di_do_adc");
  258. #ifdef RT_THREAD_DEBUG
  259. rt_printf("Thread created successfully: %s, PID: %d LWP: %d\r\n",
  260. "di_do_adc", (int)getpid(), (int)syscall(SYS_gettid));
  261. #endif
  262. while(1)
  263. {
  264. static u8 flags = 0;
  265. static unsigned long us1 = 0;
  266. unsigned long origin_ext = 0;
  267. usleep(1000);
  268. // bsp_ustimer_delay(1000); // 1ms
  269. // 检查是否需要退出。
  270. if(g_exit_flag)
  271. {
  272. //complete_and_exit(&exit_completion2, 1);
  273. break;
  274. }
  275. origin_ext = bsp_ustimer_get_origin();
  276. if (flags) {
  277. rt_stat_in(&g_stat_periodus_5ms, (origin_ext - us1));
  278. }
  279. watchdog_feed(wdt_id);
  280. adc_isr(0);
  281. //保护计算
  282. if(prt_flag)
  283. {
  284. pit_5ms_main(0);
  285. prt_flag=false;
  286. }
  287. // led_polling_5ms(); // ewen 临时测试用 ygl -
  288. us1 = origin_ext;
  289. flags = 1;
  290. }
  291. watchdog_remove_item(wdt_id);
  292. return 0;
  293. }
  294. //当装置修改app文件夹里面的文件时,需要调用该函数,以sync_cnt数减为0时,调用sync,写入flash,保存数文件。
  295. void start_sync(void)
  296. {
  297. sync_cnt = 50;//500ms
  298. }
  299. static int sync_func(void *arg)
  300. {
  301. // int ret = 0;
  302. uint32_t wdt_id;
  303. int rc = watchdog_add_item("sync_func", &wdt_id,60);
  304. if(rc != 0) {
  305. printf("can not add sync_func task to wdt\r\n");
  306. return 0;
  307. }
  308. sync_cnt = 0;
  309. prctl(PR_SET_NAME, "sync_func");
  310. #ifdef RT_THREAD_DEBUG
  311. rt_printf("Thread created successfully: %s, PID: %d LWP: %d\r\n",
  312. "sync_func", (int)getpid(), (int)syscall(SYS_gettid));
  313. #endif
  314. while(1)
  315. {
  316. msleep(10);
  317. watchdog_feed(wdt_id);
  318. if(main_mod_is_exit())
  319. {
  320. break;
  321. }
  322. if(sync_cnt > 0)
  323. {
  324. if(--sync_cnt <= 0)
  325. {
  326. system("sync");
  327. // rt_printf_time("--- sync.\r\n");
  328. }
  329. }
  330. }
  331. watchdog_remove_item(wdt_id);
  332. return 0;
  333. }
  334. int main(void)
  335. {
  336. // pid_t pid;
  337. char *argv[] = { "/sbin/ifconfig", "eth1", "192.168.2.100",NULL};
  338. char *envp[] = { NULL };
  339. // struct task_struct * ts;
  340. // struct sched_param sp;
  341. int ret;
  342. SystemInit_finish_flag = false;
  343. //停止喂狗,让程序复位.在命令行中输入insmod f306.ko m_reset=1
  344. if(m_reset==1)
  345. {
  346. rt_printf("watchdog_m_reset(1)...\n");
  347. watchdog_m_reset(1);
  348. return 0;
  349. }
  350. call_usermodehelper("/sbin/ifconfig", argv, envp, UMH_WAIT_PROC);
  351. //if(mod_init() < 0) //jack.liu 20200904 认证信息先不使用
  352. // return -1;
  353. bsp_init(); // bsp必须先初始化
  354. rt_init(); // 实时系统后初始化
  355. app_init(); // 应用初始化最后初始化
  356. adc_init();
  357. // 建立主函数入口线程
  358. ret = pthread_create(&AW_DTU_PTHREAD_TAB[PTHREAD_MAIN_LOOP], NULL, (void *)mainloop_soft_isr, NULL);
  359. if(ret)
  360. {
  361. rt_printf("mainloop_soft_isr thread create failed!\r\n");
  362. rt_printf("ret = %d, err = %s\r\n", ret, strerror(ret));
  363. memset((char *)&AW_DTU_PTHREAD_TAB,0,sizeof(AW_DTU_PTHREAD_TAB));
  364. return ret;
  365. }
  366. // 创建主循环线程
  367. ret = pthread_create(&AW_DTU_PTHREAD_TAB[PTHREAD_MAIN_APP], NULL, (void *)app_main, NULL);
  368. if(ret)
  369. {
  370. rt_printf("app_main thread create failed!\r\n");
  371. rt_printf("ret = %d, err = %s\r\n", ret, strerror(ret));
  372. AW_DTU_PTHREAD_TAB[PTHREAD_MAIN_APP] = 0;
  373. memset((char *)&AW_DTU_PTHREAD_TAB,0,sizeof(AW_DTU_PTHREAD_TAB));
  374. return ret;
  375. }
  376. #if 1
  377. // 创建三遥线程
  378. ret = pthread_create(&AW_DTU_PTHREAD_TAB[PTHREAD_MAIN_DIDO_ADC], NULL, (void *)di_do_adc, NULL);
  379. if(ret)
  380. {
  381. rt_printf("di_do_adc thread create failed!\r\n");
  382. rt_printf("ret = %d, err = %s\r\n", ret, strerror(ret));
  383. AW_DTU_PTHREAD_TAB[PTHREAD_MAIN_DIDO_ADC] = 0;
  384. memset((char *)&AW_DTU_PTHREAD_TAB,0,sizeof(AW_DTU_PTHREAD_TAB));
  385. return ret;
  386. }
  387. // 创建采样数据计算线程
  388. ret = pthread_create(&AW_DTU_PTHREAD_TAB[PTHREAD_CAL_SAMPLE], NULL, (void *)cal_thread, NULL);
  389. if(ret)
  390. {
  391. rt_printf("cal_thread thread create failed!\r\n");
  392. rt_printf("ret = %d, err = %s\r\n", ret, strerror(ret));
  393. AW_DTU_PTHREAD_TAB[PTHREAD_CAL_SAMPLE] = 0;
  394. memset((char *)&AW_DTU_PTHREAD_TAB,0,sizeof(AW_DTU_PTHREAD_TAB));
  395. return ret;
  396. }
  397. ret = pthread_create(&sync_tid, NULL, (void *)sync_func, NULL);
  398. if(ret)
  399. {
  400. rt_printf("ret = %d, err = %s\r\n", ret, strerror(ret));
  401. sync_tid = 0;
  402. return ret;
  403. }
  404. // 设置进程名字
  405. prctl( PR_SET_NAME, "AW_DTU_CALL", 0, 0, 0);
  406. signal(SIGINT, main_mod_exit);
  407. #endif
  408. #ifdef RT_THREAD_DEBUG
  409. rt_printf("thread create success!\r\n");
  410. #endif
  411. // 主线程阻塞
  412. while(1) {
  413. usleep(1000*100);
  414. }
  415. return 0;
  416. }
  417. int net_debug_exit(void);
  418. int net_maintain_exit(void);
  419. int net_104_exit(void);
  420. static void main_mod_exit(int signo)
  421. {
  422. if (corp_info_proc_entry)
  423. {
  424. ;//remove_proc_entry("corp_info", NULL);
  425. }
  426. //
  427. if(m_reset == 1)
  428. {
  429. watchdog_m_reset(0);
  430. rt_printf("watchdog_m_reset(0)...\n");
  431. return ;
  432. }
  433. //gh_sm2_dev_exit();
  434. //console_exit();
  435. //watchdog_unregister_all();
  436. //rt_sirq_unregister(RT_SOFT_IRQ_MAINLOOP);
  437. net_maintain_exit();
  438. net_104_exit();
  439. net_104link_exit();
  440. g_exit_flag = 1;
  441. //wait_for_completion(&exit_completion);
  442. //wait_for_completion(&exit_completion2);
  443. app_exit();
  444. rt_exit();
  445. bsp_exit();
  446. // sunxi 20190418 goose_app_exit();
  447. open_inet_port();
  448. rt_printf("main_mod_exit\n");
  449. }