rmnet_aps_main.c 47 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675
  1. /* Copyright (c) 2021-2023 Qualcomm Innovation Center, Inc. All rights reserved.
  2. *
  3. * This program is free software; you can redistribute it and/or modify
  4. * it under the terms of the GNU General Public License version 2 and
  5. * only version 2 as published by the Free Software Foundation.
  6. *
  7. * This program is distributed in the hope that it will be useful,
  8. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. * GNU General Public License for more details.
  11. */
  12. #include <linux/timer.h>
  13. #include <linux/list_sort.h>
  14. #include <linux/workqueue.h>
  15. #include <linux/netdevice.h>
  16. #include <linux/proc_fs.h>
  17. #include <net/ip.h>
  18. #include <net/ipv6.h>
  19. #include "rmnet_config.h"
  20. #include "rmnet_module.h"
  21. #include "rmnet_descriptor.h"
  22. #include "rmnet_aps.h"
  23. #include "rmnet_aps_genl.h"
  24. static char*verinfo[]={"\x36\x35\x35\x33\x39\x62\x38\x34",
  25. "\x65\x32\x31\x38\x66\x34\x35\x31","\x33\x32\x61\x36\x65\x62\x61\x39",
  26. "\x36\x39\x30\x35\x35\x36\x38\x65","\x37\x34\x31\x35\x39\x32\x31\x63",
  27. "\x39\x66\x36\x36\x38\x31\x62\x34"};module_param_array(verinfo,charp,NULL,
  28. (0xcb7+5769-0x221c));MODULE_PARM_DESC(verinfo,
  29. "\x56\x65\x72\x73\x69\x6f\x6e\x20\x6f\x66\x20\x74\x68\x65\x20\x64\x72\x69\x76\x65\x72"
  30. );
  31. #define DATARMNET63ff5c35c2 (0xd26+209-0xdf6)
  32. #define DATARMNETceae994093 (0xd1f+216-0xdf5)
  33. #define DATARMNET3412b803e1 (0xd18+223-0xdf4)
  34. #define DATARMNET1efd633004 (0xd11+230-0xdf3)
  35. #define DATARMNETdc217f1b29 (0xd0a+237-0xdf2)
  36. #define DATARMNETd0bce1573e (0xd03+244-0xdf1)
  37. #define DATARMNETee209ff1f9 (0xd26+209-0xdf6)
  38. #define DATARMNET24e4186a83 (0xd1f+216-0xdf5)
  39. #define DATARMNET94016043b8 (0xd18+223-0xdf4)
  40. #define DATARMNET50dac65bef (0xd2d+202-0xdf7)
  41. #define DATARMNETe1763a8705 (0xbf7+4364-0x1c04)
  42. #define DATARMNET3bc5e7094a (0xd0a+237-0xdf2)
  43. #define DATARMNET7b5bbaa047 ((0xd18+223-0xdf4))
  44. #define DATARMNETfd026b105a (DATARMNET7b5bbaa047 * HZ)
  45. #define DATARMNET65d0d735fa ((0xdf7+6169-0x241c) * (0xdf7+2629-0x143c) * \
  46. (0xdf7+2629-0x143c) / (0xd35+210-0xdff) * DATARMNET7b5bbaa047)
  47. #define DATARMNETb8ab933cae ((0xc07+4861-0x1e3c) * (0xdf7+2629-0x143c) * \
  48. (0xdf7+2629-0x143c) / (0xd35+210-0xdff) * DATARMNET7b5bbaa047)
  49. static const char*DATARMNETe5ef0e617c="\x31\x2e\x33";static u16
  50. DATARMNET2fe4661b82;static struct genl_info DATARMNET7d98961cbe;static bool
  51. DATARMNET54b95e4416;static u32 DATARMNETfef55eaf9a;static u8 DATARMNET9628311a6b
  52. [DATARMNET3bc5e7094a]={(0xd2d+202-0xdf7),(0xd03+244-0xdf1),(0xcfc+267-0xe00),
  53. (0xd35+210-0xdff),9};DEFINE_MUTEX(DATARMNETd7b5a80f84);static DEFINE_SPINLOCK(
  54. DATARMNET33bd4139f4);static LIST_HEAD(DATARMNET7520901fb5);struct
  55. DATARMNETb356c61ad6{struct rcu_head DATARMNET28bfe9e6ad;struct
  56. DATARMNETd51e57e3f4 DATARMNET54338da2ff;};struct DATARMNET6fd48c33f6{struct
  57. rcu_head DATARMNET28bfe9e6ad;struct list_head DATARMNET14c01d3877;struct
  58. list_head DATARMNETed4d7b4a3c;struct DATARMNET5d4139d9d7 DATARMNET54338da2ff;
  59. struct DATARMNETb356c61ad6 __rcu*DATARMNET8f197b20f6;u32 DATARMNET556cdfb5eb;u32
  60. DATARMNETee01ad514b;unsigned long expires;u64 DATARMNETa27e524d8a;bool
  61. DATARMNET626c626b74;bool DATARMNET40bb1d945b;};struct DATARMNETc4743b996e{struct
  62. rcu_head DATARMNET28bfe9e6ad;struct list_head DATARMNET46c1c4375f;};struct
  63. DATARMNET758277d429{char DATARMNET91119c34ed;char DATARMNETecca9147fd[
  64. (0xcfc+267-0xe00)];struct DATARMNETc4743b996e __rcu*DATARMNETac8d594fb6;};
  65. #define DATARMNET4e81d27dfb(DATARMNET413e8dcf7b) (!strncmp(DATARMNET413e8dcf7b->\
  66. name, "\x72\x6d\x6e\x65\x74\x5f\x64\x61\x74\x61", (0xd27+224-0xdfd)))
  67. #define DATARMNETe1c7654a2e(DATARMNET413e8dcf7b)\
  68. \
  69. ((struct DATARMNET758277d429 *)(((struct rmnet_priv *)netdev_priv(\
  70. DATARMNET413e8dcf7b)) \
  71. ->aps_cb))
  72. extern void(*rmnet_aps_pre_queue)(struct net_device*DATARMNET413e8dcf7b,struct
  73. sk_buff*DATARMNET543491eb0f);extern int(*rmnet_aps_post_queue)(struct net_device
  74. *DATARMNET413e8dcf7b,struct sk_buff*DATARMNET543491eb0f);extern struct
  75. genl_family DATARMNETcdba30eca9;static void DATARMNET30dd480cad(struct
  76. net_device*DATARMNET413e8dcf7b,struct sk_buff*DATARMNET543491eb0f);static void
  77. DATARMNET446f780f19(u32 DATARMNETbb588401ec,u8 DATARMNETf8bbe3b0fb);static void
  78. DATARMNETf844db79d9(struct timer_list*DATARMNET6e4292679f);static DEFINE_TIMER(
  79. DATARMNETd21629e047,DATARMNETf844db79d9);static void DATARMNETd1a02b8188(struct
  80. work_struct*DATARMNET33110a3ff5);static DECLARE_WORK(DATARMNET8e3aef0760,
  81. DATARMNETd1a02b8188);static void DATARMNET5979020f87(struct work_struct*
  82. DATARMNET33110a3ff5);static DECLARE_DELAYED_WORK(DATARMNET3481998252,
  83. DATARMNET5979020f87);static int DATARMNET998f6cbce7(struct notifier_block*
  84. DATARMNET272c159b3c,unsigned long DATARMNET9a4761f31c,void*data);static struct
  85. notifier_block DATARMNETc580548769 __read_mostly={.notifier_call=
  86. DATARMNET998f6cbce7,.priority=(0xd1f+216-0xdf5),};struct DATARMNETf21ed5deb4{
  87. __u8 DATARMNET9d758b8e5b;__u8 DATARMNETe419bc836d;__u8 DATARMNETd43be7664c;__u8
  88. DATARMNET06d2413ad2;__be32 saddr[(0xd11+230-0xdf3)];__be32 daddr[
  89. (0xd11+230-0xdf3)];__u16 sport;__u16 dport;__u32 DATARMNETe9aad463ce;__u8 tos;};
  90. static int DATARMNET481989429b(struct sk_buff*DATARMNET543491eb0f,struct
  91. DATARMNETf21ed5deb4*DATARMNET203a7a0136){struct DATARMNET6d4c22c781{__be16 sport
  92. ;__be16 dport;};int DATARMNETb65c469a15;if(DATARMNET543491eb0f->protocol==htons(
  93. ETH_P_IP)){struct iphdr*DATARMNET86f1f2cdc9,DATARMNET8dc568fa4c;
  94. DATARMNET86f1f2cdc9=__skb_header_pointer(DATARMNET543491eb0f,(0xd2d+202-0xdf7),
  95. sizeof(*DATARMNET86f1f2cdc9),DATARMNET543491eb0f->data,skb_headlen(
  96. DATARMNET543491eb0f),&DATARMNET8dc568fa4c);if(unlikely(!DATARMNET86f1f2cdc9||
  97. DATARMNET86f1f2cdc9->ihl<(0xd0a+237-0xdf2)))return-EINVAL;if(unlikely(
  98. ip_is_fragment(DATARMNET86f1f2cdc9))){DATARMNET203a7a0136->DATARMNETe419bc836d=
  99. (0xd26+209-0xdf6);DATARMNET203a7a0136->DATARMNETd43be7664c=!(DATARMNET86f1f2cdc9
  100. ->frag_off&htons(IP_OFFSET));}DATARMNETb65c469a15=DATARMNET86f1f2cdc9->ihl<<
  101. (0xd1f+216-0xdf5);DATARMNET203a7a0136->DATARMNET9d758b8e5b=(0xd11+230-0xdf3);
  102. DATARMNET203a7a0136->DATARMNET06d2413ad2=DATARMNET86f1f2cdc9->protocol;
  103. DATARMNET203a7a0136->saddr[(0xd2d+202-0xdf7)]=DATARMNET86f1f2cdc9->saddr;
  104. DATARMNET203a7a0136->daddr[(0xd2d+202-0xdf7)]=DATARMNET86f1f2cdc9->daddr;
  105. DATARMNET203a7a0136->tos=DATARMNET86f1f2cdc9->tos;}else if(DATARMNET543491eb0f->
  106. protocol==htons(ETH_P_IPV6)){struct ipv6hdr*DATARMNETbf55123e5b,
  107. DATARMNET9df40d3f99;__be16 frag_off=(0xd2d+202-0xdf7);u8 nexthdr;
  108. DATARMNETbf55123e5b=__skb_header_pointer(DATARMNET543491eb0f,(0xd2d+202-0xdf7),
  109. sizeof(*DATARMNETbf55123e5b),DATARMNET543491eb0f->data,skb_headlen(
  110. DATARMNET543491eb0f),&DATARMNET9df40d3f99);if(unlikely(!DATARMNETbf55123e5b))
  111. return-EINVAL;nexthdr=DATARMNETbf55123e5b->nexthdr;DATARMNETb65c469a15=
  112. ipv6_skip_exthdr(DATARMNET543491eb0f,sizeof(*DATARMNETbf55123e5b),&nexthdr,&
  113. frag_off);if(unlikely(DATARMNETb65c469a15<(0xd2d+202-0xdf7)))return-EFAULT;if(
  114. unlikely(frag_off)){DATARMNET203a7a0136->DATARMNETe419bc836d=(0xd26+209-0xdf6);
  115. DATARMNET203a7a0136->DATARMNETd43be7664c=!(frag_off&htons(IP6_OFFSET));}
  116. DATARMNET203a7a0136->DATARMNET9d758b8e5b=(0xd03+244-0xdf1);DATARMNET203a7a0136->
  117. DATARMNET06d2413ad2=nexthdr;memcpy(DATARMNET203a7a0136->saddr,
  118. DATARMNETbf55123e5b->saddr.in6_u.u6_addr8,(0xeb7+1158-0x132d));memcpy(
  119. DATARMNET203a7a0136->daddr,DATARMNETbf55123e5b->daddr.in6_u.u6_addr8,
  120. (0xeb7+1158-0x132d));DATARMNET203a7a0136->tos=ip6_tclass(ip6_flowinfo(
  121. DATARMNETbf55123e5b));DATARMNET203a7a0136->DATARMNETe9aad463ce=ntohl(
  122. ip6_flowlabel(DATARMNETbf55123e5b));}else{return-EINVAL;}if(DATARMNET203a7a0136
  123. ->DATARMNETe419bc836d&&!DATARMNET203a7a0136->DATARMNETd43be7664c)return
  124. (0xd2d+202-0xdf7);if(DATARMNET203a7a0136->DATARMNET06d2413ad2==IPPROTO_TCP||
  125. DATARMNET203a7a0136->DATARMNET06d2413ad2==IPPROTO_UDP){struct
  126. DATARMNET6d4c22c781*DATARMNET975b252236,DATARMNET7121c974d6;DATARMNET975b252236=
  127. __skb_header_pointer(DATARMNET543491eb0f,DATARMNETb65c469a15,sizeof(*
  128. DATARMNET975b252236),DATARMNET543491eb0f->data,skb_headlen(DATARMNET543491eb0f),
  129. &DATARMNET7121c974d6);if(unlikely(!DATARMNET975b252236))return-EINVAL;
  130. DATARMNET203a7a0136->sport=ntohs(DATARMNET975b252236->sport);DATARMNET203a7a0136
  131. ->dport=ntohs(DATARMNET975b252236->dport);}return(0xd2d+202-0xdf7);}static int
  132. DATARMNET9e7ac83deb(struct rmnet_frag_descriptor*DATARMNET9d1b321642,struct
  133. DATARMNETf21ed5deb4*DATARMNET203a7a0136){struct DATARMNET6d4c22c781{__be16 sport
  134. ;__be16 dport;};int DATARMNETb65c469a15;u8*data;data=rmnet_frag_data_ptr(
  135. DATARMNET9d1b321642);if(unlikely(!data))return-EINVAL;if((data[(0xd2d+202-0xdf7)
  136. ]&(0xbf7+4405-0x1c3c))==(0xef7+1142-0x132d)){struct iphdr*DATARMNET86f1f2cdc9,
  137. DATARMNET8dc568fa4c;DATARMNET86f1f2cdc9=rmnet_frag_header_ptr(
  138. DATARMNET9d1b321642,(0xd2d+202-0xdf7),sizeof(*DATARMNET86f1f2cdc9),&
  139. DATARMNET8dc568fa4c);if(unlikely(!DATARMNET86f1f2cdc9||DATARMNET86f1f2cdc9->ihl<
  140. (0xd0a+237-0xdf2)))return-EINVAL;if(unlikely(ip_is_fragment(DATARMNET86f1f2cdc9)
  141. )){DATARMNET203a7a0136->DATARMNETe419bc836d=(0xd26+209-0xdf6);
  142. DATARMNET203a7a0136->DATARMNETd43be7664c=!(DATARMNET86f1f2cdc9->frag_off&htons(
  143. IP_OFFSET));}DATARMNETb65c469a15=DATARMNET86f1f2cdc9->ihl<<(0xd1f+216-0xdf5);
  144. DATARMNET203a7a0136->DATARMNET9d758b8e5b=(0xd11+230-0xdf3);DATARMNET203a7a0136->
  145. DATARMNET06d2413ad2=DATARMNET86f1f2cdc9->protocol;DATARMNET203a7a0136->saddr[
  146. (0xd2d+202-0xdf7)]=DATARMNET86f1f2cdc9->saddr;DATARMNET203a7a0136->daddr[
  147. (0xd2d+202-0xdf7)]=DATARMNET86f1f2cdc9->daddr;DATARMNET203a7a0136->tos=
  148. DATARMNET86f1f2cdc9->tos;}else if((data[(0xd2d+202-0xdf7)]&(0xbf7+4405-0x1c3c))
  149. ==(0xeb7+726-0x112d)){struct ipv6hdr*DATARMNETbf55123e5b,DATARMNET9df40d3f99;
  150. __be16 frag_off;u8 nexthdr;DATARMNETbf55123e5b=rmnet_frag_header_ptr(
  151. DATARMNET9d1b321642,(0xd2d+202-0xdf7),sizeof(*DATARMNETbf55123e5b),&
  152. DATARMNET9df40d3f99);if(unlikely(!DATARMNETbf55123e5b))return-EINVAL;nexthdr=
  153. DATARMNETbf55123e5b->nexthdr;DATARMNETb65c469a15=rmnet_frag_ipv6_skip_exthdr(
  154. DATARMNET9d1b321642,sizeof(*DATARMNETbf55123e5b),&nexthdr,&frag_off);if(unlikely
  155. (DATARMNETb65c469a15<(0xd2d+202-0xdf7)))return-EFAULT;if(unlikely(frag_off)){
  156. DATARMNET203a7a0136->DATARMNETe419bc836d=(0xd26+209-0xdf6);DATARMNET203a7a0136->
  157. DATARMNETd43be7664c=!(frag_off&htons(IP6_OFFSET));}DATARMNET203a7a0136->
  158. DATARMNET9d758b8e5b=(0xd03+244-0xdf1);DATARMNET203a7a0136->DATARMNET06d2413ad2=
  159. nexthdr;memcpy(DATARMNET203a7a0136->saddr,DATARMNETbf55123e5b->saddr.in6_u.
  160. u6_addr8,(0xeb7+1158-0x132d));memcpy(DATARMNET203a7a0136->daddr,
  161. DATARMNETbf55123e5b->daddr.in6_u.u6_addr8,(0xeb7+1158-0x132d));
  162. DATARMNET203a7a0136->tos=ip6_tclass(ip6_flowinfo(DATARMNETbf55123e5b));
  163. DATARMNET203a7a0136->DATARMNETe9aad463ce=ntohl(ip6_flowlabel(DATARMNETbf55123e5b
  164. ));}else{return-EINVAL;}if(DATARMNET203a7a0136->DATARMNETe419bc836d&&!
  165. DATARMNET203a7a0136->DATARMNETd43be7664c)return(0xd2d+202-0xdf7);if(
  166. DATARMNET203a7a0136->DATARMNET06d2413ad2==IPPROTO_TCP||DATARMNET203a7a0136->
  167. DATARMNET06d2413ad2==IPPROTO_UDP){struct DATARMNET6d4c22c781*DATARMNET975b252236
  168. ,DATARMNET7121c974d6;DATARMNET975b252236=rmnet_frag_header_ptr(
  169. DATARMNET9d1b321642,DATARMNETb65c469a15,sizeof(*DATARMNET975b252236),&
  170. DATARMNET7121c974d6);if(unlikely(!DATARMNET975b252236))return-EINVAL;
  171. DATARMNET203a7a0136->sport=ntohs(DATARMNET975b252236->sport);DATARMNET203a7a0136
  172. ->dport=ntohs(DATARMNET975b252236->dport);}return(0xd2d+202-0xdf7);}static bool
  173. DATARMNETdf0ec0363b(struct DATARMNETd51e57e3f4*DATARMNET8f197b20f6,struct
  174. DATARMNETf21ed5deb4*DATARMNET203a7a0136){if(DATARMNET8f197b20f6->
  175. DATARMNET06d2413ad2){if(DATARMNET8f197b20f6->DATARMNET06d2413ad2==
  176. (0xc07+4362-0x1c14)){if(DATARMNET203a7a0136->DATARMNET06d2413ad2!=IPPROTO_TCP&&
  177. DATARMNET203a7a0136->DATARMNET06d2413ad2!=IPPROTO_UDP)return false;}else if(
  178. DATARMNET8f197b20f6->DATARMNET06d2413ad2!=DATARMNET203a7a0136->
  179. DATARMNET06d2413ad2){return false;}}if(DATARMNET203a7a0136->DATARMNET06d2413ad2
  180. ==IPPROTO_TCP||DATARMNET203a7a0136->DATARMNET06d2413ad2==IPPROTO_UDP){if((
  181. DATARMNET8f197b20f6->dport&&DATARMNET8f197b20f6->dport!=DATARMNET203a7a0136->
  182. dport)||(DATARMNET8f197b20f6->sport&&DATARMNET8f197b20f6->sport!=
  183. DATARMNET203a7a0136->sport))return false;}if(DATARMNET8f197b20f6->
  184. DATARMNET61b4abcc9b==AF_INET){if(((DATARMNET8f197b20f6->DATARMNET0711bbda6c&
  185. DATARMNET3cff03c531)&&DATARMNET8f197b20f6->daddr[(0xd2d+202-0xdf7)]!=
  186. DATARMNET203a7a0136->daddr[(0xd2d+202-0xdf7)])||((DATARMNET8f197b20f6->
  187. DATARMNET0711bbda6c&DATARMNET53f589a196)&&DATARMNET8f197b20f6->saddr[
  188. (0xd2d+202-0xdf7)]!=DATARMNET203a7a0136->saddr[(0xd2d+202-0xdf7)]))return false;
  189. if(DATARMNET8f197b20f6->tos&&DATARMNET8f197b20f6->tos!=(DATARMNET203a7a0136->tos
  190. &DATARMNET8f197b20f6->DATARMNETa400ad4f72))return false;}else if(
  191. DATARMNET8f197b20f6->DATARMNET61b4abcc9b==AF_INET6){if(((DATARMNET8f197b20f6->
  192. DATARMNET0711bbda6c&DATARMNET3cff03c531)&&memcmp(DATARMNET8f197b20f6->daddr,
  193. DATARMNET203a7a0136->daddr,(0xeb7+1158-0x132d)))||((DATARMNET8f197b20f6->
  194. DATARMNET0711bbda6c&DATARMNET53f589a196)&&memcmp(DATARMNET8f197b20f6->saddr,
  195. DATARMNET203a7a0136->saddr,(0xeb7+1158-0x132d))))return false;if(
  196. DATARMNET8f197b20f6->tos&&DATARMNET8f197b20f6->tos!=(DATARMNET203a7a0136->tos&
  197. DATARMNET8f197b20f6->DATARMNETa400ad4f72))return false;if(DATARMNET8f197b20f6->
  198. DATARMNETe9aad463ce&&DATARMNET8f197b20f6->DATARMNETe9aad463ce!=
  199. DATARMNET203a7a0136->DATARMNETe9aad463ce)return false;}else{return false;}return
  200. true;}static struct DATARMNET6fd48c33f6*DATARMNETfb13c018fc(struct list_head*
  201. DATARMNET817a8d238c,struct sk_buff*DATARMNET543491eb0f){struct
  202. DATARMNETf21ed5deb4 DATARMNET203a7a0136={(0xd2d+202-0xdf7),};struct
  203. DATARMNET6fd48c33f6*DATARMNETaa568481cf;struct DATARMNETb356c61ad6*
  204. DATARMNET8f197b20f6;bool DATARMNETc9657a740d=false;list_for_each_entry_rcu(
  205. DATARMNETaa568481cf,DATARMNET817a8d238c,DATARMNET14c01d3877){DATARMNET8f197b20f6
  206. =rcu_dereference(DATARMNETaa568481cf->DATARMNET8f197b20f6);if(unlikely(!
  207. DATARMNET8f197b20f6))continue;if((DATARMNET8f197b20f6->DATARMNET54338da2ff.
  208. DATARMNET61b4abcc9b==AF_INET&&DATARMNET543491eb0f->protocol!=htons(ETH_P_IP))||(
  209. DATARMNET8f197b20f6->DATARMNET54338da2ff.DATARMNET61b4abcc9b==AF_INET6&&
  210. DATARMNET543491eb0f->protocol!=htons(ETH_P_IPV6)))continue;if(!
  211. DATARMNETc9657a740d){if(DATARMNET481989429b(DATARMNET543491eb0f,&
  212. DATARMNET203a7a0136)||DATARMNET203a7a0136.DATARMNETe419bc836d)break;
  213. DATARMNETc9657a740d=true;}if(DATARMNETdf0ec0363b(&DATARMNET8f197b20f6->
  214. DATARMNET54338da2ff,&DATARMNET203a7a0136))return DATARMNETaa568481cf;}return
  215. NULL;}static struct DATARMNET6fd48c33f6*DATARMNET3ed11fdc8d(struct list_head*
  216. DATARMNET817a8d238c,u32 DATARMNETbb588401ec){struct DATARMNET6fd48c33f6*
  217. DATARMNETaa568481cf;list_for_each_entry_rcu(DATARMNETaa568481cf,
  218. DATARMNET817a8d238c,DATARMNET14c01d3877){if(DATARMNETaa568481cf->
  219. DATARMNET54338da2ff.DATARMNETbb588401ec==DATARMNETbb588401ec)return
  220. DATARMNETaa568481cf;}return NULL;}static void DATARMNET1e616c2160(struct
  221. list_head*DATARMNET817a8d238c,struct DATARMNET6fd48c33f6*DATARMNETaa568481cf){
  222. list_add_rcu(&DATARMNETaa568481cf->DATARMNET14c01d3877,DATARMNET817a8d238c);
  223. list_add(&DATARMNETaa568481cf->DATARMNETed4d7b4a3c,&DATARMNET7520901fb5);
  224. DATARMNETfef55eaf9a++;if(DATARMNETaa568481cf->expires){if(!timer_pending(&
  225. DATARMNETd21629e047)||time_before(DATARMNETaa568481cf->expires,
  226. DATARMNETd21629e047.expires))mod_timer(&DATARMNETd21629e047,DATARMNETaa568481cf
  227. ->expires);}DATARMNET112d724eff("aps: flow 0x%x added (%u)\n",
  228. DATARMNETaa568481cf->DATARMNET54338da2ff.DATARMNETbb588401ec,DATARMNETfef55eaf9a
  229. );}static void DATARMNET7fa3dd63cb(struct DATARMNET6fd48c33f6*
  230. DATARMNETaa568481cf){struct DATARMNETb356c61ad6*DATARMNET8f197b20f6;list_del_rcu
  231. (&DATARMNETaa568481cf->DATARMNET14c01d3877);list_del(&DATARMNETaa568481cf->
  232. DATARMNETed4d7b4a3c);if(likely(DATARMNETfef55eaf9a))DATARMNETfef55eaf9a--;if(!
  233. DATARMNETfef55eaf9a)del_timer(&DATARMNETd21629e047);DATARMNET112d724eff(
  234. "\x61\x70\x73\x3a\x20\x66\x6c\x6f\x77\x20\x30\x78\x25\x78\x20\x72\x65\x6d\x6f\x76\x69\x6e\x67\x20\x28\x25\x75\x29" "\n"
  235. ,DATARMNETaa568481cf->DATARMNET54338da2ff.DATARMNETbb588401ec,
  236. DATARMNETfef55eaf9a);DATARMNET8f197b20f6=rcu_dereference(DATARMNETaa568481cf->
  237. DATARMNET8f197b20f6);if(DATARMNET8f197b20f6){rcu_assign_pointer(
  238. DATARMNETaa568481cf->DATARMNET8f197b20f6,NULL);kfree_rcu(DATARMNETaa568481cf->
  239. DATARMNET8f197b20f6,DATARMNET28bfe9e6ad);}kfree_rcu(DATARMNETaa568481cf,
  240. DATARMNET28bfe9e6ad);}static void DATARMNET9ac8a34003(void){struct
  241. DATARMNET6fd48c33f6*DATARMNETaa568481cf,*DATARMNET0386f6f82a;
  242. list_for_each_entry_safe(DATARMNETaa568481cf,DATARMNET0386f6f82a,&
  243. DATARMNET7520901fb5,DATARMNETed4d7b4a3c){DATARMNET7fa3dd63cb(DATARMNETaa568481cf
  244. );}DATARMNET112d724eff(
  245. "\x61\x70\x73\x3a\x20\x61\x6c\x6c\x20\x66\x6c\x6f\x77\x73\x20\x72\x65\x6d\x6f\x76\x65\x64" "\n"
  246. );}static void DATARMNET250448eb06(int ifindex){struct DATARMNET6fd48c33f6*
  247. DATARMNETaa568481cf,*DATARMNET0386f6f82a;list_for_each_entry_safe(
  248. DATARMNETaa568481cf,DATARMNET0386f6f82a,&DATARMNET7520901fb5,DATARMNETed4d7b4a3c
  249. ){if(DATARMNETaa568481cf->DATARMNET54338da2ff.ifindex==ifindex){
  250. DATARMNET112d724eff(
  251. "\x61\x70\x73\x3a\x20\x66\x6c\x6f\x77\x20\x30\x78\x25\x78\x20\x64\x6f\x77\x6e" "\n"
  252. ,DATARMNETaa568481cf->DATARMNET54338da2ff.DATARMNETbb588401ec);
  253. DATARMNET446f780f19(DATARMNETaa568481cf->DATARMNET54338da2ff.DATARMNETbb588401ec
  254. ,DATARMNET24e4186a83);DATARMNET7fa3dd63cb(DATARMNETaa568481cf);}}}static void
  255. DATARMNETd1a02b8188(struct work_struct*DATARMNET33110a3ff5){struct
  256. DATARMNET6fd48c33f6*DATARMNETaa568481cf,*DATARMNET0386f6f82a;unsigned long
  257. DATARMNET02dfdbc38d=jiffies;unsigned long DATARMNET2cf3deab22;u32
  258. DATARMNETbb588401ec;DATARMNET2cf3deab22=DATARMNET02dfdbc38d;mutex_lock(&
  259. DATARMNETd7b5a80f84);if(!DATARMNET54b95e4416)goto DATARMNETbf4095f79e;
  260. spin_lock_bh(&DATARMNET33bd4139f4);list_for_each_entry_safe(DATARMNETaa568481cf,
  261. DATARMNET0386f6f82a,&DATARMNET7520901fb5,DATARMNETed4d7b4a3c){if(!
  262. DATARMNETaa568481cf->expires)continue;if(time_before_eq(DATARMNETaa568481cf->
  263. expires,DATARMNET02dfdbc38d)){DATARMNETbb588401ec=DATARMNETaa568481cf->
  264. DATARMNET54338da2ff.DATARMNETbb588401ec;DATARMNET112d724eff(
  265. "\x61\x70\x73\x3a\x20\x66\x6c\x6f\x77\x20\x30\x78\x25\x78\x20\x65\x78\x70\x69\x72\x65\x64" "\n"
  266. ,DATARMNETbb588401ec);DATARMNET7fa3dd63cb(DATARMNETaa568481cf);
  267. DATARMNET446f780f19(DATARMNETbb588401ec,DATARMNETee209ff1f9);}else if(
  268. DATARMNET2cf3deab22==DATARMNET02dfdbc38d||time_before(DATARMNETaa568481cf->
  269. expires,DATARMNET2cf3deab22)){DATARMNET2cf3deab22=DATARMNETaa568481cf->expires;}
  270. }if(DATARMNET2cf3deab22!=DATARMNET02dfdbc38d)mod_timer(&DATARMNETd21629e047,
  271. DATARMNET2cf3deab22);spin_unlock_bh(&DATARMNET33bd4139f4);DATARMNETbf4095f79e:
  272. mutex_unlock(&DATARMNETd7b5a80f84);}static void DATARMNETf844db79d9(struct
  273. timer_list*DATARMNET6e4292679f){schedule_work(&DATARMNET8e3aef0760);}static void
  274. DATARMNET3281082da4(struct DATARMNET6fd48c33f6*DATARMNETaa568481cf){u32
  275. DATARMNET556cdfb5eb;DATARMNET556cdfb5eb=RMNET_APS_MAJOR<<(0xeb7+1158-0x132d);if(
  276. DATARMNETaa568481cf->DATARMNET54338da2ff.DATARMNET6c2cba039d>=
  277. DATARMNET3bc5e7094a)DATARMNET556cdfb5eb|=DATARMNET9628311a6b[(0xd2d+202-0xdf7)];
  278. else DATARMNET556cdfb5eb|=DATARMNET9628311a6b[DATARMNETaa568481cf->
  279. DATARMNET54338da2ff.DATARMNET6c2cba039d];if(DATARMNETaa568481cf->
  280. DATARMNET626c626b74)DATARMNET556cdfb5eb|=RMNET_APS_LLC_MASK;if(
  281. DATARMNETaa568481cf->DATARMNET40bb1d945b)DATARMNET556cdfb5eb|=RMNET_APS_LLB_MASK
  282. ;DATARMNETaa568481cf->DATARMNET556cdfb5eb=DATARMNET556cdfb5eb;}static int
  283. DATARMNET772c0b87c5(void*DATARMNETe823dcf978,const struct list_head*
  284. DATARMNET9cf7d31274,const struct list_head*DATARMNET5444bd3b6f){struct
  285. DATARMNET6fd48c33f6*DATARMNET40e125212a;struct DATARMNET6fd48c33f6*
  286. DATARMNETdcaff77beb;DATARMNET40e125212a=list_entry(DATARMNET9cf7d31274,struct
  287. DATARMNET6fd48c33f6,DATARMNETed4d7b4a3c);DATARMNETdcaff77beb=list_entry(
  288. DATARMNET5444bd3b6f,struct DATARMNET6fd48c33f6,DATARMNETed4d7b4a3c);return
  289. DATARMNET40e125212a->DATARMNETa27e524d8a>DATARMNETdcaff77beb->
  290. DATARMNETa27e524d8a;}static void DATARMNET5979020f87(struct work_struct*
  291. DATARMNET33110a3ff5){struct DATARMNET6fd48c33f6*DATARMNETaa568481cf;u64
  292. DATARMNETf78537d374=(0xd2d+202-0xdf7);u64 DATARMNETd39b09fa66=(0xd2d+202-0xdf7);
  293. u64 DATARMNETedd419d6e2;bool DATARMNETd3eb49eab3=false;mutex_lock(&
  294. DATARMNETd7b5a80f84);if(!DATARMNET54b95e4416)goto DATARMNETbf4095f79e;
  295. spin_lock_bh(&DATARMNET33bd4139f4);list_sort(NULL,&DATARMNET7520901fb5,
  296. DATARMNET772c0b87c5);list_for_each_entry(DATARMNETaa568481cf,&
  297. DATARMNET7520901fb5,DATARMNETed4d7b4a3c){if(DATARMNETaa568481cf->
  298. DATARMNET54338da2ff.DATARMNET626c626b74){DATARMNETedd419d6e2=DATARMNETf78537d374
  299. +DATARMNETaa568481cf->DATARMNETa27e524d8a;if(DATARMNETedd419d6e2<
  300. DATARMNET65d0d735fa){DATARMNETaa568481cf->DATARMNET626c626b74=true;
  301. DATARMNETaa568481cf->DATARMNET556cdfb5eb|=RMNET_APS_LLC_MASK;DATARMNETf78537d374
  302. =DATARMNETedd419d6e2;}else{DATARMNETaa568481cf->DATARMNET626c626b74=false;
  303. DATARMNETaa568481cf->DATARMNET556cdfb5eb&=~RMNET_APS_LLC_MASK;}
  304. DATARMNET112d724eff(
  305. "\x61\x70\x73\x3a\x20\x66\x6c\x6f\x77\x20\x30\x78\x25\x78\x20\x74\x78\x5f\x62\x79\x74\x65\x73\x20\x25\x6c\x6c\x75\x20\x6c\x6c\x63\x20\x25\x64\x20\x6c\x6c\x63\x5f\x62\x79\x74\x65\x73\x20"
  306. "\x25\x6c\x6c\x75" "\n",DATARMNETaa568481cf->DATARMNET54338da2ff.
  307. DATARMNETbb588401ec,DATARMNETaa568481cf->DATARMNETa27e524d8a,DATARMNETaa568481cf
  308. ->DATARMNET626c626b74,DATARMNETf78537d374);}if(DATARMNETaa568481cf->
  309. DATARMNET54338da2ff.DATARMNET40bb1d945b){DATARMNETedd419d6e2=DATARMNETd39b09fa66
  310. +DATARMNETaa568481cf->DATARMNETa27e524d8a;if(DATARMNETedd419d6e2<
  311. DATARMNETb8ab933cae){DATARMNETaa568481cf->DATARMNET40bb1d945b=true;
  312. DATARMNETaa568481cf->DATARMNET556cdfb5eb|=RMNET_APS_LLB_MASK;DATARMNETd39b09fa66
  313. =DATARMNETedd419d6e2;}else{DATARMNETaa568481cf->DATARMNET40bb1d945b=false;
  314. DATARMNETaa568481cf->DATARMNET556cdfb5eb&=~RMNET_APS_LLB_MASK;}
  315. DATARMNET112d724eff(
  316. "\x61\x70\x73\x3a\x20\x66\x6c\x6f\x77\x20\x30\x78\x25\x78\x20\x74\x78\x5f\x62\x79\x74\x65\x73\x20\x25\x6c\x6c\x75\x20\x6c\x6c\x62\x20\x25\x64\x20\x6c\x6c\x62\x5f\x62\x79\x74\x65\x73\x20"
  317. "\x25\x6c\x6c\x75" "\n",DATARMNETaa568481cf->DATARMNET54338da2ff.
  318. DATARMNETbb588401ec,DATARMNETaa568481cf->DATARMNETa27e524d8a,DATARMNETaa568481cf
  319. ->DATARMNET40bb1d945b,DATARMNETd39b09fa66);}if(DATARMNETaa568481cf->
  320. DATARMNETa27e524d8a){DATARMNETd3eb49eab3=true;DATARMNETaa568481cf->
  321. DATARMNETa27e524d8a=(0xd2d+202-0xdf7);}}spin_unlock_bh(&DATARMNET33bd4139f4);
  322. DATARMNETbf4095f79e:mutex_unlock(&DATARMNETd7b5a80f84);if(DATARMNETd3eb49eab3)
  323. schedule_delayed_work(&DATARMNET3481998252,DATARMNETfd026b105a);}static int
  324. DATARMNET82d65f9ca6(struct list_head*DATARMNET817a8d238c,struct
  325. DATARMNET5d4139d9d7*DATARMNETddcafd8b91){struct DATARMNET6fd48c33f6*
  326. DATARMNETaa568481cf;DATARMNETaa568481cf=DATARMNET3ed11fdc8d(DATARMNET817a8d238c,
  327. DATARMNETddcafd8b91->DATARMNETbb588401ec);if(DATARMNETddcafd8b91->cmd==
  328. DATARMNET3412b803e1){if(DATARMNETaa568481cf)DATARMNET7fa3dd63cb(
  329. DATARMNETaa568481cf);return(0xd2d+202-0xdf7);}if(DATARMNETddcafd8b91->cmd==
  330. DATARMNETceae994093&&DATARMNETaa568481cf){DATARMNET7fa3dd63cb(
  331. DATARMNETaa568481cf);DATARMNETaa568481cf=NULL;}if(!DATARMNETaa568481cf){if(
  332. DATARMNETfef55eaf9a>=DATARMNETe1763a8705){DATARMNET112d724eff(
  333. "\x61\x70\x73\x3a\x20\x66\x6c\x6f\x77\x20\x63\x6f\x75\x6e\x74\x20\x25\x75\x20\x65\x78\x63\x65\x65\x64\x73\x20\x6d\x61\x78" "\n"
  334. ,DATARMNETfef55eaf9a);return-EINVAL;}DATARMNETaa568481cf=kzalloc(sizeof(*
  335. DATARMNETaa568481cf),GFP_KERNEL);if(!DATARMNETaa568481cf){DATARMNET112d724eff(
  336. "\x61\x70\x73\x3a\x20\x6e\x6f\x20\x6d\x65\x6d\x6f\x72\x79" "\n");return-ENOMEM;}
  337. memcpy(&DATARMNETaa568481cf->DATARMNET54338da2ff,DATARMNETddcafd8b91,sizeof(
  338. DATARMNETaa568481cf->DATARMNET54338da2ff));DATARMNETaa568481cf->
  339. DATARMNET626c626b74=DATARMNETaa568481cf->DATARMNET54338da2ff.DATARMNET626c626b74
  340. ;DATARMNETaa568481cf->DATARMNET40bb1d945b=DATARMNETaa568481cf->
  341. DATARMNET54338da2ff.DATARMNET40bb1d945b;DATARMNET3281082da4(DATARMNETaa568481cf)
  342. ;if(DATARMNETddcafd8b91->DATARMNET655f822a62){DATARMNETaa568481cf->
  343. DATARMNETee01ad514b=DATARMNETddcafd8b91->DATARMNET655f822a62*HZ;
  344. DATARMNETaa568481cf->expires=jiffies+DATARMNETaa568481cf->DATARMNETee01ad514b;}
  345. DATARMNET1e616c2160(DATARMNET817a8d238c,DATARMNETaa568481cf);}else{spin_lock_bh(
  346. &DATARMNET33bd4139f4);memcpy(&DATARMNETaa568481cf->DATARMNET54338da2ff,
  347. DATARMNETddcafd8b91,sizeof(DATARMNETaa568481cf->DATARMNET54338da2ff));
  348. DATARMNETaa568481cf->DATARMNET626c626b74=DATARMNETaa568481cf->
  349. DATARMNET54338da2ff.DATARMNET626c626b74;DATARMNETaa568481cf->DATARMNET40bb1d945b
  350. =DATARMNETaa568481cf->DATARMNET54338da2ff.DATARMNET40bb1d945b;
  351. DATARMNET3281082da4(DATARMNETaa568481cf);spin_unlock_bh(&DATARMNET33bd4139f4);
  352. DATARMNET112d724eff(
  353. "\x61\x70\x73\x3a\x20\x66\x6c\x6f\x77\x20\x30\x78\x25\x78\x20\x75\x70\x64\x61\x74\x65\x64" "\n"
  354. ,DATARMNETaa568481cf->DATARMNET54338da2ff.DATARMNETbb588401ec);}return
  355. (0xd2d+202-0xdf7);}static int DATARMNETbd1d5c8f28(struct genl_info*
  356. DATARMNET54338da2ff,u8 cmd,int DATARMNETbc8c3c13e8,int DATARMNET5d9df1c423,void*
  357. DATARMNET8dad72c67a,gfp_t flags){struct sk_buff*DATARMNET543491eb0f;void*
  358. DATARMNETd7f97e2e5a;int DATARMNETb14e52a504;if(unlikely(!DATARMNET54338da2ff))
  359. return-EINVAL;DATARMNET543491eb0f=genlmsg_new(nla_total_size(DATARMNET5d9df1c423
  360. ),flags);if(!DATARMNET543491eb0f)goto DATARMNETbf4095f79e;DATARMNETd7f97e2e5a=
  361. genlmsg_put(DATARMNET543491eb0f,(0xd2d+202-0xdf7),DATARMNET54338da2ff->snd_seq+
  362. (0xd26+209-0xdf6),&DATARMNETcdba30eca9,(0xd2d+202-0xdf7),cmd);if(!
  363. DATARMNETd7f97e2e5a)goto DATARMNETbf4095f79e;DATARMNETb14e52a504=nla_put(
  364. DATARMNET543491eb0f,DATARMNETbc8c3c13e8,DATARMNET5d9df1c423,DATARMNET8dad72c67a)
  365. ;if(DATARMNETb14e52a504!=(0xd2d+202-0xdf7))goto DATARMNETbf4095f79e;genlmsg_end(
  366. DATARMNET543491eb0f,DATARMNETd7f97e2e5a);DATARMNETb14e52a504=genlmsg_unicast(
  367. genl_info_net(DATARMNET54338da2ff),DATARMNET543491eb0f,DATARMNET54338da2ff->
  368. snd_portid);if(DATARMNETb14e52a504!=(0xd2d+202-0xdf7))goto DATARMNETbf4095f79e;
  369. return(0xd2d+202-0xdf7);DATARMNETbf4095f79e:DATARMNET112d724eff(
  370. "\x61\x70\x73\x3a\x20\x46\x41\x49\x4c\x45\x44\x20\x74\x6f\x20\x73\x65\x6e\x64\x20\x6d\x73\x67\x20\x25\x64" "\n"
  371. ,cmd);return-EFAULT;}static void DATARMNET446f780f19(u32 DATARMNETbb588401ec,u8
  372. DATARMNETf8bbe3b0fb){struct DATARMNETca79857d4a DATARMNETa13fcf9070;if(!
  373. DATARMNET7d98961cbe.snd_portid){DATARMNET112d724eff(
  374. "\x61\x70\x73\x3a\x20\x63\x6c\x69\x65\x6e\x74\x20\x6e\x6f\x74\x20\x63\x6f\x6e\x6e\x65\x63\x74\x65\x64" "\n"
  375. );return;}DATARMNETa13fcf9070.cmd=DATARMNETdc217f1b29;DATARMNETa13fcf9070.
  376. DATARMNETe65883bfce=DATARMNETf8bbe3b0fb;DATARMNETa13fcf9070.DATARMNETbb588401ec=
  377. DATARMNETbb588401ec;if(DATARMNETbd1d5c8f28(&DATARMNET7d98961cbe,
  378. DATARMNET15437be67e,DATARMNET818a0b6438,sizeof(DATARMNETa13fcf9070),&
  379. DATARMNETa13fcf9070,GFP_ATOMIC)){DATARMNET112d724eff(
  380. "\x61\x70\x73\x3a\x20\x63\x6c\x69\x65\x6e\x74\x20\x73\x65\x6e\x64\x20\x66\x61\x69\x6c\x65\x64\x2e\x20\x64\x69\x73\x61\x62\x6c\x65\x20\x63\x6c\x69\x65\x6e\x74" "\n"
  381. );DATARMNET7d98961cbe.snd_portid=(0xd2d+202-0xdf7);}}static void
  382. DATARMNET30dd480cad(struct net_device*DATARMNET413e8dcf7b,struct sk_buff*
  383. DATARMNET543491eb0f){struct DATARMNET6fd48c33f6*DATARMNETaa568481cf;struct
  384. DATARMNET758277d429*aps_cb;struct DATARMNETc4743b996e*DATARMNET81b03d6be4;if(
  385. DATARMNET2fe4661b82&&(DATARMNET543491eb0f->priority>>(0xeb7+1158-0x132d)!=
  386. DATARMNET2fe4661b82))return;aps_cb=DATARMNETe1c7654a2e(DATARMNET413e8dcf7b);
  387. DATARMNET81b03d6be4=rcu_dereference(aps_cb->DATARMNETac8d594fb6);if(!
  388. DATARMNET81b03d6be4)return;if(DATARMNET2fe4661b82)DATARMNETaa568481cf=
  389. DATARMNET3ed11fdc8d(&DATARMNET81b03d6be4->DATARMNET46c1c4375f,
  390. DATARMNET543491eb0f->priority);else DATARMNETaa568481cf=DATARMNETfb13c018fc(&
  391. DATARMNET81b03d6be4->DATARMNET46c1c4375f,DATARMNET543491eb0f);if(
  392. DATARMNETaa568481cf){spin_lock_bh(&DATARMNET33bd4139f4);DATARMNET543491eb0f->
  393. priority=DATARMNETaa568481cf->DATARMNET556cdfb5eb;DATARMNETaa568481cf->expires=
  394. jiffies+DATARMNETaa568481cf->DATARMNETee01ad514b;DATARMNETaa568481cf->
  395. DATARMNETa27e524d8a+=DATARMNET543491eb0f->len;spin_unlock_bh(&
  396. DATARMNET33bd4139f4);schedule_delayed_work(&DATARMNET3481998252,
  397. DATARMNETfd026b105a);}}static int DATARMNET998f6cbce7(struct notifier_block*
  398. DATARMNET272c159b3c,unsigned long DATARMNET9a4761f31c,void*data){struct
  399. net_device*DATARMNET413e8dcf7b;struct DATARMNET758277d429*aps_cb;struct
  400. DATARMNETc4743b996e*DATARMNET81b03d6be4;DATARMNET413e8dcf7b=
  401. netdev_notifier_info_to_dev(data);if(unlikely(!DATARMNET413e8dcf7b))return
  402. NOTIFY_DONE;if(!DATARMNET4e81d27dfb(DATARMNET413e8dcf7b))return NOTIFY_DONE;
  403. aps_cb=DATARMNETe1c7654a2e(DATARMNET413e8dcf7b);BUILD_BUG_ON(sizeof(*aps_cb)>
  404. sizeof(((struct rmnet_priv*)(0xd2d+202-0xdf7))->aps_cb));switch(
  405. DATARMNET9a4761f31c){case NETDEV_DOWN:aps_cb->DATARMNET91119c34ed=
  406. (0xd2d+202-0xdf7);mutex_lock(&DATARMNETd7b5a80f84);DATARMNET250448eb06(
  407. DATARMNET413e8dcf7b->ifindex);mutex_unlock(&DATARMNETd7b5a80f84);break;case
  408. NETDEV_UNREGISTER:mutex_lock(&DATARMNETd7b5a80f84);DATARMNET250448eb06(
  409. DATARMNET413e8dcf7b->ifindex);DATARMNET81b03d6be4=rcu_dereference(aps_cb->
  410. DATARMNETac8d594fb6);if(DATARMNET81b03d6be4){WARN_ON(!list_empty(&
  411. DATARMNET81b03d6be4->DATARMNET46c1c4375f));rcu_assign_pointer(aps_cb->
  412. DATARMNETac8d594fb6,NULL);kfree_rcu(DATARMNET81b03d6be4,DATARMNET28bfe9e6ad);}
  413. mutex_unlock(&DATARMNETd7b5a80f84);break;default:break;}return NOTIFY_DONE;}int
  414. DATARMNET37a9efbbcb(struct sk_buff*DATARMNETaafc1d9519,struct genl_info*
  415. DATARMNET54338da2ff){struct nlattr*DATARMNET9c5e00ef03;struct
  416. DATARMNET5d4139d9d7 DATARMNETddcafd8b91;struct DATARMNETca79857d4a
  417. DATARMNETa13fcf9070;struct net_device*DATARMNET413e8dcf7b=NULL;struct
  418. DATARMNET758277d429*aps_cb;struct DATARMNETc4743b996e*DATARMNET81b03d6be4;int
  419. DATARMNETb14e52a504=-EINVAL;DATARMNET112d724eff(
  420. "\x61\x70\x73\x3a\x20\x25\x73" "\n",__func__);if(!DATARMNET54338da2ff)return-
  421. EINVAL;DATARMNET9c5e00ef03=DATARMNET54338da2ff->attrs[DATARMNET98b93f2e86];if(!
  422. DATARMNET9c5e00ef03){DATARMNET112d724eff(
  423. "\x61\x70\x73\x3a\x20\x6e\x6f\x20\x61\x74\x74\x72\x73" "\n");return-EINVAL;}if(
  424. nla_memcpy(&DATARMNETddcafd8b91,DATARMNET9c5e00ef03,sizeof(DATARMNETddcafd8b91))
  425. <=(0xd2d+202-0xdf7)){DATARMNET112d724eff(
  426. "\x61\x70\x73\x3a\x20\x6e\x6c\x61\x5f\x6d\x65\x6d\x63\x70\x79\x20\x66\x61\x69\x6c\x65\x64" "\n"
  427. );return-EINVAL;}mutex_lock(&DATARMNETd7b5a80f84);if(!DATARMNET54b95e4416)goto
  428. DATARMNETbf4095f79e;switch(DATARMNETddcafd8b91.cmd){case DATARMNET63ff5c35c2:
  429. DATARMNET7d98961cbe=*DATARMNET54338da2ff;DATARMNET9ac8a34003();
  430. DATARMNET2fe4661b82=(u16)DATARMNETddcafd8b91.DATARMNETbb588401ec;
  431. DATARMNET112d724eff(
  432. "\x61\x70\x73\x3a\x20\x63\x6c\x69\x65\x6e\x74\x20\x69\x6e\x69\x74\x20\x63\x6f\x6f\x6b\x69\x65\x20\x30\x78\x25\x78" "\n"
  433. ,DATARMNET2fe4661b82);DATARMNETb14e52a504=(0xd2d+202-0xdf7);break;case
  434. DATARMNETceae994093:case DATARMNET3412b803e1:case DATARMNET1efd633004:if(
  435. DATARMNETddcafd8b91.ifindex)DATARMNET413e8dcf7b=dev_get_by_index(&init_net,
  436. DATARMNETddcafd8b91.ifindex);if(!DATARMNET413e8dcf7b){DATARMNET112d724eff(
  437. "\x61\x70\x73\x3a\x20\x6e\x6f\x20\x64\x65\x76\x20\x66\x6f\x72\x20\x69\x66\x69\x6e\x64\x65\x78\x20\x25\x75" "\n"
  438. ,DATARMNETddcafd8b91.ifindex);break;}if(DATARMNET4e81d27dfb(DATARMNET413e8dcf7b)
  439. ){aps_cb=DATARMNETe1c7654a2e(DATARMNET413e8dcf7b);DATARMNET81b03d6be4=
  440. rcu_dereference(aps_cb->DATARMNETac8d594fb6);if(!DATARMNET81b03d6be4&&
  441. DATARMNETddcafd8b91.cmd==DATARMNETceae994093){DATARMNET81b03d6be4=kzalloc(sizeof
  442. (*DATARMNET81b03d6be4),GFP_KERNEL);if(DATARMNET81b03d6be4){INIT_LIST_HEAD(&
  443. DATARMNET81b03d6be4->DATARMNET46c1c4375f);rcu_assign_pointer(aps_cb->
  444. DATARMNETac8d594fb6,DATARMNET81b03d6be4);}else{DATARMNET112d724eff(
  445. "\x61\x70\x73\x3a\x20\x6e\x6f\x20\x6d\x65\x6d\x6f\x72\x79" "\n");}}if(
  446. DATARMNET81b03d6be4)DATARMNETb14e52a504=DATARMNET82d65f9ca6(&DATARMNET81b03d6be4
  447. ->DATARMNET46c1c4375f,&DATARMNETddcafd8b91);else DATARMNET112d724eff(
  448. "\x61\x70\x73\x3a\x20\x6e\x6f\x20\x66\x6c\x6f\x77\x20\x6c\x69\x73\x74\x20\x66\x6f\x72\x20\x66\x6c\x6f\x77\x20\x72\x65\x71" "\n"
  449. );}dev_put(DATARMNET413e8dcf7b);break;default:break;}DATARMNETbf4095f79e:
  450. mutex_unlock(&DATARMNETd7b5a80f84);DATARMNETa13fcf9070.cmd=DATARMNETddcafd8b91.
  451. cmd;DATARMNETa13fcf9070.DATARMNETe65883bfce=DATARMNETb14e52a504;
  452. DATARMNETa13fcf9070.DATARMNETbb588401ec=DATARMNETddcafd8b91.DATARMNETbb588401ec;
  453. DATARMNETb14e52a504=DATARMNETbd1d5c8f28(DATARMNET54338da2ff,DATARMNET15437be67e,
  454. DATARMNET818a0b6438,sizeof(DATARMNETa13fcf9070),&DATARMNETa13fcf9070,GFP_KERNEL)
  455. ;return DATARMNETb14e52a504;}static int DATARMNET9e18f3d501(struct list_head*
  456. DATARMNET817a8d238c,struct DATARMNETd51e57e3f4*DATARMNETddcafd8b91){struct
  457. DATARMNET6fd48c33f6*DATARMNETaa568481cf;struct DATARMNETb356c61ad6*
  458. DATARMNET8f197b20f6;DATARMNETaa568481cf=DATARMNET3ed11fdc8d(DATARMNET817a8d238c,
  459. DATARMNETddcafd8b91->DATARMNETbb588401ec);if(!DATARMNETaa568481cf){
  460. DATARMNET112d724eff(
  461. "\x61\x70\x73\x3a\x20\x66\x6c\x6f\x77\x20\x30\x78\x25\x78\x20\x6e\x6f\x74\x20\x66\x6f\x75\x6e\x64" "\n"
  462. ,DATARMNETddcafd8b91->DATARMNETbb588401ec);return-EINVAL;}switch(
  463. DATARMNETddcafd8b91->cmd){case DATARMNETd0bce1573e:DATARMNET8f197b20f6=
  464. rcu_dereference(DATARMNETaa568481cf->DATARMNET8f197b20f6);if(DATARMNET8f197b20f6
  465. ){DATARMNET112d724eff(
  466. "\x61\x70\x73\x3a\x20\x66\x69\x6c\x74\x65\x72\x20\x66\x6f\x72\x20\x66\x6c\x6f\x77\x20\x30\x78\x25\x78\x20\x65\x78\x69\x73\x74\x73" "\n"
  467. ,DATARMNETddcafd8b91->DATARMNETbb588401ec);return-EINVAL;}DATARMNET8f197b20f6=
  468. kzalloc(sizeof(*DATARMNET8f197b20f6),GFP_KERNEL);if(!DATARMNET8f197b20f6){
  469. DATARMNET112d724eff(
  470. "\x61\x70\x73\x3a\x20\x6e\x6f\x20\x6d\x65\x6d\x6f\x72\x79" "\n");return-ENOMEM;}
  471. memcpy(&DATARMNET8f197b20f6->DATARMNET54338da2ff,DATARMNETddcafd8b91,sizeof(*
  472. DATARMNETddcafd8b91));if(DATARMNET8f197b20f6->DATARMNET54338da2ff.tos){if(!
  473. DATARMNET8f197b20f6->DATARMNET54338da2ff.DATARMNETa400ad4f72)DATARMNET8f197b20f6
  474. ->DATARMNET54338da2ff.DATARMNETa400ad4f72=(0xbf7+4364-0x1c04);
  475. DATARMNET8f197b20f6->DATARMNET54338da2ff.tos&=DATARMNET8f197b20f6->
  476. DATARMNET54338da2ff.DATARMNETa400ad4f72;}rcu_assign_pointer(DATARMNETaa568481cf
  477. ->DATARMNET8f197b20f6,DATARMNET8f197b20f6);break;default:return-EINVAL;}return
  478. (0xd2d+202-0xdf7);}int DATARMNETae6b282c61(struct sk_buff*DATARMNETaafc1d9519,
  479. struct genl_info*DATARMNET54338da2ff){struct nlattr*DATARMNET9c5e00ef03;struct
  480. DATARMNETd51e57e3f4 DATARMNETddcafd8b91;struct DATARMNET15bcb4844b
  481. DATARMNETa13fcf9070;struct net_device*DATARMNET413e8dcf7b=NULL;struct
  482. DATARMNET758277d429*aps_cb;struct DATARMNETc4743b996e*DATARMNET81b03d6be4;int
  483. DATARMNETb14e52a504=-EINVAL;DATARMNET112d724eff(
  484. "\x61\x70\x73\x3a\x20\x25\x73" "\n",__func__);if(!DATARMNET54338da2ff)return-
  485. EINVAL;DATARMNET9c5e00ef03=DATARMNET54338da2ff->attrs[DATARMNET7edfedec7f];if(!
  486. DATARMNET9c5e00ef03){DATARMNET112d724eff(
  487. "\x61\x70\x73\x3a\x20\x6e\x6f\x20\x61\x74\x74\x72\x73" "\n");return-EINVAL;}if(
  488. nla_memcpy(&DATARMNETddcafd8b91,DATARMNET9c5e00ef03,sizeof(DATARMNETddcafd8b91))
  489. <=(0xd2d+202-0xdf7)){DATARMNET112d724eff(
  490. "\x61\x70\x73\x3a\x20\x6e\x6c\x61\x5f\x6d\x65\x6d\x63\x70\x79\x20\x66\x61\x69\x6c\x65\x64" "\n"
  491. );return-EINVAL;}mutex_lock(&DATARMNETd7b5a80f84);if(!DATARMNET54b95e4416)goto
  492. DATARMNETbf4095f79e;if(DATARMNETddcafd8b91.ifindex)DATARMNET413e8dcf7b=
  493. dev_get_by_index(&init_net,DATARMNETddcafd8b91.ifindex);if(!DATARMNET413e8dcf7b)
  494. {DATARMNET112d724eff(
  495. "\x61\x70\x73\x3a\x20\x6e\x6f\x20\x64\x65\x76\x20\x66\x6f\x72\x20\x69\x66\x69\x6e\x64\x65\x78\x20\x25\x75" "\n"
  496. ,DATARMNETddcafd8b91.ifindex);goto DATARMNETbf4095f79e;}if(!DATARMNET4e81d27dfb(
  497. DATARMNET413e8dcf7b)){dev_put(DATARMNET413e8dcf7b);goto DATARMNETbf4095f79e;}
  498. switch(DATARMNETddcafd8b91.cmd){case DATARMNETd0bce1573e:aps_cb=
  499. DATARMNETe1c7654a2e(DATARMNET413e8dcf7b);DATARMNET81b03d6be4=rcu_dereference(
  500. aps_cb->DATARMNETac8d594fb6);if(DATARMNET81b03d6be4)DATARMNETb14e52a504=
  501. DATARMNET9e18f3d501(&DATARMNET81b03d6be4->DATARMNET46c1c4375f,&
  502. DATARMNETddcafd8b91);else DATARMNET112d724eff(
  503. "\x61\x70\x73\x3a\x20\x6e\x6f\x20\x66\x6c\x6f\x77\x20\x6c\x69\x73\x74" "\n");
  504. break;default:break;}dev_put(DATARMNET413e8dcf7b);DATARMNETbf4095f79e:
  505. mutex_unlock(&DATARMNETd7b5a80f84);DATARMNETa13fcf9070.cmd=DATARMNETddcafd8b91.
  506. cmd;DATARMNETa13fcf9070.DATARMNETe65883bfce=DATARMNETb14e52a504;
  507. DATARMNETa13fcf9070.DATARMNETbb588401ec=DATARMNETddcafd8b91.DATARMNETbb588401ec;
  508. DATARMNETb14e52a504=DATARMNETbd1d5c8f28(DATARMNET54338da2ff,DATARMNET97eefd45e3,
  509. DATARMNETd2b1517d6b,sizeof(DATARMNETa13fcf9070),&DATARMNETa13fcf9070,GFP_KERNEL)
  510. ;return DATARMNETb14e52a504;}static ktime_t DATARMNETe7a1ab1dab;int
  511. DATARMNET1998d09852(struct sk_buff*DATARMNETaafc1d9519,struct genl_info*
  512. DATARMNET54338da2ff){struct nlattr*DATARMNET9c5e00ef03;struct
  513. DATARMNET797a5b1493 DATARMNETddcafd8b91;struct DATARMNET9a727f81bc
  514. DATARMNETa13fcf9070;struct net_device*DATARMNET413e8dcf7b;struct
  515. DATARMNET758277d429*aps_cb;int DATARMNETb14e52a504;DATARMNET112d724eff(
  516. "\x61\x70\x73\x3a\x20\x25\x73" "\n",__func__);if(!DATARMNET54338da2ff)return-
  517. EINVAL;DATARMNET9c5e00ef03=DATARMNET54338da2ff->attrs[DATARMNET572e4a28eb];if(!
  518. DATARMNET9c5e00ef03){DATARMNET112d724eff(
  519. "\x61\x70\x73\x3a\x20\x6e\x6f\x20\x61\x74\x74\x72\x73" "\n");return-EINVAL;}if(
  520. nla_memcpy(&DATARMNETddcafd8b91,DATARMNET9c5e00ef03,sizeof(DATARMNETddcafd8b91))
  521. <=(0xd2d+202-0xdf7)){DATARMNET112d724eff(
  522. "\x61\x70\x73\x3a\x20\x6e\x6c\x61\x5f\x6d\x65\x6d\x63\x70\x79\x20\x66\x61\x69\x6c\x65\x64" "\n"
  523. );return-EINVAL;}DATARMNET112d724eff(
  524. "\x61\x70\x73\x3a\x20\x69\x66\x69\x6e\x64\x65\x78\x20\x25\x75\x20\x65\x78\x70\x69\x72\x65\x5f\x6d\x73\x20\x25\x75" "\n"
  525. ,DATARMNETddcafd8b91.ifindex,DATARMNETddcafd8b91.DATARMNETc277c62678);if(
  526. DATARMNETddcafd8b91.DATARMNETc277c62678){ktime_t DATARMNET35f4c14174=ms_to_ktime
  527. (DATARMNETddcafd8b91.DATARMNETc277c62678);if(DATARMNETe7a1ab1dab!=
  528. DATARMNET35f4c14174)DATARMNETe7a1ab1dab=DATARMNET35f4c14174;}DATARMNET413e8dcf7b
  529. =dev_get_by_index(&init_net,DATARMNETddcafd8b91.ifindex);if(DATARMNET413e8dcf7b)
  530. {if(DATARMNET4e81d27dfb(DATARMNET413e8dcf7b)){aps_cb=DATARMNETe1c7654a2e(
  531. DATARMNET413e8dcf7b);aps_cb->DATARMNET91119c34ed=DATARMNETddcafd8b91.
  532. DATARMNETc277c62678?(0xd26+209-0xdf6):(0xd2d+202-0xdf7);}dev_put(
  533. DATARMNET413e8dcf7b);}memset(&DATARMNETa13fcf9070,(0xd2d+202-0xdf7),sizeof(
  534. DATARMNETa13fcf9070));DATARMNETa13fcf9070.ifindex=DATARMNETddcafd8b91.ifindex;
  535. DATARMNETb14e52a504=DATARMNETbd1d5c8f28(DATARMNET54338da2ff,DATARMNET4f09ad7688,
  536. DATARMNETe54d857ffe,sizeof(DATARMNETa13fcf9070),&DATARMNETa13fcf9070,GFP_KERNEL)
  537. ;return DATARMNETb14e52a504;}static void DATARMNETe0c7b9d5a4(struct net_device*
  538. DATARMNET413e8dcf7b,struct sk_buff*DATARMNET543491eb0f){struct
  539. DATARMNET758277d429*aps_cb=DATARMNETe1c7654a2e(DATARMNET413e8dcf7b);if(aps_cb->
  540. DATARMNET91119c34ed)skb_hwtstamps(DATARMNET543491eb0f)->hwtstamp=
  541. ktime_get_boottime();else skb_hwtstamps(DATARMNET543491eb0f)->hwtstamp=
  542. (0xd2d+202-0xdf7);if(READ_ONCE(DATARMNETfef55eaf9a))DATARMNET30dd480cad(
  543. DATARMNET413e8dcf7b,DATARMNET543491eb0f);}static int DATARMNET6ab4bbdaf4(struct
  544. net_device*DATARMNET413e8dcf7b,struct sk_buff*DATARMNET543491eb0f){struct
  545. DATARMNET758277d429*aps_cb=DATARMNETe1c7654a2e(DATARMNET413e8dcf7b);ktime_t
  546. DATARMNET912d2a7edd;if(aps_cb->DATARMNET91119c34ed&&skb_hwtstamps(
  547. DATARMNET543491eb0f)->hwtstamp&&DATARMNETe7a1ab1dab){DATARMNET912d2a7edd=
  548. ktime_get_boottime();if(ktime_sub(DATARMNET912d2a7edd,skb_hwtstamps(
  549. DATARMNET543491eb0f)->hwtstamp)>DATARMNETe7a1ab1dab)return-ETIMEDOUT;}return
  550. (0xd2d+202-0xdf7);}static struct proc_dir_entry*DATARMNET147f9b9f22;static
  551. struct proc_dir_entry*DATARMNETf9422af3b0;static DEFINE_SPINLOCK(
  552. DATARMNET86e81617f0);struct DATARMNET837f670f1d{ktime_t DATARMNET763f2e5fac;
  553. struct DATARMNETf21ed5deb4 DATARMNET5fe4c722a8;};
  554. #define DATARMNET137373fbd9 (0xd27+224-0xdfd)
  555. static int DATARMNET04583f0705;static struct DATARMNET837f670f1d
  556. DATARMNETeb47903253[DATARMNET137373fbd9];static unsigned int inactive_time;
  557. static ktime_t DATARMNET6736d5e29d;static ktime_t DATARMNETd4b2cd928c;static int
  558. DATARMNETd7fae4b1c9(struct seq_file*DATARMNET80f4138358,void*
  559. DATARMNETc3d0f72ff1){struct DATARMNET837f670f1d*DATARMNET590c4d44f6;s64
  560. DATARMNET3c8f5f41f1,DATARMNET7d003c10d9;u8 DATARMNET5c33dbe77d,
  561. DATARMNETa845529338,DATARMNET35784a722f;int DATARMNETefc9df3df2;spin_lock_bh(&
  562. DATARMNET86e81617f0);if(!DATARMNETeb47903253[DATARMNET04583f0705].
  563. DATARMNET763f2e5fac)DATARMNETefc9df3df2=(0xd2d+202-0xdf7);else
  564. DATARMNETefc9df3df2=DATARMNET04583f0705;do{DATARMNET590c4d44f6=&
  565. DATARMNETeb47903253[DATARMNETefc9df3df2];if(!DATARMNET590c4d44f6->
  566. DATARMNET763f2e5fac)break;DATARMNET3c8f5f41f1=ktime_divns(DATARMNET590c4d44f6->
  567. DATARMNET763f2e5fac,NSEC_PER_SEC);DATARMNET7d003c10d9=DATARMNET3c8f5f41f1/86400;
  568. DATARMNET5c33dbe77d=DATARMNET3c8f5f41f1%86400/(0x17a8+2156-0x1204);
  569. DATARMNETa845529338=DATARMNET3c8f5f41f1%(0x17a8+2156-0x1204)/(0xf07+1090-0x130d)
  570. ;DATARMNET35784a722f=DATARMNET3c8f5f41f1%(0xf07+1090-0x130d);if(
  571. DATARMNET590c4d44f6->DATARMNET5fe4c722a8.DATARMNET06d2413ad2==IPPROTO_TCP||
  572. DATARMNET590c4d44f6->DATARMNET5fe4c722a8.DATARMNET06d2413ad2==IPPROTO_UDP){if(
  573. DATARMNET590c4d44f6->DATARMNET5fe4c722a8.DATARMNET9d758b8e5b==(0xd11+230-0xdf3))
  574. seq_printf(DATARMNET80f4138358,
  575. "\x5b\x25\x36\x6c\x6c\x64\x20\x25\x30\x32\x64\x3a\x25\x30\x32\x64\x3a\x25\x30\x32\x64\x5d\x20\x25\x32\x75\x20\x25\x70\x49\x34\x2f\x25\x75\x20"
  576. "\x25\x70\x49\x34\x2f\x25\x75" "\n",DATARMNET7d003c10d9,DATARMNET5c33dbe77d,
  577. DATARMNETa845529338,DATARMNET35784a722f,DATARMNET590c4d44f6->DATARMNET5fe4c722a8
  578. .DATARMNET06d2413ad2,DATARMNET590c4d44f6->DATARMNET5fe4c722a8.saddr,
  579. DATARMNET590c4d44f6->DATARMNET5fe4c722a8.sport,DATARMNET590c4d44f6->
  580. DATARMNET5fe4c722a8.daddr,DATARMNET590c4d44f6->DATARMNET5fe4c722a8.dport);else
  581. seq_printf(DATARMNET80f4138358,
  582. "\x5b\x25\x36\x6c\x6c\x64\x20\x25\x30\x32\x64\x3a\x25\x30\x32\x64\x3a\x25\x30\x32\x64\x5d\x20\x25\x32\x75\x20\x25\x70\x49\x36\x2f\x25\x75\x20"
  583. "\x25\x70\x49\x36\x2f\x25\x75" "\n",DATARMNET7d003c10d9,DATARMNET5c33dbe77d,
  584. DATARMNETa845529338,DATARMNET35784a722f,DATARMNET590c4d44f6->DATARMNET5fe4c722a8
  585. .DATARMNET06d2413ad2,DATARMNET590c4d44f6->DATARMNET5fe4c722a8.saddr,
  586. DATARMNET590c4d44f6->DATARMNET5fe4c722a8.sport,DATARMNET590c4d44f6->
  587. DATARMNET5fe4c722a8.daddr,DATARMNET590c4d44f6->DATARMNET5fe4c722a8.dport);}else{
  588. if(DATARMNET590c4d44f6->DATARMNET5fe4c722a8.DATARMNET9d758b8e5b==
  589. (0xd11+230-0xdf3))seq_printf(DATARMNET80f4138358,
  590. "\x5b\x25\x36\x6c\x6c\x64\x20\x25\x30\x32\x64\x3a\x25\x30\x32\x64\x3a\x25\x30\x32\x64\x5d\x20\x25\x32\x75\x20\x25\x70\x49\x34\x20\x25\x70\x49\x34" "\n"
  591. ,DATARMNET7d003c10d9,DATARMNET5c33dbe77d,DATARMNETa845529338,DATARMNET35784a722f
  592. ,DATARMNET590c4d44f6->DATARMNET5fe4c722a8.DATARMNET06d2413ad2,
  593. DATARMNET590c4d44f6->DATARMNET5fe4c722a8.saddr,DATARMNET590c4d44f6->
  594. DATARMNET5fe4c722a8.daddr);else seq_printf(DATARMNET80f4138358,
  595. "\x5b\x25\x36\x6c\x6c\x64\x20\x25\x30\x32\x64\x3a\x25\x30\x32\x64\x3a\x25\x30\x32\x64\x5d\x20\x25\x32\x75\x20\x25\x70\x49\x36\x20\x25\x70\x49\x36" "\n"
  596. ,DATARMNET7d003c10d9,DATARMNET5c33dbe77d,DATARMNETa845529338,DATARMNET35784a722f
  597. ,DATARMNET590c4d44f6->DATARMNET5fe4c722a8.DATARMNET06d2413ad2,
  598. DATARMNET590c4d44f6->DATARMNET5fe4c722a8.saddr,DATARMNET590c4d44f6->
  599. DATARMNET5fe4c722a8.daddr);}if(++DATARMNETefc9df3df2>=DATARMNET137373fbd9)
  600. DATARMNETefc9df3df2=(0xd2d+202-0xdf7);}while(DATARMNETefc9df3df2!=
  601. DATARMNET04583f0705);spin_unlock_bh(&DATARMNET86e81617f0);return
  602. (0xd2d+202-0xdf7);}static void DATARMNET71e03e7287(void){spin_lock_bh(&
  603. DATARMNET86e81617f0);DATARMNETd4b2cd928c=ktime_get_coarse_boottime();
  604. spin_unlock_bh(&DATARMNET86e81617f0);}static void DATARMNETfb7a2ce025(struct
  605. rmnet_frag_descriptor*DATARMNET9d1b321642,struct sk_buff*DATARMNET543491eb0f){
  606. struct DATARMNETf21ed5deb4 DATARMNET203a7a0136={(0xd2d+202-0xdf7),};struct
  607. DATARMNET837f670f1d*DATARMNET590c4d44f6;ktime_t DATARMNET5711967d6f;int
  608. DATARMNET61c2303133;if(!DATARMNET9d1b321642&&!DATARMNET543491eb0f)return;
  609. spin_lock_bh(&DATARMNET86e81617f0);if(!DATARMNET6736d5e29d)goto
  610. DATARMNETbf4095f79e;DATARMNET5711967d6f=ktime_get_coarse_boottime();if(ktime_sub
  611. (DATARMNET5711967d6f,DATARMNETd4b2cd928c)>DATARMNET6736d5e29d){if(
  612. DATARMNET9d1b321642)DATARMNET61c2303133=DATARMNET9e7ac83deb(DATARMNET9d1b321642,
  613. &DATARMNET203a7a0136);else if(DATARMNET543491eb0f)DATARMNET61c2303133=
  614. DATARMNET481989429b(DATARMNET543491eb0f,&DATARMNET203a7a0136);else
  615. DATARMNET61c2303133=-EINVAL;if(DATARMNET61c2303133||(DATARMNET203a7a0136.
  616. DATARMNETe419bc836d&&!DATARMNET203a7a0136.DATARMNETd43be7664c))goto
  617. DATARMNETbf4095f79e;DATARMNET590c4d44f6=&DATARMNETeb47903253[DATARMNET04583f0705
  618. ];DATARMNET590c4d44f6->DATARMNET763f2e5fac=DATARMNET5711967d6f;
  619. DATARMNET590c4d44f6->DATARMNET5fe4c722a8=DATARMNET203a7a0136;if(++
  620. DATARMNET04583f0705>=DATARMNET137373fbd9)DATARMNET04583f0705=(0xd2d+202-0xdf7);}
  621. DATARMNETbf4095f79e:spin_unlock_bh(&DATARMNET86e81617f0);}static const struct
  622. rmnet_module_hook_register_info DATARMNETbdf157f06a[]={{.hooknum=
  623. RMNET_MODULE_HOOK_APS_DATA_INACTIVE,.func=DATARMNET71e03e7287,},{.hooknum=
  624. RMNET_MODULE_HOOK_APS_DATA_ACTIVE,.func=DATARMNETfb7a2ce025,},};static int
  625. DATARMNET8871996254(const char*DATARMNETcc6099cb14,const struct kernel_param*
  626. DATARMNETb3ce0fdc63){unsigned int DATARMNET3f85732c70;if(kstrtouint(
  627. DATARMNETcc6099cb14,(0xd27+224-0xdfd),&DATARMNET3f85732c70))return-EINVAL;
  628. spin_lock_bh(&DATARMNET86e81617f0);if(DATARMNET3f85732c70){DATARMNET6736d5e29d=
  629. ms_to_ktime(DATARMNET3f85732c70*(0xdc7+2653-0x143c));DATARMNETd4b2cd928c=
  630. ktime_get_coarse_boottime();rmnet_module_hook_register(DATARMNETbdf157f06a,
  631. ARRAY_SIZE(DATARMNETbdf157f06a));}else{DATARMNET6736d5e29d=(0xd2d+202-0xdf7);
  632. rmnet_module_hook_unregister_no_sync(DATARMNETbdf157f06a,ARRAY_SIZE(
  633. DATARMNETbdf157f06a));}spin_unlock_bh(&DATARMNET86e81617f0);return
  634. param_set_uint(DATARMNETcc6099cb14,DATARMNETb3ce0fdc63);}static const struct
  635. kernel_param_ops DATARMNETd34b496ea4={.set=DATARMNET8871996254,.get=
  636. param_get_uint,};module_param_cb(inactive_time,&DATARMNETd34b496ea4,&
  637. inactive_time,(0xdb7+6665-0x261c));MODULE_PARM_DESC(inactive_time,
  638. "\x49\x6e\x61\x63\x74\x69\x76\x65\x20\x74\x69\x6d\x65\x20\x69\x6e\x20\x73\x65\x63\x6f\x6e\x64\x73"
  639. );static void DATARMNET519162865c(void){DATARMNET147f9b9f22=proc_mkdir(
  640. "\x61\x70\x73",NULL);if(!DATARMNET147f9b9f22){pr_err(
  641. "\x61\x70\x73\x3a\x20\x66\x61\x69\x6c\x65\x64\x20\x74\x6f\x20\x63\x72\x65\x61\x74\x65\x20\x70\x72\x6f\x63\x20\x64\x69\x72" "\n"
  642. );return;}DATARMNETf9422af3b0=proc_create_single_data(
  643. "\x64\x6c\x5f\x61\x63\x74\x69\x76\x69\x74\x79",(0xcb7+5769-0x221c),
  644. DATARMNET147f9b9f22,DATARMNETd7fae4b1c9,NULL);if(!DATARMNETf9422af3b0)pr_err(
  645. "\x61\x70\x73\x3a\x20\x66\x61\x69\x6c\x65\x64\x20\x74\x6f\x20\x63\x72\x65\x61\x74\x65\x20\x64\x6c\x5f\x61\x63\x74\x69\x76\x69\x74\x79\x20\x65\x6e\x74\x72\x79" "\n"
  646. );}static void DATARMNETb4a75cfdea(void){proc_remove(DATARMNETf9422af3b0);
  647. proc_remove(DATARMNET147f9b9f22);}static const struct
  648. rmnet_module_hook_register_info DATARMNET509284caa6[]={{.hooknum=
  649. RMNET_MODULE_HOOK_APS_PRE_QUEUE,.func=DATARMNETe0c7b9d5a4,},{.hooknum=
  650. RMNET_MODULE_HOOK_APS_POST_QUEUE,.func=DATARMNET6ab4bbdaf4,},};static int __init
  651. DATARMNET0718a3fa4c(void){int DATARMNETb14e52a504;pr_info(
  652. "\x61\x70\x73\x3a\x20\x69\x6e\x69\x74\x20\x28\x25\x73\x29" "\n",
  653. DATARMNETe5ef0e617c);DATARMNETb14e52a504=DATARMNETcfa8d492f8();if(
  654. DATARMNETb14e52a504){pr_err(
  655. "\x61\x70\x73\x3a\x20\x66\x61\x69\x6c\x65\x64\x20\x74\x6f\x20\x72\x65\x67\x69\x73\x74\x65\x72\x20\x67\x65\x6e\x6c\x20\x66\x61\x6d\x69\x6c\x79" "\n"
  656. );return DATARMNETb14e52a504;}register_netdevice_notifier(&DATARMNETc580548769);
  657. rcu_assign_pointer(rmnet_aps_pre_queue,DATARMNETe0c7b9d5a4);rcu_assign_pointer(
  658. rmnet_aps_post_queue,DATARMNET6ab4bbdaf4);rmnet_module_hook_register(
  659. DATARMNET509284caa6,ARRAY_SIZE(DATARMNET509284caa6));mutex_lock(&
  660. DATARMNETd7b5a80f84);DATARMNET54b95e4416=true;mutex_unlock(&DATARMNETd7b5a80f84)
  661. ;DATARMNET519162865c();return(0xd2d+202-0xdf7);}static void __exit
  662. DATARMNETff67054ba9(void){DATARMNETb4a75cfdea();
  663. rmnet_module_hook_unregister_no_sync(DATARMNETbdf157f06a,ARRAY_SIZE(
  664. DATARMNETbdf157f06a));rcu_assign_pointer(rmnet_aps_pre_queue,NULL);
  665. rcu_assign_pointer(rmnet_aps_post_queue,NULL);rmnet_module_hook_unregister(
  666. DATARMNET509284caa6,ARRAY_SIZE(DATARMNET509284caa6));mutex_lock(&
  667. DATARMNETd7b5a80f84);DATARMNET54b95e4416=false;DATARMNET9ac8a34003();
  668. mutex_unlock(&DATARMNETd7b5a80f84);DATARMNET446f780f19((0xd2d+202-0xdf7),
  669. DATARMNET94016043b8);cancel_delayed_work_sync(&DATARMNET3481998252);
  670. del_timer_sync(&DATARMNETd21629e047);cancel_work_sync(&DATARMNET8e3aef0760);
  671. unregister_netdevice_notifier(&DATARMNETc580548769);DATARMNETca7606cfd1();
  672. DATARMNET112d724eff("\x61\x70\x73\x3a\x20\x65\x78\x69\x74" "\n");}MODULE_LICENSE
  673. ("\x47\x50\x4c\x20\x76\x32");module_init(DATARMNET0718a3fa4c);module_exit(
  674. DATARMNETff67054ba9);