equ.c 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935
  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;
  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. index++;
  309. if(index > g_led_slot[slot].num)
  310. {
  311. g_led_slot[slot].num = index;
  312. }
  313. }
  314. }
  315. // 初始化开关灯
  316. for(sw=0; sw<SWITCH_NUM_MAX; sw++)
  317. {
  318. for(i=0; i< SW_LED_NUM; i++)
  319. {
  320. index = g_sw[sw].led_cfg_index[i];
  321. if ((index != INDEX_INVALLID))
  322. {
  323. slot = g_equ_config_do[index].slot;
  324. index = g_equ_config_do[index].index;
  325. g_led_slot[slot].sn[index].sw = sw;
  326. g_led_slot[slot].sn[index].no = i;
  327. index++;
  328. if(index > g_led_slot[slot].num)
  329. {
  330. g_led_slot[slot].num = index;
  331. }
  332. }
  333. }
  334. }
  335. #endif
  336. return 0;
  337. }
  338. int equ_config_check(void)
  339. {
  340. int i;
  341. bool b_err=false;
  342. const int bank_cfg[EQU_SLOT_NUM_MAX]=
  343. {
  344. BOARD_TYPE_FUXI_DI,
  345. BOARD_TYPE_FUXI_DO,
  346. BOARD_TYPE_FUXI_AC,
  347. -1,
  348. -1,
  349. -1,
  350. -1,
  351. -1,
  352. -1,
  353. -1,
  354. -1,
  355. };
  356. for(i=0;i<EQU_SLOT_NUM_MAX;i++)
  357. {
  358. if(bank_cfg[i] != -1 && bank_cfg[i]!=g_board_info[i].type)
  359. {
  360. char *name;
  361. b_err=true;
  362. name = equ_info_brd_type(g_board_info[i].type);
  363. rt_printf("通道配置错误:slot=%d,当前类型=%s,应该配成%s\r\n",i,(name==NULL)?"无":name,equ_info_brd_type(bank_cfg[i]));
  364. }
  365. }
  366. return (b_err?-1:0);
  367. }
  368. /******************************************************************************
  369. 函数名称: equ_init
  370. 函数版本: 01.01
  371. 创建作者: sunxi
  372. 创建日期: 2013-08-08
  373. 函数说明: 装置初始化
  374. 参数说明:
  375. 返回值:
  376. 0: 成功
  377. 其它: 失败
  378. 修改记录:
  379. */
  380. int equ_init(void)
  381. {
  382. int i,ret;
  383. struct timespec ts;
  384. // 得到装置地址和硬件版本
  385. g_slot_addr = gpio_get_addr();
  386. g_hw_version = gpio_get_version();
  387. rt_printf("g_hw_version=0x%02x, g_slot_addr=0x%02x.\r\n",g_hw_version,g_slot_addr);
  388. // 装置板卡资源
  389. ret = equ_init_file_brd_res();
  390. if(ret != 0)
  391. {
  392. rt_err_set(ERR_CODE_EQU_RESOURCE,0);
  393. dp_err_n_c_rt("equ_init_file_resource err(ret=%d)\r\n",ret);
  394. return -1;
  395. }
  396. // 装载装置配置
  397. ret = equ_init_file_config();
  398. if(ret != 0)
  399. {
  400. rt_err_set(ERR_CODE_EQU_CONFIG,0);
  401. dp_err_n_c_rt("equ_init_file_config err(ret=%d)\r\n",ret);
  402. return -2;
  403. }
  404. // 初始化板卡信息
  405. memset(g_board_info,0,sizeof(g_board_info));
  406. clk_time_get(&ts);
  407. for(i=0; i<g_equ_config->equ_slot_num; i++)
  408. {
  409. if(equ_info_brd_type(g_equ_config->brd_type[i]) == 0)
  410. {
  411. equ_led_init();
  412. dp_err_n_c_rt("板卡类型不存在(type=%d)!\r\n",g_equ_config->brd_type[i]);
  413. return -3;
  414. }
  415. g_board_info[i].type = g_equ_config->brd_type[i];
  416. g_board_info[i].di_num = _equ_get_di_num(i);
  417. g_board_info[i].do_num = _equ_get_do_num(i);
  418. g_board_info[i].ac_num = _equ_get_ac_num(i);
  419. if((g_board_info[i].type < BOARD_TYPE_GROUP_RS)
  420. && (g_board_info[i].di_num || g_board_info[i].do_num || g_board_info[i].ac_num))
  421. {
  422. // 板卡需要周期性的检查是否正常工作。
  423. g_board_info[i].is_check = 1;
  424. }
  425. g_board_info[i].us0 = ustimer_get_origin();
  426. g_board_info[i].is_ok = 1;
  427. // 主板信息
  428. if(g_board_info[i].type == BOARD_TYPE_MAIN || g_board_info[i].type == BOARD_TYPE_FTUMAIN || g_board_info[i].type == BOARD_TYPE_FBDTU_MAIN|| g_board_info[i].type == BOARD_TYPE_FBDTU_MAIN1)
  429. {
  430. g_board_info[i].crc = m_CodeCrc;
  431. g_board_info[i].version = VER_NUM;
  432. }
  433. }
  434. // 模拟通道配置
  435. memset(g_equ_adc_inv,0,sizeof(g_equ_adc_inv));
  436. for(i=0; i<g_equ_config->ac_num; i++)
  437. {
  438. u32 adc;
  439. adc = equ_get_ac_channel(g_equ_config_ac[i].slot,g_equ_config_ac[i].index);
  440. if (adc<CFG_ADC_CHANNEL)
  441. {
  442. // 是否配置
  443. if(g_equ_config_ac[i].type)
  444. {
  445. g_equ_adc_config[adc] = 1;
  446. }
  447. // 是否取反
  448. if (g_equ_config_ac[i].is_ct_inverse)
  449. {
  450. g_equ_adc_inv[g_equ_adc_inv_num++] = adc;
  451. }
  452. }
  453. }
  454. // 初始化灯
  455. equ_led_init();
  456. ret = equ_config_check();
  457. if(ret)
  458. {
  459. dp_err_n_c_rt("%s:ret=%d\r\n",__func__,ret);
  460. return -4;
  461. }
  462. return 0;
  463. }
  464. /******************************************************************************
  465. 函数名称: equ_exit
  466. 函数版本: 01.01
  467. 创建作者: sunxi
  468. 创建日期: 2013-08-08
  469. 函数说明: 装置退出
  470. 参数说明:
  471. 返回值:
  472. 0: 成功
  473. 其它: 失败
  474. 修改记录:
  475. */
  476. int equ_exit(void)
  477. {
  478. if(g_equ_config && (g_equ_config != &g_equ_config_null))
  479. {
  480. rt_free(g_equ_config);
  481. }
  482. if(g_board_res_head && (g_board_res_head != &g_board_res_head_null))
  483. {
  484. rt_free(g_board_res_head);
  485. }
  486. return 0;
  487. }
  488. /******************************************************************************
  489. 函数名称: equ_get_di_num
  490. 函数版本: 01.01
  491. 创建作者: sunxi
  492. 创建日期: 2013-08-08
  493. 函数说明: 得到插槽中子板的开入资源个数
  494. 参数说明:
  495. slot 插槽索引号
  496. 返回值: 开入资源个数
  497. 修改记录:
  498. */
  499. int _equ_get_di_num(u32 slot)
  500. {
  501. int i;
  502. u8 type;
  503. if(slot >= g_equ_config->equ_slot_num)
  504. {
  505. return 0;
  506. }
  507. type = g_equ_config->brd_type[slot];
  508. for(i=0; i<g_board_res_head->br_num; i++)
  509. {
  510. if(g_board_res[i].type == type)
  511. {
  512. return g_board_res[i].di_num;
  513. }
  514. }
  515. return 0;
  516. }
  517. int equ_get_di_num(u32 slot)
  518. {
  519. return (slot >=EQU_SLOT_NUM_MAX) ? 0 : g_board_info[slot].di_num;
  520. }
  521. /******************************************************************************
  522. 函数名称: equ_get_do_num
  523. 函数版本: 01.01
  524. 创建作者: sunxi
  525. 创建日期: 2013-08-08
  526. 函数说明: 得到插槽中子板的开出资源个数
  527. 参数说明:
  528. slot 插槽索引号
  529. 返回值: 开出资源个数
  530. 修改记录:
  531. */
  532. int _equ_get_do_num(u32 slot)
  533. {
  534. int i;
  535. u8 type;
  536. if(slot >= g_equ_config->equ_slot_num)
  537. {
  538. return 0;
  539. }
  540. type = g_equ_config->brd_type[slot];
  541. for(i=0; i<g_board_res_head->br_num; i++)
  542. {
  543. if(g_board_res[i].type == type)
  544. {
  545. return g_board_res[i].do_num;
  546. }
  547. }
  548. return 0;
  549. }
  550. int equ_get_do_num(u32 slot)
  551. {
  552. return (slot >=EQU_SLOT_NUM_MAX) ? 0 : g_board_info[slot].do_num;
  553. }
  554. /******************************************************************************
  555. 函数名称: equ_get_ac_num
  556. 函数版本: 01.01
  557. 创建作者: sunxi
  558. 创建日期: 2013-08-08
  559. 函数说明: 得到插槽中子板的模拟量资源个数
  560. 参数说明:
  561. slot 插槽索引号
  562. 返回值: 模拟量资源个数
  563. 修改记录:
  564. */
  565. int _equ_get_ac_num(u32 slot)
  566. {
  567. int i;
  568. u8 type;
  569. if(slot >= g_equ_config->equ_slot_num)
  570. {
  571. return 0;
  572. }
  573. type = g_equ_config->brd_type[slot];
  574. for(i=0; i<g_board_res_head->br_num; i++)
  575. {
  576. if(g_board_res[i].type == type)
  577. {
  578. return g_board_res[i].ac_num;
  579. }
  580. }
  581. return 0;
  582. }
  583. int equ_get_ac_num(u32 slot)
  584. {
  585. return (slot >=EQU_SLOT_NUM_MAX) ? 0 : g_board_info[slot].ac_num;
  586. }
  587. int equ_get_ac_scale(u8 slot,u8 no)
  588. {
  589. int i;
  590. for(i=0; i< g_equ_config->ac_num; i++)
  591. {
  592. if((g_equ_config_ac[i].slot==slot)&&(g_equ_config_ac[i].index==no))
  593. {
  594. return g_equ_config_ac[i].scale;
  595. }
  596. }
  597. return -1;
  598. }
  599. /******************************************************************************
  600. 函数名称: equ_get_slot_by_type
  601. 函数版本: 01.01
  602. 创建作者: sunxi
  603. 创建日期: 2013-08-08
  604. 函数说明: 通过子板的类型查找插槽。
  605. 参数说明:
  606. type 子板类型。
  607. 返回值: 插槽号
  608. 修改记录:
  609. */
  610. u32 equ_get_slot_by_type(u8 type)
  611. {
  612. u32 i;
  613. struct board_info *bi;
  614. bi = g_board_info;
  615. for(i=0; i<g_equ_config->equ_slot_num; i++)
  616. {
  617. if(equ_slot_check(i) != 0)
  618. {
  619. continue;
  620. }
  621. if(g_board_info[i].type == type)
  622. {
  623. return i;
  624. }
  625. }
  626. return 0;
  627. }
  628. /******************************************************************************
  629. 函数名称: equ_slot_check
  630. 函数版本: 01.01
  631. 创建作者: sunxi
  632. 创建日期: 2013-08-08
  633. 函数说明: 检查对应插槽中的子板是否正常。
  634. 参数说明:
  635. slot 插槽索引号
  636. 返回值: 插槽号
  637. 0: 成功
  638. 其它: 失败
  639. 修改记录:
  640. */
  641. int equ_slot_check(u32 slot)
  642. {
  643. if(slot >= g_equ_config->equ_slot_num)
  644. {
  645. return -1;
  646. }
  647. if(g_board_info[slot].is_ok == 0)
  648. {
  649. return -2;
  650. }
  651. return 0;
  652. }
  653. /******************************************************************************
  654. 函数名称: equ_di_name
  655. 函数版本: 01.01
  656. 创建作者: sunxi
  657. 创建日期: 2013-08-08
  658. 函数说明: 从板卡号和硬件编号得到开入点的名称
  659. 参数说明:
  660. slot 插槽索引号
  661. index 子板上开入索引号
  662. 返回值: 开入点的名称
  663. 修改记录:
  664. */
  665. char * equ_di_name(u8 slot,u8 no)
  666. {
  667. int i;
  668. for(i=0; i< g_equ_config->di_num; i++)
  669. {
  670. if((g_equ_config_di[i].slot==slot)&&(g_equ_config_di[i].index==no))
  671. {
  672. return shield_str(&g_equ_config_di[i]);
  673. }
  674. }
  675. return 0;
  676. }
  677. u8 equ_di_type(u8 slot,u8 no)
  678. {
  679. int i;
  680. for(i=0; i< g_equ_config->di_num; i++)
  681. {
  682. if((g_equ_config_di[i].slot==slot)&&(g_equ_config_di[i].index==no)&&(g_equ_config_di[i].owner>0)) //只有开关遥信才返回真正类型
  683. {
  684. return g_equ_config_di[i].type;
  685. }
  686. }
  687. return 0;
  688. }
  689. u8 equ_pub_di_type(u8 slot,u8 no)
  690. {
  691. int i;
  692. for(i=0; i< g_equ_config->di_num; i++)
  693. {
  694. if((g_equ_config_di[i].slot==slot)&&(g_equ_config_di[i].index==no)&&(g_equ_config_di[i].owner==0)) //公共类型
  695. {
  696. return g_equ_config_di[i].type;
  697. }
  698. }
  699. return 0;
  700. }
  701. /*------------------------------ 内部函数 -------------------------------------
  702. 内部函数以下划线‘_’开头,不需要检查参数的合法性.
  703. */
  704. /*------------------------------ 测试函数 -------------------------------------
  705. 一个实体文件必须带一个本模块的测试函数来进行单元测试,如果的确不方便在本模块中
  706. 进行单元测试,必须在此注明实际的测试位置(例如在哪个实体文件中使用哪个测试函数).
  707. */
  708. int equ_info_printf(void)
  709. {
  710. int i;
  711. struct rtc_time_t rtc;
  712. struct timespec ts;
  713. struct board_res *br;
  714. struct board_info *bi;
  715. 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);
  716. br = g_board_res;
  717. rt_printf("name\t\ttype\tdi_num\tdo_num\tac_num\r\n");
  718. for(i=0; i<g_board_res_head->br_num; i++)
  719. {
  720. 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);
  721. }
  722. bi = g_board_info;
  723. rt_printf("\r\nslot\ttype\tcan\tstatus\terrcode\tcrc\tversion\t\ttime\r\n");
  724. for(i=0; i<g_equ_config->equ_slot_num; i++)
  725. {
  726. 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);
  727. timespec_to_rtc(bi[i].update_time,&rtc,0);
  728. rt_printf("%04d-%02d-%02d %02d:%02d:%02d:%09d\r\n",
  729. rtc.year + 2000, rtc.month, rtc.day, rtc.hour, rtc.min, rtc.ms/1000,bi[i].update_time.tv_nsec );
  730. }
  731. clk_time_get(&ts);
  732. timespec_to_rtc(ts,&rtc,0);
  733. rt_printf("now:%04d-%02d-%02d %02d:%02d:%02d:%09d\r\n",
  734. rtc.year + 2000, rtc.month, rtc.day, rtc.hour, rtc.min, rtc.ms/1000,ts.tv_nsec );
  735. return 0;
  736. }
  737. int equ_info_printf_di(void)
  738. {
  739. int i;
  740. struct equ_config_di *cdi;
  741. cdi = g_equ_config_di;
  742. rt_printf("\r\nslot\tindex\ttype\towner\tfilter\tis_inv\tname\r\n");
  743. for(i=0; i<g_equ_config->di_num; i++)
  744. {
  745. rt_printf("%02d\t%02d\t%02d\t%d\t%d\t%d\t%s\r\n",
  746. cdi[i].slot,cdi[i].index+1,cdi[i].type,cdi[i].owner,cdi[i].filter_time,cdi[i].is_Inverse,cdi[i].name);
  747. }
  748. return 0;
  749. }
  750. int equ_info_printf_do(void)
  751. {
  752. int i;
  753. struct equ_config_do *cdo;
  754. cdo = g_equ_config_do;
  755. rt_printf("\r\nslot\tindex\ttype\towner\tpulse_t\tname\r\n");
  756. for(i=0; i<g_equ_config->do_num; i++)
  757. {
  758. rt_printf("%02d\t%02d\t%02d\t%d\t%d\t%s\r\n",
  759. cdo[i].slot,cdo[i].index+1,cdo[i].type,cdo[i].owner, cdo[i].time_pulse,cdo[i].name);
  760. }
  761. return 0;
  762. }
  763. int equ_info_printf_ac(void)
  764. {
  765. int i;
  766. struct equ_config_ac *cac;
  767. cac = g_equ_config_ac;
  768. rt_printf("\r\nslot\tindex\ttype\towner\tct_inv\tscale\tname\r\n");
  769. for(i=0; i<g_equ_config->ac_num; i++)
  770. {
  771. rt_printf("%02d\t%02d\t%02d\t%d\t%d\t%d\t%s\r\n",
  772. cac[i].slot,cac[i].index+1,cac[i].type,cac[i].owner,
  773. cac[i].is_ct_inverse,cac[i].scale,cac[i].name);
  774. }
  775. return 0;
  776. }
  777. /*------------------------------ 文件结束 -------------------------------------
  778. */