get_ifi_info.lc 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. #include "unpifi.h"## 1 ##src/route/get_ifi_info.c##
  2. #include "unproute.h"## 2 ##src/route/get_ifi_info.c##
  3. /* include get_ifi_info1 */
  4. struct ifi_info *## 3 ##src/route/get_ifi_info.c##
  5. get_ifi_info(int family, int doaliases)## 4 ##src/route/get_ifi_info.c##
  6. {## 5 ##src/route/get_ifi_info.c##
  7. int flags;## 6 ##src/route/get_ifi_info.c##
  8. char *buf, *next, *lim;## 7 ##src/route/get_ifi_info.c##
  9. size_t len;## 8 ##src/route/get_ifi_info.c##
  10. struct if_msghdr *ifm;## 9 ##src/route/get_ifi_info.c##
  11. struct ifa_msghdr *ifam;## 10 ##src/route/get_ifi_info.c##
  12. struct sockaddr *sa, *rti_info[RTAX_MAX];## 11 ##src/route/get_ifi_info.c##
  13. struct sockaddr_dl *sdl;## 12 ##src/route/get_ifi_info.c##
  14. struct ifi_info *ifi, *ifisave, *ifihead, **ifipnext;## 13 ##src/route/get_ifi_info.c##
  15. buf = Net_rt_iflist(family, 0, &len);## 14 ##src/route/get_ifi_info.c##
  16. ifihead = NULL;## 15 ##src/route/get_ifi_info.c##
  17. ifipnext = &ifihead;## 16 ##src/route/get_ifi_info.c##
  18. lim = buf + len;## 17 ##src/route/get_ifi_info.c##
  19. for (next = buf; next < lim; next += ifm->ifm_msglen) {## 18 ##src/route/get_ifi_info.c##
  20. ifm = (struct if_msghdr *) next;## 19 ##src/route/get_ifi_info.c##
  21. if (ifm->ifm_type == RTM_IFINFO) {## 20 ##src/route/get_ifi_info.c##
  22. if (((flags = ifm->ifm_flags) & IFF_UP) == 0)## 21 ##src/route/get_ifi_info.c##
  23. continue; /* ignore if interface not up */## 22 ##src/route/get_ifi_info.c##
  24. sa = (struct sockaddr *) (ifm + 1);## 23 ##src/route/get_ifi_info.c##
  25. get_rtaddrs(ifm->ifm_addrs, sa, rti_info);## 24 ##src/route/get_ifi_info.c##
  26. if ((sa = rti_info[RTAX_IFP]) != NULL) {## 25 ##src/route/get_ifi_info.c##
  27. ifi = Calloc(1, sizeof(struct ifi_info));## 26 ##src/route/get_ifi_info.c##
  28. *ifipnext = ifi; /* prev points to this new one */## 27 ##src/route/get_ifi_info.c##
  29. ifipnext = &ifi->ifi_next; /* ptr to next one goes here */## 28 ##src/route/get_ifi_info.c##
  30. ifi->ifi_flags = flags;## 29 ##src/route/get_ifi_info.c##
  31. if (sa->sa_family == AF_LINK) {## 30 ##src/route/get_ifi_info.c##
  32. sdl = (struct sockaddr_dl *) sa;## 31 ##src/route/get_ifi_info.c##
  33. if (sdl->sdl_nlen > 0)## 32 ##src/route/get_ifi_info.c##
  34. snprintf(ifi->ifi_name, IFI_NAME, "%*s",## 33 ##src/route/get_ifi_info.c##
  35. sdl->sdl_nlen, &sdl->sdl_data[0]);## 34 ##src/route/get_ifi_info.c##
  36. else## 35 ##src/route/get_ifi_info.c##
  37. snprintf(ifi->ifi_name, IFI_NAME, "index %d",## 36 ##src/route/get_ifi_info.c##
  38. sdl->sdl_index);## 37 ##src/route/get_ifi_info.c##
  39. if ((ifi->ifi_hlen = sdl->sdl_alen) > 0)## 38 ##src/route/get_ifi_info.c##
  40. memcpy(ifi->ifi_haddr, LLADDR(sdl),## 39 ##src/route/get_ifi_info.c##
  41. min(IFI_HADDR, sdl->sdl_alen));## 40 ##src/route/get_ifi_info.c##
  42. }## 41 ##src/route/get_ifi_info.c##
  43. }## 42 ##src/route/get_ifi_info.c##
  44. /* end get_ifi_info1 */
  45. /* include get_ifi_info3 */
  46. } else if (ifm->ifm_type == RTM_NEWADDR) {## 43 ##src/route/get_ifi_info.c##
  47. if (ifi->ifi_addr) { /* already have an IP addr for i/f */## 44 ##src/route/get_ifi_info.c##
  48. if (doaliases == 0)## 45 ##src/route/get_ifi_info.c##
  49. continue;## 46 ##src/route/get_ifi_info.c##
  50. /* 4we have a new IP addr for existing interface */## 47 ##src/route/get_ifi_info.c##
  51. ifisave = ifi;## 48 ##src/route/get_ifi_info.c##
  52. ifi = Calloc(1, sizeof(struct ifi_info));## 49 ##src/route/get_ifi_info.c##
  53. *ifipnext = ifi; /* prev points to this new one */## 50 ##src/route/get_ifi_info.c##
  54. ifipnext = &ifi->ifi_next; /* ptr to next one goes here */## 51 ##src/route/get_ifi_info.c##
  55. ifi->ifi_flags = ifisave->ifi_flags;## 52 ##src/route/get_ifi_info.c##
  56. ifi->ifi_hlen = ifisave->ifi_hlen;## 53 ##src/route/get_ifi_info.c##
  57. memcpy(ifi->ifi_name, ifisave->ifi_name, IFI_NAME);## 54 ##src/route/get_ifi_info.c##
  58. memcpy(ifi->ifi_haddr, ifisave->ifi_haddr, IFI_HADDR);## 55 ##src/route/get_ifi_info.c##
  59. }## 56 ##src/route/get_ifi_info.c##
  60. ifam = (struct ifa_msghdr *) next;## 57 ##src/route/get_ifi_info.c##
  61. sa = (struct sockaddr *) (ifam + 1);## 58 ##src/route/get_ifi_info.c##
  62. get_rtaddrs(ifam->ifam_addrs, sa, rti_info);## 59 ##src/route/get_ifi_info.c##
  63. if ((sa = rti_info[RTAX_IFA]) != NULL) {## 60 ##src/route/get_ifi_info.c##
  64. ifi->ifi_addr = Calloc(1, sa->sa_len);## 61 ##src/route/get_ifi_info.c##
  65. memcpy(ifi->ifi_addr, sa, sa->sa_len);## 62 ##src/route/get_ifi_info.c##
  66. }## 63 ##src/route/get_ifi_info.c##
  67. if ((flags & IFF_BROADCAST) && (sa = rti_info[RTAX_BRD]) != NULL) {## 64 ##src/route/get_ifi_info.c##
  68. ifi->ifi_brdaddr = Calloc(1, sa->sa_len);## 65 ##src/route/get_ifi_info.c##
  69. memcpy(ifi->ifi_brdaddr, sa, sa->sa_len);## 66 ##src/route/get_ifi_info.c##
  70. }## 67 ##src/route/get_ifi_info.c##
  71. if ((flags & IFF_POINTOPOINT) &&## 68 ##src/route/get_ifi_info.c##
  72. (sa = rti_info[RTAX_BRD]) != NULL) {## 69 ##src/route/get_ifi_info.c##
  73. ifi->ifi_dstaddr = Calloc(1, sa->sa_len);## 70 ##src/route/get_ifi_info.c##
  74. memcpy(ifi->ifi_dstaddr, sa, sa->sa_len);## 71 ##src/route/get_ifi_info.c##
  75. }## 72 ##src/route/get_ifi_info.c##
  76. } else## 73 ##src/route/get_ifi_info.c##
  77. err_quit("unexpected message type %d", ifm->ifm_type);## 74 ##src/route/get_ifi_info.c##
  78. }## 75 ##src/route/get_ifi_info.c##
  79. /* "ifihead" points to the first structure in the linked list */## 76 ##src/route/get_ifi_info.c##
  80. return (ifihead); /* ptr to first structure in linked list */## 77 ##src/route/get_ifi_info.c##
  81. }## 78 ##src/route/get_ifi_info.c##
  82. /* end get_ifi_info3 */
  83. void## 79 ##src/route/get_ifi_info.c##
  84. free_ifi_info(struct ifi_info *ifihead)## 80 ##src/route/get_ifi_info.c##
  85. {## 81 ##src/route/get_ifi_info.c##
  86. struct ifi_info *ifi, *ifinext;## 82 ##src/route/get_ifi_info.c##
  87. for (ifi = ifihead; ifi != NULL; ifi = ifinext) {## 83 ##src/route/get_ifi_info.c##
  88. if (ifi->ifi_addr != NULL)## 84 ##src/route/get_ifi_info.c##
  89. free(ifi->ifi_addr);## 85 ##src/route/get_ifi_info.c##
  90. if (ifi->ifi_brdaddr != NULL)## 86 ##src/route/get_ifi_info.c##
  91. free(ifi->ifi_brdaddr);## 87 ##src/route/get_ifi_info.c##
  92. if (ifi->ifi_dstaddr != NULL)## 88 ##src/route/get_ifi_info.c##
  93. free(ifi->ifi_dstaddr);## 89 ##src/route/get_ifi_info.c##
  94. ifinext = ifi->ifi_next; /* can't fetch ifi_next after free() */## 90 ##src/route/get_ifi_info.c##
  95. free(ifi); /* the ifi_info{} itself */## 91 ##src/route/get_ifi_info.c##
  96. }## 92 ##src/route/get_ifi_info.c##
  97. }## 93 ##src/route/get_ifi_info.c##
  98. struct ifi_info *## 94 ##src/route/get_ifi_info.c##
  99. Get_ifi_info(int family, int doaliases)## 95 ##src/route/get_ifi_info.c##
  100. {## 96 ##src/route/get_ifi_info.c##
  101. struct ifi_info *ifi;## 97 ##src/route/get_ifi_info.c##
  102. if ((ifi = get_ifi_info(family, doaliases)) == NULL)## 98 ##src/route/get_ifi_info.c##
  103. err_quit("get_ifi_info error");## 99 ##src/route/get_ifi_info.c##
  104. return (ifi);##100 ##src/route/get_ifi_info.c##
  105. }##101 ##src/route/get_ifi_info.c##