Loading drivers/net/ethernet/qualcomm/rmnet/rmnet_handlers.c +12 −19 Original line number Diff line number Diff line Loading @@ -43,7 +43,7 @@ static void rmnet_set_skb_proto(struct sk_buff *skb) /* Generic handler */ static rx_handler_result_t static void rmnet_deliver_skb(struct sk_buff *skb) { skb_reset_transport_header(skb); Loading @@ -53,12 +53,11 @@ rmnet_deliver_skb(struct sk_buff *skb) skb->pkt_type = PACKET_HOST; skb_set_mac_header(skb, 0); netif_receive_skb(skb); return RX_HANDLER_CONSUMED; } /* MAP handler */ static rx_handler_result_t static void __rmnet_map_ingress_handler(struct sk_buff *skb, struct rmnet_port *port) { Loading Loading @@ -91,31 +90,27 @@ __rmnet_map_ingress_handler(struct sk_buff *skb, skb_pull(skb, sizeof(struct rmnet_map_header)); skb_trim(skb, len); rmnet_set_skb_proto(skb); return rmnet_deliver_skb(skb); rmnet_deliver_skb(skb); return; free_skb: kfree_skb(skb); return RX_HANDLER_CONSUMED; } static rx_handler_result_t static void rmnet_map_ingress_handler(struct sk_buff *skb, struct rmnet_port *port) { struct sk_buff *skbn; int rc; if (port->ingress_data_format & RMNET_INGRESS_FORMAT_DEAGGREGATION) { while ((skbn = rmnet_map_deaggregate(skb)) != NULL) __rmnet_map_ingress_handler(skbn, port); consume_skb(skb); rc = RX_HANDLER_CONSUMED; } else { rc = __rmnet_map_ingress_handler(skb, port); __rmnet_map_ingress_handler(skb, port); } return rc; } static int rmnet_map_egress_handler(struct sk_buff *skb, Loading Loading @@ -149,15 +144,13 @@ static int rmnet_map_egress_handler(struct sk_buff *skb, return RMNET_MAP_SUCCESS; } static rx_handler_result_t static void rmnet_bridge_handler(struct sk_buff *skb, struct net_device *bridge_dev) { if (bridge_dev) { skb->dev = bridge_dev; dev_queue_xmit(skb); } return RX_HANDLER_CONSUMED; } /* Ingress / Egress Entry Points */ Loading @@ -168,13 +161,12 @@ rmnet_bridge_handler(struct sk_buff *skb, struct net_device *bridge_dev) */ rx_handler_result_t rmnet_rx_handler(struct sk_buff **pskb) { int rc = RX_HANDLER_CONSUMED; struct sk_buff *skb = *pskb; struct rmnet_port *port; struct net_device *dev; if (!skb) return RX_HANDLER_CONSUMED; goto done; dev = skb->dev; port = rmnet_get_port(dev); Loading @@ -182,14 +174,15 @@ rx_handler_result_t rmnet_rx_handler(struct sk_buff **pskb) switch (port->rmnet_mode) { case RMNET_EPMODE_VND: if (port->ingress_data_format & RMNET_INGRESS_FORMAT_MAP) rc = rmnet_map_ingress_handler(skb, port); rmnet_map_ingress_handler(skb, port); break; case RMNET_EPMODE_BRIDGE: rc = rmnet_bridge_handler(skb, port->bridge_ep); rmnet_bridge_handler(skb, port->bridge_ep); break; } return rc; done: return RX_HANDLER_CONSUMED; } /* Modifies packet as per logical endpoint configuration and egress data format Loading drivers/net/ethernet/qualcomm/rmnet/rmnet_map.h +1 −2 Original line number Diff line number Diff line Loading @@ -80,7 +80,6 @@ u8 rmnet_map_demultiplex(struct sk_buff *skb); struct sk_buff *rmnet_map_deaggregate(struct sk_buff *skb); struct rmnet_map_header *rmnet_map_add_map_header(struct sk_buff *skb, int hdrlen, int pad); rx_handler_result_t rmnet_map_command(struct sk_buff *skb, struct rmnet_port *port); void rmnet_map_command(struct sk_buff *skb, struct rmnet_port *port); #endif /* _RMNET_MAP_H_ */ drivers/net/ethernet/qualcomm/rmnet/rmnet_map_command.c +1 −3 Original line number Diff line number Diff line Loading @@ -76,8 +76,7 @@ static void rmnet_map_send_ack(struct sk_buff *skb, /* Process MAP command frame and send N/ACK message as appropriate. Message cmd * name is decoded here and appropriate handler is called. */ rx_handler_result_t rmnet_map_command(struct sk_buff *skb, struct rmnet_port *port) void rmnet_map_command(struct sk_buff *skb, struct rmnet_port *port) { struct rmnet_map_control_command *cmd; unsigned char command_name; Loading @@ -102,5 +101,4 @@ rx_handler_result_t rmnet_map_command(struct sk_buff *skb, } if (rc == RMNET_MAP_COMMAND_ACK) rmnet_map_send_ack(skb, rc); return RX_HANDLER_CONSUMED; } Loading
drivers/net/ethernet/qualcomm/rmnet/rmnet_handlers.c +12 −19 Original line number Diff line number Diff line Loading @@ -43,7 +43,7 @@ static void rmnet_set_skb_proto(struct sk_buff *skb) /* Generic handler */ static rx_handler_result_t static void rmnet_deliver_skb(struct sk_buff *skb) { skb_reset_transport_header(skb); Loading @@ -53,12 +53,11 @@ rmnet_deliver_skb(struct sk_buff *skb) skb->pkt_type = PACKET_HOST; skb_set_mac_header(skb, 0); netif_receive_skb(skb); return RX_HANDLER_CONSUMED; } /* MAP handler */ static rx_handler_result_t static void __rmnet_map_ingress_handler(struct sk_buff *skb, struct rmnet_port *port) { Loading Loading @@ -91,31 +90,27 @@ __rmnet_map_ingress_handler(struct sk_buff *skb, skb_pull(skb, sizeof(struct rmnet_map_header)); skb_trim(skb, len); rmnet_set_skb_proto(skb); return rmnet_deliver_skb(skb); rmnet_deliver_skb(skb); return; free_skb: kfree_skb(skb); return RX_HANDLER_CONSUMED; } static rx_handler_result_t static void rmnet_map_ingress_handler(struct sk_buff *skb, struct rmnet_port *port) { struct sk_buff *skbn; int rc; if (port->ingress_data_format & RMNET_INGRESS_FORMAT_DEAGGREGATION) { while ((skbn = rmnet_map_deaggregate(skb)) != NULL) __rmnet_map_ingress_handler(skbn, port); consume_skb(skb); rc = RX_HANDLER_CONSUMED; } else { rc = __rmnet_map_ingress_handler(skb, port); __rmnet_map_ingress_handler(skb, port); } return rc; } static int rmnet_map_egress_handler(struct sk_buff *skb, Loading Loading @@ -149,15 +144,13 @@ static int rmnet_map_egress_handler(struct sk_buff *skb, return RMNET_MAP_SUCCESS; } static rx_handler_result_t static void rmnet_bridge_handler(struct sk_buff *skb, struct net_device *bridge_dev) { if (bridge_dev) { skb->dev = bridge_dev; dev_queue_xmit(skb); } return RX_HANDLER_CONSUMED; } /* Ingress / Egress Entry Points */ Loading @@ -168,13 +161,12 @@ rmnet_bridge_handler(struct sk_buff *skb, struct net_device *bridge_dev) */ rx_handler_result_t rmnet_rx_handler(struct sk_buff **pskb) { int rc = RX_HANDLER_CONSUMED; struct sk_buff *skb = *pskb; struct rmnet_port *port; struct net_device *dev; if (!skb) return RX_HANDLER_CONSUMED; goto done; dev = skb->dev; port = rmnet_get_port(dev); Loading @@ -182,14 +174,15 @@ rx_handler_result_t rmnet_rx_handler(struct sk_buff **pskb) switch (port->rmnet_mode) { case RMNET_EPMODE_VND: if (port->ingress_data_format & RMNET_INGRESS_FORMAT_MAP) rc = rmnet_map_ingress_handler(skb, port); rmnet_map_ingress_handler(skb, port); break; case RMNET_EPMODE_BRIDGE: rc = rmnet_bridge_handler(skb, port->bridge_ep); rmnet_bridge_handler(skb, port->bridge_ep); break; } return rc; done: return RX_HANDLER_CONSUMED; } /* Modifies packet as per logical endpoint configuration and egress data format Loading
drivers/net/ethernet/qualcomm/rmnet/rmnet_map.h +1 −2 Original line number Diff line number Diff line Loading @@ -80,7 +80,6 @@ u8 rmnet_map_demultiplex(struct sk_buff *skb); struct sk_buff *rmnet_map_deaggregate(struct sk_buff *skb); struct rmnet_map_header *rmnet_map_add_map_header(struct sk_buff *skb, int hdrlen, int pad); rx_handler_result_t rmnet_map_command(struct sk_buff *skb, struct rmnet_port *port); void rmnet_map_command(struct sk_buff *skb, struct rmnet_port *port); #endif /* _RMNET_MAP_H_ */
drivers/net/ethernet/qualcomm/rmnet/rmnet_map_command.c +1 −3 Original line number Diff line number Diff line Loading @@ -76,8 +76,7 @@ static void rmnet_map_send_ack(struct sk_buff *skb, /* Process MAP command frame and send N/ACK message as appropriate. Message cmd * name is decoded here and appropriate handler is called. */ rx_handler_result_t rmnet_map_command(struct sk_buff *skb, struct rmnet_port *port) void rmnet_map_command(struct sk_buff *skb, struct rmnet_port *port) { struct rmnet_map_control_command *cmd; unsigned char command_name; Loading @@ -102,5 +101,4 @@ rx_handler_result_t rmnet_map_command(struct sk_buff *skb, } if (rc == RMNET_MAP_COMMAND_ACK) rmnet_map_send_ack(skb, rc); return RX_HANDLER_CONSUMED; }