core: Add hooks for perf tether ingress and egress

Define the hooks to be used be perf tether ingress and egress.

CRs-Fixed: 2813607
Change-Id: I68c4cc1e73c60e784fd4117679b3a373d29f539c
Signed-off-by: Subash Abhinov Kasiviswanathan <subashab@codeaurora.org>
Dieser Commit ist enthalten in:
Subash Abhinov Kasiviswanathan
2021-03-15 16:12:06 -06:00
Ursprung dad91a4eff
Commit eec13e2c69
2 geänderte Dateien mit 19 neuen und 0 gelöschten Zeilen

Datei anzeigen

@@ -37,6 +37,10 @@ typedef void (*rmnet_perf_desc_hook_t)(struct rmnet_frag_descriptor *frag_desc,
struct rmnet_port *port);
typedef void (*rmnet_perf_chain_hook_t)(void);
typedef void (*rmnet_perf_tether_ingress_hook_t)(struct tcphdr *tp, struct sk_buff *skb);
rmnet_perf_tether_ingress_hook_t rmnet_perf_tether_ingress_hook __rcu __read_mostly;
EXPORT_SYMBOL(rmnet_perf_tether_ingress_hook);
struct rmnet_frag_descriptor *
rmnet_get_frag_descriptor(struct rmnet_port *port)
{
@@ -731,6 +735,7 @@ static void rmnet_frag_gso_stamp(struct sk_buff *skb,
static void rmnet_frag_partial_csum(struct sk_buff *skb,
struct rmnet_frag_descriptor *frag_desc)
{
rmnet_perf_tether_ingress_hook_t rmnet_perf_tether_ingress;
struct iphdr *iph = (struct iphdr *)skb->data;
__sum16 pseudo;
u16 pkt_len = skb->len - frag_desc->ip_len;
@@ -757,6 +762,10 @@ static void rmnet_frag_partial_csum(struct sk_buff *skb,
tp->check = pseudo;
skb->csum_offset = offsetof(struct tcphdr, check);
rmnet_perf_tether_ingress = rcu_dereference(rmnet_perf_tether_ingress_hook);
if (rmnet_perf_tether_ingress)
rmnet_perf_tether_ingress(tp, skb);
} else {
struct udphdr *up = (struct udphdr *)
((u8 *)iph + frag_desc->ip_len);

Datei anzeigen

@@ -31,6 +31,11 @@
#include "rmnet_qmi.h"
#include "rmnet_trace.h"
typedef void (*rmnet_perf_tether_egress_hook_t)(struct sk_buff *skb);
rmnet_perf_tether_egress_hook_t rmnet_perf_tether_egress_hook __rcu __read_mostly;
EXPORT_SYMBOL(rmnet_perf_tether_egress_hook);
/* RX/TX Fixup */
void rmnet_vnd_rx_fixup(struct net_device *dev, u32 skb_len)
@@ -68,6 +73,7 @@ static netdev_tx_t rmnet_vnd_start_xmit(struct sk_buff *skb,
int ip_type;
u32 mark;
unsigned int len;
rmnet_perf_tether_egress_hook_t rmnet_perf_tether_egress;
priv = netdev_priv(dev);
if (priv->real_dev) {
@@ -76,6 +82,10 @@ static netdev_tx_t rmnet_vnd_start_xmit(struct sk_buff *skb,
mark = skb->mark;
len = skb->len;
trace_rmnet_xmit_skb(skb);
rmnet_perf_tether_egress = rcu_dereference(rmnet_perf_tether_egress_hook);
if (rmnet_perf_tether_egress) {
rmnet_perf_tether_egress(skb);
}
rmnet_egress_handler(skb);
qmi_rmnet_burst_fc_check(dev, ip_type, mark, len);
qmi_rmnet_work_maybe_restart(rmnet_get_rmnet_port(dev));