Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp459209pxf; Wed, 7 Apr 2021 03:59:16 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzmfIFx3Uhb0C0dWFH+ngL734UCe1spEb23RWYhBKJYW5nJe9LqMXhDZR10XNtDtChxGaMT X-Received: by 2002:a05:6402:1cc1:: with SMTP id ds1mr3566272edb.135.1617793156619; Wed, 07 Apr 2021 03:59:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1617793156; cv=none; d=google.com; s=arc-20160816; b=oX4grKy8g7Pz3aF5ScDZG9GmG+u5G39B8cSKhDynxXc8HGkb/5wRLEp0bIESkxY2zs NvcT1jYhkV2UsHybiTqzBwu8X4PnPJ/+z8k0c8Cwwh8eXb2S+iGU9i0cWFpyosroWv14 ZrQ1envt+r8K7OISYf7wDtqqIjFGl/n1n5LmIQdSDoL3TkNihuzhQ39GINJxJ2l5ZHWv UIiP4pVx6yrCHewcALU4SmE+cf4L1+KpykRP7GFRnRxiHJc4ibBNPIySUSSUdFjexsDD 87PbhkQrGMoe97cHezLcRyH9Lb5XDm4kSlDShfzHflQ7ybyq/buiDSev/G6Y88JUeH/K UqWQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=kCAf5d6xJqY5Q8zM1sPQ1qtqWFvTOznw7t/fkKxHwDg=; b=uhXhWyUkpd1GPcBC2WtoTsG0qW2SlyaJ4CL7auAnlQsqe95MjUvmWq3aEwRInwzs3B 6kwSjHZXjMVooMhZfoI3u+PZ6olbzwYe5XLKYv3Zy3WZG0uYWKMV6v2puw366m4fI2X6 s/CqflN4rJpOeJ/BM7cTBG0NcsqjYfkonlnCd9oyHu+cceQgNe4gCQK8SlzMEqStXfd7 QnTK03jp5ct5Gtg/zaIkzi/65GzRU70MCf0N595cOMGy4ARfAAIxBOoqIBWdyn4sc5cu 2DaC2SyEaazAJqnVL7Rep27/gsnIgOoJqn6cRcr4C04pKBh33abrddGvHEp/4TJEt+8R yqrw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=eraLe5d5; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id ga23si18329169ejc.129.2021.04.07.03.58.48; Wed, 07 Apr 2021 03:59:16 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=eraLe5d5; spf=pass (google.com: domain of linux-wireless-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-wireless-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S245525AbhDFUmS (ORCPT + 99 others); Tue, 6 Apr 2021 16:42:18 -0400 Received: from mail.kernel.org ([198.145.29.99]:37712 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235692AbhDFUmR (ORCPT ); Tue, 6 Apr 2021 16:42:17 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 7F4B4613D5; Tue, 6 Apr 2021 20:42:08 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1617741729; bh=x2IDkvYzPt7iRCYOSqejx+ek2TphX4rDcDIZfN48YeM=; h=From:To:Cc:Subject:Date:From; b=eraLe5d5MmbXTVwaaHzxZIY+0kJiS+Hq2iUIbIXkMCrhcKexy4lIqgThd+VeBr7Ty Ci6PaE7XqUzQp1CZcZXIHdsxhhj6NCFyThB37MWp9mmAnwr28KsC8S7eKn1R6z8ehZ jFMUCfBJLfjMQPsMe5fkaScMb2+jdo3bfeQXZC6IFe06Qoc2DJhNVn9MTihgsWvvtK NicsEi7DUT+kbaTEZEC32fVKebmRRFaTDHiQL/QKxGljEikcK4EDslF1dDsLn+hpiX GqW4BH4HtHZRJGb7lMa5ah39u96zluQL+3ufNuYyxq20GLn4AYLQtHQC7AZHc9rvUu ob0M/BQ/zxVJw== From: Lorenzo Bianconi To: nbd@nbd.name Cc: linux-wireless@vger.kernel.org, lorenzo.bianconi@redhat.com, sean.wang@mediatek.com Subject: [PATCH] mt76: mt7921: introduce MCU_EVENT_LP_INFO event parsing Date: Tue, 6 Apr 2021 22:41:53 +0200 Message-Id: X-Mailer: git-send-email 2.30.2 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org Report trace event related to MCU_EVENT_LP_INFO that is sent by the mcu when it is ready to enter in deep sleep state Signed-off-by: Lorenzo Bianconi --- .../wireless/mediatek/mt76/mt76_connac_mcu.h | 1 + .../wireless/mediatek/mt76/mt7921/Makefile | 4 +- .../net/wireless/mediatek/mt76/mt7921/mcu.c | 19 +++++++ .../mediatek/mt76/mt7921/mt7921_trace.h | 51 +++++++++++++++++++ .../net/wireless/mediatek/mt76/mt7921/trace.c | 12 +++++ 5 files changed, 86 insertions(+), 1 deletion(-) create mode 100644 drivers/net/wireless/mediatek/mt76/mt7921/mt7921_trace.h create mode 100644 drivers/net/wireless/mediatek/mt76/mt7921/trace.c diff --git a/drivers/net/wireless/mediatek/mt76/mt76_connac_mcu.h b/drivers/net/wireless/mediatek/mt76/mt76_connac_mcu.h index b209a76c1bac..d3c25f0984fd 100644 --- a/drivers/net/wireless/mediatek/mt76/mt76_connac_mcu.h +++ b/drivers/net/wireless/mediatek/mt76/mt76_connac_mcu.h @@ -572,6 +572,7 @@ enum { MCU_EVENT_ACCESS_REG = 0x02, MCU_EVENT_MT_PATCH_SEM = 0x04, MCU_EVENT_REG_ACCESS = 0x05, + MCU_EVENT_LP_INFO = 0x07, MCU_EVENT_SCAN_DONE = 0x0d, MCU_EVENT_ROC = 0x10, MCU_EVENT_BSS_ABSENCE = 0x11, diff --git a/drivers/net/wireless/mediatek/mt76/mt7921/Makefile b/drivers/net/wireless/mediatek/mt76/mt7921/Makefile index 09d1446ad933..e531666f9fb4 100644 --- a/drivers/net/wireless/mediatek/mt76/mt7921/Makefile +++ b/drivers/net/wireless/mediatek/mt76/mt7921/Makefile @@ -2,4 +2,6 @@ obj-$(CONFIG_MT7921E) += mt7921e.o -mt7921e-y := pci.o mac.o mcu.o dma.o eeprom.o main.o init.o debugfs.o +CFLAGS_trace.o := -I$(src) + +mt7921e-y := pci.o mac.o mcu.o dma.o eeprom.o main.o init.o debugfs.o trace.o diff --git a/drivers/net/wireless/mediatek/mt76/mt7921/mcu.c b/drivers/net/wireless/mediatek/mt76/mt7921/mcu.c index e44ce9bdfa9d..c8e24ffa3f03 100644 --- a/drivers/net/wireless/mediatek/mt76/mt7921/mcu.c +++ b/drivers/net/wireless/mediatek/mt76/mt7921/mcu.c @@ -4,6 +4,7 @@ #include #include #include "mt7921.h" +#include "mt7921_trace.h" #include "mcu.h" #include "mac.h" @@ -509,6 +510,20 @@ mt7921_mcu_debug_msg_event(struct mt7921_dev *dev, struct sk_buff *skb) } } +static void +mt7921_mcu_low_power_event(struct mt7921_dev *dev, struct sk_buff *skb) +{ + struct mt7921_mcu_lp_event { + u8 state; + u8 reserved[3]; + } __packed * event; + + skb_pull(skb, sizeof(struct mt7921_mcu_rxd)); + event = (struct mt7921_mcu_lp_event *)skb->data; + + trace_lp_event(dev, event->state); +} + static void mt7921_mcu_rx_unsolicited_event(struct mt7921_dev *dev, struct sk_buff *skb) { @@ -535,6 +550,9 @@ mt7921_mcu_rx_unsolicited_event(struct mt7921_dev *dev, struct sk_buff *skb) mt76_connac_mcu_coredump_event(&dev->mt76, skb, &dev->coredump); return; + case MCU_EVENT_LP_INFO: + mt7921_mcu_low_power_event(dev, skb); + break; default: break; } @@ -557,6 +575,7 @@ void mt7921_mcu_rx_event(struct mt7921_dev *dev, struct sk_buff *skb) rxd->eid == MCU_EVENT_SCAN_DONE || rxd->eid == MCU_EVENT_DBG_MSG || rxd->eid == MCU_EVENT_COREDUMP || + rxd->eid == MCU_EVENT_LP_INFO || rxd->eid == MCU_EVENT_ROC || !rxd->seq) mt7921_mcu_rx_unsolicited_event(dev, skb); diff --git a/drivers/net/wireless/mediatek/mt76/mt7921/mt7921_trace.h b/drivers/net/wireless/mediatek/mt76/mt7921/mt7921_trace.h new file mode 100644 index 000000000000..9bc4db67f352 --- /dev/null +++ b/drivers/net/wireless/mediatek/mt76/mt7921/mt7921_trace.h @@ -0,0 +1,51 @@ +/* SPDX-License-Identifier: ISC */ +/* + * Copyright (C) 2021 Lorenzo Bianconi + */ + +#if !defined(__MT7921_TRACE_H) || defined(TRACE_HEADER_MULTI_READ) +#define __MT7921_TRACE_H + +#include +#include "mt7921.h" + +#undef TRACE_SYSTEM +#define TRACE_SYSTEM mt7921 + +#define MAXNAME 32 +#define DEV_ENTRY __array(char, wiphy_name, 32) +#define DEV_ASSIGN strlcpy(__entry->wiphy_name, \ + wiphy_name(mt76_hw(dev)->wiphy), MAXNAME) +#define DEV_PR_FMT "%s" +#define DEV_PR_ARG __entry->wiphy_name +#define LP_STATE_PR_ARG __entry->lp_state ? "lp ready" : "lp not ready" + +TRACE_EVENT(lp_event, + TP_PROTO(struct mt7921_dev *dev, u8 lp_state), + + TP_ARGS(dev, lp_state), + + TP_STRUCT__entry( + DEV_ENTRY + __field(u8, lp_state) + ), + + TP_fast_assign( + DEV_ASSIGN; + __entry->lp_state = lp_state; + ), + + TP_printk( + DEV_PR_FMT " %s", + DEV_PR_ARG, LP_STATE_PR_ARG + ) +); + +#endif + +#undef TRACE_INCLUDE_PATH +#define TRACE_INCLUDE_PATH . +#undef TRACE_INCLUDE_FILE +#define TRACE_INCLUDE_FILE mt7921_trace + +#include diff --git a/drivers/net/wireless/mediatek/mt76/mt7921/trace.c b/drivers/net/wireless/mediatek/mt76/mt7921/trace.c new file mode 100644 index 000000000000..4dc3c7b89ebd --- /dev/null +++ b/drivers/net/wireless/mediatek/mt76/mt7921/trace.c @@ -0,0 +1,12 @@ +// SPDX-License-Identifier: ISC +/* + * Copyright (C) 2021 Lorenzo Bianconi + */ + +#include + +#ifndef __CHECKER__ +#define CREATE_TRACE_POINTS +#include "mt7921_trace.h" + +#endif -- 2.30.2