xref: /freebsd/sys/contrib/dev/iwlwifi/mvm/rfi.c (revision d9836fb4b9380e2ed1c38455fb31a3832b452671)
1bfcc09ddSBjoern A. Zeeb // SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause
2bfcc09ddSBjoern A. Zeeb /*
3bfcc09ddSBjoern A. Zeeb  * Copyright (C) 2020 - 2021 Intel Corporation
4bfcc09ddSBjoern A. Zeeb  */
5bfcc09ddSBjoern A. Zeeb 
6bfcc09ddSBjoern A. Zeeb #include "mvm.h"
7bfcc09ddSBjoern A. Zeeb #include "fw/api/commands.h"
8bfcc09ddSBjoern A. Zeeb #include "fw/api/phy-ctxt.h"
9bfcc09ddSBjoern A. Zeeb 
10*d9836fb4SBjoern A. Zeeb /*
11bfcc09ddSBjoern A. Zeeb  * DDR needs frequency in units of 16.666MHz, so provide FW with the
12bfcc09ddSBjoern A. Zeeb  * frequency values in the adjusted format.
13bfcc09ddSBjoern A. Zeeb  */
14bfcc09ddSBjoern A. Zeeb static const struct iwl_rfi_lut_entry iwl_rfi_table[IWL_RFI_LUT_SIZE] = {
15*d9836fb4SBjoern A. Zeeb 	/* frequency 2667MHz */
16*d9836fb4SBjoern A. Zeeb 	{cpu_to_le16(160), {50, 58, 60, 62, 64, 52, 54, 56},
17*d9836fb4SBjoern A. Zeeb 	      {PHY_BAND_5, PHY_BAND_5, PHY_BAND_5, PHY_BAND_5, PHY_BAND_5,
18*d9836fb4SBjoern A. Zeeb 	       PHY_BAND_5, PHY_BAND_5, PHY_BAND_5,}},
19*d9836fb4SBjoern A. Zeeb 
20*d9836fb4SBjoern A. Zeeb 	/* frequency 2933MHz */
21*d9836fb4SBjoern A. Zeeb 	{cpu_to_le16(176), {149, 151, 153, 157, 159, 161, 165, 163, 167, 169,
22*d9836fb4SBjoern A. Zeeb 			    171, 173, 175},
23*d9836fb4SBjoern A. Zeeb 	      {PHY_BAND_5, PHY_BAND_5, PHY_BAND_5, PHY_BAND_5, PHY_BAND_5,
24*d9836fb4SBjoern A. Zeeb 	       PHY_BAND_5, PHY_BAND_5, PHY_BAND_5, PHY_BAND_5, PHY_BAND_5,
25*d9836fb4SBjoern A. Zeeb 	       PHY_BAND_5, PHY_BAND_5, PHY_BAND_5,}},
26*d9836fb4SBjoern A. Zeeb 
27*d9836fb4SBjoern A. Zeeb 	/* frequency 3200MHz */
28*d9836fb4SBjoern A. Zeeb 	{cpu_to_le16(192), {79, 81, 83, 85, 87, 89, 91, 93},
29*d9836fb4SBjoern A. Zeeb 	      {PHY_BAND_6, PHY_BAND_6, PHY_BAND_6, PHY_BAND_6, PHY_BAND_6,
30*d9836fb4SBjoern A. Zeeb 	       PHY_BAND_6, PHY_BAND_6, PHY_BAND_6,}},
31bfcc09ddSBjoern A. Zeeb 
32bfcc09ddSBjoern A. Zeeb 	/* frequency 3733MHz */
33*d9836fb4SBjoern A. Zeeb 	{cpu_to_le16(223), {114, 116, 118, 120, 122, 106, 110, 124, 126},
34*d9836fb4SBjoern A. Zeeb 	      {PHY_BAND_5, PHY_BAND_5, PHY_BAND_5, PHY_BAND_5, PHY_BAND_5,
35*d9836fb4SBjoern A. Zeeb 	       PHY_BAND_5, PHY_BAND_5, PHY_BAND_5, PHY_BAND_5,}},
36*d9836fb4SBjoern A. Zeeb 
37*d9836fb4SBjoern A. Zeeb 	/* frequency 4000MHz */
38*d9836fb4SBjoern A. Zeeb 	{cpu_to_le16(240), {114, 151, 155, 157, 159, 161, 165},
39*d9836fb4SBjoern A. Zeeb 	      {PHY_BAND_5, PHY_BAND_5, PHY_BAND_5, PHY_BAND_5, PHY_BAND_5,
40*d9836fb4SBjoern A. Zeeb 	       PHY_BAND_5, PHY_BAND_5,}},
41bfcc09ddSBjoern A. Zeeb 
42bfcc09ddSBjoern A. Zeeb 	/* frequency 4267MHz */
43bfcc09ddSBjoern A. Zeeb 	{cpu_to_le16(256), {79, 83, 85, 87, 89, 91, 93,},
44bfcc09ddSBjoern A. Zeeb 	       {PHY_BAND_6, PHY_BAND_6, PHY_BAND_6, PHY_BAND_6, PHY_BAND_6,
45bfcc09ddSBjoern A. Zeeb 		PHY_BAND_6, PHY_BAND_6,}},
46bfcc09ddSBjoern A. Zeeb 
47bfcc09ddSBjoern A. Zeeb 	/* frequency 4400MHz */
48bfcc09ddSBjoern A. Zeeb 	{cpu_to_le16(264), {111, 119, 123, 125, 129, 131, 133, 135, 143,},
49bfcc09ddSBjoern A. Zeeb 	      {PHY_BAND_6, PHY_BAND_6, PHY_BAND_6, PHY_BAND_6, PHY_BAND_6,
50bfcc09ddSBjoern A. Zeeb 	       PHY_BAND_6, PHY_BAND_6, PHY_BAND_6, PHY_BAND_6,}},
51bfcc09ddSBjoern A. Zeeb 
52bfcc09ddSBjoern A. Zeeb 	/* frequency 5200MHz */
53*d9836fb4SBjoern A. Zeeb 	{cpu_to_le16(312), {36, 38, 40, 42, 44, 46, 50,},
54*d9836fb4SBjoern A. Zeeb 	       {PHY_BAND_5, PHY_BAND_5, PHY_BAND_5, PHY_BAND_5, PHY_BAND_5,
55*d9836fb4SBjoern A. Zeeb 		PHY_BAND_5, PHY_BAND_5,}},
56*d9836fb4SBjoern A. Zeeb 
57*d9836fb4SBjoern A. Zeeb 	/* frequency 5600MHz */
58*d9836fb4SBjoern A. Zeeb 	{cpu_to_le16(336), {106, 110, 112, 114, 116, 118, 120, 122},
59*d9836fb4SBjoern A. Zeeb 	       {PHY_BAND_5, PHY_BAND_5, PHY_BAND_5, PHY_BAND_5, PHY_BAND_5,
60*d9836fb4SBjoern A. Zeeb 		PHY_BAND_5, PHY_BAND_5, PHY_BAND_5,}},
61bfcc09ddSBjoern A. Zeeb 
62bfcc09ddSBjoern A. Zeeb 	/* frequency 6000MHz */
63bfcc09ddSBjoern A. Zeeb 	{cpu_to_le16(360), {3, 5, 7, 9, 11, 13, 15,},
64bfcc09ddSBjoern A. Zeeb 	       {PHY_BAND_6, PHY_BAND_6, PHY_BAND_6, PHY_BAND_6, PHY_BAND_6,
65bfcc09ddSBjoern A. Zeeb 		PHY_BAND_6, PHY_BAND_6,}},
66bfcc09ddSBjoern A. Zeeb 
67bfcc09ddSBjoern A. Zeeb 	/* frequency 6400MHz */
68bfcc09ddSBjoern A. Zeeb 	{cpu_to_le16(384), {79, 83, 85, 87, 89, 91, 93,},
69bfcc09ddSBjoern A. Zeeb 	       {PHY_BAND_6, PHY_BAND_6, PHY_BAND_6, PHY_BAND_6, PHY_BAND_6,
70bfcc09ddSBjoern A. Zeeb 		PHY_BAND_6, PHY_BAND_6,}},
71bfcc09ddSBjoern A. Zeeb };
72bfcc09ddSBjoern A. Zeeb 
73bfcc09ddSBjoern A. Zeeb int iwl_rfi_send_config_cmd(struct iwl_mvm *mvm, struct iwl_rfi_lut_entry *rfi_table)
74bfcc09ddSBjoern A. Zeeb {
75bfcc09ddSBjoern A. Zeeb 	int ret;
76bfcc09ddSBjoern A. Zeeb 	struct iwl_rfi_config_cmd cmd;
77bfcc09ddSBjoern A. Zeeb 	struct iwl_host_cmd hcmd = {
78bfcc09ddSBjoern A. Zeeb 		.id = WIDE_ID(SYSTEM_GROUP, RFI_CONFIG_CMD),
79bfcc09ddSBjoern A. Zeeb 		.dataflags[0] = IWL_HCMD_DFL_DUP,
80bfcc09ddSBjoern A. Zeeb 		.data[0] = &cmd,
81bfcc09ddSBjoern A. Zeeb 		.len[0] = sizeof(cmd),
82bfcc09ddSBjoern A. Zeeb 	};
83bfcc09ddSBjoern A. Zeeb 
84bfcc09ddSBjoern A. Zeeb 	if (!fw_has_capa(&mvm->fw->ucode_capa, IWL_UCODE_TLV_CAPA_RFIM_SUPPORT))
85bfcc09ddSBjoern A. Zeeb 		return -EOPNOTSUPP;
86bfcc09ddSBjoern A. Zeeb 
87bfcc09ddSBjoern A. Zeeb 	lockdep_assert_held(&mvm->mutex);
88bfcc09ddSBjoern A. Zeeb 
89bfcc09ddSBjoern A. Zeeb 	/* in case no table is passed, use the default one */
90bfcc09ddSBjoern A. Zeeb 	if (!rfi_table) {
91bfcc09ddSBjoern A. Zeeb 		memcpy(cmd.table, iwl_rfi_table, sizeof(cmd.table));
92bfcc09ddSBjoern A. Zeeb 	} else {
93bfcc09ddSBjoern A. Zeeb 		memcpy(cmd.table, rfi_table, sizeof(cmd.table));
94bfcc09ddSBjoern A. Zeeb 		/* notify FW the table is not the default one */
95bfcc09ddSBjoern A. Zeeb 		cmd.oem = 1;
96bfcc09ddSBjoern A. Zeeb 	}
97bfcc09ddSBjoern A. Zeeb 
98bfcc09ddSBjoern A. Zeeb 	ret = iwl_mvm_send_cmd(mvm, &hcmd);
99bfcc09ddSBjoern A. Zeeb 
100bfcc09ddSBjoern A. Zeeb 	if (ret)
101bfcc09ddSBjoern A. Zeeb 		IWL_ERR(mvm, "Failed to send RFI config cmd %d\n", ret);
102bfcc09ddSBjoern A. Zeeb 
103bfcc09ddSBjoern A. Zeeb 	return ret;
104bfcc09ddSBjoern A. Zeeb }
105bfcc09ddSBjoern A. Zeeb 
106bfcc09ddSBjoern A. Zeeb struct iwl_rfi_freq_table_resp_cmd *iwl_rfi_get_freq_table(struct iwl_mvm *mvm)
107bfcc09ddSBjoern A. Zeeb {
108bfcc09ddSBjoern A. Zeeb 	struct iwl_rfi_freq_table_resp_cmd *resp;
109bfcc09ddSBjoern A. Zeeb 	int resp_size = sizeof(*resp);
110bfcc09ddSBjoern A. Zeeb 	int ret;
111bfcc09ddSBjoern A. Zeeb 	struct iwl_host_cmd cmd = {
112bfcc09ddSBjoern A. Zeeb 		.id = WIDE_ID(SYSTEM_GROUP, RFI_GET_FREQ_TABLE_CMD),
113bfcc09ddSBjoern A. Zeeb 		.flags = CMD_WANT_SKB,
114bfcc09ddSBjoern A. Zeeb 	};
115bfcc09ddSBjoern A. Zeeb 
116bfcc09ddSBjoern A. Zeeb 	if (!fw_has_capa(&mvm->fw->ucode_capa, IWL_UCODE_TLV_CAPA_RFIM_SUPPORT))
117bfcc09ddSBjoern A. Zeeb 		return ERR_PTR(-EOPNOTSUPP);
118bfcc09ddSBjoern A. Zeeb 
119bfcc09ddSBjoern A. Zeeb 	mutex_lock(&mvm->mutex);
120bfcc09ddSBjoern A. Zeeb 	ret = iwl_mvm_send_cmd(mvm, &cmd);
121bfcc09ddSBjoern A. Zeeb 	mutex_unlock(&mvm->mutex);
122bfcc09ddSBjoern A. Zeeb 	if (ret)
123bfcc09ddSBjoern A. Zeeb 		return ERR_PTR(ret);
124bfcc09ddSBjoern A. Zeeb 
125bfcc09ddSBjoern A. Zeeb 	if (WARN_ON_ONCE(iwl_rx_packet_payload_len(cmd.resp_pkt) != resp_size))
126bfcc09ddSBjoern A. Zeeb 		return ERR_PTR(-EIO);
127bfcc09ddSBjoern A. Zeeb 
128*d9836fb4SBjoern A. Zeeb 	resp = kmemdup(cmd.resp_pkt->data, resp_size, GFP_KERNEL);
129bfcc09ddSBjoern A. Zeeb 	if (!resp)
130bfcc09ddSBjoern A. Zeeb 		return ERR_PTR(-ENOMEM);
131bfcc09ddSBjoern A. Zeeb 
132bfcc09ddSBjoern A. Zeeb 	iwl_free_resp(&cmd);
133bfcc09ddSBjoern A. Zeeb 	return resp;
134bfcc09ddSBjoern A. Zeeb }
135*d9836fb4SBjoern A. Zeeb 
136*d9836fb4SBjoern A. Zeeb void iwl_rfi_deactivate_notif_handler(struct iwl_mvm *mvm,
137*d9836fb4SBjoern A. Zeeb 				      struct iwl_rx_cmd_buffer *rxb)
138*d9836fb4SBjoern A. Zeeb {
139*d9836fb4SBjoern A. Zeeb 	struct iwl_rx_packet *pkt = rxb_addr(rxb);
140*d9836fb4SBjoern A. Zeeb 	struct iwl_rfi_deactivate_notif *notif = (void *)pkt->data;
141*d9836fb4SBjoern A. Zeeb 
142*d9836fb4SBjoern A. Zeeb 	IWL_INFO(mvm, "RFIm is deactivated, reason = %d\n", notif->reason);
143*d9836fb4SBjoern A. Zeeb }
144