rmnet_offload_main.c 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267
  1. /* Copyright (c) 2018-2021, The Linux Foundation. All rights reserved.
  2. * Copyright (c) 2022-2023, Qualcomm Innovation Center, Inc. All rights reserved.
  3. *
  4. * This program is free software; you can redistribute it and/or modify
  5. * it under the terms of the GNU General Public License version 2 and
  6. * only version 2 as published by the Free Software Foundation.
  7. *
  8. * This program is distributed in the hope that it will be useful,
  9. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. * GNU General Public License for more details.
  12. */
  13. #include <linux/compiler.h>
  14. #include <linux/rcupdate.h>
  15. #include <linux/jhash.h>
  16. #include <linux/spinlock.h>
  17. #include "rmnet_descriptor.h"
  18. #include "rmnet_handlers.h"
  19. #include "rmnet_map.h"
  20. #include "rmnet_module.h"
  21. #include "rmnet_offload_main.h"
  22. #include "rmnet_offload_state.h"
  23. #include "rmnet_offload_engine.h"
  24. #include "rmnet_offload_stats.h"
  25. static char*verinfo[]={"\x63\x38\x61\x63\x61\x66\x38\x35",
  26. "\x65\x32\x31\x38\x66\x34\x35\x31","\x32\x61\x34\x34\x66\x36\x62\x65",
  27. "\x37\x34\x31\x35\x39\x32\x31\x63","\x34\x31\x32\x39\x36\x62\x30\x39"};
  28. module_param_array(verinfo,charp,NULL,(0xcb7+5769-0x221c));MODULE_PARM_DESC(
  29. verinfo,
  30. "\x56\x65\x72\x73\x69\x6f\x6e\x20\x6f\x66\x20\x74\x68\x65\x20\x64\x72\x69\x76\x65\x72"
  31. );static DEFINE_SPINLOCK(DATARMNET0b5e447f18);static u32 DATARMNETcb7325e02d(
  32. struct DATARMNETd812bcdbb5*DATARMNET458b70e7e5){struct DATARMNET4287f07234*
  33. DATARMNET8814564ab9=&DATARMNET458b70e7e5->DATARMNET144d119066;__be32
  34. DATARMNETdfd47b00ff[(0xd20+231-0xdfc)];u32 DATARMNET5ebf661879;__be16
  35. DATARMNET08e913477e=(0xd2d+202-0xdf7),DATARMNETda7f7fa492=(0xd2d+202-0xdf7);if(
  36. DATARMNET8814564ab9->DATARMNET7fa8b2acbf==DATARMNETa656f324b2||
  37. DATARMNET8814564ab9->DATARMNET7fa8b2acbf==DATARMNETfd5c3d30e5){
  38. DATARMNET08e913477e=DATARMNET8814564ab9->DATARMNETa60d2ae3f6;DATARMNETda7f7fa492
  39. =DATARMNET8814564ab9->DATARMNET5e7452ec23;}if(DATARMNET8814564ab9->
  40. DATARMNET388842c721==(0xd11+230-0xdf3)){DATARMNETdfd47b00ff[(0xd2d+202-0xdf7)]=
  41. DATARMNET8814564ab9->DATARMNET0a28fa80f4;DATARMNETdfd47b00ff[(0xd26+209-0xdf6)]=
  42. DATARMNET8814564ab9->DATARMNET1a2be7b6c2;DATARMNETdfd47b00ff[(0xd1f+216-0xdf5)]=
  43. DATARMNET8814564ab9->DATARMNET7fa8b2acbf;DATARMNETdfd47b00ff[(0xd18+223-0xdf4)]=
  44. DATARMNETda7f7fa492;DATARMNETdfd47b00ff[(0xd11+230-0xdf3)]=DATARMNET08e913477e;
  45. DATARMNET5ebf661879=(0xd0a+237-0xdf2);}else{memcpy(&DATARMNETdfd47b00ff[
  46. (0xd2d+202-0xdf7)],&DATARMNET8814564ab9->DATARMNET45ec858bc5[(0xd2d+202-0xdf7)],
  47. sizeof(DATARMNET8814564ab9->DATARMNET45ec858bc5));memcpy(&DATARMNETdfd47b00ff[
  48. (0xd0a+237-0xdf2)],&DATARMNET8814564ab9->DATARMNET949c2754de[(0xd2d+202-0xdf7)],
  49. sizeof(DATARMNET8814564ab9->DATARMNET45ec858bc5));DATARMNETdfd47b00ff[
  50. (0xd35+210-0xdff)]=DATARMNET8814564ab9->DATARMNET7fa8b2acbf;DATARMNETdfd47b00ff[
  51. 9]=DATARMNETda7f7fa492;DATARMNETdfd47b00ff[(0xd27+224-0xdfd)]=
  52. DATARMNET08e913477e;DATARMNET5ebf661879=(0xd20+231-0xdfc);}return jhash2(
  53. DATARMNETdfd47b00ff,DATARMNET5ebf661879,(0xd2d+202-0xdf7));}static void
  54. DATARMNETe26a68d20e(u32 DATARMNET5affe290b8){u32 DATARMNET2991ac9aa9;if(
  55. DATARMNET5affe290b8>50000)DATARMNET2991ac9aa9=DATARMNETa121404606;else if(
  56. DATARMNET5affe290b8>30000)DATARMNET2991ac9aa9=DATARMNET787b04223a;else if(
  57. DATARMNET5affe290b8>23000)DATARMNET2991ac9aa9=DATARMNET8e1480cff2;else if(
  58. DATARMNET5affe290b8>14500)DATARMNET2991ac9aa9=DATARMNETf335e26298;else if(
  59. DATARMNET5affe290b8>7000)DATARMNET2991ac9aa9=DATARMNET3067ea3199;else if(
  60. DATARMNET5affe290b8>(0x5b4+1875-0x78f))DATARMNET2991ac9aa9=DATARMNETa76d93355c;
  61. else DATARMNET2991ac9aa9=DATARMNET92f3434694;DATARMNETa00cda79d0(
  62. DATARMNET2991ac9aa9);}static bool DATARMNET1a7ed9a6a2(struct
  63. rmnet_frag_descriptor*DATARMNET9d1b321642,struct DATARMNETd812bcdbb5*
  64. DATARMNET458b70e7e5){struct DATARMNET4287f07234*DATARMNET8814564ab9=&
  65. DATARMNET458b70e7e5->DATARMNET144d119066;u8*DATARMNETdf2dbc641f;u16
  66. DATARMNET5affe290b8;u16 DATARMNETdaa9248df1;DATARMNET5affe290b8=
  67. DATARMNET9d1b321642->len;DATARMNET458b70e7e5->DATARMNET3eb91ee54d=true;if(
  68. unlikely(!(DATARMNET9d1b321642->dev->features&NETIF_F_RXCSUM))){goto
  69. DATARMNETaabe3a05f8;}if(DATARMNET9d1b321642->hdrs_valid){struct
  70. DATARMNET0b82084e89*DATARMNET75be5f3406,DATARMNETc82d2f4e16;struct
  71. DATARMNETd2991e8952*DATARMNET2e7cc88971,DATARMNETd1ff6cd568;DATARMNET8814564ab9
  72. ->DATARMNET388842c721=DATARMNET9d1b321642->ip_proto;DATARMNET8814564ab9->
  73. DATARMNET4ca5ac9de1=DATARMNET9d1b321642->ip_len;DATARMNET8814564ab9->
  74. DATARMNET7fa8b2acbf=DATARMNET9d1b321642->trans_proto;DATARMNET8814564ab9->
  75. DATARMNET0aeee57ceb=DATARMNET9d1b321642->trans_len;DATARMNET5affe290b8=
  76. DATARMNET9d1b321642->len;if(DATARMNET8814564ab9->DATARMNET388842c721==
  77. (0xd11+230-0xdf3)){struct DATARMNET308c06fca6*DATARMNET86f1f2cdc9,
  78. DATARMNETbf6548198e;DATARMNET86f1f2cdc9=rmnet_frag_header_ptr(
  79. DATARMNET9d1b321642,(0xd2d+202-0xdf7),sizeof(*DATARMNET86f1f2cdc9),&
  80. DATARMNETbf6548198e);if(!DATARMNET86f1f2cdc9)goto DATARMNETaabe3a05f8;
  81. DATARMNET8814564ab9->DATARMNET1a2be7b6c2=DATARMNET86f1f2cdc9->
  82. DATARMNET9bbd2ca483;DATARMNET8814564ab9->DATARMNET0a28fa80f4=DATARMNET86f1f2cdc9
  83. ->DATARMNET11ef55b2bb;DATARMNET8814564ab9->DATARMNET19b03754c4=
  84. DATARMNET86f1f2cdc9->DATARMNET1eb6c27583;DATARMNET8814564ab9->
  85. DATARMNET57bf608183=DATARMNET86f1f2cdc9->DATARMNET03e081f69f;DATARMNET8814564ab9
  86. ->DATARMNETcf915688f5=DATARMNET86f1f2cdc9->DATARMNET2c091223da;}else{struct
  87. DATARMNET64bb8f616e*DATARMNETbf55123e5b,DATARMNETcf1d9e2c1e;DATARMNETbf55123e5b=
  88. rmnet_frag_header_ptr(DATARMNET9d1b321642,(0xd2d+202-0xdf7),sizeof(*
  89. DATARMNETbf55123e5b),&DATARMNETcf1d9e2c1e);if(!DATARMNETbf55123e5b)goto
  90. DATARMNETaabe3a05f8;memcpy(&DATARMNET8814564ab9->DATARMNET949c2754de[
  91. (0xd2d+202-0xdf7)],&DATARMNETbf55123e5b->DATARMNET31202449fc[(0xd2d+202-0xdf7)],
  92. sizeof(DATARMNETbf55123e5b->DATARMNET31202449fc));memcpy(&DATARMNET8814564ab9->
  93. DATARMNET45ec858bc5[(0xd2d+202-0xdf7)],&DATARMNETbf55123e5b->DATARMNETc657c0a139
  94. [(0xd2d+202-0xdf7)],sizeof(DATARMNETbf55123e5b->DATARMNETc657c0a139));
  95. DATARMNET8814564ab9->DATARMNETabd58f7f89=DATARMNETbf55123e5b->
  96. DATARMNET0687f7ecdc;if(DATARMNET8814564ab9->DATARMNET4ca5ac9de1>sizeof(*
  97. DATARMNETbf55123e5b)){int DATARMNET0afb05821a;__be16 DATARMNET833503918f;bool
  98. DATARMNETcd214ed34c;u8 DATARMNET615595a09c=DATARMNETbf55123e5b->
  99. DATARMNET7244bfdc4f;DATARMNET0afb05821a=rmnet_frag_ipv6_skip_exthdr(
  100. DATARMNET9d1b321642,sizeof(*DATARMNETbf55123e5b),&DATARMNET615595a09c,&
  101. DATARMNET833503918f,&DATARMNETcd214ed34c);if(DATARMNET0afb05821a<
  102. (0xd2d+202-0xdf7)||DATARMNET833503918f||DATARMNETcd214ed34c){if(
  103. DATARMNET615595a09c==DATARMNET5b166167a8)DATARMNET8814564ab9->
  104. DATARMNET4ca5ac9de1+=(0xd35+210-0xdff);DATARMNETa00cda79d0(DATARMNET807e4dad18);
  105. goto DATARMNETaabe3a05f8;}}}DATARMNET75be5f3406=rmnet_frag_header_ptr(
  106. DATARMNET9d1b321642,DATARMNET8814564ab9->DATARMNET4ca5ac9de1,sizeof(*
  107. DATARMNET75be5f3406),&DATARMNETc82d2f4e16);if(!DATARMNET75be5f3406)goto
  108. DATARMNETaabe3a05f8;DATARMNET8814564ab9->DATARMNETa60d2ae3f6=DATARMNET75be5f3406
  109. ->DATARMNET1b1c406ae9;DATARMNET8814564ab9->DATARMNET5e7452ec23=
  110. DATARMNET75be5f3406->DATARMNETdf0e8545ee;if(DATARMNET8814564ab9->
  111. DATARMNET7fa8b2acbf==DATARMNETfd5c3d30e5){__be32 DATARMNET0849981c7c;
  112. DATARMNET2e7cc88971=rmnet_frag_header_ptr(DATARMNET9d1b321642,
  113. DATARMNET8814564ab9->DATARMNET4ca5ac9de1,sizeof(*DATARMNET2e7cc88971),&
  114. DATARMNETd1ff6cd568);if(!DATARMNET2e7cc88971)goto DATARMNETaabe3a05f8;if(
  115. DATARMNET9d1b321642->tcp_seq_set)DATARMNET0849981c7c=DATARMNET9d1b321642->
  116. tcp_seq;else DATARMNET0849981c7c=DATARMNET2e7cc88971->DATARMNETb3e70104e0;
  117. DATARMNET8814564ab9->DATARMNETbc28a5970f=ntohl(DATARMNET0849981c7c);}
  118. DATARMNET458b70e7e5->DATARMNET645e8912b8=DATARMNETcb7325e02d(DATARMNET458b70e7e5
  119. );DATARMNET458b70e7e5->DATARMNET1ef22e4c76=DATARMNET9d1b321642->len-
  120. DATARMNET9d1b321642->ip_len-DATARMNET9d1b321642->trans_len;DATARMNET458b70e7e5->
  121. DATARMNET719f68fb88=DATARMNET9d1b321642;DATARMNET458b70e7e5->DATARMNET3eb91ee54d
  122. =false;return false;}DATARMNETdf2dbc641f=rmnet_frag_data_ptr(DATARMNET9d1b321642
  123. );if(unlikely(!DATARMNETdf2dbc641f))return true;DATARMNET8814564ab9->
  124. DATARMNET388842c721=(DATARMNETdf2dbc641f[(0xd2d+202-0xdf7)]&(0xbf7+4405-0x1c3c))
  125. >>(0xd11+230-0xdf3);if(DATARMNET8814564ab9->DATARMNET388842c721==
  126. (0xd11+230-0xdf3)){struct DATARMNET308c06fca6*DATARMNET86f1f2cdc9,
  127. DATARMNETbf6548198e;DATARMNET86f1f2cdc9=rmnet_frag_header_ptr(
  128. DATARMNET9d1b321642,(0xd2d+202-0xdf7),sizeof(*DATARMNET86f1f2cdc9),&
  129. DATARMNETbf6548198e);if(!DATARMNET86f1f2cdc9)goto DATARMNETaabe3a05f8;
  130. DATARMNET8814564ab9->DATARMNET4ca5ac9de1=DATARMNET86f1f2cdc9->
  131. DATARMNET610d06a887*(0xd11+230-0xdf3);DATARMNET8814564ab9->DATARMNET7fa8b2acbf=
  132. DATARMNET86f1f2cdc9->DATARMNET953d32410f;DATARMNET8814564ab9->
  133. DATARMNET1a2be7b6c2=DATARMNET86f1f2cdc9->DATARMNET9bbd2ca483;DATARMNET8814564ab9
  134. ->DATARMNET0a28fa80f4=DATARMNET86f1f2cdc9->DATARMNET11ef55b2bb;
  135. DATARMNET8814564ab9->DATARMNET19b03754c4=DATARMNET86f1f2cdc9->
  136. DATARMNET1eb6c27583;DATARMNET8814564ab9->DATARMNET57bf608183=DATARMNET86f1f2cdc9
  137. ->DATARMNET03e081f69f;DATARMNET8814564ab9->DATARMNETcf915688f5=
  138. DATARMNET86f1f2cdc9->DATARMNET2c091223da;if(DATARMNET86f1f2cdc9->
  139. DATARMNET2c091223da&htons(16383)){DATARMNETa00cda79d0(DATARMNET807e4dad18);goto
  140. DATARMNETaabe3a05f8;}DATARMNETdaa9248df1=ntohs(DATARMNET86f1f2cdc9->
  141. DATARMNET8e175ac02d);DATARMNET458b70e7e5->DATARMNET8f59f5a745=
  142. DATARMNETdaa9248df1!=DATARMNET5affe290b8;}else if(DATARMNET8814564ab9->
  143. DATARMNET388842c721==(0xd03+244-0xdf1)){struct DATARMNET64bb8f616e*
  144. DATARMNETbf55123e5b,DATARMNETcf1d9e2c1e;int DATARMNET0549c61885;__be16
  145. DATARMNET833503918f;bool DATARMNETcd214ed34c;u8 DATARMNET3f56a2bcf4;
  146. DATARMNETbf55123e5b=rmnet_frag_header_ptr(DATARMNET9d1b321642,(0xd2d+202-0xdf7),
  147. sizeof(*DATARMNETbf55123e5b),&DATARMNETcf1d9e2c1e);if(!DATARMNETbf55123e5b)goto
  148. DATARMNETaabe3a05f8;DATARMNET3f56a2bcf4=DATARMNETbf55123e5b->DATARMNET7244bfdc4f
  149. ;DATARMNET0549c61885=rmnet_frag_ipv6_skip_exthdr(DATARMNET9d1b321642,sizeof(*
  150. DATARMNETbf55123e5b),&DATARMNET3f56a2bcf4,&DATARMNET833503918f,&
  151. DATARMNETcd214ed34c);if(DATARMNET0549c61885<(0xd2d+202-0xdf7)){goto
  152. DATARMNETaabe3a05f8;}DATARMNET8814564ab9->DATARMNET4ca5ac9de1=(u16)
  153. DATARMNET0549c61885;DATARMNET8814564ab9->DATARMNET7fa8b2acbf=DATARMNET3f56a2bcf4
  154. ;memcpy(&DATARMNET8814564ab9->DATARMNET949c2754de[(0xd2d+202-0xdf7)],&
  155. DATARMNETbf55123e5b->DATARMNET31202449fc[(0xd2d+202-0xdf7)],sizeof(
  156. DATARMNETbf55123e5b->DATARMNET31202449fc));memcpy(&DATARMNET8814564ab9->
  157. DATARMNET45ec858bc5[(0xd2d+202-0xdf7)],&DATARMNETbf55123e5b->DATARMNETc657c0a139
  158. [(0xd2d+202-0xdf7)],sizeof(DATARMNETbf55123e5b->DATARMNETc657c0a139));
  159. DATARMNET8814564ab9->DATARMNETabd58f7f89=DATARMNETbf55123e5b->
  160. DATARMNET0687f7ecdc;if(DATARMNET833503918f||DATARMNETcd214ed34c){if(
  161. DATARMNET8814564ab9->DATARMNET7fa8b2acbf==DATARMNET5b166167a8)
  162. DATARMNET8814564ab9->DATARMNET4ca5ac9de1+=(0xd35+210-0xdff);DATARMNETa00cda79d0(
  163. DATARMNET807e4dad18);goto DATARMNETaabe3a05f8;}DATARMNETdaa9248df1=ntohs(
  164. DATARMNETbf55123e5b->DATARMNETaa340485c5)+sizeof(*DATARMNETbf55123e5b);
  165. DATARMNET458b70e7e5->DATARMNET8f59f5a745=DATARMNETdaa9248df1!=
  166. DATARMNET5affe290b8;}else{return true;}if(DATARMNET8814564ab9->
  167. DATARMNET7fa8b2acbf==DATARMNETfd5c3d30e5){struct DATARMNETd2991e8952*
  168. DATARMNET2e7cc88971,DATARMNETd1ff6cd568;DATARMNET2e7cc88971=
  169. rmnet_frag_header_ptr(DATARMNET9d1b321642,DATARMNET8814564ab9->
  170. DATARMNET4ca5ac9de1,sizeof(*DATARMNET2e7cc88971),&DATARMNETd1ff6cd568);if(!
  171. DATARMNET2e7cc88971)goto DATARMNETaabe3a05f8;DATARMNET8814564ab9->
  172. DATARMNET0aeee57ceb=DATARMNET2e7cc88971->DATARMNETcf2e43ad69*(0xd11+230-0xdf3);
  173. DATARMNET8814564ab9->DATARMNETa60d2ae3f6=DATARMNET2e7cc88971->
  174. DATARMNET6acbeeebb1;DATARMNET8814564ab9->DATARMNET5e7452ec23=DATARMNET2e7cc88971
  175. ->DATARMNET29b8c05d14;DATARMNET8814564ab9->DATARMNETbc28a5970f=ntohl(
  176. DATARMNET2e7cc88971->DATARMNETb3e70104e0);}else if(DATARMNET8814564ab9->
  177. DATARMNET7fa8b2acbf==DATARMNETa656f324b2){struct DATARMNET0b82084e89*
  178. DATARMNET75be5f3406,DATARMNETc82d2f4e16;DATARMNET75be5f3406=
  179. rmnet_frag_header_ptr(DATARMNET9d1b321642,DATARMNET8814564ab9->
  180. DATARMNET4ca5ac9de1,sizeof(*DATARMNET75be5f3406),&DATARMNETc82d2f4e16);if(!
  181. DATARMNET75be5f3406)goto DATARMNETaabe3a05f8;DATARMNET8814564ab9->
  182. DATARMNET0aeee57ceb=sizeof(*DATARMNET75be5f3406);DATARMNET8814564ab9->
  183. DATARMNETa60d2ae3f6=DATARMNET75be5f3406->DATARMNET1b1c406ae9;DATARMNET8814564ab9
  184. ->DATARMNET5e7452ec23=DATARMNET75be5f3406->DATARMNETdf0e8545ee;}else{goto
  185. DATARMNETaabe3a05f8;}DATARMNET458b70e7e5->DATARMNET3eb91ee54d=false;
  186. DATARMNET458b70e7e5->DATARMNET645e8912b8=DATARMNETcb7325e02d(DATARMNET458b70e7e5
  187. );if(!DATARMNET458b70e7e5->DATARMNET8f59f5a745){DATARMNET9d1b321642->ip_proto=
  188. DATARMNET8814564ab9->DATARMNET388842c721;DATARMNET9d1b321642->ip_len=
  189. DATARMNET8814564ab9->DATARMNET4ca5ac9de1;DATARMNET9d1b321642->trans_proto=
  190. DATARMNET8814564ab9->DATARMNET7fa8b2acbf;DATARMNET9d1b321642->trans_len=
  191. DATARMNET8814564ab9->DATARMNET0aeee57ceb;DATARMNET9d1b321642->hdrs_valid=
  192. (0xd26+209-0xdf6);}DATARMNETaabe3a05f8:DATARMNET458b70e7e5->DATARMNET1ef22e4c76=
  193. DATARMNET5affe290b8-DATARMNET8814564ab9->DATARMNET4ca5ac9de1-DATARMNET8814564ab9
  194. ->DATARMNET0aeee57ceb;if(DATARMNET458b70e7e5->DATARMNET8f59f5a745)
  195. DATARMNETa00cda79d0(DATARMNET52b7da9033);DATARMNET458b70e7e5->
  196. DATARMNET719f68fb88=DATARMNET9d1b321642;return false;}static void
  197. DATARMNETb56d685c50(struct rmnet_frag_descriptor*DATARMNET9d1b321642,struct
  198. rmnet_port*DATARMNETf0d9de7e2f){struct DATARMNET70f3b87b5d*DATARMNETe05748b000=
  199. DATARMNETc2a630b113();struct DATARMNETd812bcdbb5 DATARMNET458b70e7e5;LIST_HEAD(
  200. DATARMNET6f9bfa17e6);memset(&DATARMNET458b70e7e5,(0xd2d+202-0xdf7),sizeof(
  201. DATARMNET458b70e7e5));DATARMNET664568fcd0();DATARMNETe05748b000->
  202. DATARMNET403589239f=DATARMNETf0d9de7e2f;if(DATARMNET1a7ed9a6a2(
  203. DATARMNET9d1b321642,&DATARMNET458b70e7e5)){DATARMNETa00cda79d0(
  204. DATARMNET1cddffce49);rmnet_recycle_frag_descriptor(DATARMNET9d1b321642,
  205. DATARMNETf0d9de7e2f);goto DATARMNETbf4095f79e;}DATARMNETa00cda79d0(
  206. DATARMNET9b3fdb0e16);if(DATARMNET458b70e7e5.DATARMNET3eb91ee54d){goto
  207. DATARMNET806c6f8e60;}else if(DATARMNET458b70e7e5.DATARMNET8f59f5a745){
  208. DATARMNETc38c135c9f(DATARMNET458b70e7e5.DATARMNET645e8912b8,&DATARMNET6f9bfa17e6
  209. );goto DATARMNET806c6f8e60;}if(!DATARMNET9d1b321642->csum_valid){goto
  210. DATARMNET806c6f8e60;}if(!DATARMNETfbf5798e15(&DATARMNET458b70e7e5,&
  211. DATARMNET6f9bfa17e6))goto DATARMNET806c6f8e60;goto DATARMNETbf4095f79e;
  212. DATARMNET806c6f8e60:DATARMNET19d190f2bd(&DATARMNET458b70e7e5,&
  213. DATARMNET6f9bfa17e6);DATARMNETbf4095f79e:DATARMNET6a76048590();
  214. DATARMNETc70e73c8d4(&DATARMNET6f9bfa17e6);}static void DATARMNET29e8d137c4(
  215. struct list_head*DATARMNETb5730f5283,struct rmnet_port*DATARMNETf0d9de7e2f){
  216. struct rmnet_frag_descriptor*DATARMNETced5b4128f,*DATARMNET0386f6f82a;
  217. list_for_each_entry_safe(DATARMNETced5b4128f,DATARMNET0386f6f82a,
  218. DATARMNETb5730f5283,list){list_del_init(&DATARMNETced5b4128f->list);
  219. DATARMNETb56d685c50(DATARMNETced5b4128f,DATARMNETf0d9de7e2f);}}void
  220. DATARMNET664568fcd0(void){spin_lock_bh(&DATARMNET0b5e447f18);}void
  221. DATARMNET6a76048590(void){spin_unlock_bh(&DATARMNET0b5e447f18);}static const
  222. struct rmnet_module_hook_register_info DATARMNET162e7a2013={.hooknum=
  223. RMNET_MODULE_HOOK_OFFLOAD_INGRESS,.func=DATARMNET29e8d137c4,};void
  224. DATARMNET818b960147(void){rcu_assign_pointer(rmnet_perf_desc_entry,
  225. DATARMNETb56d685c50);rmnet_module_hook_register(&DATARMNET162e7a2013,
  226. (0xd26+209-0xdf6));}void DATARMNETba38823a2f(void){rcu_assign_pointer(
  227. rmnet_perf_desc_entry,NULL);rmnet_module_hook_unregister_no_sync(&
  228. DATARMNET162e7a2013,(0xd26+209-0xdf6));}void DATARMNETc70e73c8d4(struct
  229. list_head*DATARMNETb5730f5283){struct DATARMNET70f3b87b5d*DATARMNETe05748b000=
  230. DATARMNETc2a630b113();struct rmnet_frag_descriptor*DATARMNET9d1b321642,*
  231. DATARMNET0386f6f82a;list_for_each_entry_safe(DATARMNET9d1b321642,
  232. DATARMNET0386f6f82a,DATARMNETb5730f5283,list){DATARMNETe26a68d20e(
  233. DATARMNET9d1b321642->len);DATARMNETa00cda79d0(DATARMNET65843ad009);list_del_init
  234. (&DATARMNET9d1b321642->list);rmnet_frag_deliver(DATARMNET9d1b321642,
  235. DATARMNETe05748b000->DATARMNET403589239f);}}void DATARMNET19d190f2bd(struct
  236. DATARMNETd812bcdbb5*DATARMNET458b70e7e5,struct list_head*DATARMNET6f9bfa17e6){
  237. struct rmnet_frag_descriptor*DATARMNET9d1b321642=DATARMNET458b70e7e5->
  238. DATARMNET719f68fb88;u32 DATARMNET5affe290b8=DATARMNET458b70e7e5->
  239. DATARMNET1ef22e4c76+DATARMNET458b70e7e5->DATARMNET144d119066.DATARMNET4ca5ac9de1
  240. +DATARMNET458b70e7e5->DATARMNET144d119066.DATARMNET0aeee57ceb;if(
  241. DATARMNET5affe290b8>65536)return;if(!DATARMNET458b70e7e5->DATARMNET3eb91ee54d)
  242. DATARMNET9d1b321642->hash=DATARMNET458b70e7e5->DATARMNET645e8912b8;list_add_tail
  243. (&DATARMNET9d1b321642->list,DATARMNET6f9bfa17e6);}void DATARMNET9292bebdd3(void*
  244. DATARMNETf0d9de7e2f){}void DATARMNETb7e47d7254(void*DATARMNETf0d9de7e2f){}void
  245. DATARMNET95e1703026(struct rmnet_map_dl_ind_hdr*DATARMNET7c7748ef7a,struct
  246. rmnet_map_control_command_header*DATARMNET8b07ee3e82){struct DATARMNET70f3b87b5d
  247. *DATARMNETe05748b000=DATARMNETc2a630b113();LIST_HEAD(DATARMNET6f9bfa17e6);(void)
  248. DATARMNET8b07ee3e82;DATARMNET664568fcd0();if(DATARMNETe05748b000->
  249. DATARMNETa9f2b2f677.DATARMNETb165d2c5c4&&DATARMNETae70636c90(&
  250. DATARMNET6f9bfa17e6))DATARMNETa00cda79d0(DATARMNET372ef39ae4);
  251. DATARMNETe05748b000->DATARMNETa9f2b2f677.DATARMNETb165d2c5c4=true;
  252. DATARMNETe05748b000->DATARMNETa9f2b2f677.DATARMNETe2251ce433=DATARMNET7c7748ef7a
  253. ->le.seq;DATARMNETe05748b000->DATARMNETa9f2b2f677.DATARMNET7f59b108db=
  254. DATARMNET7c7748ef7a->le.pkts;DATARMNET6a76048590();DATARMNETc70e73c8d4(&
  255. DATARMNET6f9bfa17e6);}void DATARMNETc9dd320f49(struct rmnet_map_dl_ind_trl*
  256. DATARMNET2541770fea,struct rmnet_map_control_command_header*DATARMNET8b07ee3e82)
  257. {struct DATARMNET70f3b87b5d*DATARMNETe05748b000=DATARMNETc2a630b113();LIST_HEAD(
  258. DATARMNET6f9bfa17e6);(void)DATARMNET8b07ee3e82;DATARMNET664568fcd0();if(
  259. DATARMNETe05748b000->DATARMNETa9f2b2f677.DATARMNETe2251ce433!=
  260. DATARMNET2541770fea->seq_le)DATARMNETa00cda79d0(DATARMNET30a4d88ea6);if(
  261. DATARMNETae70636c90(&DATARMNET6f9bfa17e6))DATARMNETa00cda79d0(
  262. DATARMNETa03ed3629e);DATARMNETe05748b000->DATARMNETa9f2b2f677.
  263. DATARMNETb165d2c5c4=false;DATARMNETe05748b000->DATARMNETa9f2b2f677.
  264. DATARMNETe2251ce433=(0xd2d+202-0xdf7);DATARMNETe05748b000->DATARMNETa9f2b2f677.
  265. DATARMNET7f59b108db=(0xd2d+202-0xdf7);DATARMNET6a76048590();DATARMNETc70e73c8d4(
  266. &DATARMNET6f9bfa17e6);}