qdf_tracepoint.c 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. /*
  2. * Copyright (c) 2021 Qualcomm Innovation Center, Inc. All rights reserved.
  3. *
  4. * Permission to use, copy, modify, and/or distribute this software for
  5. * any purpose with or without fee is hereby granted, provided that the
  6. * above copyright notice and this permission notice appear in all
  7. * copies.
  8. *
  9. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
  10. * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
  11. * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
  12. * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
  13. * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
  14. * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
  15. * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  16. * PERFORMANCE OF THIS SOFTWARE.
  17. */
  18. #include <qdf_tracepoint.h>
  19. #define CREATE_TRACE_POINTS
  20. #include "qdf_tracepoint_defs.h"
  21. #ifdef WLAN_TRACEPOINTS
  22. static void qdf_trace_dp_tx_ip_packet(qdf_nbuf_t nbuf, uint8_t *trans_hdr,
  23. uint8_t ip_proto, uint16_t ip_id,
  24. struct qdf_tso_seg_elem_t *tso_desc,
  25. uint64_t latency)
  26. {
  27. if (ip_proto == QDF_NBUF_TRAC_TCP_TYPE &&
  28. __qdf_trace_dp_tx_comp_tcp_pkt_enabled()) {
  29. qdf_net_tcphdr_t *tcph = (qdf_net_tcphdr_t *)trans_hdr;
  30. uint32_t tcp_seq;
  31. if (tso_desc)
  32. tcp_seq = tso_desc->seg.tso_flags.tcp_seq_num;
  33. else
  34. tcp_seq = qdf_ntohl(tcph->seq);
  35. __qdf_trace_dp_tx_comp_tcp_pkt(nbuf, tcp_seq,
  36. qdf_ntohl(tcph->ack_seq),
  37. qdf_ntohs(tcph->source),
  38. qdf_ntohs(tcph->dest),
  39. latency);
  40. } else if (ip_proto == QDF_NBUF_TRAC_UDP_TYPE &&
  41. __qdf_trace_dp_tx_comp_udp_pkt_enabled()) {
  42. qdf_net_udphdr_t *udph = (qdf_net_udphdr_t *)trans_hdr;
  43. __qdf_trace_dp_tx_comp_udp_pkt(nbuf, qdf_ntohs(ip_id),
  44. qdf_ntohs(udph->src_port),
  45. qdf_ntohs(udph->dst_port),
  46. latency);
  47. }
  48. }
  49. static void qdf_trace_dp_rx_ip_packet(qdf_nbuf_t nbuf, uint8_t *trans_hdr,
  50. uint8_t ip_proto, uint16_t ip_id,
  51. uint64_t latency)
  52. {
  53. if (ip_proto == QDF_NBUF_TRAC_TCP_TYPE &&
  54. __qdf_trace_dp_rx_tcp_pkt_enabled()) {
  55. qdf_net_tcphdr_t *tcph = (qdf_net_tcphdr_t *)trans_hdr;
  56. __qdf_trace_dp_rx_tcp_pkt(nbuf, qdf_ntohl(tcph->seq),
  57. qdf_ntohl(tcph->ack_seq),
  58. qdf_ntohs(tcph->source),
  59. qdf_ntohs(tcph->dest),
  60. latency);
  61. } else if (ip_proto == QDF_NBUF_TRAC_UDP_TYPE &&
  62. __qdf_trace_dp_rx_udp_pkt_enabled()) {
  63. qdf_net_udphdr_t *udph = (qdf_net_udphdr_t *)trans_hdr;
  64. __qdf_trace_dp_rx_udp_pkt(nbuf, qdf_ntohs(ip_id),
  65. qdf_ntohs(udph->src_port),
  66. qdf_ntohs(udph->dst_port),
  67. latency);
  68. }
  69. }
  70. void qdf_trace_dp_packet(qdf_nbuf_t nbuf, enum qdf_proto_dir dir,
  71. struct qdf_tso_seg_elem_t *tso_desc, uint64_t enq_time)
  72. {
  73. uint8_t *data = qdf_nbuf_data(nbuf);
  74. uint64_t latency;
  75. uint16_t ether_type;
  76. uint8_t ip_offset = QDF_NBUF_TRAC_IP_OFFSET;
  77. if (dir == QDF_TX)
  78. latency = (qdf_ktime_to_ms(qdf_ktime_real_get()) - enq_time);
  79. else
  80. latency = qdf_nbuf_get_timedelta_ms(nbuf);
  81. ether_type = QDF_SWAP_U16(*(uint16_t *)(data +
  82. QDF_NBUF_TRAC_ETH_TYPE_OFFSET));
  83. if (unlikely(ether_type == QDF_ETH_TYPE_8021Q)) {
  84. ether_type = QDF_SWAP_U16(*(uint16_t *)(data +
  85. QDF_NBUF_TRAC_VLAN_ETH_TYPE_OFFSET));
  86. ip_offset = QDF_NBUF_TRAC_VLAN_IP_OFFSET;
  87. } else if (unlikely(ether_type == QDF_ETH_TYPE_8021AD)) {
  88. ether_type = QDF_SWAP_U16(*(uint16_t *)(data +
  89. QDF_NBUF_TRAC_DOUBLE_VLAN_ETH_TYPE_OFFSET));
  90. ip_offset = QDF_NBUF_TRAC_DOUBLE_VLAN_IP_OFFSET;
  91. }
  92. switch (ether_type) {
  93. case QDF_NBUF_TRAC_IPV4_ETH_TYPE:
  94. case QDF_NBUF_TRAC_IPV6_ETH_TYPE:
  95. {
  96. uint8_t *net_hdr;
  97. uint8_t *trans_hdr;
  98. uint8_t ip_proto;
  99. uint16_t ip_id = 0;
  100. net_hdr = data + ip_offset;
  101. if (ether_type == QDF_NBUF_TRAC_IPV4_ETH_TYPE) {
  102. ip_proto = ((qdf_net_iphdr_t *)net_hdr)->ip_proto;
  103. ip_id = ((qdf_net_iphdr_t *)net_hdr)->ip_id;
  104. trans_hdr = net_hdr + QDF_NBUF_TRAC_IPV4_HEADER_SIZE;
  105. } else {
  106. ip_proto = ((qdf_net_ipv6hdr_t *)net_hdr)->ipv6_nexthdr;
  107. trans_hdr = net_hdr + QDF_NBUF_TRAC_IPV6_HEADER_SIZE;
  108. }
  109. if (dir == QDF_TX)
  110. qdf_trace_dp_tx_ip_packet(nbuf, trans_hdr, ip_proto,
  111. ip_id, tso_desc, latency);
  112. else
  113. qdf_trace_dp_rx_ip_packet(nbuf, trans_hdr, ip_proto,
  114. ip_id, latency);
  115. break;
  116. }
  117. default:
  118. if (dir == QDF_TX && __qdf_trace_dp_tx_comp_pkt_enabled())
  119. __qdf_trace_dp_tx_comp_pkt(nbuf, ether_type, latency);
  120. else if (__qdf_trace_dp_rx_pkt_enabled())
  121. __qdf_trace_dp_rx_pkt(nbuf, ether_type, latency);
  122. break;
  123. }
  124. }
  125. #endif