You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
kernel_samsung_sm7125/drivers/net/ethernet/aquantia/atlantic-fwd/atl_trace.h

275 lines
8.6 KiB

/* SPDX-License-Identifier: GPL-2.0-only */
/* Atlantic Network Driver
atlantic-forwarding driver v1.0.15 Signed-off-by: Vadim Solomin <vadim.solomin@aquantia.com> Signed-off-by: Dmitry Bogdanov <dmitry.bogdanov@aquantia.com> Signed-off-by: Igor Russkikh <igor.russkikh@aquantia.com> commit 867cda83973229f68560723c9972905c589856c4 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Tue Dec 4 01:57:51 2018 +0300 Version 1.0.15 commit 52c23fa41ef5f8f5667b454e8361a55322e3108a Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Tue Dec 4 00:38:45 2018 +0300 Implement ethtool control for stripping Rx ethernet frame's padding Padding stripping only supported for frame formats with explicit length field commit 6154d236021bfbe14e9c129456e5d5e585a2ba0b Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Tue Dec 4 01:48:47 2018 +0300 Report ring's and buffer's physical addresses on ring request commit 03002d61a96b2640684cfacefedc10e2d80afccd Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Fri Nov 23 02:56:02 2018 +0300 Implement PHY temperature sensor commit 02ed2019bebdf5d0347185d5022022c44c11dec8 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Fri Nov 23 01:42:47 2018 +0300 Introduce a FW mutex, handle link interrupts in a workqueue commit e8552ade0ab5d58cbc6c503fda92e3ed499b5615 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Mon Dec 3 23:39:42 2018 +0300 Implement interrupt moderation for offload engine's rings commit 49e7698a420eb3aa32e9aa3a15879f07e6cf71cf Author: Dmitry Bogdanov <dmitry.bogdanov@aquantia.com> Date: Mon Sep 10 16:28:24 2018 +0300 Reset statistics via private flag HW counters are reported as a diff from the value at the last reset. commit 7f4f3461aa71fbe79455f2727274320ac5aa46c3 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Fri Nov 16 22:51:41 2018 +0300 Version 1.0.14 commit 67002520027178ef697b0ae322fc2b502d9cdd38 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Tue Nov 13 22:48:08 2018 +0300 Implement WoL support commit f67632663eeae770f7205ec1377f6b2010479b5c Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Fri Nov 16 22:18:46 2018 +0300 Implement Linux PM support commit de8bd72e1d32818286d9915c4f4d0a67af6545d6 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Wed Nov 7 21:46:45 2018 +0300 Change the driver name to reflect the new module name commit f4c8a7f4bbffa19abbec706b9d0beb6450a87816 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Wed Nov 7 21:36:46 2018 +0300 Fix forwarding engine interface * Zero-init struct atl_nic on alloc (shouldn't be necessary) * Fix event index initialization in atl_fwd_request_event() commit 8ee73a3cd4fa0d0a8384561dbf941fab074bf08a Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Mon Oct 29 14:40:54 2018 +0300 Version 1.0.13 commit 1d5da44aa59bc94073e5ad8a33738953eb98ac6a Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Mon Oct 29 13:33:39 2018 +0300 Integrate Linux VLAN filter hw acceleration with ethtool filters commit dd353ed40f38958de96f0b9f8c2b95dbcc4a8b0e Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Thu Oct 18 21:21:07 2018 +0300 Version 1.0.12 commit 7155f12f35cfb5fea62ce08c851a8a20a141f75d Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Thu Oct 18 20:02:50 2018 +0300 Expose PHY LPI state via ethtool private flags commit feacf926415da1af62265c8cf33afe1aae48c931 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Fri Oct 12 23:57:04 2018 +0300 Version 1.0.11 commit 64c211cc173e23609f55f210d1220b20bd2c6e57 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Thu Oct 11 00:34:18 2018 +0300 Add ethtool private flags tracking LPI state commit 8e914fc4e863af0b22623be1e7efe86fe3d91927 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Tue Oct 9 00:24:07 2018 +0300 Move HW init to PCI probe time commit b7d1836255a54834bd700a04c9b11989b75fd760 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Mon Oct 8 19:51:50 2018 +0300 Add more Felicity PCI IDsc Fixes ATLDRV-531 commit 67e24851c128c9867a9cbe1c18d0535e5311212c Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Wed Oct 3 23:13:05 2018 +0300 Fix build errors * Misc build errors * Drop compat stub for eth_platform_get_mac_address() as apparently it had been cherry-picked into Ubuntu's 4.4 kernel commit b355acb274010606e01714d0b12d15ea89650f2f Author: Dmitry Bogdanov <dmitry.bogdanov@aquantia.com> Date: Tue Sep 18 17:08:29 2018 +0300 Add Host and Lost counters to statistics Add Host Packet Counter and Lost Packet Counter from RX Filter block to the statistics in 'ethtool -S' commit 6ae04f2d2bd3ceb8f29af550b6c03dd34019198c Author: Dmitry Bogdanov <dmitry.bogdanov@aquantia.com> Date: Tue Sep 18 12:47:05 2018 +0300 Add some HW counters from RMON MIB Add the following counters from RMON MIB: etherStatsDropEvents, etherStatsPkts, etherStatsOctets,etherStatsBroadcastPkts, etherStatsMulticastPkts, etherStatsCRCAlignErrors commit 04ed8bcc26ec2762231c2c564109b5493771bd29 Author: Dmitry Bogdanov <dmitry.bogdanov@aquantia.com> Date: Fri Sep 14 12:46:38 2018 +0300 Fix advertizing EEE linkk modes and show LPI timer (AQ016) Advertize all supported EEE link modes if none is requested upon turning EEE on. Show Tx LPI Timer in ethtool output. commit 1b0ade8a1d53aeaabc1395e403a1370afbc6066a Author: Dmitry Bogdanov <dmitry.bogdanov@aquantia.com> Date: Wed Sep 19 15:27:14 2018 +0300 Turn on/off Rx XOFF flow control when needed (AQ021) Firmware does not set rx0_xoff_en (0x5714.1F register) and RPB continues sending Pause frames even when flow control is turned off. This fix turns on/off Rx XOFF flow control according to negotiated flow control settings. commit 6d51e89a7e2c980c76da4b1f38e5a6a97550fa30 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Wed Sep 26 23:41:41 2018 +0300 Minor IPA interface fixes * Remove a check obsoleted by folding the buffer page array into struct atl_fwd_bufs. * Move atl_msix_bar() from atl_compat.c to atl_fwd.c commit 788f4f99fc390e6abbc6c7161bf4ba70ed86ec61 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Wed Sep 26 00:42:07 2018 +0300 Version 1.0.10 commit ac838ac2b776e8a2a9eb4b15100f3674dc5a0e2c Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Wed Sep 26 00:39:51 2018 +0300 Initial offload engine iface implementation. commit 0f1295e2f9c8d42913a6274473ef06181bd0b9d4 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Tue Sep 11 21:59:56 2018 +0300 Initial offload engine iface API commit bb8e9568c67f90e3d758b98ffdd613a50582c9c1 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Tue Sep 11 22:04:21 2018 +0300 Fix tx-lpi handling in ethtool --set-eee Makes tx-lpi enable follow the eee enable setting. commit 0f72ac36bfe8441f052ced4a345648e3d0477f63 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Fri Sep 7 19:21:40 2018 +0300 Make atl_module_init() / _exit() available for future use commit 0c64854442d0684901df2a818d2e1e1a019c0024 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Thu Sep 6 23:27:45 2018 +0300 Version 1.0.9 commit 1772f185d796510a97d976d8e1d5286eae1ac503 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Thu Sep 6 23:24:21 2018 +0300 Add AQC100 / -111 / -112 IDs commit a2fa151fbc795e3f008c3cd6fb3a0d8038b05b4e Author: Dmitry Bogdanov <dmitry.bogdanov@aquantia.com> Date: Wed Sep 5 19:44:27 2018 +0300 Fix adding vlan with vlan id > 64 (AQ013) Wrong length (in longs instead of in bits) of the vlan bit array is used for looking the set bit there. commit ebd6a3f876e7de40962c53dbccd2d644dd2dbcf8 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Thu Sep 6 20:17:32 2018 +0300 Fix ethtool IPv4 filter reporting (AQ022) commit 3f6d20b3dd662d094dcd8e780fc73b670a09691a Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Thu Aug 30 20:05:46 2018 +0300 Implement ethtool interface for ethertype filters. commit 469740b8cb8a2531385b4f96be86880a3d610e6d Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Thu Sep 6 21:43:57 2018 +0300 Restore backward compat for Linux 4.4 commit dd0ef0a364d3522f7b18de98aedee77058fe36f2 Author: Dmitry Bogdanov <dmitry.bogdanov@aquantia.com> Date: Mon Aug 13 17:59:40 2018 +0300 net: aquantia: atlantic-forwarding driver for Qualcomm Signed-off-by: Dmitry Bogdanov <dmitry.bogdanov@aquantia.com> Signed-off-by: Igor Russkikh <igor.russkikh@aquantia.com> Co-authored-by: Vadim Solomin <vadim.solomin@aquantia.com> CRs-Fixed: 2309519 Change-Id: I1b302f54c00e9b3bf936eddec5e816d93cfe9772 Git-commit: abd3119fadbecba1de363c75aaaf958ec99dd2b9 Git-repo: https://github.com/aquantia/linux-4.14-atlantic-forwarding Signed-off-by: Jinesh K. Jayakumar <jineshk@codeaurora.org>
6 years ago
*
* Copyright (C) 2017 aQuantia Corporation
* Copyright (C) 2019-2020 Marvell International Ltd.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation.
atlantic-forwarding driver v1.0.15 Signed-off-by: Vadim Solomin <vadim.solomin@aquantia.com> Signed-off-by: Dmitry Bogdanov <dmitry.bogdanov@aquantia.com> Signed-off-by: Igor Russkikh <igor.russkikh@aquantia.com> commit 867cda83973229f68560723c9972905c589856c4 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Tue Dec 4 01:57:51 2018 +0300 Version 1.0.15 commit 52c23fa41ef5f8f5667b454e8361a55322e3108a Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Tue Dec 4 00:38:45 2018 +0300 Implement ethtool control for stripping Rx ethernet frame's padding Padding stripping only supported for frame formats with explicit length field commit 6154d236021bfbe14e9c129456e5d5e585a2ba0b Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Tue Dec 4 01:48:47 2018 +0300 Report ring's and buffer's physical addresses on ring request commit 03002d61a96b2640684cfacefedc10e2d80afccd Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Fri Nov 23 02:56:02 2018 +0300 Implement PHY temperature sensor commit 02ed2019bebdf5d0347185d5022022c44c11dec8 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Fri Nov 23 01:42:47 2018 +0300 Introduce a FW mutex, handle link interrupts in a workqueue commit e8552ade0ab5d58cbc6c503fda92e3ed499b5615 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Mon Dec 3 23:39:42 2018 +0300 Implement interrupt moderation for offload engine's rings commit 49e7698a420eb3aa32e9aa3a15879f07e6cf71cf Author: Dmitry Bogdanov <dmitry.bogdanov@aquantia.com> Date: Mon Sep 10 16:28:24 2018 +0300 Reset statistics via private flag HW counters are reported as a diff from the value at the last reset. commit 7f4f3461aa71fbe79455f2727274320ac5aa46c3 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Fri Nov 16 22:51:41 2018 +0300 Version 1.0.14 commit 67002520027178ef697b0ae322fc2b502d9cdd38 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Tue Nov 13 22:48:08 2018 +0300 Implement WoL support commit f67632663eeae770f7205ec1377f6b2010479b5c Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Fri Nov 16 22:18:46 2018 +0300 Implement Linux PM support commit de8bd72e1d32818286d9915c4f4d0a67af6545d6 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Wed Nov 7 21:46:45 2018 +0300 Change the driver name to reflect the new module name commit f4c8a7f4bbffa19abbec706b9d0beb6450a87816 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Wed Nov 7 21:36:46 2018 +0300 Fix forwarding engine interface * Zero-init struct atl_nic on alloc (shouldn't be necessary) * Fix event index initialization in atl_fwd_request_event() commit 8ee73a3cd4fa0d0a8384561dbf941fab074bf08a Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Mon Oct 29 14:40:54 2018 +0300 Version 1.0.13 commit 1d5da44aa59bc94073e5ad8a33738953eb98ac6a Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Mon Oct 29 13:33:39 2018 +0300 Integrate Linux VLAN filter hw acceleration with ethtool filters commit dd353ed40f38958de96f0b9f8c2b95dbcc4a8b0e Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Thu Oct 18 21:21:07 2018 +0300 Version 1.0.12 commit 7155f12f35cfb5fea62ce08c851a8a20a141f75d Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Thu Oct 18 20:02:50 2018 +0300 Expose PHY LPI state via ethtool private flags commit feacf926415da1af62265c8cf33afe1aae48c931 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Fri Oct 12 23:57:04 2018 +0300 Version 1.0.11 commit 64c211cc173e23609f55f210d1220b20bd2c6e57 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Thu Oct 11 00:34:18 2018 +0300 Add ethtool private flags tracking LPI state commit 8e914fc4e863af0b22623be1e7efe86fe3d91927 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Tue Oct 9 00:24:07 2018 +0300 Move HW init to PCI probe time commit b7d1836255a54834bd700a04c9b11989b75fd760 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Mon Oct 8 19:51:50 2018 +0300 Add more Felicity PCI IDsc Fixes ATLDRV-531 commit 67e24851c128c9867a9cbe1c18d0535e5311212c Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Wed Oct 3 23:13:05 2018 +0300 Fix build errors * Misc build errors * Drop compat stub for eth_platform_get_mac_address() as apparently it had been cherry-picked into Ubuntu's 4.4 kernel commit b355acb274010606e01714d0b12d15ea89650f2f Author: Dmitry Bogdanov <dmitry.bogdanov@aquantia.com> Date: Tue Sep 18 17:08:29 2018 +0300 Add Host and Lost counters to statistics Add Host Packet Counter and Lost Packet Counter from RX Filter block to the statistics in 'ethtool -S' commit 6ae04f2d2bd3ceb8f29af550b6c03dd34019198c Author: Dmitry Bogdanov <dmitry.bogdanov@aquantia.com> Date: Tue Sep 18 12:47:05 2018 +0300 Add some HW counters from RMON MIB Add the following counters from RMON MIB: etherStatsDropEvents, etherStatsPkts, etherStatsOctets,etherStatsBroadcastPkts, etherStatsMulticastPkts, etherStatsCRCAlignErrors commit 04ed8bcc26ec2762231c2c564109b5493771bd29 Author: Dmitry Bogdanov <dmitry.bogdanov@aquantia.com> Date: Fri Sep 14 12:46:38 2018 +0300 Fix advertizing EEE linkk modes and show LPI timer (AQ016) Advertize all supported EEE link modes if none is requested upon turning EEE on. Show Tx LPI Timer in ethtool output. commit 1b0ade8a1d53aeaabc1395e403a1370afbc6066a Author: Dmitry Bogdanov <dmitry.bogdanov@aquantia.com> Date: Wed Sep 19 15:27:14 2018 +0300 Turn on/off Rx XOFF flow control when needed (AQ021) Firmware does not set rx0_xoff_en (0x5714.1F register) and RPB continues sending Pause frames even when flow control is turned off. This fix turns on/off Rx XOFF flow control according to negotiated flow control settings. commit 6d51e89a7e2c980c76da4b1f38e5a6a97550fa30 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Wed Sep 26 23:41:41 2018 +0300 Minor IPA interface fixes * Remove a check obsoleted by folding the buffer page array into struct atl_fwd_bufs. * Move atl_msix_bar() from atl_compat.c to atl_fwd.c commit 788f4f99fc390e6abbc6c7161bf4ba70ed86ec61 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Wed Sep 26 00:42:07 2018 +0300 Version 1.0.10 commit ac838ac2b776e8a2a9eb4b15100f3674dc5a0e2c Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Wed Sep 26 00:39:51 2018 +0300 Initial offload engine iface implementation. commit 0f1295e2f9c8d42913a6274473ef06181bd0b9d4 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Tue Sep 11 21:59:56 2018 +0300 Initial offload engine iface API commit bb8e9568c67f90e3d758b98ffdd613a50582c9c1 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Tue Sep 11 22:04:21 2018 +0300 Fix tx-lpi handling in ethtool --set-eee Makes tx-lpi enable follow the eee enable setting. commit 0f72ac36bfe8441f052ced4a345648e3d0477f63 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Fri Sep 7 19:21:40 2018 +0300 Make atl_module_init() / _exit() available for future use commit 0c64854442d0684901df2a818d2e1e1a019c0024 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Thu Sep 6 23:27:45 2018 +0300 Version 1.0.9 commit 1772f185d796510a97d976d8e1d5286eae1ac503 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Thu Sep 6 23:24:21 2018 +0300 Add AQC100 / -111 / -112 IDs commit a2fa151fbc795e3f008c3cd6fb3a0d8038b05b4e Author: Dmitry Bogdanov <dmitry.bogdanov@aquantia.com> Date: Wed Sep 5 19:44:27 2018 +0300 Fix adding vlan with vlan id > 64 (AQ013) Wrong length (in longs instead of in bits) of the vlan bit array is used for looking the set bit there. commit ebd6a3f876e7de40962c53dbccd2d644dd2dbcf8 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Thu Sep 6 20:17:32 2018 +0300 Fix ethtool IPv4 filter reporting (AQ022) commit 3f6d20b3dd662d094dcd8e780fc73b670a09691a Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Thu Aug 30 20:05:46 2018 +0300 Implement ethtool interface for ethertype filters. commit 469740b8cb8a2531385b4f96be86880a3d610e6d Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Thu Sep 6 21:43:57 2018 +0300 Restore backward compat for Linux 4.4 commit dd0ef0a364d3522f7b18de98aedee77058fe36f2 Author: Dmitry Bogdanov <dmitry.bogdanov@aquantia.com> Date: Mon Aug 13 17:59:40 2018 +0300 net: aquantia: atlantic-forwarding driver for Qualcomm Signed-off-by: Dmitry Bogdanov <dmitry.bogdanov@aquantia.com> Signed-off-by: Igor Russkikh <igor.russkikh@aquantia.com> Co-authored-by: Vadim Solomin <vadim.solomin@aquantia.com> CRs-Fixed: 2309519 Change-Id: I1b302f54c00e9b3bf936eddec5e816d93cfe9772 Git-commit: abd3119fadbecba1de363c75aaaf958ec99dd2b9 Git-repo: https://github.com/aquantia/linux-4.14-atlantic-forwarding Signed-off-by: Jinesh K. Jayakumar <jineshk@codeaurora.org>
6 years ago
*/
#undef TRACE_SYSTEM
#define TRACE_SYSTEM atlnew
#if !defined(_ATL_TRACE_H) || defined(TRACE_HEADER_MULTI_READ)
#define _ATL_TRACE_H
#include <linux/tracepoint.h>
#include "atl_desc.h"
DECLARE_EVENT_CLASS(atl_dma_map_class,
TP_PROTO(int frag_idx, int ring_idx, dma_addr_t daddr, size_t size, struct sk_buff *skb,
void *vaddr),
TP_ARGS(frag_idx, ring_idx, daddr, size, skb, vaddr),
TP_STRUCT__entry(
__field(int, frag_idx)
__field(int, ring_idx)
__field(dma_addr_t, daddr)
__field(size_t, size)
__field(struct sk_buff *, skb)
__field(void *, vaddr)
),
TP_fast_assign(
__entry->frag_idx = frag_idx;
__entry->ring_idx = ring_idx;
__entry->daddr = daddr;
__entry->size = size;
__entry->skb = skb;
__entry->vaddr = vaddr;
),
TP_printk("idx %d ring idx %d daddr %pad len %#zx skb %p vaddr %p",
__entry->frag_idx, __entry->ring_idx, &__entry->daddr,
__entry->size, __entry->skb, __entry->vaddr)
);
#define DEFINE_MAP_EVENT(name) \
DEFINE_EVENT(atl_dma_map_class, name, \
TP_PROTO(int frag_idx, int ring_idx, \
dma_addr_t daddr, size_t size, \
struct sk_buff *skb, void *vaddr), \
TP_ARGS(frag_idx, ring_idx, daddr, size, skb, vaddr))
DEFINE_MAP_EVENT(atl_dma_map_head);
DEFINE_MAP_EVENT(atl_dma_map_frag);
DEFINE_MAP_EVENT(atl_dma_map_rxbuf);
DECLARE_EVENT_CLASS(atl_dma_unmap_class,
TP_PROTO(int frag_idx, int ring_idx, dma_addr_t daddr, size_t size,
struct sk_buff *skb),
TP_ARGS(frag_idx, ring_idx, daddr, size, skb),
TP_STRUCT__entry(
__field(int, frag_idx)
__field(int, ring_idx)
__field(dma_addr_t, daddr)
__field(size_t, size)
__field(struct sk_buff *, skb)
),
TP_fast_assign(
__entry->frag_idx = frag_idx;
__entry->ring_idx = ring_idx;
__entry->daddr = daddr;
__entry->size = size;
__entry->skb = skb;
),
TP_printk("idx %d ring idx %d daddr %pad len %#zx skb %p",
__entry->frag_idx, __entry->ring_idx, &__entry->daddr,
__entry->size, __entry->skb)
);
#define DEFINE_UNMAP_EVENT(name) \
DEFINE_EVENT(atl_dma_unmap_class, name, \
TP_PROTO(int frag_idx, int ring_idx, dma_addr_t daddr, \
size_t size, struct sk_buff *skb), \
TP_ARGS(frag_idx, ring_idx, daddr, size, skb))
DEFINE_UNMAP_EVENT(atl_dma_unmap_head);
DEFINE_UNMAP_EVENT(atl_dma_unmap_frag);
DEFINE_UNMAP_EVENT(atl_dma_unmap_rxbuf);
TRACE_EVENT(atl_fill_rx_desc,
TP_PROTO(int ring_idx, struct atl_rx_desc *desc),
TP_ARGS(ring_idx, desc),
TP_STRUCT__entry(
__field(int, ring_idx)
__field(dma_addr_t, daddr)
__field(dma_addr_t, haddr)
),
TP_fast_assign(
__entry->ring_idx = ring_idx;
__entry->daddr = desc->daddr;
__entry->haddr = desc->haddr;
),
TP_printk("[%d] daddr %pad", __entry->ring_idx, &__entry->daddr)
);
TRACE_EVENT(atl_sync_rx_range,
TP_PROTO(int ring_idx, dma_addr_t daddr, unsigned long pg_off,
size_t size),
TP_ARGS(ring_idx, daddr, pg_off, size),
TP_STRUCT__entry(
__field(int, ring_idx)
__field(dma_addr_t, daddr)
__field(unsigned long, pg_off)
__field(size_t, size)
),
TP_fast_assign(
__entry->ring_idx = ring_idx;
__entry->daddr = daddr;
__entry->pg_off = pg_off;
__entry->size = size;
),
TP_printk("[%d] daddr %pad pg_off %#lx size %#zx", __entry->ring_idx,
&__entry->daddr, __entry->pg_off, __entry->size)
);
#define DESCR_FIELD(DESCR, BIT_BEGIN, BIT_END) \
((DESCR >> BIT_END) &\
(BIT_ULL(BIT_BEGIN - BIT_END + 1) - 1))
TRACE_EVENT(atl_rx_descr,
TP_PROTO(int ring_idx, unsigned int pointer, u64 *descr),
TP_ARGS(ring_idx, pointer, descr),
TP_STRUCT__entry(
__field(unsigned int, ring_idx)
__field(unsigned int, pointer)
__field(u8, dd)
__field(u8, eop)
__field(u8, rx_stat)
__field(u8, rx_estat)
__field(u8, rsc_cnt)
__field(u16, pkt_len)
__field(u16, next_desp)
__field(u16, vlan_tag)
__field(u8, rss_type)
__field(u8, pkt_type)
__field(u8, rsvd)
__field(u8, rx_cntl)
__field(u8, sph)
__field(u16, hdr_len)
__field(u32, rss_hash)
),
TP_fast_assign(
__entry->ring_idx = ring_idx;
__entry->pointer = pointer;
__entry->rss_hash = DESCR_FIELD(descr[0], 63, 32);
__entry->hdr_len = DESCR_FIELD(descr[0], 31, 22);
__entry->sph = DESCR_FIELD(descr[0], 21, 21);
__entry->rx_cntl = DESCR_FIELD(descr[0], 20, 19);
__entry->rsvd = DESCR_FIELD(descr[0], 18, 12);
__entry->pkt_type = DESCR_FIELD(descr[0], 11, 4);
__entry->rss_type = DESCR_FIELD(descr[0], 3, 0);
__entry->vlan_tag = DESCR_FIELD(descr[1], 63, 48);
__entry->next_desp = DESCR_FIELD(descr[1], 47, 32);
__entry->pkt_len = DESCR_FIELD(descr[1], 31, 16);
__entry->rsc_cnt = DESCR_FIELD(descr[1], 15, 12);
__entry->rx_estat = DESCR_FIELD(descr[1], 11, 6);
__entry->rx_stat = DESCR_FIELD(descr[1], 5, 2);
__entry->eop = DESCR_FIELD(descr[1], 1, 1);
__entry->dd = DESCR_FIELD(descr[1], 0, 0);
),
TP_printk("ring=%d descr=%u rss_hash=0x%x hdr_len=%u sph=%u rx_cntl=%u rsvd=0x%x pkt_type=%u rss_type=%u vlan_tag=%u next_desp=%u pkt_len=%u rsc_cnt=%u rx_estat=0x%x rx_stat=0x%x eop=%u dd=%u",
__entry->ring_idx, __entry->pointer, __entry->rss_hash,
__entry->hdr_len, __entry->sph, __entry->rx_cntl,
__entry->rsvd, __entry->pkt_type, __entry->rss_type,
__entry->vlan_tag, __entry->next_desp, __entry->pkt_len,
__entry->rsc_cnt, __entry->rx_estat, __entry->rx_stat,
__entry->eop, __entry->dd)
);
TRACE_EVENT(atl_tx_descr,
TP_PROTO(int ring_idx, unsigned int pointer, u64 *descr),
TP_ARGS(ring_idx, pointer, descr),
TP_STRUCT__entry(
__field(unsigned int, ring_idx)
__field(unsigned int, pointer)
/* Tx Descriptor */
__field(u64, data_buf_addr)
__field(u32, pay_len)
__field(u8, ct_en)
__field(u8, ct_idx)
__field(u16, rsvd2)
__field(u8, tx_cmd)
__field(u8, eop)
__field(u8, dd)
__field(u16, buf_len)
__field(u8, rsvd1)
__field(u8, des_typ)
),
TP_fast_assign(
__entry->ring_idx = ring_idx;
__entry->pointer = pointer;
__entry->data_buf_addr = descr[0];
__entry->pay_len = DESCR_FIELD(descr[1], 63, 46);
__entry->ct_en = DESCR_FIELD(descr[1], 45, 45);
__entry->ct_idx = DESCR_FIELD(descr[1], 44, 44);
__entry->rsvd2 = DESCR_FIELD(descr[1], 43, 30);
__entry->tx_cmd = DESCR_FIELD(descr[1], 29, 22);
__entry->eop = DESCR_FIELD(descr[1], 21, 21);
__entry->dd = DESCR_FIELD(descr[1], 20, 20);
__entry->buf_len = DESCR_FIELD(descr[1], 19, 4);
__entry->rsvd1 = DESCR_FIELD(descr[1], 3, 3);
__entry->des_typ = DESCR_FIELD(descr[1], 2, 0);
),
TP_printk("ring=%d descr=%u pay_len=%u ct_en=%u ct_idx=%u rsvd2=0x%x tx_cmd=0x%x eop=%u dd=%u buf_len=%u rsvd1=%u des_typ=0x%x",
__entry->ring_idx, __entry->pointer, __entry->pay_len,
__entry->ct_en, __entry->ct_idx, __entry->rsvd2,
__entry->tx_cmd, __entry->eop, __entry->dd, __entry->buf_len,
__entry->rsvd1, __entry->des_typ)
);
TRACE_EVENT(atl_tx_context_descr,
TP_PROTO(int ring_idx, unsigned int pointer, u64 *descr),
TP_ARGS(ring_idx, pointer, descr),
TP_STRUCT__entry(
__field(unsigned int, ring_idx)
__field(unsigned int, pointer)
/* Tx Context Descriptor */
__field(u8, out_len)
__field(u8, tun_len)
__field(u64, resvd3)
__field(u16, mss_len)
__field(u8, l4_len)
__field(u8, l3_len)
__field(u8, l2_len)
__field(u8, ct_cmd)
__field(u16, vlan_tag)
__field(u8, ct_idx)
__field(u8, des_typ)
),
TP_fast_assign(
__entry->ring_idx = ring_idx;
__entry->pointer = pointer;
__entry->out_len = DESCR_FIELD(descr[0], 63, 56);
__entry->tun_len = DESCR_FIELD(descr[0], 55, 48);
__entry->resvd3 = DESCR_FIELD(descr[0], 47, 0);
__entry->mss_len = DESCR_FIELD(descr[1], 63, 48);
__entry->l4_len = DESCR_FIELD(descr[1], 47, 40);
__entry->l3_len = DESCR_FIELD(descr[1], 39, 31);
__entry->l2_len = DESCR_FIELD(descr[1], 30, 24);
__entry->ct_cmd = DESCR_FIELD(descr[1], 23, 20);
__entry->vlan_tag = DESCR_FIELD(descr[1], 19, 4);
__entry->ct_idx = DESCR_FIELD(descr[1], 3, 3);
__entry->des_typ = DESCR_FIELD(descr[1], 2, 0);
),
TP_printk("ring=%d descr=%u out_len=%u tun_len=%u resvd3=%llu mss_len=%u l4_len=%u l3_len=%u l2_len=0x%x ct_cmd=%u vlan_tag=%u ct_idx=%u des_typ=0x%x",
__entry->ring_idx, __entry->pointer, __entry->out_len,
__entry->tun_len, __entry->resvd3, __entry->mss_len,
__entry->l4_len, __entry->l3_len, __entry->l2_len,
__entry->ct_cmd, __entry->vlan_tag, __entry->ct_idx,
__entry->des_typ)
);
atlantic-forwarding driver v1.0.15 Signed-off-by: Vadim Solomin <vadim.solomin@aquantia.com> Signed-off-by: Dmitry Bogdanov <dmitry.bogdanov@aquantia.com> Signed-off-by: Igor Russkikh <igor.russkikh@aquantia.com> commit 867cda83973229f68560723c9972905c589856c4 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Tue Dec 4 01:57:51 2018 +0300 Version 1.0.15 commit 52c23fa41ef5f8f5667b454e8361a55322e3108a Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Tue Dec 4 00:38:45 2018 +0300 Implement ethtool control for stripping Rx ethernet frame's padding Padding stripping only supported for frame formats with explicit length field commit 6154d236021bfbe14e9c129456e5d5e585a2ba0b Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Tue Dec 4 01:48:47 2018 +0300 Report ring's and buffer's physical addresses on ring request commit 03002d61a96b2640684cfacefedc10e2d80afccd Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Fri Nov 23 02:56:02 2018 +0300 Implement PHY temperature sensor commit 02ed2019bebdf5d0347185d5022022c44c11dec8 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Fri Nov 23 01:42:47 2018 +0300 Introduce a FW mutex, handle link interrupts in a workqueue commit e8552ade0ab5d58cbc6c503fda92e3ed499b5615 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Mon Dec 3 23:39:42 2018 +0300 Implement interrupt moderation for offload engine's rings commit 49e7698a420eb3aa32e9aa3a15879f07e6cf71cf Author: Dmitry Bogdanov <dmitry.bogdanov@aquantia.com> Date: Mon Sep 10 16:28:24 2018 +0300 Reset statistics via private flag HW counters are reported as a diff from the value at the last reset. commit 7f4f3461aa71fbe79455f2727274320ac5aa46c3 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Fri Nov 16 22:51:41 2018 +0300 Version 1.0.14 commit 67002520027178ef697b0ae322fc2b502d9cdd38 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Tue Nov 13 22:48:08 2018 +0300 Implement WoL support commit f67632663eeae770f7205ec1377f6b2010479b5c Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Fri Nov 16 22:18:46 2018 +0300 Implement Linux PM support commit de8bd72e1d32818286d9915c4f4d0a67af6545d6 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Wed Nov 7 21:46:45 2018 +0300 Change the driver name to reflect the new module name commit f4c8a7f4bbffa19abbec706b9d0beb6450a87816 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Wed Nov 7 21:36:46 2018 +0300 Fix forwarding engine interface * Zero-init struct atl_nic on alloc (shouldn't be necessary) * Fix event index initialization in atl_fwd_request_event() commit 8ee73a3cd4fa0d0a8384561dbf941fab074bf08a Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Mon Oct 29 14:40:54 2018 +0300 Version 1.0.13 commit 1d5da44aa59bc94073e5ad8a33738953eb98ac6a Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Mon Oct 29 13:33:39 2018 +0300 Integrate Linux VLAN filter hw acceleration with ethtool filters commit dd353ed40f38958de96f0b9f8c2b95dbcc4a8b0e Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Thu Oct 18 21:21:07 2018 +0300 Version 1.0.12 commit 7155f12f35cfb5fea62ce08c851a8a20a141f75d Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Thu Oct 18 20:02:50 2018 +0300 Expose PHY LPI state via ethtool private flags commit feacf926415da1af62265c8cf33afe1aae48c931 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Fri Oct 12 23:57:04 2018 +0300 Version 1.0.11 commit 64c211cc173e23609f55f210d1220b20bd2c6e57 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Thu Oct 11 00:34:18 2018 +0300 Add ethtool private flags tracking LPI state commit 8e914fc4e863af0b22623be1e7efe86fe3d91927 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Tue Oct 9 00:24:07 2018 +0300 Move HW init to PCI probe time commit b7d1836255a54834bd700a04c9b11989b75fd760 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Mon Oct 8 19:51:50 2018 +0300 Add more Felicity PCI IDsc Fixes ATLDRV-531 commit 67e24851c128c9867a9cbe1c18d0535e5311212c Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Wed Oct 3 23:13:05 2018 +0300 Fix build errors * Misc build errors * Drop compat stub for eth_platform_get_mac_address() as apparently it had been cherry-picked into Ubuntu's 4.4 kernel commit b355acb274010606e01714d0b12d15ea89650f2f Author: Dmitry Bogdanov <dmitry.bogdanov@aquantia.com> Date: Tue Sep 18 17:08:29 2018 +0300 Add Host and Lost counters to statistics Add Host Packet Counter and Lost Packet Counter from RX Filter block to the statistics in 'ethtool -S' commit 6ae04f2d2bd3ceb8f29af550b6c03dd34019198c Author: Dmitry Bogdanov <dmitry.bogdanov@aquantia.com> Date: Tue Sep 18 12:47:05 2018 +0300 Add some HW counters from RMON MIB Add the following counters from RMON MIB: etherStatsDropEvents, etherStatsPkts, etherStatsOctets,etherStatsBroadcastPkts, etherStatsMulticastPkts, etherStatsCRCAlignErrors commit 04ed8bcc26ec2762231c2c564109b5493771bd29 Author: Dmitry Bogdanov <dmitry.bogdanov@aquantia.com> Date: Fri Sep 14 12:46:38 2018 +0300 Fix advertizing EEE linkk modes and show LPI timer (AQ016) Advertize all supported EEE link modes if none is requested upon turning EEE on. Show Tx LPI Timer in ethtool output. commit 1b0ade8a1d53aeaabc1395e403a1370afbc6066a Author: Dmitry Bogdanov <dmitry.bogdanov@aquantia.com> Date: Wed Sep 19 15:27:14 2018 +0300 Turn on/off Rx XOFF flow control when needed (AQ021) Firmware does not set rx0_xoff_en (0x5714.1F register) and RPB continues sending Pause frames even when flow control is turned off. This fix turns on/off Rx XOFF flow control according to negotiated flow control settings. commit 6d51e89a7e2c980c76da4b1f38e5a6a97550fa30 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Wed Sep 26 23:41:41 2018 +0300 Minor IPA interface fixes * Remove a check obsoleted by folding the buffer page array into struct atl_fwd_bufs. * Move atl_msix_bar() from atl_compat.c to atl_fwd.c commit 788f4f99fc390e6abbc6c7161bf4ba70ed86ec61 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Wed Sep 26 00:42:07 2018 +0300 Version 1.0.10 commit ac838ac2b776e8a2a9eb4b15100f3674dc5a0e2c Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Wed Sep 26 00:39:51 2018 +0300 Initial offload engine iface implementation. commit 0f1295e2f9c8d42913a6274473ef06181bd0b9d4 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Tue Sep 11 21:59:56 2018 +0300 Initial offload engine iface API commit bb8e9568c67f90e3d758b98ffdd613a50582c9c1 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Tue Sep 11 22:04:21 2018 +0300 Fix tx-lpi handling in ethtool --set-eee Makes tx-lpi enable follow the eee enable setting. commit 0f72ac36bfe8441f052ced4a345648e3d0477f63 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Fri Sep 7 19:21:40 2018 +0300 Make atl_module_init() / _exit() available for future use commit 0c64854442d0684901df2a818d2e1e1a019c0024 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Thu Sep 6 23:27:45 2018 +0300 Version 1.0.9 commit 1772f185d796510a97d976d8e1d5286eae1ac503 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Thu Sep 6 23:24:21 2018 +0300 Add AQC100 / -111 / -112 IDs commit a2fa151fbc795e3f008c3cd6fb3a0d8038b05b4e Author: Dmitry Bogdanov <dmitry.bogdanov@aquantia.com> Date: Wed Sep 5 19:44:27 2018 +0300 Fix adding vlan with vlan id > 64 (AQ013) Wrong length (in longs instead of in bits) of the vlan bit array is used for looking the set bit there. commit ebd6a3f876e7de40962c53dbccd2d644dd2dbcf8 Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Thu Sep 6 20:17:32 2018 +0300 Fix ethtool IPv4 filter reporting (AQ022) commit 3f6d20b3dd662d094dcd8e780fc73b670a09691a Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Thu Aug 30 20:05:46 2018 +0300 Implement ethtool interface for ethertype filters. commit 469740b8cb8a2531385b4f96be86880a3d610e6d Author: Vadim Solomin <vadim.solomin@aquantia.com> Date: Thu Sep 6 21:43:57 2018 +0300 Restore backward compat for Linux 4.4 commit dd0ef0a364d3522f7b18de98aedee77058fe36f2 Author: Dmitry Bogdanov <dmitry.bogdanov@aquantia.com> Date: Mon Aug 13 17:59:40 2018 +0300 net: aquantia: atlantic-forwarding driver for Qualcomm Signed-off-by: Dmitry Bogdanov <dmitry.bogdanov@aquantia.com> Signed-off-by: Igor Russkikh <igor.russkikh@aquantia.com> Co-authored-by: Vadim Solomin <vadim.solomin@aquantia.com> CRs-Fixed: 2309519 Change-Id: I1b302f54c00e9b3bf936eddec5e816d93cfe9772 Git-commit: abd3119fadbecba1de363c75aaaf958ec99dd2b9 Git-repo: https://github.com/aquantia/linux-4.14-atlantic-forwarding Signed-off-by: Jinesh K. Jayakumar <jineshk@codeaurora.org>
6 years ago
#endif /* _ATL_TRACE_H */
#undef TRACE_INCLUDE_PATH
#define TRACE_INCLUDE_PATH .
#undef TRACE_INCLUDE_FILE
#define TRACE_INCLUDE_FILE atl_trace
#include <trace/define_trace.h>