rt_socket.c 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389
  1. /******************************************************************************
  2. 版权所有:
  3. 文件名称: rt_socket.c
  4. 文件版本: 01.01
  5. 创建作者: sunxi
  6. 创建日期: 2020-06-18
  7. 功能说明: 实时微系统网络接口.所有接口必须在线程中调用,不能在中断中调用。
  8. 其它说明:
  9. 修改记录:
  10. */
  11. /*------------------------------- 头文件 --------------------------------------
  12. */
  13. #include <rt.h>
  14. #include "rt_socket.h"
  15. #include "rt_printf.h"
  16. #include <linux/route.h>
  17. #include <linux/ethtool.h>
  18. #include <linux/sockios.h>
  19. #include "bspconfig.h"
  20. /*------------------------------- 宏定义 --------------------------------------
  21. */
  22. /*------------------------------ 类型结构 -------------------------------------
  23. */
  24. /*------------------------------ 全局变量 -------------------------------------
  25. */
  26. char *g_if_name[] =
  27. {
  28. "eth0",
  29. "eth1",
  30. "eth2",
  31. "eth3",
  32. "eth4",
  33. };
  34. #define IF_NUM ((int)(sizeof(g_if_name) / 4))
  35. int g_net_num = CFG_ETH_MAX_PHY; // 正常的网口数量
  36. /*------------------------------ 函数声明 -------------------------------------
  37. */
  38. /*------------------------------ 外部函数 -------------------------------------
  39. 外部函数供其它实体文件引用,必须仔细检查传入参数的合法性.
  40. */
  41. int rt_socket_init(void)
  42. {
  43. unsigned int ret;
  44. // 目前工厂主板标准硬件版本为0,2个网口。
  45. // 以后如果使用3个网口,需修改硬件版本号。
  46. ret = 3; // gpio_get_version();
  47. if (ret < 3)
  48. {
  49. g_net_num = 2;
  50. }
  51. return 0;
  52. }
  53. // 打开关闭
  54. SOCKET rt_socket(int domain, int type, int protocol)
  55. {
  56. SOCKET s;
  57. s = socket(domain, type, protocol);
  58. return s;
  59. }
  60. int rt_socket_close(SOCKET s)
  61. {
  62. if (s > 0)
  63. {
  64. close(s);
  65. }
  66. return 0;
  67. }
  68. // 连接
  69. SOCKET rt_accept(SOCKET s, struct sockaddr *addr, unsigned int *addr_len)
  70. {
  71. SOCKET newsock = 0;
  72. newsock = accept(s, addr, addr_len);
  73. return newsock;
  74. }
  75. int rt_bind(SOCKET s, struct sockaddr *addr, unsigned int len)
  76. {
  77. return bind(s, addr, len);
  78. }
  79. int rt_connect(SOCKET s, struct sockaddr *addr, unsigned int len)
  80. {
  81. return connect(s, addr, len);
  82. }
  83. int rt_listen(SOCKET s, int n)
  84. {
  85. return listen(s, n);
  86. }
  87. int rt_shutdown(SOCKET s, int how)
  88. {
  89. return shutdown(s, how);
  90. }
  91. // 接收发送
  92. int rt_send(SOCKET s, void *buf, int n, int flags)
  93. {
  94. // flags加上MSG_NOSIGNAL标志,解决主循环在此断开的socket上继续发送数据,引起系统异常的问题。
  95. // return rt_sendto(s,buf,n,flags,NULL,0);
  96. return sendto(s, buf, n, flags | MSG_NOSIGNAL, NULL, 0);
  97. }
  98. int rt_recv(SOCKET s, void *buf, int n, int flags)
  99. {
  100. return rt_recvfrom(s, buf, n, flags, NULL, 0);
  101. }
  102. int rt_sendto(SOCKET s, void *buf, int n, int flags, struct sockaddr *addr, unsigned int addr_len)
  103. {
  104. return sendto(s, buf, n, flags, addr, addr_len);
  105. }
  106. int rt_recvfrom(SOCKET s, void *buf, int n, int flags, struct sockaddr *addr, unsigned int *addr_len)
  107. {
  108. return recvfrom(s, buf, n, flags, addr, addr_len);
  109. }
  110. // 控制
  111. int rt_getsockname(SOCKET s, struct sockaddr *addr, unsigned int *len)
  112. {
  113. return getsockname(s, addr, len);
  114. }
  115. int rt_getpeername(SOCKET s, struct sockaddr *addr, unsigned int *len)
  116. {
  117. return getpeername(s, addr, len);
  118. }
  119. int rt_getsockopt(SOCKET s, int level, int optname, void *optval, unsigned int *optlen)
  120. {
  121. return getsockopt(s, level, optname, optval, optlen);
  122. }
  123. int rt_setsockopt(SOCKET s, int level, int optname, void *optval, unsigned int optlen)
  124. {
  125. return setsockopt(s, level, optname, optval, optlen);
  126. }
  127. int rt_sockioctl(SOCKET s, int cmd, uint64_t arg)
  128. {
  129. return ioctl(s, cmd, arg);
  130. }
  131. int set_net_param_fun(char *NetNum, char *para, char *cmd)
  132. {
  133. int ret;
  134. char argv[256] = {0x00};
  135. // sprintf(argv, "/bin/ifconfig %s %s %s", NetNum,para,cmd);
  136. sprintf(argv, "ifconfig %s %s %d.%d.%d.%d", NetNum, para, cmd[0], cmd[1], cmd[2], cmd[3]);
  137. #ifdef RT_SOCKET_DEBUG
  138. rt_printf("sh cmd=%s\r\n", argv);
  139. #endif
  140. ret = system(argv);
  141. return ret;
  142. }
  143. int set_gw_param_fun(char *ip, char *gw)
  144. {
  145. int ret;
  146. char argv[256] = {0x00};
  147. // sprintf(argv, "/bin/ifconfig %s %s %s", NetNum,para,cmd);
  148. sprintf(argv, "route add %s gw %s", ip, gw);
  149. #ifdef RT_SOCKET_DEBUG
  150. rt_printf("sh cmd=%s\r\n", argv);
  151. #endif
  152. ret = system(argv);
  153. return ret;
  154. }
  155. #if 0 // 没有用到
  156. int rt_sockconnected(SOCKET s)
  157. {
  158. struct tcp_info info;
  159. int len=sizeof(info);
  160. int ret=-1;
  161. if(!s)
  162. return ret;
  163. memset(&info, 0, sizeof(info));
  164. ret=rt_getsockopt(s, IPPROTO_TCP, TCP_INFO, (char *)&info, &len);
  165. if(info.tcpi_state==1)
  166. {
  167. //处于链接状态
  168. ret = 0;
  169. }
  170. else
  171. {
  172. //处于断开状态
  173. ret = -1;
  174. }
  175. return ret;
  176. }
  177. int rt_net_set_KeepAlive(SOCKET s, int interval)
  178. {
  179. int val = interval;
  180. //开启keepalive机制
  181. if (rt_setsockopt(s, SOL_SOCKET, SO_KEEPALIVE, &val, sizeof(val)) == -1)
  182. {
  183. // printf("setsockopt SO_KEEPALIVE: %s", strerror(errno));
  184. return -1;
  185. }
  186. /* Default settings are more or less garbage, with the keepalive time
  187. * set to 7200 by default on Linux. Modify settings to make the feature
  188. * actually useful. */
  189. /* Send first probe after interval. */
  190. val = interval;
  191. if (rt_setsockopt(s, IPPROTO_TCP, TCP_KEEPIDLE, &val, sizeof(val)) < 0) {
  192. // printf("setsockopt TCP_KEEPIDLE: %s\n", strerror(errno));
  193. return -1;
  194. }
  195. /* Send next probes after the specified interval. Note that we set the
  196. * delay as interval / 3, as we send three probes before detecting
  197. * an error (see the next setsockopt call). */
  198. val = interval / 3;
  199. if (val == 0) val = 1;
  200. if (rt_setsockopt(s, IPPROTO_TCP, TCP_KEEPINTVL, &val, sizeof(val)) < 0) {
  201. // printf("setsockopt TCP_KEEPINTVL: %s\n", strerror(errno));
  202. return -1;
  203. }
  204. /* Consider the socket in error state after three we send three ACK
  205. * probes without getting a reply. */
  206. val = 3;
  207. if (rt_setsockopt(s, IPPROTO_TCP, TCP_KEEPCNT, &val, sizeof(val)) < 0) {
  208. // printf("setsockopt TCP_KEEPCNT: %s\n", strerror(errno));
  209. return -1;
  210. }
  211. return 0;
  212. }
  213. #endif
  214. /******************************************************************************
  215. 函数名称:rt_if_up
  216. 函数版本:01.01
  217. 创建作者:sunxi
  218. 创建日期:2020-06-18
  219. 函数说明:UP一个接口。
  220. 参数说明:
  221. if_name: 接口名称,如eth0,fei1等。
  222. 返回值 :
  223. >=0 : 成功。
  224. -1 : 失败。
  225. 更新记录:
  226. */
  227. #if 0
  228. int rt_if_up(int index)
  229. {
  230. struct ifreq ifr;
  231. SOCKET sock;
  232. if(index >= IF_NUM)
  233. {
  234. return -1;
  235. }
  236. sock = rt_socket(AF_INET, SOCK_DGRAM, 0);
  237. if (sock == RT_SOCKET_ERR)
  238. {
  239. rt_printf("rt_if_up:: rt_socket::error\n");
  240. return -1;
  241. }
  242. memset(&ifr,0,sizeof(ifr));
  243. strcpy(ifr.ifr_name,g_if_name[index]);
  244. /* 得到标志*/
  245. if(rt_sockioctl(sock,SIOCGIFFLAGS,(uint32_t)&ifr) != 0)
  246. {
  247. rt_socket_close(sock);
  248. return -1;
  249. }
  250. /* 修改标志*/
  251. ifr.ifr_ifru.ifru_flags |= IFF_UP;
  252. /* 写回标志*/
  253. if(rt_sockioctl(sock,SIOCSIFFLAGS,(uint32_t)&ifr) != 0)
  254. {
  255. rt_socket_close(sock);
  256. return -1;
  257. }
  258. rt_socket_close(sock);
  259. return 0;
  260. }
  261. #endif
  262. int rt_if_up(int index)
  263. {
  264. int ret;
  265. char argv[256] = {0x00};
  266. sprintf(argv, "/sbin/ifconfig eth%d up", index);
  267. ret = system(argv);
  268. return ret;
  269. }
  270. /******************************************************************************
  271. 函数名称:rt_if_down
  272. 函数版本:01.01
  273. 创建作者:sunxi
  274. 创建日期:2020-06-18
  275. 函数说明:DOWN一个接口。
  276. 参数说明:
  277. if_name: 接口名称,如eth0,fei1等。
  278. 返回值 :
  279. >=0 : 成功。
  280. -1 : 失败。
  281. 更新记录:
  282. */
  283. int rt_if_down(int index)
  284. {
  285. int ret;
  286. char argv[256] = {0x00};
  287. sprintf(argv, "/sbin/ifconfig eth%d down", index);
  288. ret = system(argv);
  289. return ret;
  290. }
  291. int c2n(char c)
  292. {
  293. if (c >= '0' && c <= '9')
  294. {
  295. return c - '0';
  296. }
  297. if (c >= 'A' && c <= 'F')
  298. {
  299. return c - 'A' + 10;
  300. }
  301. if (c >= 'a' && c <= 'f')
  302. {
  303. return c - 'a' + 10;
  304. }
  305. return -1;
  306. }
  307. // 将标准MAC地址字符串转换为6字节MAC地址
  308. // 80-81-00-b0-32-81
  309. int rt_if_sz2mac(char *sz, unsigned char *mac)
  310. {
  311. int i;
  312. int c0, c1;
  313. if (sz == NULL || mac == NULL)
  314. {
  315. return -1;
  316. }
  317. if (strlen(sz) != 17)
  318. {
  319. return -1;
  320. }
  321. i = 0;
  322. while (i < 17)
  323. {
  324. if ((i % 3 == 2))
  325. {
  326. if (sz[i++] != '-')
  327. {
  328. return -2;
  329. }
  330. }
  331. c0 = c2n(sz[i++]);
  332. if (c0 < 0)
  333. {
  334. return -3;
  335. }
  336. c1 = c2n(sz[i++]);
  337. if (c1 < 0)
  338. {
  339. return -4;
  340. }
  341. *mac++ = (c0 << 4) | c1;
  342. }
  343. return 0;
  344. }
  345. /*
  346. int rt_if_mac_set(int index, unsigned char *mac)
  347. {
  348. int ret;
  349. struct ifreq ifr;
  350. int sock;
  351. if((unsigned int)index >= IF_NUM)
  352. {
  353. return -1;
  354. }
  355. if(mac == NULL)
  356. {
  357. return -1;
  358. }
  359. memset(&ifr, 0, sizeof(struct ifreq));
  360. //创建socket
  361. sock = rt_socket(AF_INET, SOCK_DGRAM, 0);
  362. if(sock < 0)
  363. {
  364. rt_printf("Not create network rt_socket connection\\n");
  365. return (-1);
  366. }
  367. strncpy(ifr.ifr_name,g_if_name[index],IFNAMSIZ);
  368. ifr.ifr_name[IFNAMSIZ - 1] = 0;
  369. //关闭网卡
  370. ifr.ifr_flags &= ~IFF_UP;
  371. if(ioctl(sock,SIOCSIFFLAGS,(uint32_t)&ifr) < 0)
  372. {
  373. //rt_printf("SIOCSIFFLAGS");
  374. close(sock);
  375. return (-1);
  376. }
  377. //获取Mac地址
  378. ret = ioctl(sock,SIOCGIFHWADDR,(uint32_t)&ifr);
  379. if( ret < 0)
  380. {
  381. //rt_printf("Not setup SIOCGIFHWADDR(ret=%d)\n",ret);
  382. close(sock);
  383. return (-1);
  384. }
  385. //填充Mac地址
  386. ifr.ifr_hwaddr.sa_data[0]=mac[0];
  387. ifr.ifr_hwaddr.sa_data[1]=mac[1];
  388. ifr.ifr_hwaddr.sa_data[2]=mac[2];
  389. ifr.ifr_hwaddr.sa_data[3]=mac[3];
  390. ifr.ifr_hwaddr.sa_data[4]=mac[4];
  391. ifr.ifr_hwaddr.sa_data[5]=mac[5];
  392. //修改Mac地址
  393. ret = ioctl(sock, SIOCSIFHWADDR, (uint32_t)&ifr);
  394. if( ret < 0)
  395. {
  396. rt_printf("Not setup SIOCSIFHWADDR(ret=%d)\n",ret);
  397. close(sock);
  398. return (-1);
  399. }
  400. //启动网卡
  401. ifr.ifr_flags |= IFF_UP|IFF_RUNNING;
  402. if(ioctl(sock,SIOCSIFFLAGS,(uint32_t)&ifr)<0)
  403. {
  404. rt_printf("SIOCSIFFLAGS");
  405. close(sock);
  406. return (-1);
  407. }
  408. close(sock);
  409. return 0;
  410. }
  411. */
  412. int rt_if_mac_set(int index, unsigned char *mac)
  413. {
  414. char argv[256] = {0x00};
  415. int ret;
  416. char NetNum[20] = "";
  417. sprintf(NetNum, "eth%d", index);
  418. sprintf(argv, "ifconfig %s hw ether %02X:%02X:%02X:%02X:%02X:%02X", NetNum, mac[0], mac[1], mac[2], mac[3], mac[4], mac[5]);
  419. #ifdef RT_SOCKET_DEBUG
  420. rt_printf("sh cmd=%s\r\n", argv);
  421. #endif
  422. ret = system(argv);
  423. return ret;
  424. }
  425. int rt_if_mac_get(int index, unsigned char *mac)
  426. {
  427. int ret;
  428. struct ifreq ifr;
  429. int sock;
  430. if ((unsigned int)index >= IF_NUM)
  431. {
  432. return -1;
  433. }
  434. if (mac == NULL)
  435. {
  436. return -1;
  437. }
  438. memset(&ifr, 0, sizeof(struct ifreq));
  439. // 创建socket
  440. sock = rt_socket(AF_INET, SOCK_DGRAM, 0);
  441. if (sock < 0)
  442. {
  443. rt_printf("Not create network rt_socket connection\\n");
  444. return (-1);
  445. }
  446. strncpy(ifr.ifr_name, g_if_name[index], IFNAMSIZ);
  447. ifr.ifr_name[IFNAMSIZ - 1] = 0;
  448. // 获取Mac地址
  449. ret = ioctl(sock, SIOCGIFHWADDR, (uint64_t)&ifr);
  450. if (ret < 0)
  451. {
  452. // rt_printf("Not setup SIOCGIFHWADDR(ret=%d)\n",ret);
  453. close(sock);
  454. return (-1);
  455. }
  456. // 填充Mac地址
  457. mac[0] = ifr.ifr_hwaddr.sa_data[0];
  458. mac[1] = ifr.ifr_hwaddr.sa_data[1];
  459. mac[2] = ifr.ifr_hwaddr.sa_data[2];
  460. mac[3] = ifr.ifr_hwaddr.sa_data[3];
  461. mac[4] = ifr.ifr_hwaddr.sa_data[4];
  462. mac[5] = ifr.ifr_hwaddr.sa_data[5];
  463. close(sock);
  464. return 0;
  465. }
  466. /******************************************************************************
  467. 函数名称:rt_if_ip_set
  468. 函数版本:01.01
  469. 创建作者:sunxi
  470. 创建日期:2020-06-18
  471. 函数说明:设置一个接口的IP地址。
  472. 参数说明:
  473. if_name: 接口名称,如eth0,fei1等。
  474. ip : IP地址。
  475. 返回值 :
  476. >=0 : 成功。
  477. -1 : 失败。
  478. 更新记录:
  479. */
  480. int rt_if_ip_set(int index, unsigned char *ip)
  481. {
  482. int ret;
  483. char NetNum[20] = "";
  484. if ((unsigned int)index >= IF_NUM)
  485. {
  486. return -1;
  487. }
  488. sprintf(NetNum, "eth%d", index);
  489. ret = set_net_param_fun(NetNum, " ", ip); // 设置ip
  490. return ret;
  491. }
  492. /******************************************************************************
  493. 函数名称:rt_if_ip_get
  494. 函数版本:01.01
  495. 创建作者:sunxi
  496. 创建日期:2020-06-18
  497. 函数说明:得到一个接口的IP地址。
  498. 参数说明:
  499. if_name: 接口名称,如eth0,fei1等。
  500. ip : 返回的IP地址在*if_addr中。
  501. 返回值 :
  502. >=0 : 成功。
  503. -1 : 失败。
  504. 更新记录:
  505. */
  506. int rt_if_ip_get(int index, unsigned char *ip)
  507. {
  508. unsigned int addr;
  509. struct ifreq ifr;
  510. SOCKET sock;
  511. if ((unsigned int)index >= IF_NUM)
  512. {
  513. return -1;
  514. }
  515. if (ip == NULL)
  516. {
  517. return -1;
  518. }
  519. sock = rt_socket(AF_INET, SOCK_DGRAM, 0);
  520. if (sock == RT_SOCKET_ERR)
  521. {
  522. rt_printf("%s:: rt_socket [%d]::error\n", __FUNCTION__, index);
  523. return -1;
  524. }
  525. memset(&ifr, 0, sizeof(ifr));
  526. strcpy(ifr.ifr_name, g_if_name[index]);
  527. if (rt_sockioctl(sock, SIOCGIFADDR, (uint64_t)&ifr) != 0)
  528. {
  529. rt_socket_close(sock);
  530. return -1;
  531. }
  532. addr = ((struct sockaddr_in *)&ifr.ifr_addr)->sin_addr.s_addr;
  533. addr = ntohl(addr);
  534. memcpy(ip, &addr, 4);
  535. rt_socket_close(sock);
  536. return 0;
  537. }
  538. /******************************************************************************
  539. 函数名称:rt_if_mask_set
  540. 函数版本:01.01
  541. 创建作者:sunxi
  542. 创建日期:2020-06-18
  543. 函数说明:设置一个接口的子网屏蔽。
  544. 参数说明:
  545. if_name: 接口名称,如eth0,fei1等。
  546. mask : 子网屏蔽
  547. 返回值 :
  548. >=0 : 成功。
  549. -1 : 失败。
  550. 更新记录:
  551. */
  552. int rt_if_mask_set(int index, unsigned char *mask)
  553. {
  554. int ret;
  555. char NetNum[20] = "";
  556. if ((unsigned int)index >= IF_NUM)
  557. {
  558. return -1;
  559. }
  560. sprintf(NetNum, "eth%d", index);
  561. ret = set_net_param_fun(NetNum, "netmask", mask); // 设置子网掩码
  562. return ret;
  563. }
  564. /******************************************************************************
  565. 函数名称:rt_if_mask_get
  566. 函数版本:01.01
  567. 创建作者:sunxi
  568. 创建日期:2020-06-18
  569. 函数说明:得到一个接口的子网屏蔽。
  570. 参数说明:
  571. if_name: 接口名称,如eth0,fei1等。
  572. mask : 返回的子网屏蔽在*if_mask中。
  573. 返回值 :
  574. >=0 : 成功。
  575. -1 : 失败。
  576. 更新记录:
  577. */
  578. int rt_if_mask_get(int index, unsigned char *mask)
  579. {
  580. unsigned int addr;
  581. struct ifreq ifr;
  582. SOCKET sock;
  583. if ((unsigned int)index >= IF_NUM)
  584. {
  585. return -1;
  586. }
  587. if (mask == NULL)
  588. {
  589. return -1;
  590. }
  591. sock = rt_socket(AF_INET, SOCK_DGRAM, 0);
  592. if (sock == RT_SOCKET_ERR)
  593. {
  594. rt_printf("rt_if_mask_get:: rt_socket::error\n");
  595. return -1;
  596. }
  597. memset(&ifr, 0, sizeof(ifr));
  598. strcpy(ifr.ifr_name, g_if_name[index]);
  599. if (rt_sockioctl(sock, SIOCGIFNETMASK, (uint64_t)&ifr) != 0)
  600. {
  601. rt_socket_close(sock);
  602. return -1;
  603. }
  604. addr = ((struct sockaddr_in *)&ifr.ifr_netmask)->sin_addr.s_addr;
  605. addr = ntohl(addr);
  606. memcpy(mask, &addr, 4);
  607. rt_socket_close(sock);
  608. return 0;
  609. }
  610. /******************************************************************************
  611. 函数名称:rt_route_add
  612. 函数版本:01.01
  613. 创建作者:xxxxxx
  614. 创建日期:2008-04-09
  615. 函数说明:增加一个接口的路由。
  616. 参数说明:
  617. destination : 目标网络。
  618. gateway : 网关
  619. 返回值 :
  620. >=0 : 成功。
  621. -1 : 失败。
  622. 更新记录:
  623. */
  624. int rt_route_add(int index, unsigned char *destination, unsigned char *gateway)
  625. {
  626. int sock;
  627. unsigned int destination2, gateway2;
  628. struct rtentry rt;
  629. if (destination == NULL || gateway == NULL)
  630. {
  631. return -1;
  632. }
  633. memcpy(&destination2, destination, 4);
  634. memcpy(&gateway2, gateway, 4);
  635. sock = rt_socket(AF_INET, SOCK_DGRAM, 0);
  636. if (sock < 0)
  637. {
  638. rt_printf("Create Socket Erro\r\n");
  639. return -1;
  640. }
  641. memset(&rt, 0, sizeof(struct rtentry));
  642. rt.rt_dev = g_if_name[index];
  643. rt.rt_flags = RTF_UP | RTF_GATEWAY;
  644. ((struct sockaddr_in *)&rt.rt_gateway)->sin_family = AF_INET;
  645. ((struct sockaddr_in *)&rt.rt_gateway)->sin_addr.s_addr = htonl(gateway2);
  646. ((struct sockaddr_in *)&rt.rt_dst)->sin_family = AF_INET;
  647. ((struct sockaddr_in *)&rt.rt_dst)->sin_addr.s_addr = htonl(destination2);
  648. /* The netmask for the destination net; ’255.255.255.255’ for a
  649. host destination and ’0.0.0.0’ for the default route.
  650. */
  651. ((struct sockaddr_in *)&rt.rt_genmask)->sin_family = AF_INET;
  652. ((struct sockaddr_in *)&rt.rt_genmask)->sin_addr.s_addr = 0;
  653. if (-1 == ioctl(sock, SIOCADDRT, (uint64_t)&rt))
  654. {
  655. rt_printf("rt_route_add fail");
  656. close(sock);
  657. return -1;
  658. }
  659. close(sock);
  660. return 0;
  661. }
  662. /******************************************************************************
  663. 函数名称:rt_route_delete
  664. 函数版本:01.01
  665. 创建作者:sunxi
  666. 创建日期:2020-6-19
  667. 函数说明:删除一个接口的路由。
  668. 参数说明:
  669. if_name_prefic : 接口名称前缀,如eth,fei等。
  670. unit : 网卡编号,如,0,1,2等
  671. 返回值 :
  672. >=0 : 成功。
  673. -1 : 失败。
  674. 更新记录:
  675. */
  676. int rt_route_del(int index, unsigned char *destination, unsigned char *gateway)
  677. {
  678. int sock;
  679. unsigned int destination2, gateway2;
  680. struct rtentry rt;
  681. if (destination == NULL || gateway == NULL)
  682. {
  683. return -1;
  684. }
  685. memcpy(&destination2, destination, 4);
  686. memcpy(&gateway2, gateway, 4);
  687. sock = rt_socket(AF_INET, SOCK_DGRAM, 0);
  688. if (sock < 0)
  689. {
  690. rt_printf("Create Socket Erro\r\n");
  691. return -1;
  692. }
  693. memset(&rt, 0, sizeof(struct rtentry));
  694. rt.rt_dev = g_if_name[index];
  695. rt.rt_flags = RTF_UP | RTF_GATEWAY;
  696. // ((struct sockaddr_in *) &rt.rt_gateway)->sin_family = AF_INET;
  697. // ((struct sockaddr_in *) &rt.rt_gateway)->sin_addr.s_addr = htonl(gateway2);
  698. ((struct sockaddr_in *)&rt.rt_dst)->sin_family = AF_INET;
  699. ((struct sockaddr_in *)&rt.rt_dst)->sin_addr.s_addr = htonl(destination2);
  700. /* The netmask for the destination net; ’255.255.255.255’ for a
  701. host destination and ’0.0.0.0’ for the default route.
  702. */
  703. ((struct sockaddr_in *)&rt.rt_genmask)->sin_family = AF_INET;
  704. ((struct sockaddr_in *)&rt.rt_genmask)->sin_addr.s_addr = 0;
  705. if (-1 == ioctl(sock, SIOCDELRT, (uint64_t)&rt))
  706. {
  707. rt_printf("rt_route_del fail");
  708. close(sock);
  709. return -1;
  710. }
  711. close(sock);
  712. return 0;
  713. }
  714. int net_gateway_set(unsigned char *gateway)
  715. {
  716. int ret;
  717. char argv_del[] = "/sbin/route del default";
  718. char argv_add[256] = {0x00};
  719. if (gateway == 0)
  720. {
  721. return -1;
  722. }
  723. sprintf(argv_add, "/sbin/route add default gw %d.%d.%d.%d", gateway[0], gateway[1], gateway[2], gateway[3]);
  724. ret = system(argv_del);
  725. ret = system(argv_add);
  726. return ret;
  727. }
  728. int net_if_set(int if_index, unsigned char *mac, unsigned char *ip, unsigned char *mask)
  729. {
  730. if ((unsigned int)if_index >= IF_NUM)
  731. {
  732. return -1;
  733. }
  734. if (mac)
  735. {
  736. rt_if_mac_set(if_index, mac);
  737. }
  738. if (ip)
  739. {
  740. rt_if_ip_set(if_index, ip);
  741. }
  742. if (mask)
  743. {
  744. rt_if_mask_set(if_index, mask);
  745. }
  746. return 0;
  747. }
  748. int net_if_get(int if_index, unsigned char *mac, unsigned char *ip, unsigned char *mask)
  749. {
  750. int ret;
  751. char buf[64];
  752. if ((unsigned int)if_index >= IF_NUM)
  753. {
  754. return -1;
  755. }
  756. if (mac)
  757. {
  758. ret = rt_if_mac_get(if_index, mac);
  759. if (ret != 0)
  760. {
  761. return -1;
  762. }
  763. sprintf(buf, "%02x:%02x:%02x:%02x:%02x:%02x", mac[0], mac[1], mac[2], mac[3], mac[4], mac[5]);
  764. }
  765. if (ip)
  766. {
  767. ret = rt_if_ip_get(if_index, ip);
  768. if (ret != 0)
  769. {
  770. return -2;
  771. }
  772. sprintf(buf, "%d.%d.%d.%d", ip[0], ip[1], ip[2], ip[3]);
  773. }
  774. if (mask)
  775. {
  776. ret = rt_if_mask_get(if_index, mask);
  777. if (ret != 0)
  778. {
  779. return -3;
  780. }
  781. sprintf(buf, "%d.%d.%d.%d", mask[0], mask[1], mask[2], mask[3]);
  782. }
  783. return 0;
  784. }
  785. int rt_get_net_linkstatus(int if_index)
  786. {
  787. int skfd = -1;
  788. struct ifreq ifr;
  789. unsigned short *data, mii_val;
  790. unsigned phy_id;
  791. if (if_index < 0)
  792. {
  793. return -1;
  794. }
  795. if ((skfd = rt_socket(AF_INET, SOCK_DGRAM, 0)) < 0)
  796. {
  797. return -1;
  798. }
  799. /* Get the vitals from the interface. */
  800. strncpy(ifr.ifr_name, g_if_name[if_index], IFNAMSIZ);
  801. if (if_index <= 1)
  802. {
  803. if (ioctl(skfd, SIOCGMIIPHY, (uint64_t)&ifr) < 0)
  804. {
  805. rt_printf("SIOCGMIIPHY on %s failed!\n", ifr.ifr_name);
  806. close(skfd);
  807. return -2;
  808. }
  809. data = (unsigned short *)(&ifr.ifr_data);
  810. phy_id = data[0];
  811. data[1] = 1;
  812. if (ioctl(skfd, SIOCGMIIREG, (uint64_t)&ifr) < 0)
  813. {
  814. rt_printf("SIOCGMIIREG on %s failed!\n", ifr.ifr_name);
  815. close(skfd);
  816. return -3;
  817. }
  818. close(skfd);
  819. mii_val = data[3];
  820. return (((mii_val & 0x0016) == 0x0004) ? 0 : 1);
  821. }
  822. else
  823. {
  824. /* ----- ethtool 方式(适用于 USB 网卡)----- */
  825. struct ethtool_value edata;
  826. edata.cmd = ETHTOOL_GLINK; // 获取链路状态命令
  827. ifr.ifr_data = (void *)&edata;
  828. if (ioctl(skfd, SIOCETHTOOL, &ifr) == 0)
  829. {
  830. // edata.data = 1 表示链路 up,返回 0;0 表示 down,返回 1
  831. close(skfd);
  832. return edata.data ? 0 : 1;
  833. }
  834. else
  835. {
  836. rt_printf("SIOCETHTOOL (ETHTOOL_GLINK) on %s failed!\n", ifr.ifr_name);
  837. close(skfd);
  838. return -4; // 自定义错误码:ethtool 方式失败
  839. }
  840. }
  841. }
  842. #define NET_NUM_CNT 3
  843. int rt_get_netcard_id_from_socket(SOCKET s)
  844. {
  845. struct sockaddr_in local_addr;
  846. unsigned int len = sizeof(local_addr);
  847. char buf[32] = {0};
  848. unsigned int ip = 0;
  849. int i, j;
  850. int index;
  851. rt_getsockname(s, (struct sockaddr *)&local_addr, &len);
  852. // 此处需转换,否则匹配不到对应ip
  853. local_addr.sin_addr.s_addr = ntohl(local_addr.sin_addr.s_addr);
  854. index = -1;
  855. for (i = 0; i < g_net_num; i++)
  856. {
  857. // 获取网卡IP
  858. rt_if_ip_get(i, buf);
  859. memcpy(&ip, buf, 4);
  860. if (ip == local_addr.sin_addr.s_addr)
  861. {
  862. index = i;
  863. break;
  864. }
  865. else
  866. {
  867. for (j = 1; j <= NET_NUM_CNT; j++)
  868. {
  869. rt_if_ip_get2(i, j, buf);
  870. memcpy(&ip, buf, 4);
  871. if (ip == local_addr.sin_addr.s_addr)
  872. {
  873. return i;
  874. }
  875. }
  876. }
  877. }
  878. return index;
  879. }
  880. int net_route_set(unsigned char *routenet, unsigned char *routenetmask, unsigned char *routegate)
  881. {
  882. int ret;
  883. char buf_routenet[32];
  884. char buf_routenetmask[32];
  885. char buf_routegate[32];
  886. char argv_add[512] = {0x00};
  887. char argv_add2[512] = {0x00};
  888. if ((routenet == 0) || (routenetmask == 0) || (routegate == 0))
  889. {
  890. return -1;
  891. }
  892. if ((routenet[0] == 0) && (routenet[1] == 0) && (routenet[2] == 0) && (routenet[3] == 0))
  893. {
  894. return 0;
  895. }
  896. if ((routegate[0] == 0) && (routegate[1] == 0) && (routegate[2] == 0) && (routegate[3] == 0))
  897. {
  898. return 0;
  899. }
  900. sprintf(buf_routenet, "%d.%d.%d.%d", routenet[0], routenet[1], routenet[2], routenet[3]);
  901. sprintf(buf_routenetmask, "%d.%d.%d.%d", routenetmask[0], routenetmask[1], routenetmask[2], routenetmask[3]);
  902. sprintf(buf_routegate, "%d.%d.%d.%d", routegate[0], routegate[1], routegate[2], routegate[3]);
  903. sprintf(argv_add, "/sbin/route add -net %s netmask %s gw %s", buf_routenet, buf_routenetmask, buf_routegate);
  904. sprintf(argv_add2, "/sbin/route add -host %s gw %s", buf_routenet, buf_routegate);
  905. if ((routenetmask[0] == 0) && (routenetmask[1] == 0) && (routenetmask[2] == 0) && (routenetmask[3] == 0))
  906. {
  907. ret = system(argv_add2);
  908. }
  909. else
  910. {
  911. ret = system(argv_add);
  912. }
  913. return ret;
  914. }
  915. int rt_if_ip_set2(int eth_id, int index, unsigned char *ip)
  916. {
  917. int ret;
  918. char NetNum[20] = "";
  919. if ((unsigned int)index >= IF_NUM)
  920. {
  921. return -1;
  922. }
  923. sprintf(NetNum, "eth%d:%d", eth_id, index);
  924. ret = set_net_param_fun(NetNum, " ", ip); // 设置ip
  925. return ret;
  926. }
  927. int rt_if_mask_set2(int eth_id, int index, unsigned char *mask)
  928. {
  929. int ret;
  930. char NetNum[20] = "";
  931. if ((unsigned int)index >= IF_NUM)
  932. {
  933. return -1;
  934. }
  935. sprintf(NetNum, "eth%d:%d", eth_id, index);
  936. ret = set_net_param_fun(NetNum, "netmask", mask); // 设置子网掩码
  937. return ret;
  938. }
  939. int net_if_set2(int eth_id, int if_index, unsigned char *mac, unsigned char *ip, unsigned char *mask)
  940. {
  941. if ((unsigned int)if_index > IF_NUM)
  942. {
  943. return -1;
  944. }
  945. if (mac)
  946. {
  947. // rt_if_mac_set(if_index,mac);
  948. mac = mac;
  949. }
  950. if (ip)
  951. {
  952. rt_if_ip_set2(eth_id, if_index, ip);
  953. }
  954. if (mask)
  955. {
  956. rt_if_mask_set2(eth_id, if_index, mask);
  957. }
  958. return 0;
  959. }
  960. int rt_if_ip_get2(int eth_id, int index, unsigned char *ip)
  961. {
  962. unsigned int addr;
  963. char buf[32];
  964. struct ifreq ifr;
  965. SOCKET sock;
  966. if ((unsigned int)eth_id >= IF_NUM)
  967. {
  968. return -1;
  969. }
  970. if (ip == NULL)
  971. {
  972. return -1;
  973. }
  974. sock = rt_socket(AF_INET, SOCK_DGRAM, 0);
  975. if (sock == RT_SOCKET_ERR)
  976. {
  977. rt_printf("%s:: rt_socket [%d][%d]::error\n", __FUNCTION__, eth_id, index);
  978. return -1;
  979. }
  980. sprintf(buf, "eth%d:%d", eth_id, index);
  981. memset(&ifr, 0, sizeof(ifr));
  982. strcpy(ifr.ifr_name, buf);
  983. if (rt_sockioctl(sock, SIOCGIFADDR, (uint64_t)&ifr) != 0)
  984. {
  985. rt_socket_close(sock);
  986. return -1;
  987. }
  988. addr = ((struct sockaddr_in *)&ifr.ifr_addr)->sin_addr.s_addr;
  989. addr = ntohl(addr);
  990. memcpy(ip, &addr, 4);
  991. rt_socket_close(sock);
  992. return 0;
  993. }
  994. int rt_if_down2(int eth_id, int index)
  995. {
  996. int ret;
  997. char argv[256] = {0x00};
  998. sprintf(argv, "/sbin/ifconfig eth%d:%d down", eth_id, index);
  999. ret = system(argv);
  1000. return ret;
  1001. }
  1002. /*------------------------------ 内部函数 -------------------------------------
  1003. 内部函数以下划线‘_’开头,不需要检查参数的合法性.
  1004. */
  1005. /*------------------------------ 测试函数 -------------------------------------
  1006. 一个实体文件必须带一个本模块的测试函数来进行单元测试,如果的确不方便在本模块中
  1007. 进行单元测试,必须在此注明实际的测试位置(例如在哪个实体文件中使用哪个测试函数).
  1008. */
  1009. #define IF_INDEX 1
  1010. int net_if_test(void)
  1011. {
  1012. // uint32_t us0;
  1013. unsigned char mac[6];
  1014. unsigned char ip[4];
  1015. unsigned char mask[4];
  1016. unsigned char gateway[4];
  1017. rt_printf("net_if_test begin...\r\n");
  1018. // 得到并打印旧的网络参数
  1019. net_if_get(IF_INDEX, mac, ip, mask);
  1020. rt_printf("old mac: %02x:%02x:%02x:%02x:%02x:%02x\r\n", mac[0], mac[1], mac[2], mac[3], mac[4], mac[5]);
  1021. rt_printf("old ip:%d.%d.%d.%d\r\n", ip[0], ip[1], ip[2], ip[3]);
  1022. rt_printf("old mask:%d.%d.%d.%d\r\n", mask[0], mask[1], mask[2], mask[3]);
  1023. rt_printf("old gateway:%d.%d.%d.%d\r\n", gateway[0], gateway[1], gateway[2], gateway[3]);
  1024. // 设置接口MAC地址
  1025. mac[0] = 'H';
  1026. mac[1] = 'G';
  1027. mac[2] = 192;
  1028. mac[3] = 168;
  1029. mac[4] = 1;
  1030. mac[5] = 240;
  1031. // 设置IP
  1032. memcpy(ip, mac + 2, 4);
  1033. // 设置MASK
  1034. mask[0] = 255;
  1035. mask[1] = 255;
  1036. mask[2] = 0;
  1037. mask[3] = 0;
  1038. // 设置网关
  1039. gateway[0] = 192;
  1040. gateway[1] = 168;
  1041. gateway[2] = 1;
  1042. gateway[3] = 254;
  1043. // 设置网络参数
  1044. // us0 = ustimer_get_origin();
  1045. net_if_set(IF_INDEX, mac, ip, mask);
  1046. net_gateway_set(gateway);
  1047. // rt_printf("net_if_set duration:%dus.\r\n",ustimer_get_duration(us0));
  1048. // 得到并打印新的网络参数
  1049. net_if_get(IF_INDEX, mac, ip, mask);
  1050. rt_printf("new mac: %02x:%02x:%02x:%02x:%02x:%02x\r\n", mac[0], mac[1], mac[2], mac[3], mac[4], mac[5]);
  1051. rt_printf("new ip:%d.%d.%d.%d\r\n", ip[0], ip[1], ip[2], ip[3]);
  1052. rt_printf("new mask:%d.%d.%d.%d\r\n", mask[0], mask[1], mask[2], mask[3]);
  1053. rt_printf("new gateway:%d.%d.%d.%d\r\n", gateway[0], gateway[1], gateway[2], gateway[3]);
  1054. rt_printf("net_if_test ok\r\n");
  1055. return 0;
  1056. }
  1057. int socket_test(void)
  1058. {
  1059. unsigned char buf[512];
  1060. SOCKET sock, new_fd;
  1061. struct sockaddr_in server_addr;
  1062. struct sockaddr_in client_addr;
  1063. int sin_size, portnumber;
  1064. char hello[] = "Hello! Are You Fine?\n";
  1065. portnumber = 1111;
  1066. /*服务器端开始建立socket描述符*/
  1067. if ((sock = rt_socket(AF_INET, SOCK_STREAM, 0)) == RT_SOCKET_ERR)
  1068. {
  1069. rt_printf("Socket error:%d\n\a", sock);
  1070. }
  1071. /*服务器端填充sockaddr结构*/
  1072. memset(&server_addr, 0, sizeof(struct sockaddr_in)); // 将
  1073. server_addr.sin_family = AF_INET;
  1074. server_addr.sin_addr.s_addr = htonl(INADDR_ANY);
  1075. server_addr.sin_port = htons(portnumber);
  1076. /*捆绑sock描述符*/
  1077. if (rt_bind(sock, (struct sockaddr *)(&server_addr), sizeof(struct sockaddr)) == -1)
  1078. {
  1079. rt_printf("Bind error:%d\n\a", sock);
  1080. }
  1081. /*监听sock描述符*/
  1082. if (rt_listen(sock, 5) == -1)
  1083. {
  1084. rt_printf("Listen error:%d\n\a", sock);
  1085. }
  1086. while (1)
  1087. {
  1088. /*服务器阻塞,直到客户程序建立连接*/
  1089. sin_size = sizeof(struct sockaddr_in);
  1090. if ((new_fd = rt_accept(sock, (struct sockaddr *)(&client_addr), &sin_size)) == RT_SOCKET_ACCEPT_RST)
  1091. {
  1092. rt_printf("Accept error:%d\n\a", sock);
  1093. }
  1094. rt_printf("Server get connection from %d\n", new_fd);
  1095. if (rt_send(new_fd, hello, strlen(hello), 0) == -1)
  1096. {
  1097. rt_printf("Write Error:%d\n", new_fd);
  1098. }
  1099. while (1)
  1100. {
  1101. int flag;
  1102. if ((flag = rt_recv(new_fd, buf, 512, 0)) < 0)
  1103. {
  1104. rt_printf("Reading data error!\n");
  1105. break;
  1106. }
  1107. if (flag == 0)
  1108. {
  1109. rt_printf("Ending current connection!\n");
  1110. break;
  1111. }
  1112. else
  1113. {
  1114. rt_printf("-->%s\n", buf);
  1115. if (strstr(buf, "exit"))
  1116. {
  1117. rt_printf("Ending current connection!\n");
  1118. break;
  1119. }
  1120. }
  1121. rt_socket_close(new_fd);
  1122. }
  1123. rt_socket_close(sock);
  1124. }
  1125. return 0;
  1126. }
  1127. /*------------------------------ 文件结束 -------------------------------------
  1128. */