rmnet_perf_main.c 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /* Copyright (c) 2021-2023 Qualcomm Innovation Center, Inc. All rights reserved.
  3. *
  4. * RMNET PERF framework
  5. *
  6. */
  7. #include <linux/module.h>
  8. #include <linux/skbuff.h>
  9. #include <linux/in.h>
  10. #include <linux/udp.h>
  11. #include <linux/ip.h>
  12. #include <linux/ipv6.h>
  13. #include <net/ip.h>
  14. #include <net/ipv6.h>
  15. #include "rmnet_module.h"
  16. #include <net/ipv6.h>
  17. #include <net/ip.h>
  18. #include "rmnet_perf_tcp.h"
  19. #include "rmnet_perf_udp.h"
  20. MODULE_LICENSE("\x47\x50\x4c\x20\x76\x32");static char*verinfo[]={
  21. "\x37\x66\x30\x37\x38\x66\x39\x36","\x65\x35\x36\x63\x62\x35\x35\x64",
  22. "\x65\x32\x31\x38\x66\x34\x35\x31","\x33\x39\x63\x62\x64\x37\x64\x35",
  23. "\x37\x34\x31\x35\x39\x32\x31\x63","\x34\x64\x65\x34\x39\x64\x62\x35",
  24. "\x62\x31\x63\x34\x34\x62\x34\x63"};module_param_array(verinfo,charp,NULL,
  25. (0xcb7+5769-0x221c));MODULE_PARM_DESC(verinfo,
  26. "\x56\x65\x72\x73\x69\x6f\x6e\x20\x6f\x66\x20\x74\x68\x65\x20\x64\x72\x69\x76\x65\x72"
  27. );static bool DATARMNETc03b668e4c=true;module_param_named(rmnet_perf_knob0,
  28. DATARMNETc03b668e4c,bool,(0xdb7+6665-0x261c));static bool DATARMNET21c7a3c377=
  29. true;module_param_named(rmnet_perf_knob1,DATARMNET21c7a3c377,bool,
  30. (0xdb7+6665-0x261c));extern void(*rmnet_perf_egress_hook1)(struct sk_buff*
  31. DATARMNET543491eb0f);
  32. #define DATARMNETf241a4b20f (0xe07+6616-0x2624)
  33. static inline bool DATARMNETe1ef3edea2(struct udphdr*DATARMNETa1abb4897c){return
  34. be16_to_cpu(DATARMNETa1abb4897c->source)==DATARMNETf241a4b20f||be16_to_cpu(
  35. DATARMNETa1abb4897c->dest)==DATARMNETf241a4b20f;}static bool DATARMNET77ab42949f
  36. (struct sk_buff*DATARMNET543491eb0f,int DATARMNET611d08d671){u8*
  37. DATARMNET352416e828,DATARMNETd9bda61912;struct udphdr*DATARMNETa1abb4897c,
  38. DATARMNET7b1af10647;DATARMNETa1abb4897c=skb_header_pointer(DATARMNET543491eb0f,
  39. DATARMNET611d08d671,sizeof(*DATARMNETa1abb4897c),&DATARMNET7b1af10647);if(!
  40. DATARMNETa1abb4897c||!DATARMNETe1ef3edea2(DATARMNETa1abb4897c))return false;if(
  41. be16_to_cpu(DATARMNETa1abb4897c->len)<sizeof(struct udphdr)+(0xd26+209-0xdf6))
  42. return false;DATARMNET352416e828=skb_header_pointer(DATARMNET543491eb0f,
  43. DATARMNET611d08d671+sizeof(struct udphdr),(0xd26+209-0xdf6),&DATARMNETd9bda61912
  44. );if(!DATARMNET352416e828)return false;return((*DATARMNET352416e828)&
  45. (0xbf7+4869-0x1e3c))==(0xbf7+4869-0x1e3c);}static int DATARMNETee9214ce9b(struct
  46. sk_buff*DATARMNET543491eb0f,int DATARMNET611d08d671){if(DATARMNET77ab42949f(
  47. DATARMNET543491eb0f,DATARMNET611d08d671)){DATARMNET543491eb0f->hash=
  48. (0xd2d+202-0xdf7);DATARMNET543491eb0f->sw_hash=(0xd26+209-0xdf6);return
  49. (0xd2d+202-0xdf7);}return-EINVAL;}int DATARMNETf2958615b1(struct sk_buff*
  50. DATARMNET543491eb0f){if(DATARMNET543491eb0f->protocol==htons(ETH_P_IP)){struct
  51. iphdr*DATARMNET86f1f2cdc9,DATARMNETbf6548198e;DATARMNET86f1f2cdc9=
  52. skb_header_pointer(DATARMNET543491eb0f,(0xd2d+202-0xdf7),sizeof(*
  53. DATARMNET86f1f2cdc9),&DATARMNETbf6548198e);if(!DATARMNET86f1f2cdc9||
  54. ip_is_fragment(DATARMNET86f1f2cdc9))return-EINVAL;if(DATARMNET86f1f2cdc9->
  55. protocol==IPPROTO_UDP){if(DATARMNET21c7a3c377)DATARMNET2a6d02a6a5(
  56. DATARMNET543491eb0f);return DATARMNETee9214ce9b(DATARMNET543491eb0f,
  57. DATARMNET86f1f2cdc9->ihl*(0xd11+230-0xdf3));}if(DATARMNET86f1f2cdc9->protocol==
  58. IPPROTO_TCP){if(DATARMNETc03b668e4c)DATARMNET9250714999(DATARMNET543491eb0f);
  59. return-EINVAL;}}else if(DATARMNET543491eb0f->protocol==htons(ETH_P_IPV6)){struct
  60. ipv6hdr*DATARMNETbf55123e5b,DATARMNETcf1d9e2c1e;int DATARMNET611d08d671;__be16
  61. DATARMNET98fed39916;u8 DATARMNET65293f17c4;DATARMNETbf55123e5b=
  62. skb_header_pointer(DATARMNET543491eb0f,(0xd2d+202-0xdf7),sizeof(*
  63. DATARMNETbf55123e5b),&DATARMNETcf1d9e2c1e);if(!DATARMNETbf55123e5b)return-EINVAL
  64. ;DATARMNET65293f17c4=DATARMNETbf55123e5b->nexthdr;DATARMNET611d08d671=
  65. ipv6_skip_exthdr(DATARMNET543491eb0f,sizeof(*DATARMNETbf55123e5b),&
  66. DATARMNET65293f17c4,&DATARMNET98fed39916);if(DATARMNET611d08d671<
  67. (0xd2d+202-0xdf7)||DATARMNET98fed39916)return-EINVAL;if(DATARMNET65293f17c4==
  68. IPPROTO_UDP){if(DATARMNET21c7a3c377)DATARMNET2a6d02a6a5(DATARMNET543491eb0f);
  69. return DATARMNETee9214ce9b(DATARMNET543491eb0f,DATARMNET611d08d671);}if(
  70. DATARMNET65293f17c4==IPPROTO_TCP){if(DATARMNETc03b668e4c)DATARMNET9250714999(
  71. DATARMNET543491eb0f);return-EINVAL;}}return-EINVAL;}static void
  72. DATARMNET05c4bf8af9(struct sk_buff*DATARMNET543491eb0f,int DATARMNET611d08d671){
  73. if(DATARMNET77ab42949f(DATARMNET543491eb0f,DATARMNET611d08d671))
  74. DATARMNET543491eb0f->priority=14286874;}void DATARMNET324fe25dad(struct sk_buff*
  75. DATARMNET543491eb0f){if(DATARMNET543491eb0f->protocol==htons(ETH_P_IP)){struct
  76. iphdr*DATARMNET86f1f2cdc9,DATARMNETbf6548198e;DATARMNET86f1f2cdc9=
  77. skb_header_pointer(DATARMNET543491eb0f,(0xd2d+202-0xdf7),sizeof(*
  78. DATARMNET86f1f2cdc9),&DATARMNETbf6548198e);if(!DATARMNET86f1f2cdc9||
  79. ip_is_fragment(DATARMNET86f1f2cdc9))return;if(DATARMNET86f1f2cdc9->protocol==
  80. IPPROTO_UDP){if(DATARMNET21c7a3c377)DATARMNET5ecc30669c(DATARMNET543491eb0f);
  81. DATARMNET05c4bf8af9(DATARMNET543491eb0f,DATARMNET86f1f2cdc9->ihl*
  82. (0xd11+230-0xdf3));return;}if(DATARMNET86f1f2cdc9->protocol==IPPROTO_TCP){if(
  83. DATARMNETc03b668e4c)DATARMNET9d574e64b1(DATARMNET543491eb0f);return;}}else if(
  84. DATARMNET543491eb0f->protocol==htons(ETH_P_IPV6)){struct ipv6hdr*
  85. DATARMNETbf55123e5b,DATARMNETcf1d9e2c1e;int DATARMNET611d08d671;__be16
  86. DATARMNET98fed39916;u8 DATARMNET65293f17c4;DATARMNETbf55123e5b=
  87. skb_header_pointer(DATARMNET543491eb0f,(0xd2d+202-0xdf7),sizeof(*
  88. DATARMNETbf55123e5b),&DATARMNETcf1d9e2c1e);if(!DATARMNETbf55123e5b)return;
  89. DATARMNET65293f17c4=DATARMNETbf55123e5b->nexthdr;DATARMNET611d08d671=
  90. ipv6_skip_exthdr(DATARMNET543491eb0f,sizeof(*DATARMNETbf55123e5b),&
  91. DATARMNET65293f17c4,&DATARMNET98fed39916);if(DATARMNET611d08d671<
  92. (0xd2d+202-0xdf7)||DATARMNET98fed39916)return;if(DATARMNET65293f17c4==
  93. IPPROTO_UDP){if(DATARMNET21c7a3c377)DATARMNET5ecc30669c(DATARMNET543491eb0f);
  94. DATARMNET05c4bf8af9(DATARMNET543491eb0f,DATARMNET611d08d671);return;}if(
  95. DATARMNET65293f17c4==IPPROTO_TCP){if(DATARMNETc03b668e4c)DATARMNET9d574e64b1(
  96. DATARMNET543491eb0f);return;}}}static const struct
  97. rmnet_module_hook_register_info DATARMNET95a71e03c1[]={{.hooknum=
  98. RMNET_MODULE_HOOK_PERF_INGRESS,.func=DATARMNETf2958615b1,},{.hooknum=
  99. RMNET_MODULE_HOOK_PERF_EGRESS,.func=DATARMNET324fe25dad,},{.hooknum=
  100. RMNET_MODULE_HOOK_PERF_SET_THRESH,.func=DATARMNET7fa1835595,},};void
  101. DATARMNET49c17a32bc(void){rcu_assign_pointer(rmnet_perf_egress_hook1,
  102. DATARMNET324fe25dad);rmnet_module_hook_register(DATARMNET95a71e03c1,ARRAY_SIZE(
  103. DATARMNET95a71e03c1));}void DATARMNET41e8cc085c(void){rcu_assign_pointer(
  104. rmnet_perf_egress_hook1,NULL);rmnet_module_hook_unregister(DATARMNET95a71e03c1,
  105. ARRAY_SIZE(DATARMNET95a71e03c1));}static int __init DATARMNET63abbdc3d3(void){
  106. int DATARMNETb14e52a504;pr_info("%s(): Loading\n",__func__);DATARMNETb14e52a504=
  107. DATARMNET7e9995246e();if(DATARMNETb14e52a504)return DATARMNETb14e52a504;
  108. DATARMNETb14e52a504=DATARMNETe80a33d544();if(DATARMNETb14e52a504){
  109. DATARMNET38bb6f2b7a();return DATARMNETb14e52a504;}DATARMNET49c17a32bc();return
  110. (0xd2d+202-0xdf7);}static void __exit DATARMNETa343229e33(void){
  111. DATARMNET41e8cc085c();DATARMNET4b5170a1ef();DATARMNET38bb6f2b7a();pr_info(
  112. "\x25\x73\x28\x29\x3a\x20\x65\x78\x69\x74\x69\x6e\x67" "\n",__func__);}
  113. module_init(DATARMNET63abbdc3d3);module_exit(DATARMNETa343229e33);