equ.c 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943
  1. /******************************************************************************
  2. 版权所有:
  3. 文件名称: equ.c
  4. 文件版本: 01.01
  5. 创建作者: sunxi
  6. 创建日期: 2013-03-25
  7. 功能说明: 装置信息管理维护
  8. 其它说明:
  9. 修改记录:
  10. */
  11. /*------------------------------- 头文件 --------------------------------------
  12. */
  13. #include "head.h"
  14. /*------------------------------- 宏定义 --------------------------------------
  15. */
  16. /*------------------------------ 类型结构 -------------------------------------
  17. */
  18. /*------------------------------ 全局变量 -------------------------------------
  19. */
  20. // 装置通道配置文件
  21. struct equ_config g_equ_config_null; // 全0结构,防止访问异常
  22. struct equ_config *g_equ_config = &g_equ_config_null; // 装置配置文件头
  23. struct equ_config_di *g_equ_config_di; // 开入配置数组
  24. struct equ_config_do *g_equ_config_do; // 开出配置数组
  25. struct equ_config_ac *g_equ_config_ac; // 模拟量配置数组
  26. // 采样通道取反,以ADC为索引
  27. u8 g_equ_adc_inv[CFG_ADC_CHANNEL];
  28. int g_equ_adc_inv_num;
  29. // ADC通道是否配置
  30. u8 g_equ_adc_config[CFG_ADC_CHANNEL];
  31. // 板卡资源文件
  32. struct board_res_head g_board_res_head_null; // 全0结构,防止访问异常
  33. struct board_res_head *g_board_res_head = &g_board_res_head_null; // 板卡资源文件头
  34. struct board_res *g_board_res; // 板卡资源数组
  35. #if defined(CAN_SLAVE_BOARD)
  36. struct board_info g_board_info[EQU_SLOT_NUM_MAX+CAN_BOARD_NUM]; // 板卡实时信息
  37. #else
  38. struct board_info g_board_info[EQU_SLOT_NUM_MAX]; // 板卡实时信息
  39. #endif
  40. //已配置的开关数
  41. u32 g_sw_num;
  42. int g_slot_addr; // 插槽地址
  43. int g_hw_version; // 硬件版本
  44. u16 g_crc_brd_res;
  45. u16 g_crc_equ_cfg;
  46. // LED配置,按插槽配置
  47. struct led_config g_led_slot[EQU_SLOT_NUM_MAX];
  48. // equ文件比较用
  49. struct file_contrast g_equ_contrast;
  50. int g_sw_ac_num[SWITCH_NUM_MAX+1];
  51. int g_pub_ac_num;
  52. /*------------------------------ 函数声明 -------------------------------------
  53. */
  54. int _equ_get_di_num(u32 slot);
  55. int _equ_get_do_num(u32 slot);
  56. int _equ_get_ac_num(u32 slot);
  57. /*------------------------------ 外部函数 -------------------------------------
  58. 外部函数供其它实体文件引用,必须仔细检查传入参数的合法性.
  59. */
  60. char * equ_info_brd_type(int type)
  61. {
  62. int i;
  63. for(i=0; i<g_board_res_head->br_num; i++)
  64. {
  65. if(g_board_res[i].type == type)
  66. {
  67. return g_board_res[i].name;
  68. }
  69. }
  70. return 0;
  71. }
  72. /******************************************************************************
  73. 函数名称: equ_init_file_brd_res
  74. 函数版本: 01.01
  75. 创建作者: sunxi
  76. 创建日期: 2013-08-08
  77. 函数说明: 从板卡资源文件装载板卡资源。
  78. 参数说明:
  79. 返回值:
  80. 0: 成功
  81. 其它: 失败
  82. 修改记录:
  83. */
  84. int equ_init_file_brd_res(void)
  85. {
  86. u32 len;
  87. u8 *buf;
  88. struct board_res_head *brh;
  89. struct file * pfile;
  90. loff_t pos;
  91. // 打开文件
  92. pfile = rt_file_open("/app/data/brd_res.bin",O_RDONLY ,0);
  93. if(IS_ERR(pfile))
  94. {
  95. return -1;
  96. }
  97. // 得到文件长度
  98. len = rt_file_getfile_size(pfile);
  99. if(len <= 0)
  100. {
  101. rt_file_close(pfile,0);
  102. return -11;
  103. }
  104. // 分配内存
  105. buf = rt_malloc(len);
  106. if((buf) == NULL)
  107. {
  108. rt_file_close(pfile,0);
  109. return -2;
  110. }
  111. // 读出内容
  112. pos = 0;
  113. if(rt_file_read(pfile,buf,len,&pos) != len)
  114. {
  115. rt_file_close(pfile,0);
  116. rt_free(buf);
  117. return -3;
  118. }
  119. // 关闭文件
  120. rt_file_close(pfile,0);
  121. // 检查CRC
  122. g_crc_brd_res = CrcStr(buf,len-2);
  123. if(g_crc_brd_res != *(u16*)(buf+len-2))
  124. {
  125. rt_free(buf);
  126. return -4;
  127. }
  128. // 检查文件签名
  129. brh = (struct board_res_head*)buf;
  130. if(brh->cfh.signature != SIG_EQU_RES_FILE)
  131. {
  132. rt_free(buf);
  133. return -5;
  134. }
  135. // 检查文件长度
  136. if(len < sizeof(*brh) + brh->br_num*sizeof(struct board_res)+ 2)
  137. {
  138. rt_free(buf);
  139. return -6;
  140. }
  141. // 装置板卡资源
  142. g_board_res_head = (struct board_res_head *)buf;
  143. g_board_res = (struct board_res *)(buf + brh->br_addr);
  144. return 0;
  145. }
  146. /******************************************************************************
  147. 函数名称: equ_init_file_config
  148. 函数版本: 01.01
  149. 创建作者: sunxi
  150. 创建日期: 2013-08-08
  151. 函数说明: 从装置配置文件装载装置配置。
  152. 参数说明:
  153. 返回值:
  154. 0: 成功
  155. 其它: 失败
  156. 修改记录:
  157. */
  158. int equ_init_file_config(void)
  159. {
  160. u32 len,i;
  161. u8 *buf;
  162. struct file * pfile;
  163. loff_t pos;
  164. struct equ_config *ec;
  165. // 打开文件
  166. pfile = rt_file_open("/app/data/equ_cfg.bin",O_RDONLY ,0);
  167. if(IS_ERR(pfile))
  168. {
  169. return -1;
  170. }
  171. // 得到文件长度
  172. len = rt_file_getfile_size(pfile);
  173. if(len < sizeof(struct equ_config) + 2)
  174. {
  175. rt_file_close(pfile,0);
  176. return -11;
  177. }
  178. // 分配内存
  179. buf = rt_malloc(len);
  180. if((buf) == NULL)
  181. {
  182. rt_file_close(pfile,0);
  183. return -2;
  184. }
  185. // 读出内容
  186. pos = 0;
  187. if(rt_file_read(pfile,buf,len,&pos) != len)
  188. {
  189. rt_file_close(pfile,0);
  190. rt_free(buf);
  191. return -3;
  192. }
  193. // 关闭文件
  194. rt_file_close(pfile,0);
  195. // 检查CRC
  196. g_crc_equ_cfg = CrcStr(buf,len-2);
  197. if(g_crc_equ_cfg != *(u16*)(buf+len-2))
  198. {
  199. rt_free(buf);
  200. return -4;
  201. }
  202. // 检查文件签名
  203. ec = (struct equ_config *)buf;
  204. if(ec->cfh.signature != SIG_EQU_CFG_FILE)
  205. {
  206. rt_free(buf);
  207. return -5;
  208. }
  209. // 文件比较内容赋值
  210. g_equ_contrast.version = ec->cfh.version;
  211. g_equ_contrast.signature = ec->cfh.signature;
  212. g_equ_contrast.length = len;
  213. g_equ_contrast.crc = g_crc_equ_cfg;
  214. //比对资源表文件
  215. if ((ec->rsc_version != rsc_contrast.version)
  216. || (ec->rsc_signature != rsc_contrast.signature)
  217. || (ec->rsc_length != rsc_contrast.length)
  218. || (ec->rsc_crc != rsc_contrast.crc))
  219. {
  220. rt_printf("equ_version = 0x%x, rsc_version = 0x%x\r\n",ec->rsc_version, rsc_contrast.version);
  221. rt_printf("equ_signature = 0x%x, rsc_signature = 0x%x\r\n",ec->rsc_signature, rsc_contrast.signature);
  222. rt_printf("equ_length = 0x%x, rsc_length = 0x%x\r\n",ec->rsc_length, rsc_contrast.length);
  223. rt_printf("equ_crc = 0x%x, rsc_crc = 0x%x\r\n",ec->rsc_crc, rsc_contrast.crc);
  224. rt_free(buf);
  225. return -6;
  226. }
  227. // 装载配置
  228. g_equ_config = ec;
  229. g_equ_config_di = (struct equ_config_di *)(buf + g_equ_config->di_addr);
  230. g_equ_config_do = (struct equ_config_do *)(buf + g_equ_config->do_addr);
  231. g_equ_config_ac = (struct equ_config_ac *)(buf + g_equ_config->ac_addr);
  232. // 得到开关数量
  233. g_sw_num = 0;
  234. for(i=0;i<g_equ_config->di_num;i++)
  235. {
  236. if(g_equ_config_di[i].owner > g_sw_num && g_equ_config_di[i].index )
  237. {
  238. g_sw_num = g_equ_config_di[i].owner;
  239. }
  240. }
  241. for(i=0;i<g_equ_config->do_num;i++)
  242. {
  243. if(g_equ_config_do[i].owner > g_sw_num && g_equ_config_do[i].index )
  244. {
  245. g_sw_num = g_equ_config_do[i].owner;
  246. }
  247. }
  248. for(i=0;i<g_equ_config->ac_num;i++)
  249. {
  250. if( g_equ_config_ac[i].type == 0)
  251. {
  252. continue;
  253. }
  254. if(g_equ_config_ac[i].owner > g_sw_num && g_equ_config_ac[i].index )
  255. {
  256. g_sw_num = g_equ_config_ac[i].owner;
  257. }
  258. if( g_equ_config_ac[i].owner == 0)
  259. {
  260. g_pub_ac_num++;
  261. }
  262. else
  263. {
  264. g_sw_ac_num[ g_equ_config_ac[i].owner-1]++;
  265. }
  266. g_sw_ac_num[SWITCH_NUM_MAX]++;//总配置数
  267. }
  268. rt_printf("线路开关数量:程序=%d,配置=%d.\r\n",SWITCH_NUM_MAX,g_sw_num);
  269. if(g_sw_num > SWITCH_NUM_MAX)
  270. {
  271. return -7;
  272. }
  273. return 0;
  274. }
  275. /******************************************************************************
  276. 函数名称: equ_led_init
  277. 函数版本: 01.01
  278. 创建作者: xxxxxx
  279. 创建日期: 2015-04-16
  280. 函数说明: 开出类型LED初始化,找到对应的灯配置索引的GPIO
  281. 参数说明: 无
  282. 返回值: 成功返回0.
  283. 修改记录:
  284. */
  285. int equ_led_init(void)
  286. {
  287. int i, j, slot, index;
  288. // 默认没有配置任何灯
  289. for (i = 0; i < EQU_SLOT_NUM_MAX; i++)
  290. {
  291. g_led_slot[i].num = 0;
  292. for (j = 0; j < LED_MAX_NUM; j++)
  293. {
  294. g_led_slot[i].sn[j].no = LED_NULL;
  295. }
  296. }
  297. #if 0
  298. // 初始化公共灯
  299. for (i = 0; i < PUB_LED_NUM; i++)
  300. {
  301. index = g_sw_pub.led_cfg_index[i];
  302. if ((index != INDEX_INVALLID))
  303. {
  304. slot = g_equ_config_do[index].slot;
  305. index = g_equ_config_do[index].index;
  306. g_led_slot[slot].sn[index].sw = 0;
  307. g_led_slot[slot].sn[index].no = i;
  308. dp_info_h_c("i = %d, slot = %d, index = %d", i, slot, index);
  309. index++;
  310. if (index > g_led_slot[slot].num)
  311. {
  312. g_led_slot[slot].num = index;
  313. }
  314. }
  315. }
  316. // 初始化开关灯
  317. for (int sw = 0; sw < SWITCH_NUM_MAX; sw++)
  318. {
  319. for (i = 0; i < SW_LED_NUM; i++)
  320. {
  321. index = g_sw[sw].led_cfg_index[i];
  322. if ((index != INDEX_INVALLID))
  323. {
  324. slot = g_equ_config_do[index].slot;
  325. index = g_equ_config_do[index].index;
  326. dp_info_h_c("i = %d, slot = %d, index = %d, sw = %d", i, slot, index, sw);
  327. g_led_slot[slot].sn[index].sw = sw;
  328. g_led_slot[slot].sn[index].no = i;
  329. index++;
  330. if (index > g_led_slot[slot].num)
  331. {
  332. g_led_slot[slot].num = index;
  333. }
  334. }
  335. }
  336. }
  337. #endif
  338. return 0;
  339. }
  340. int equ_config_check(void)
  341. {
  342. int i;
  343. bool b_err=false;
  344. const int bank_cfg[EQU_SLOT_NUM_MAX]=
  345. {
  346. BOARD_TYPE_FUXI_DI,
  347. BOARD_TYPE_FUXI_DO,
  348. BOARD_TYPE_FUXI_AC,
  349. BOARD_TYPE_FUXI_24LED,
  350. BOARD_TYPE_MAIN,
  351. -1,
  352. -1,
  353. -1,
  354. -1,
  355. -1,
  356. -1,
  357. };
  358. for (i = 0; i < EQU_SLOT_NUM_MAX; i++)
  359. {
  360. if (bank_cfg[i] != -1 && bank_cfg[i] != g_board_info[i].type)
  361. {
  362. char *name;
  363. b_err = true;
  364. name = equ_info_brd_type(g_board_info[i].type);
  365. rt_printf("通道配置错误:slot=%d, 当前类型=%s, 应该配成%s\r\n", i, (name == NULL) ? "无" : name, equ_info_brd_type(bank_cfg[i]));
  366. }
  367. }
  368. return (b_err ? -1 : 0);
  369. }
  370. /******************************************************************************
  371. 函数名称: equ_init
  372. 函数版本: 01.01
  373. 创建作者: sunxi
  374. 创建日期: 2013-08-08
  375. 函数说明: 装置初始化
  376. 参数说明:
  377. 返回值:
  378. 0: 成功
  379. 其它: 失败
  380. 修改记录:
  381. */
  382. int equ_init(void)
  383. {
  384. int i, ret;
  385. struct timespec ts;
  386. // 得到装置地址和硬件版本
  387. g_slot_addr = gpio_get_addr();
  388. g_hw_version = gpio_get_version();
  389. rt_printf("g_hw_version=0x%02x, g_slot_addr=0x%02x.\r\n", g_hw_version, g_slot_addr);
  390. // 装置板卡资源
  391. ret = equ_init_file_brd_res();
  392. if (ret != 0)
  393. {
  394. rt_err_set(ERR_CODE_EQU_RESOURCE, 0);
  395. dp_err_n_c_rt("equ_init_file_resource err(ret=%d)", ret);
  396. return -1;
  397. }
  398. // 装载装置配置
  399. ret = equ_init_file_config();
  400. if (ret != 0)
  401. {
  402. rt_err_set(ERR_CODE_EQU_CONFIG, 0);
  403. dp_err_n_c_rt("equ_init_file_config err(ret=%d)", ret);
  404. return -2;
  405. }
  406. // 初始化板卡信息
  407. memset(g_board_info, 0, sizeof(g_board_info));
  408. clk_time_get(&ts);
  409. for (i = 0; i < g_equ_config->equ_slot_num; i++)
  410. {
  411. if (equ_info_brd_type(g_equ_config->brd_type[i]) == 0)
  412. {
  413. equ_led_init();
  414. dp_err_n_c_rt("板卡类型不存在(type=%d)!", g_equ_config->brd_type[i]);
  415. return -3;
  416. }
  417. g_board_info[i].type = g_equ_config->brd_type[i];
  418. g_board_info[i].di_num = _equ_get_di_num(i);
  419. g_board_info[i].do_num = _equ_get_do_num(i);
  420. g_board_info[i].ac_num = _equ_get_ac_num(i);
  421. if (0 != g_board_info[i].di_num)
  422. dp_info_nt("g_board_info[%d].di_num = %d ", i, g_board_info[i].di_num);
  423. if (0 != g_board_info[i].do_num)
  424. dp_info_nt("g_board_info[%d].do_num = %d ", i, g_board_info[i].do_num);
  425. if (0 != g_board_info[i].ac_num)
  426. dp_info_nt("g_board_info[%d].ac_num = %d ", i, g_board_info[i].ac_num);
  427. if ((g_board_info[i].type < BOARD_TYPE_GROUP_RS) && (g_board_info[i].di_num || g_board_info[i].do_num || g_board_info[i].ac_num))
  428. {
  429. // 板卡需要周期性的检查是否正常工作。
  430. g_board_info[i].is_check = 1;
  431. }
  432. g_board_info[i].us0 = ustimer_get_origin();
  433. g_board_info[i].is_ok = 1;
  434. // 主板信息
  435. if (g_board_info[i].type == BOARD_TYPE_MAIN)
  436. {
  437. g_board_info[i].crc = m_CodeCrc;
  438. g_board_info[i].version = VER_NUM;
  439. }
  440. }
  441. // 模拟通道配置
  442. memset(g_equ_adc_inv, 0, sizeof(g_equ_adc_inv));
  443. for (i = 0; i < g_equ_config->ac_num; i++)
  444. {
  445. u32 adc;
  446. adc = equ_get_ac_channel(g_equ_config_ac[i].slot, g_equ_config_ac[i].index);
  447. if (adc < CFG_ADC_CHANNEL)
  448. {
  449. // 是否配置
  450. if (g_equ_config_ac[i].type)
  451. {
  452. g_equ_adc_config[adc] = 1;
  453. }
  454. // 是否取反
  455. if (g_equ_config_ac[i].is_ct_inverse)
  456. {
  457. g_equ_adc_inv[g_equ_adc_inv_num++] = adc;
  458. }
  459. }
  460. }
  461. // 初始化灯
  462. equ_led_init();
  463. ret = equ_config_check();
  464. if (ret)
  465. {
  466. dp_err_n_c_rt("%s:ret=%d", __func__, ret);
  467. return -4;
  468. }
  469. equ_init_di();
  470. return 0;
  471. }
  472. /******************************************************************************
  473. 函数名称: equ_exit
  474. 函数版本: 01.01
  475. 创建作者: sunxi
  476. 创建日期: 2013-08-08
  477. 函数说明: 装置退出
  478. 参数说明:
  479. 返回值:
  480. 0: 成功
  481. 其它: 失败
  482. 修改记录:
  483. */
  484. int equ_exit(void)
  485. {
  486. if(g_equ_config && (g_equ_config != &g_equ_config_null))
  487. {
  488. rt_free(g_equ_config);
  489. }
  490. if(g_board_res_head && (g_board_res_head != &g_board_res_head_null))
  491. {
  492. rt_free(g_board_res_head);
  493. }
  494. return 0;
  495. }
  496. /******************************************************************************
  497. 函数名称: equ_get_di_num
  498. 函数版本: 01.01
  499. 创建作者: sunxi
  500. 创建日期: 2013-08-08
  501. 函数说明: 得到插槽中子板的开入资源个数
  502. 参数说明:
  503. slot 插槽索引号
  504. 返回值: 开入资源个数
  505. 修改记录:
  506. */
  507. int _equ_get_di_num(u32 slot)
  508. {
  509. int i;
  510. u8 type;
  511. if(slot >= g_equ_config->equ_slot_num)
  512. {
  513. return 0;
  514. }
  515. type = g_equ_config->brd_type[slot];
  516. for(i=0; i<g_board_res_head->br_num; i++)
  517. {
  518. if(g_board_res[i].type == type)
  519. {
  520. return g_board_res[i].di_num;
  521. }
  522. }
  523. return 0;
  524. }
  525. int equ_get_di_num(u32 slot)
  526. {
  527. return (slot >=EQU_SLOT_NUM_MAX) ? 0 : g_board_info[slot].di_num;
  528. }
  529. /******************************************************************************
  530. 函数名称: equ_get_do_num
  531. 函数版本: 01.01
  532. 创建作者: sunxi
  533. 创建日期: 2013-08-08
  534. 函数说明: 得到插槽中子板的开出资源个数
  535. 参数说明:
  536. slot 插槽索引号
  537. 返回值: 开出资源个数
  538. 修改记录:
  539. */
  540. int _equ_get_do_num(u32 slot)
  541. {
  542. int i;
  543. u8 type;
  544. if(slot >= g_equ_config->equ_slot_num)
  545. {
  546. return 0;
  547. }
  548. type = g_equ_config->brd_type[slot];
  549. for(i=0; i<g_board_res_head->br_num; i++)
  550. {
  551. if(g_board_res[i].type == type)
  552. {
  553. return g_board_res[i].do_num;
  554. }
  555. }
  556. return 0;
  557. }
  558. int equ_get_do_num(u32 slot)
  559. {
  560. return (slot >=EQU_SLOT_NUM_MAX) ? 0 : g_board_info[slot].do_num;
  561. }
  562. /******************************************************************************
  563. 函数名称: equ_get_ac_num
  564. 函数版本: 01.01
  565. 创建作者: sunxi
  566. 创建日期: 2013-08-08
  567. 函数说明: 得到插槽中子板的模拟量资源个数
  568. 参数说明:
  569. slot 插槽索引号
  570. 返回值: 模拟量资源个数
  571. 修改记录:
  572. */
  573. int _equ_get_ac_num(u32 slot)
  574. {
  575. int i;
  576. u8 type;
  577. if(slot >= g_equ_config->equ_slot_num)
  578. {
  579. return 0;
  580. }
  581. type = g_equ_config->brd_type[slot];
  582. for(i=0; i<g_board_res_head->br_num; i++)
  583. {
  584. if(g_board_res[i].type == type)
  585. {
  586. return g_board_res[i].ac_num;
  587. }
  588. }
  589. return 0;
  590. }
  591. int equ_get_ac_num(u32 slot)
  592. {
  593. return (slot >=EQU_SLOT_NUM_MAX) ? 0 : g_board_info[slot].ac_num;
  594. }
  595. int equ_get_ac_scale(u8 slot,u8 no)
  596. {
  597. int i;
  598. for(i=0; i< g_equ_config->ac_num; i++)
  599. {
  600. if((g_equ_config_ac[i].slot==slot)&&(g_equ_config_ac[i].index==no))
  601. {
  602. return g_equ_config_ac[i].scale;
  603. }
  604. }
  605. return -1;
  606. }
  607. /******************************************************************************
  608. 函数名称: equ_get_slot_by_type
  609. 函数版本: 01.01
  610. 创建作者: sunxi
  611. 创建日期: 2013-08-08
  612. 函数说明: 通过子板的类型查找插槽。
  613. 参数说明:
  614. type 子板类型。
  615. 返回值: 插槽号
  616. 修改记录:
  617. */
  618. u32 equ_get_slot_by_type(u8 type)
  619. {
  620. u32 i;
  621. struct board_info *bi;
  622. bi = g_board_info;
  623. for(i=0; i<g_equ_config->equ_slot_num; i++)
  624. {
  625. if(equ_slot_check(i) != 0)
  626. {
  627. continue;
  628. }
  629. if(g_board_info[i].type == type)
  630. {
  631. return i;
  632. }
  633. }
  634. return 0;
  635. }
  636. /******************************************************************************
  637. 函数名称: equ_slot_check
  638. 函数版本: 01.01
  639. 创建作者: sunxi
  640. 创建日期: 2013-08-08
  641. 函数说明: 检查对应插槽中的子板是否正常。
  642. 参数说明:
  643. slot 插槽索引号
  644. 返回值: 插槽号
  645. 0: 成功
  646. 其它: 失败
  647. 修改记录:
  648. */
  649. int equ_slot_check(u32 slot)
  650. {
  651. if(slot >= g_equ_config->equ_slot_num)
  652. {
  653. return -1;
  654. }
  655. if(g_board_info[slot].is_ok == 0)
  656. {
  657. return -2;
  658. }
  659. return 0;
  660. }
  661. /******************************************************************************
  662. 函数名称: equ_di_name
  663. 函数版本: 01.01
  664. 创建作者: sunxi
  665. 创建日期: 2013-08-08
  666. 函数说明: 从板卡号和硬件编号得到开入点的名称
  667. 参数说明:
  668. slot 插槽索引号
  669. index 子板上开入索引号
  670. 返回值: 开入点的名称
  671. 修改记录:
  672. */
  673. char * equ_di_name(u8 slot,u8 no)
  674. {
  675. int i;
  676. for(i=0; i< g_equ_config->di_num; i++)
  677. {
  678. if((g_equ_config_di[i].slot==slot)&&(g_equ_config_di[i].index==no))
  679. {
  680. return shield_str(&g_equ_config_di[i]);
  681. }
  682. }
  683. return 0;
  684. }
  685. u8 equ_di_type(u8 slot,u8 no)
  686. {
  687. int i;
  688. for(i=0; i< g_equ_config->di_num; i++)
  689. {
  690. if((g_equ_config_di[i].slot==slot)&&(g_equ_config_di[i].index==no)&&(g_equ_config_di[i].owner>0)) //只有开关遥信才返回真正类型
  691. {
  692. return g_equ_config_di[i].type;
  693. }
  694. }
  695. return 0;
  696. }
  697. u8 equ_pub_di_type(u8 slot,u8 no)
  698. {
  699. int i;
  700. for(i=0; i< g_equ_config->di_num; i++)
  701. {
  702. if((g_equ_config_di[i].slot==slot)&&(g_equ_config_di[i].index==no)&&(g_equ_config_di[i].owner==0)) //公共类型
  703. {
  704. return g_equ_config_di[i].type;
  705. }
  706. }
  707. return 0;
  708. }
  709. /*------------------------------ 内部函数 -------------------------------------
  710. 内部函数以下划线‘_’开头,不需要检查参数的合法性.
  711. */
  712. /*------------------------------ 测试函数 -------------------------------------
  713. 一个实体文件必须带一个本模块的测试函数来进行单元测试,如果的确不方便在本模块中
  714. 进行单元测试,必须在此注明实际的测试位置(例如在哪个实体文件中使用哪个测试函数).
  715. */
  716. int equ_info_printf(void)
  717. {
  718. int i;
  719. struct rtc_time_t rtc;
  720. struct timespec ts;
  721. struct board_res *br;
  722. struct board_info *bi;
  723. rt_printf("板卡资源信息:%s(可配置开关:%d,实际配置开关:%d):slot=%d\r\n",g_equ_config->equ_name,g_equ_config->equ_sw_num,g_sw_num,g_equ_config->equ_slot_num);
  724. br = g_board_res;
  725. rt_printf("name\t\ttype\tdi_num\tdo_num\tac_num\r\n");
  726. for(i=0; i<g_board_res_head->br_num; i++)
  727. {
  728. rt_printf("%-9s\t%03d\t%02d\t%02d\t%02d\r\n",br[i].name,br[i].type,br[i].di_num,br[i].do_num,br[i].ac_num);
  729. }
  730. bi = g_board_info;
  731. rt_printf("\r\nslot\ttype\tcan\tstatus\terrcode\tcrc\tversion\t\ttime\r\n");
  732. for(i=0; i<g_equ_config->equ_slot_num; i++)
  733. {
  734. rt_printf("%02d %s[%02d]\t%02d\t%02d\t%02d\t%04x\t%08x\t",i,equ_info_brd_type(bi[i].type),bi[i].type,bi[i].can_bus,bi[i].status,bi[i].errcode,bi[i].crc,bi[i].version);
  735. timespec_to_rtc(bi[i].update_time,&rtc,0);
  736. rt_printf("%04d-%02d-%02d %02d:%02d:%02d:%09d\r\n",
  737. rtc.year + 2000, rtc.month, rtc.day, rtc.hour, rtc.min, rtc.ms/1000,bi[i].update_time.tv_nsec );
  738. }
  739. clk_time_get(&ts);
  740. timespec_to_rtc(ts,&rtc,0);
  741. rt_printf("now:%04d-%02d-%02d %02d:%02d:%02d:%09d\r\n",
  742. rtc.year + 2000, rtc.month, rtc.day, rtc.hour, rtc.min, rtc.ms/1000,ts.tv_nsec );
  743. return 0;
  744. }
  745. int equ_info_printf_di(void)
  746. {
  747. int i;
  748. struct equ_config_di *cdi;
  749. cdi = g_equ_config_di;
  750. rt_printf("\r\nslot\tindex\ttype\towner\tfilter\tis_inv\tname\r\n");
  751. for(i=0; i<g_equ_config->di_num; i++)
  752. {
  753. rt_printf("%02d\t%02d\t%02d\t%d\t%d\t%d\t%s\r\n",
  754. cdi[i].slot,cdi[i].index+1,cdi[i].type,cdi[i].owner,cdi[i].filter_time,cdi[i].is_Inverse,cdi[i].name);
  755. }
  756. return 0;
  757. }
  758. int equ_info_printf_do(void)
  759. {
  760. int i;
  761. struct equ_config_do *cdo;
  762. cdo = g_equ_config_do;
  763. rt_printf("\r\nslot\tindex\ttype\towner\tpulse_t\tname\r\n");
  764. for(i=0; i<g_equ_config->do_num; i++)
  765. {
  766. rt_printf("%02d\t%02d\t%02d\t%d\t%d\t%s\r\n",
  767. cdo[i].slot,cdo[i].index+1,cdo[i].type,cdo[i].owner, cdo[i].time_pulse,cdo[i].name);
  768. }
  769. return 0;
  770. }
  771. int equ_info_printf_ac(void)
  772. {
  773. int i;
  774. struct equ_config_ac *cac;
  775. cac = g_equ_config_ac;
  776. rt_printf("\r\nslot\tindex\ttype\towner\tct_inv\tscale\tname\r\n");
  777. for(i=0; i<g_equ_config->ac_num; i++)
  778. {
  779. rt_printf("%02d\t%02d\t%02d\t%d\t%d\t%d\t%s\r\n",
  780. cac[i].slot,cac[i].index+1,cac[i].type,cac[i].owner,
  781. cac[i].is_ct_inverse,cac[i].scale,cac[i].name);
  782. }
  783. return 0;
  784. }
  785. /*------------------------------ 文件结束 -------------------------------------
  786. */