Linux Audio

Check our new training course

Loading...
v6.8
   1// SPDX-License-Identifier: BSD-3-Clause-Clear
   2/*
   3 * Copyright (c) 2019-2020 The Linux Foundation. All rights reserved.
   4 * Copyright (c) 2021-2023 Qualcomm Innovation Center, Inc. All rights reserved.
   5 */
   6
   7#include <linux/module.h>
   8#include <linux/msi.h>
   9#include <linux/pci.h>
  10#include <linux/of.h>
  11
  12#include "pci.h"
  13#include "core.h"
  14#include "hif.h"
  15#include "mhi.h"
  16#include "debug.h"
  17#include "pcic.h"
  18#include "qmi.h"
  19
  20#define ATH11K_PCI_BAR_NUM		0
  21#define ATH11K_PCI_DMA_MASK		32
  22
  23#define TCSR_SOC_HW_VERSION		0x0224
  24#define TCSR_SOC_HW_VERSION_MAJOR_MASK	GENMASK(11, 8)
  25#define TCSR_SOC_HW_VERSION_MINOR_MASK	GENMASK(7, 0)
  26
  27#define QCA6390_DEVICE_ID		0x1101
  28#define QCN9074_DEVICE_ID		0x1104
  29#define WCN6855_DEVICE_ID		0x1103
  30
  31static const struct pci_device_id ath11k_pci_id_table[] = {
  32	{ PCI_VDEVICE(QCOM, QCA6390_DEVICE_ID) },
  33	{ PCI_VDEVICE(QCOM, WCN6855_DEVICE_ID) },
  34	{ PCI_VDEVICE(QCOM, QCN9074_DEVICE_ID) },
  35	{0}
  36};
  37
  38MODULE_DEVICE_TABLE(pci, ath11k_pci_id_table);
  39
  40static int ath11k_pci_bus_wake_up(struct ath11k_base *ab)
  41{
  42	struct ath11k_pci *ab_pci = ath11k_pci_priv(ab);
  43
  44	return mhi_device_get_sync(ab_pci->mhi_ctrl->mhi_dev);
  45}
  46
  47static void ath11k_pci_bus_release(struct ath11k_base *ab)
  48{
  49	struct ath11k_pci *ab_pci = ath11k_pci_priv(ab);
  50
  51	mhi_device_put(ab_pci->mhi_ctrl->mhi_dev);
  52}
  53
  54static u32 ath11k_pci_get_window_start(struct ath11k_base *ab, u32 offset)
  55{
  56	if (!ab->hw_params.static_window_map)
  57		return ATH11K_PCI_WINDOW_START;
  58
  59	if ((offset ^ HAL_SEQ_WCSS_UMAC_OFFSET) < ATH11K_PCI_WINDOW_RANGE_MASK)
  60		/* if offset lies within DP register range, use 3rd window */
  61		return 3 * ATH11K_PCI_WINDOW_START;
  62	else if ((offset ^ HAL_SEQ_WCSS_UMAC_CE0_SRC_REG(ab)) <
  63		 ATH11K_PCI_WINDOW_RANGE_MASK)
  64		 /* if offset lies within CE register range, use 2nd window */
  65		return 2 * ATH11K_PCI_WINDOW_START;
  66	else
  67		return ATH11K_PCI_WINDOW_START;
  68}
  69
  70static inline void ath11k_pci_select_window(struct ath11k_pci *ab_pci, u32 offset)
  71{
  72	struct ath11k_base *ab = ab_pci->ab;
  73
  74	u32 window = FIELD_GET(ATH11K_PCI_WINDOW_VALUE_MASK, offset);
  75
  76	lockdep_assert_held(&ab_pci->window_lock);
  77
  78	if (window != ab_pci->register_window) {
  79		iowrite32(ATH11K_PCI_WINDOW_ENABLE_BIT | window,
  80			  ab->mem + ATH11K_PCI_WINDOW_REG_ADDRESS);
  81		ioread32(ab->mem + ATH11K_PCI_WINDOW_REG_ADDRESS);
  82		ab_pci->register_window = window;
  83	}
  84}
  85
  86static void
  87ath11k_pci_window_write32(struct ath11k_base *ab, u32 offset, u32 value)
  88{
  89	struct ath11k_pci *ab_pci = ath11k_pci_priv(ab);
  90	u32 window_start;
  91
  92	window_start = ath11k_pci_get_window_start(ab, offset);
  93
  94	if (window_start == ATH11K_PCI_WINDOW_START) {
  95		spin_lock_bh(&ab_pci->window_lock);
  96		ath11k_pci_select_window(ab_pci, offset);
  97		iowrite32(value, ab->mem + window_start +
  98			  (offset & ATH11K_PCI_WINDOW_RANGE_MASK));
  99		spin_unlock_bh(&ab_pci->window_lock);
 100	} else {
 101		iowrite32(value, ab->mem + window_start +
 102			  (offset & ATH11K_PCI_WINDOW_RANGE_MASK));
 103	}
 104}
 105
 106static u32 ath11k_pci_window_read32(struct ath11k_base *ab, u32 offset)
 107{
 108	struct ath11k_pci *ab_pci = ath11k_pci_priv(ab);
 109	u32 window_start, val;
 110
 111	window_start = ath11k_pci_get_window_start(ab, offset);
 112
 113	if (window_start == ATH11K_PCI_WINDOW_START) {
 114		spin_lock_bh(&ab_pci->window_lock);
 115		ath11k_pci_select_window(ab_pci, offset);
 116		val = ioread32(ab->mem + window_start +
 117			       (offset & ATH11K_PCI_WINDOW_RANGE_MASK));
 118		spin_unlock_bh(&ab_pci->window_lock);
 119	} else {
 120		val = ioread32(ab->mem + window_start +
 121			       (offset & ATH11K_PCI_WINDOW_RANGE_MASK));
 122	}
 123
 124	return val;
 125}
 126
 127int ath11k_pci_get_msi_irq(struct ath11k_base *ab, unsigned int vector)
 128{
 129	struct pci_dev *pci_dev = to_pci_dev(ab->dev);
 130
 131	return pci_irq_vector(pci_dev, vector);
 132}
 133
 134static const struct ath11k_pci_ops ath11k_pci_ops_qca6390 = {
 135	.wakeup = ath11k_pci_bus_wake_up,
 136	.release = ath11k_pci_bus_release,
 137	.get_msi_irq = ath11k_pci_get_msi_irq,
 138	.window_write32 = ath11k_pci_window_write32,
 139	.window_read32 = ath11k_pci_window_read32,
 140};
 141
 142static const struct ath11k_pci_ops ath11k_pci_ops_qcn9074 = {
 143	.wakeup = NULL,
 144	.release = NULL,
 145	.get_msi_irq = ath11k_pci_get_msi_irq,
 146	.window_write32 = ath11k_pci_window_write32,
 147	.window_read32 = ath11k_pci_window_read32,
 148};
 149
 150static const struct ath11k_msi_config msi_config_one_msi = {
 151	.total_vectors = 1,
 152	.total_users = 4,
 153	.users = (struct ath11k_msi_user[]) {
 154		{ .name = "MHI", .num_vectors = 3, .base_vector = 0 },
 155		{ .name = "CE", .num_vectors = 1, .base_vector = 0 },
 156		{ .name = "WAKE", .num_vectors = 1, .base_vector = 0 },
 157		{ .name = "DP", .num_vectors = 1, .base_vector = 0 },
 158	},
 159};
 160
 161static inline void ath11k_pci_select_static_window(struct ath11k_pci *ab_pci)
 162{
 163	u32 umac_window;
 164	u32 ce_window;
 165	u32 window;
 166
 167	umac_window = FIELD_GET(ATH11K_PCI_WINDOW_VALUE_MASK, HAL_SEQ_WCSS_UMAC_OFFSET);
 168	ce_window = FIELD_GET(ATH11K_PCI_WINDOW_VALUE_MASK, HAL_CE_WFSS_CE_REG_BASE);
 169	window = (umac_window << 12) | (ce_window << 6);
 170
 171	iowrite32(ATH11K_PCI_WINDOW_ENABLE_BIT | window,
 172		  ab_pci->ab->mem + ATH11K_PCI_WINDOW_REG_ADDRESS);
 173}
 174
 175static void ath11k_pci_soc_global_reset(struct ath11k_base *ab)
 176{
 177	u32 val, delay;
 178
 179	val = ath11k_pcic_read32(ab, PCIE_SOC_GLOBAL_RESET);
 180
 181	val |= PCIE_SOC_GLOBAL_RESET_V;
 182
 183	ath11k_pcic_write32(ab, PCIE_SOC_GLOBAL_RESET, val);
 184
 185	/* TODO: exact time to sleep is uncertain */
 186	delay = 10;
 187	mdelay(delay);
 188
 189	/* Need to toggle V bit back otherwise stuck in reset status */
 190	val &= ~PCIE_SOC_GLOBAL_RESET_V;
 191
 192	ath11k_pcic_write32(ab, PCIE_SOC_GLOBAL_RESET, val);
 193
 194	mdelay(delay);
 195
 196	val = ath11k_pcic_read32(ab, PCIE_SOC_GLOBAL_RESET);
 197	if (val == 0xffffffff)
 198		ath11k_warn(ab, "link down error during global reset\n");
 199}
 200
 201static void ath11k_pci_clear_dbg_registers(struct ath11k_base *ab)
 202{
 203	u32 val;
 204
 205	/* read cookie */
 206	val = ath11k_pcic_read32(ab, PCIE_Q6_COOKIE_ADDR);
 207	ath11k_dbg(ab, ATH11K_DBG_PCI, "pcie_q6_cookie_addr 0x%x\n", val);
 208
 209	val = ath11k_pcic_read32(ab, WLAON_WARM_SW_ENTRY);
 210	ath11k_dbg(ab, ATH11K_DBG_PCI, "wlaon_warm_sw_entry 0x%x\n", val);
 211
 212	/* TODO: exact time to sleep is uncertain */
 213	mdelay(10);
 214
 215	/* write 0 to WLAON_WARM_SW_ENTRY to prevent Q6 from
 216	 * continuing warm path and entering dead loop.
 217	 */
 218	ath11k_pcic_write32(ab, WLAON_WARM_SW_ENTRY, 0);
 219	mdelay(10);
 220
 221	val = ath11k_pcic_read32(ab, WLAON_WARM_SW_ENTRY);
 222	ath11k_dbg(ab, ATH11K_DBG_PCI, "wlaon_warm_sw_entry 0x%x\n", val);
 223
 224	/* A read clear register. clear the register to prevent
 225	 * Q6 from entering wrong code path.
 226	 */
 227	val = ath11k_pcic_read32(ab, WLAON_SOC_RESET_CAUSE_REG);
 228	ath11k_dbg(ab, ATH11K_DBG_PCI, "soc reset cause %d\n", val);
 229}
 230
 231static int ath11k_pci_set_link_reg(struct ath11k_base *ab,
 232				   u32 offset, u32 value, u32 mask)
 233{
 234	u32 v;
 235	int i;
 236
 237	v = ath11k_pcic_read32(ab, offset);
 238	if ((v & mask) == value)
 239		return 0;
 240
 241	for (i = 0; i < 10; i++) {
 242		ath11k_pcic_write32(ab, offset, (v & ~mask) | value);
 243
 244		v = ath11k_pcic_read32(ab, offset);
 245		if ((v & mask) == value)
 246			return 0;
 247
 248		mdelay(2);
 249	}
 250
 251	ath11k_warn(ab, "failed to set pcie link register 0x%08x: 0x%08x != 0x%08x\n",
 252		    offset, v & mask, value);
 253
 254	return -ETIMEDOUT;
 255}
 256
 257static int ath11k_pci_fix_l1ss(struct ath11k_base *ab)
 258{
 259	int ret;
 260
 261	ret = ath11k_pci_set_link_reg(ab,
 262				      PCIE_QSERDES_COM_SYSCLK_EN_SEL_REG(ab),
 263				      PCIE_QSERDES_COM_SYSCLK_EN_SEL_VAL,
 264				      PCIE_QSERDES_COM_SYSCLK_EN_SEL_MSK);
 265	if (ret) {
 266		ath11k_warn(ab, "failed to set sysclk: %d\n", ret);
 267		return ret;
 268	}
 269
 270	ret = ath11k_pci_set_link_reg(ab,
 271				      PCIE_PCS_OSC_DTCT_CONFIG1_REG(ab),
 272				      PCIE_PCS_OSC_DTCT_CONFIG1_VAL,
 273				      PCIE_PCS_OSC_DTCT_CONFIG_MSK);
 274	if (ret) {
 275		ath11k_warn(ab, "failed to set dtct config1 error: %d\n", ret);
 276		return ret;
 277	}
 278
 279	ret = ath11k_pci_set_link_reg(ab,
 280				      PCIE_PCS_OSC_DTCT_CONFIG2_REG(ab),
 281				      PCIE_PCS_OSC_DTCT_CONFIG2_VAL,
 282				      PCIE_PCS_OSC_DTCT_CONFIG_MSK);
 283	if (ret) {
 284		ath11k_warn(ab, "failed to set dtct config2: %d\n", ret);
 285		return ret;
 286	}
 287
 288	ret = ath11k_pci_set_link_reg(ab,
 289				      PCIE_PCS_OSC_DTCT_CONFIG4_REG(ab),
 290				      PCIE_PCS_OSC_DTCT_CONFIG4_VAL,
 291				      PCIE_PCS_OSC_DTCT_CONFIG_MSK);
 292	if (ret) {
 293		ath11k_warn(ab, "failed to set dtct config4: %d\n", ret);
 294		return ret;
 295	}
 296
 297	return 0;
 298}
 299
 300static void ath11k_pci_enable_ltssm(struct ath11k_base *ab)
 301{
 302	u32 val;
 303	int i;
 304
 305	val = ath11k_pcic_read32(ab, PCIE_PCIE_PARF_LTSSM);
 306
 307	/* PCIE link seems very unstable after the Hot Reset*/
 308	for (i = 0; val != PARM_LTSSM_VALUE && i < 5; i++) {
 309		if (val == 0xffffffff)
 310			mdelay(5);
 311
 312		ath11k_pcic_write32(ab, PCIE_PCIE_PARF_LTSSM, PARM_LTSSM_VALUE);
 313		val = ath11k_pcic_read32(ab, PCIE_PCIE_PARF_LTSSM);
 314	}
 315
 316	ath11k_dbg(ab, ATH11K_DBG_PCI, "ltssm 0x%x\n", val);
 317
 318	val = ath11k_pcic_read32(ab, GCC_GCC_PCIE_HOT_RST);
 319	val |= GCC_GCC_PCIE_HOT_RST_VAL;
 320	ath11k_pcic_write32(ab, GCC_GCC_PCIE_HOT_RST, val);
 321	val = ath11k_pcic_read32(ab, GCC_GCC_PCIE_HOT_RST);
 322
 323	ath11k_dbg(ab, ATH11K_DBG_PCI, "pcie_hot_rst 0x%x\n", val);
 324
 325	mdelay(5);
 326}
 327
 328static void ath11k_pci_clear_all_intrs(struct ath11k_base *ab)
 329{
 330	/* This is a WAR for PCIE Hotreset.
 331	 * When target receive Hotreset, but will set the interrupt.
 332	 * So when download SBL again, SBL will open Interrupt and
 333	 * receive it, and crash immediately.
 334	 */
 335	ath11k_pcic_write32(ab, PCIE_PCIE_INT_ALL_CLEAR, PCIE_INT_CLEAR_ALL);
 336}
 337
 338static void ath11k_pci_set_wlaon_pwr_ctrl(struct ath11k_base *ab)
 339{
 340	u32 val;
 341
 342	val = ath11k_pcic_read32(ab, WLAON_QFPROM_PWR_CTRL_REG);
 343	val &= ~QFPROM_PWR_CTRL_VDD4BLOW_MASK;
 344	ath11k_pcic_write32(ab, WLAON_QFPROM_PWR_CTRL_REG, val);
 345}
 346
 347static void ath11k_pci_force_wake(struct ath11k_base *ab)
 348{
 349	ath11k_pcic_write32(ab, PCIE_SOC_WAKE_PCIE_LOCAL_REG, 1);
 350	mdelay(5);
 351}
 352
 353static void ath11k_pci_sw_reset(struct ath11k_base *ab, bool power_on)
 354{
 355	mdelay(100);
 356
 357	if (power_on) {
 358		ath11k_pci_enable_ltssm(ab);
 359		ath11k_pci_clear_all_intrs(ab);
 360		ath11k_pci_set_wlaon_pwr_ctrl(ab);
 361		if (ab->hw_params.fix_l1ss)
 362			ath11k_pci_fix_l1ss(ab);
 363	}
 364
 365	ath11k_mhi_clear_vector(ab);
 366	ath11k_pci_clear_dbg_registers(ab);
 367	ath11k_pci_soc_global_reset(ab);
 368	ath11k_mhi_set_mhictrl_reset(ab);
 369}
 370
 371static void ath11k_pci_init_qmi_ce_config(struct ath11k_base *ab)
 372{
 373	struct ath11k_qmi_ce_cfg *cfg = &ab->qmi.ce_cfg;
 374
 375	cfg->tgt_ce = ab->hw_params.target_ce_config;
 376	cfg->tgt_ce_len = ab->hw_params.target_ce_count;
 377
 378	cfg->svc_to_ce_map = ab->hw_params.svc_to_ce_map;
 379	cfg->svc_to_ce_map_len = ab->hw_params.svc_to_ce_map_len;
 380	ab->qmi.service_ins_id = ab->hw_params.qmi_service_ins_id;
 381
 382	ath11k_ce_get_shadow_config(ab, &cfg->shadow_reg_v2,
 383				    &cfg->shadow_reg_v2_len);
 384}
 385
 386static void ath11k_pci_msi_config(struct ath11k_pci *ab_pci, bool enable)
 387{
 388	struct pci_dev *dev = ab_pci->pdev;
 389	u16 control;
 390
 391	pci_read_config_word(dev, dev->msi_cap + PCI_MSI_FLAGS, &control);
 392
 393	if (enable)
 394		control |= PCI_MSI_FLAGS_ENABLE;
 395	else
 396		control &= ~PCI_MSI_FLAGS_ENABLE;
 397
 398	pci_write_config_word(dev, dev->msi_cap + PCI_MSI_FLAGS, control);
 399}
 400
 401static void ath11k_pci_msi_enable(struct ath11k_pci *ab_pci)
 402{
 403	ath11k_pci_msi_config(ab_pci, true);
 404}
 405
 406static void ath11k_pci_msi_disable(struct ath11k_pci *ab_pci)
 407{
 408	ath11k_pci_msi_config(ab_pci, false);
 409}
 410
 411static int ath11k_pci_alloc_msi(struct ath11k_pci *ab_pci)
 412{
 413	struct ath11k_base *ab = ab_pci->ab;
 414	const struct ath11k_msi_config *msi_config = ab->pci.msi.config;
 415	struct pci_dev *pci_dev = ab_pci->pdev;
 416	struct msi_desc *msi_desc;
 417	int num_vectors;
 418	int ret;
 419
 420	num_vectors = pci_alloc_irq_vectors(pci_dev,
 421					    msi_config->total_vectors,
 422					    msi_config->total_vectors,
 423					    PCI_IRQ_MSI);
 424	if (num_vectors == msi_config->total_vectors) {
 425		set_bit(ATH11K_FLAG_MULTI_MSI_VECTORS, &ab->dev_flags);
 426	} else {
 427		num_vectors = pci_alloc_irq_vectors(ab_pci->pdev,
 428						    1,
 429						    1,
 430						    PCI_IRQ_MSI);
 431		if (num_vectors < 0) {
 432			ret = -EINVAL;
 433			goto reset_msi_config;
 434		}
 435		clear_bit(ATH11K_FLAG_MULTI_MSI_VECTORS, &ab->dev_flags);
 436		ab->pci.msi.config = &msi_config_one_msi;
 437		ath11k_dbg(ab, ATH11K_DBG_PCI, "request one msi vector\n");
 438	}
 439	ath11k_info(ab, "MSI vectors: %d\n", num_vectors);
 440
 441	ath11k_pci_msi_disable(ab_pci);
 442
 443	msi_desc = irq_get_msi_desc(ab_pci->pdev->irq);
 444	if (!msi_desc) {
 445		ath11k_err(ab, "msi_desc is NULL!\n");
 446		ret = -EINVAL;
 447		goto free_msi_vector;
 448	}
 449
 450	ab->pci.msi.ep_base_data = msi_desc->msg.data;
 451
 452	pci_read_config_dword(pci_dev, pci_dev->msi_cap + PCI_MSI_ADDRESS_LO,
 453			      &ab->pci.msi.addr_lo);
 454
 455	if (msi_desc->pci.msi_attrib.is_64) {
 456		pci_read_config_dword(pci_dev, pci_dev->msi_cap + PCI_MSI_ADDRESS_HI,
 457				      &ab->pci.msi.addr_hi);
 458	} else {
 459		ab->pci.msi.addr_hi = 0;
 460	}
 461
 462	ath11k_dbg(ab, ATH11K_DBG_PCI, "msi base data is %d\n", ab->pci.msi.ep_base_data);
 463
 464	return 0;
 465
 466free_msi_vector:
 467	pci_free_irq_vectors(ab_pci->pdev);
 468
 469reset_msi_config:
 470	return ret;
 471}
 472
 473static void ath11k_pci_free_msi(struct ath11k_pci *ab_pci)
 474{
 475	pci_free_irq_vectors(ab_pci->pdev);
 476}
 477
 478static int ath11k_pci_config_msi_data(struct ath11k_pci *ab_pci)
 479{
 480	struct msi_desc *msi_desc;
 481
 482	msi_desc = irq_get_msi_desc(ab_pci->pdev->irq);
 483	if (!msi_desc) {
 484		ath11k_err(ab_pci->ab, "msi_desc is NULL!\n");
 485		pci_free_irq_vectors(ab_pci->pdev);
 486		return -EINVAL;
 487	}
 488
 489	ab_pci->ab->pci.msi.ep_base_data = msi_desc->msg.data;
 490
 491	ath11k_dbg(ab_pci->ab, ATH11K_DBG_PCI, "after request_irq msi_ep_base_data %d\n",
 492		   ab_pci->ab->pci.msi.ep_base_data);
 493
 494	return 0;
 495}
 496
 497static int ath11k_pci_claim(struct ath11k_pci *ab_pci, struct pci_dev *pdev)
 498{
 499	struct ath11k_base *ab = ab_pci->ab;
 500	u16 device_id;
 501	int ret = 0;
 502
 503	pci_read_config_word(pdev, PCI_DEVICE_ID, &device_id);
 504	if (device_id != ab_pci->dev_id)  {
 505		ath11k_err(ab, "pci device id mismatch: 0x%x 0x%x\n",
 506			   device_id, ab_pci->dev_id);
 507		ret = -EIO;
 508		goto out;
 509	}
 510
 511	ret = pci_assign_resource(pdev, ATH11K_PCI_BAR_NUM);
 512	if (ret) {
 513		ath11k_err(ab, "failed to assign pci resource: %d\n", ret);
 514		goto out;
 515	}
 516
 517	ret = pci_enable_device(pdev);
 518	if (ret) {
 519		ath11k_err(ab, "failed to enable pci device: %d\n", ret);
 520		goto out;
 521	}
 522
 523	ret = pci_request_region(pdev, ATH11K_PCI_BAR_NUM, "ath11k_pci");
 524	if (ret) {
 525		ath11k_err(ab, "failed to request pci region: %d\n", ret);
 526		goto disable_device;
 527	}
 528
 529	ret = dma_set_mask_and_coherent(&pdev->dev,
 530					DMA_BIT_MASK(ATH11K_PCI_DMA_MASK));
 531	if (ret) {
 532		ath11k_err(ab, "failed to set pci dma mask to %d: %d\n",
 533			   ATH11K_PCI_DMA_MASK, ret);
 534		goto release_region;
 535	}
 536
 537	pci_set_master(pdev);
 538
 539	ab->mem_len = pci_resource_len(pdev, ATH11K_PCI_BAR_NUM);
 540	ab->mem = pci_iomap(pdev, ATH11K_PCI_BAR_NUM, 0);
 541	if (!ab->mem) {
 542		ath11k_err(ab, "failed to map pci bar %d\n", ATH11K_PCI_BAR_NUM);
 543		ret = -EIO;
 544		goto release_region;
 545	}
 546
 547	ab->mem_ce = ab->mem;
 548
 549	ath11k_dbg(ab, ATH11K_DBG_BOOT, "pci_mem 0x%p\n", ab->mem);
 550	return 0;
 551
 
 
 552release_region:
 553	pci_release_region(pdev, ATH11K_PCI_BAR_NUM);
 554disable_device:
 555	pci_disable_device(pdev);
 556out:
 557	return ret;
 558}
 559
 560static void ath11k_pci_free_region(struct ath11k_pci *ab_pci)
 561{
 562	struct ath11k_base *ab = ab_pci->ab;
 563	struct pci_dev *pci_dev = ab_pci->pdev;
 564
 565	pci_iounmap(pci_dev, ab->mem);
 566	ab->mem = NULL;
 
 567	pci_release_region(pci_dev, ATH11K_PCI_BAR_NUM);
 568	if (pci_is_enabled(pci_dev))
 569		pci_disable_device(pci_dev);
 570}
 571
 572static void ath11k_pci_aspm_disable(struct ath11k_pci *ab_pci)
 573{
 574	struct ath11k_base *ab = ab_pci->ab;
 575
 576	pcie_capability_read_word(ab_pci->pdev, PCI_EXP_LNKCTL,
 577				  &ab_pci->link_ctl);
 578
 579	ath11k_dbg(ab, ATH11K_DBG_PCI, "link_ctl 0x%04x L0s %d L1 %d\n",
 580		   ab_pci->link_ctl,
 581		   u16_get_bits(ab_pci->link_ctl, PCI_EXP_LNKCTL_ASPM_L0S),
 582		   u16_get_bits(ab_pci->link_ctl, PCI_EXP_LNKCTL_ASPM_L1));
 583
 584	/* disable L0s and L1 */
 585	pcie_capability_clear_word(ab_pci->pdev, PCI_EXP_LNKCTL,
 586				   PCI_EXP_LNKCTL_ASPMC);
 587
 588	set_bit(ATH11K_PCI_ASPM_RESTORE, &ab_pci->flags);
 589}
 590
 591static void ath11k_pci_aspm_restore(struct ath11k_pci *ab_pci)
 592{
 593	if (test_and_clear_bit(ATH11K_PCI_ASPM_RESTORE, &ab_pci->flags))
 594		pcie_capability_clear_and_set_word(ab_pci->pdev, PCI_EXP_LNKCTL,
 595						   PCI_EXP_LNKCTL_ASPMC,
 596						   ab_pci->link_ctl &
 597						   PCI_EXP_LNKCTL_ASPMC);
 598}
 599
 600static int ath11k_pci_power_up(struct ath11k_base *ab)
 601{
 602	struct ath11k_pci *ab_pci = ath11k_pci_priv(ab);
 603	int ret;
 604
 605	ab_pci->register_window = 0;
 606	clear_bit(ATH11K_FLAG_DEVICE_INIT_DONE, &ab->dev_flags);
 607	ath11k_pci_sw_reset(ab_pci->ab, true);
 608
 609	/* Disable ASPM during firmware download due to problems switching
 610	 * to AMSS state.
 611	 */
 612	ath11k_pci_aspm_disable(ab_pci);
 613
 614	ath11k_pci_msi_enable(ab_pci);
 615
 616	ret = ath11k_mhi_start(ab_pci);
 617	if (ret) {
 618		ath11k_err(ab, "failed to start mhi: %d\n", ret);
 619		return ret;
 620	}
 621
 622	if (ab->hw_params.static_window_map)
 623		ath11k_pci_select_static_window(ab_pci);
 624
 625	return 0;
 626}
 627
 628static void ath11k_pci_power_down(struct ath11k_base *ab)
 629{
 630	struct ath11k_pci *ab_pci = ath11k_pci_priv(ab);
 631
 632	/* restore aspm in case firmware bootup fails */
 633	ath11k_pci_aspm_restore(ab_pci);
 634
 635	ath11k_pci_force_wake(ab_pci->ab);
 636
 637	ath11k_pci_msi_disable(ab_pci);
 638
 639	ath11k_mhi_stop(ab_pci);
 640	clear_bit(ATH11K_FLAG_DEVICE_INIT_DONE, &ab->dev_flags);
 641	ath11k_pci_sw_reset(ab_pci->ab, false);
 642}
 643
 644static int ath11k_pci_hif_suspend(struct ath11k_base *ab)
 645{
 646	struct ath11k_pci *ar_pci = ath11k_pci_priv(ab);
 647
 648	return ath11k_mhi_suspend(ar_pci);
 649}
 650
 651static int ath11k_pci_hif_resume(struct ath11k_base *ab)
 652{
 653	struct ath11k_pci *ar_pci = ath11k_pci_priv(ab);
 654
 655	return ath11k_mhi_resume(ar_pci);
 656}
 657
 658static void ath11k_pci_hif_ce_irq_enable(struct ath11k_base *ab)
 659{
 660	ath11k_pcic_ce_irqs_enable(ab);
 661}
 662
 663static void ath11k_pci_hif_ce_irq_disable(struct ath11k_base *ab)
 664{
 665	ath11k_pcic_ce_irq_disable_sync(ab);
 666}
 667
 668static int ath11k_pci_start(struct ath11k_base *ab)
 669{
 670	struct ath11k_pci *ab_pci = ath11k_pci_priv(ab);
 671
 672	/* TODO: for now don't restore ASPM in case of single MSI
 673	 * vector as MHI register reading in M2 causes system hang.
 674	 */
 675	if (test_bit(ATH11K_FLAG_MULTI_MSI_VECTORS, &ab->dev_flags))
 676		ath11k_pci_aspm_restore(ab_pci);
 677	else
 678		ath11k_info(ab, "leaving PCI ASPM disabled to avoid MHI M2 problems\n");
 679
 680	ath11k_pcic_start(ab);
 681
 682	return 0;
 683}
 684
 685static const struct ath11k_hif_ops ath11k_pci_hif_ops = {
 686	.start = ath11k_pci_start,
 687	.stop = ath11k_pcic_stop,
 688	.read32 = ath11k_pcic_read32,
 689	.write32 = ath11k_pcic_write32,
 690	.read = ath11k_pcic_read,
 691	.power_down = ath11k_pci_power_down,
 692	.power_up = ath11k_pci_power_up,
 693	.suspend = ath11k_pci_hif_suspend,
 694	.resume = ath11k_pci_hif_resume,
 695	.irq_enable = ath11k_pcic_ext_irq_enable,
 696	.irq_disable = ath11k_pcic_ext_irq_disable,
 697	.get_msi_address =  ath11k_pcic_get_msi_address,
 698	.get_user_msi_vector = ath11k_pcic_get_user_msi_assignment,
 699	.map_service_to_pipe = ath11k_pcic_map_service_to_pipe,
 700	.ce_irq_enable = ath11k_pci_hif_ce_irq_enable,
 701	.ce_irq_disable = ath11k_pci_hif_ce_irq_disable,
 702	.get_ce_msi_idx = ath11k_pcic_get_ce_msi_idx,
 703};
 704
 705static void ath11k_pci_read_hw_version(struct ath11k_base *ab, u32 *major, u32 *minor)
 706{
 707	u32 soc_hw_version;
 708
 709	soc_hw_version = ath11k_pcic_read32(ab, TCSR_SOC_HW_VERSION);
 710	*major = FIELD_GET(TCSR_SOC_HW_VERSION_MAJOR_MASK,
 711			   soc_hw_version);
 712	*minor = FIELD_GET(TCSR_SOC_HW_VERSION_MINOR_MASK,
 713			   soc_hw_version);
 714
 715	ath11k_dbg(ab, ATH11K_DBG_PCI, "tcsr_soc_hw_version major %d minor %d\n",
 716		   *major, *minor);
 717}
 718
 719static int ath11k_pci_set_irq_affinity_hint(struct ath11k_pci *ab_pci,
 720					    const struct cpumask *m)
 721{
 722	if (test_bit(ATH11K_FLAG_MULTI_MSI_VECTORS, &ab_pci->ab->dev_flags))
 723		return 0;
 724
 725	return irq_set_affinity_hint(ab_pci->pdev->irq, m);
 726}
 727
 728static int ath11k_pci_probe(struct pci_dev *pdev,
 729			    const struct pci_device_id *pci_dev)
 730{
 731	struct ath11k_base *ab;
 732	struct ath11k_pci *ab_pci;
 733	u32 soc_hw_version_major, soc_hw_version_minor, addr;
 734	const struct ath11k_pci_ops *pci_ops;
 735	int ret;
 736
 737	ab = ath11k_core_alloc(&pdev->dev, sizeof(*ab_pci), ATH11K_BUS_PCI);
 738
 739	if (!ab) {
 740		dev_err(&pdev->dev, "failed to allocate ath11k base\n");
 741		return -ENOMEM;
 742	}
 743
 744	ab->dev = &pdev->dev;
 745	pci_set_drvdata(pdev, ab);
 746	ab_pci = ath11k_pci_priv(ab);
 747	ab_pci->dev_id = pci_dev->device;
 748	ab_pci->ab = ab;
 749	ab_pci->pdev = pdev;
 750	ab->hif.ops = &ath11k_pci_hif_ops;
 751	ab->fw_mode = ATH11K_FIRMWARE_MODE_NORMAL;
 752	pci_set_drvdata(pdev, ab);
 753	spin_lock_init(&ab_pci->window_lock);
 754
 755	/* Set fixed_mem_region to true for platforms support reserved memory
 756	 * from DT. If memory is reserved from DT for FW, ath11k driver need not
 757	 * allocate memory.
 758	 */
 759	ret = of_property_read_u32(ab->dev->of_node, "memory-region", &addr);
 760	if (!ret)
 761		set_bit(ATH11K_FLAG_FIXED_MEM_RGN, &ab->dev_flags);
 762
 763	ret = ath11k_pci_claim(ab_pci, pdev);
 764	if (ret) {
 765		ath11k_err(ab, "failed to claim device: %d\n", ret);
 766		goto err_free_core;
 767	}
 768
 769	ath11k_dbg(ab, ATH11K_DBG_BOOT, "pci probe %04x:%04x %04x:%04x\n",
 770		   pdev->vendor, pdev->device,
 771		   pdev->subsystem_vendor, pdev->subsystem_device);
 772
 773	ab->id.vendor = pdev->vendor;
 774	ab->id.device = pdev->device;
 775	ab->id.subsystem_vendor = pdev->subsystem_vendor;
 776	ab->id.subsystem_device = pdev->subsystem_device;
 777
 778	switch (pci_dev->device) {
 779	case QCA6390_DEVICE_ID:
 780		ath11k_pci_read_hw_version(ab, &soc_hw_version_major,
 781					   &soc_hw_version_minor);
 782		switch (soc_hw_version_major) {
 783		case 2:
 784			ab->hw_rev = ATH11K_HW_QCA6390_HW20;
 785			break;
 786		default:
 787			dev_err(&pdev->dev, "Unsupported QCA6390 SOC hardware version: %d %d\n",
 788				soc_hw_version_major, soc_hw_version_minor);
 789			ret = -EOPNOTSUPP;
 790			goto err_pci_free_region;
 791		}
 792
 793		pci_ops = &ath11k_pci_ops_qca6390;
 794		break;
 795	case QCN9074_DEVICE_ID:
 796		pci_ops = &ath11k_pci_ops_qcn9074;
 797		ab->hw_rev = ATH11K_HW_QCN9074_HW10;
 798		break;
 799	case WCN6855_DEVICE_ID:
 800		ab->id.bdf_search = ATH11K_BDF_SEARCH_BUS_AND_BOARD;
 801		ath11k_pci_read_hw_version(ab, &soc_hw_version_major,
 802					   &soc_hw_version_minor);
 803		switch (soc_hw_version_major) {
 804		case 2:
 805			switch (soc_hw_version_minor) {
 806			case 0x00:
 807			case 0x01:
 808				ab->hw_rev = ATH11K_HW_WCN6855_HW20;
 809				break;
 810			case 0x10:
 811			case 0x11:
 812				ab->hw_rev = ATH11K_HW_WCN6855_HW21;
 813				break;
 814			default:
 815				goto unsupported_wcn6855_soc;
 816			}
 817			break;
 818		default:
 819unsupported_wcn6855_soc:
 820			dev_err(&pdev->dev, "Unsupported WCN6855 SOC hardware version: %d %d\n",
 821				soc_hw_version_major, soc_hw_version_minor);
 822			ret = -EOPNOTSUPP;
 823			goto err_pci_free_region;
 824		}
 825
 826		pci_ops = &ath11k_pci_ops_qca6390;
 827		break;
 828	default:
 829		dev_err(&pdev->dev, "Unknown PCI device found: 0x%x\n",
 830			pci_dev->device);
 831		ret = -EOPNOTSUPP;
 832		goto err_pci_free_region;
 833	}
 834
 835	ret = ath11k_pcic_register_pci_ops(ab, pci_ops);
 836	if (ret) {
 837		ath11k_err(ab, "failed to register PCI ops: %d\n", ret);
 838		goto err_pci_free_region;
 839	}
 840
 841	ret = ath11k_pcic_init_msi_config(ab);
 842	if (ret) {
 843		ath11k_err(ab, "failed to init msi config: %d\n", ret);
 844		goto err_pci_free_region;
 845	}
 846
 847	ret = ath11k_pci_alloc_msi(ab_pci);
 848	if (ret) {
 849		ath11k_err(ab, "failed to enable msi: %d\n", ret);
 850		goto err_pci_free_region;
 851	}
 852
 853	ret = ath11k_core_pre_init(ab);
 854	if (ret)
 855		goto err_pci_disable_msi;
 856
 857	ret = ath11k_pci_set_irq_affinity_hint(ab_pci, cpumask_of(0));
 858	if (ret) {
 859		ath11k_err(ab, "failed to set irq affinity %d\n", ret);
 860		goto err_pci_disable_msi;
 861	}
 862
 863	ret = ath11k_mhi_register(ab_pci);
 864	if (ret) {
 865		ath11k_err(ab, "failed to register mhi: %d\n", ret);
 866		goto err_irq_affinity_cleanup;
 867	}
 868
 869	ret = ath11k_hal_srng_init(ab);
 870	if (ret)
 871		goto err_mhi_unregister;
 872
 873	ret = ath11k_ce_alloc_pipes(ab);
 874	if (ret) {
 875		ath11k_err(ab, "failed to allocate ce pipes: %d\n", ret);
 876		goto err_hal_srng_deinit;
 877	}
 878
 879	ath11k_pci_init_qmi_ce_config(ab);
 880
 881	ret = ath11k_pcic_config_irq(ab);
 882	if (ret) {
 883		ath11k_err(ab, "failed to config irq: %d\n", ret);
 884		goto err_ce_free;
 885	}
 886
 
 
 
 
 
 
 887	/* kernel may allocate a dummy vector before request_irq and
 888	 * then allocate a real vector when request_irq is called.
 889	 * So get msi_data here again to avoid spurious interrupt
 890	 * as msi_data will configured to srngs.
 891	 */
 892	ret = ath11k_pci_config_msi_data(ab_pci);
 893	if (ret) {
 894		ath11k_err(ab, "failed to config msi_data: %d\n", ret);
 895		goto err_free_irq;
 896	}
 897
 898	ret = ath11k_core_init(ab);
 899	if (ret) {
 900		ath11k_err(ab, "failed to init core: %d\n", ret);
 901		goto err_free_irq;
 902	}
 903	ath11k_qmi_fwreset_from_cold_boot(ab);
 904	return 0;
 905
 
 
 
 906err_free_irq:
 907	ath11k_pcic_free_irq(ab);
 908
 909err_ce_free:
 910	ath11k_ce_free_pipes(ab);
 911
 912err_hal_srng_deinit:
 913	ath11k_hal_srng_deinit(ab);
 914
 915err_mhi_unregister:
 916	ath11k_mhi_unregister(ab_pci);
 917
 918err_irq_affinity_cleanup:
 919	ath11k_pci_set_irq_affinity_hint(ab_pci, NULL);
 920
 921err_pci_disable_msi:
 922	ath11k_pci_free_msi(ab_pci);
 923
 924err_pci_free_region:
 925	ath11k_pci_free_region(ab_pci);
 926
 927err_free_core:
 928	ath11k_core_free(ab);
 929
 930	return ret;
 931}
 932
 933static void ath11k_pci_remove(struct pci_dev *pdev)
 934{
 935	struct ath11k_base *ab = pci_get_drvdata(pdev);
 936	struct ath11k_pci *ab_pci = ath11k_pci_priv(ab);
 937
 938	ath11k_pci_set_irq_affinity_hint(ab_pci, NULL);
 939
 940	if (test_bit(ATH11K_FLAG_QMI_FAIL, &ab->dev_flags)) {
 941		ath11k_pci_power_down(ab);
 942		ath11k_debugfs_soc_destroy(ab);
 943		ath11k_qmi_deinit_service(ab);
 944		goto qmi_fail;
 945	}
 946
 947	set_bit(ATH11K_FLAG_UNREGISTERING, &ab->dev_flags);
 948
 949	ath11k_core_deinit(ab);
 950
 951qmi_fail:
 952	ath11k_mhi_unregister(ab_pci);
 953
 954	ath11k_pcic_free_irq(ab);
 955	ath11k_pci_free_msi(ab_pci);
 956	ath11k_pci_free_region(ab_pci);
 957
 958	ath11k_hal_srng_deinit(ab);
 959	ath11k_ce_free_pipes(ab);
 960	ath11k_core_free(ab);
 961}
 962
 963static void ath11k_pci_shutdown(struct pci_dev *pdev)
 964{
 965	struct ath11k_base *ab = pci_get_drvdata(pdev);
 966	struct ath11k_pci *ab_pci = ath11k_pci_priv(ab);
 967
 968	ath11k_pci_set_irq_affinity_hint(ab_pci, NULL);
 969	ath11k_pci_power_down(ab);
 970}
 971
 972static __maybe_unused int ath11k_pci_pm_suspend(struct device *dev)
 973{
 974	struct ath11k_base *ab = dev_get_drvdata(dev);
 975	int ret;
 976
 977	if (test_bit(ATH11K_FLAG_QMI_FAIL, &ab->dev_flags)) {
 978		ath11k_dbg(ab, ATH11K_DBG_BOOT, "boot skipping pci suspend as qmi is not initialised\n");
 979		return 0;
 980	}
 981
 982	ret = ath11k_core_suspend(ab);
 983	if (ret)
 984		ath11k_warn(ab, "failed to suspend core: %d\n", ret);
 985
 986	return 0;
 987}
 988
 989static __maybe_unused int ath11k_pci_pm_resume(struct device *dev)
 990{
 991	struct ath11k_base *ab = dev_get_drvdata(dev);
 992	int ret;
 993
 994	if (test_bit(ATH11K_FLAG_QMI_FAIL, &ab->dev_flags)) {
 995		ath11k_dbg(ab, ATH11K_DBG_BOOT, "boot skipping pci resume as qmi is not initialised\n");
 996		return 0;
 997	}
 998
 999	ret = ath11k_core_resume(ab);
1000	if (ret)
1001		ath11k_warn(ab, "failed to resume core: %d\n", ret);
1002
1003	return ret;
1004}
1005
1006static SIMPLE_DEV_PM_OPS(ath11k_pci_pm_ops,
1007			 ath11k_pci_pm_suspend,
1008			 ath11k_pci_pm_resume);
1009
1010static struct pci_driver ath11k_pci_driver = {
1011	.name = "ath11k_pci",
1012	.id_table = ath11k_pci_id_table,
1013	.probe = ath11k_pci_probe,
1014	.remove = ath11k_pci_remove,
1015	.shutdown = ath11k_pci_shutdown,
1016#ifdef CONFIG_PM
1017	.driver.pm = &ath11k_pci_pm_ops,
1018#endif
1019};
1020
1021static int ath11k_pci_init(void)
1022{
1023	int ret;
1024
1025	ret = pci_register_driver(&ath11k_pci_driver);
1026	if (ret)
1027		pr_err("failed to register ath11k pci driver: %d\n",
1028		       ret);
1029
1030	return ret;
1031}
1032module_init(ath11k_pci_init);
1033
1034static void ath11k_pci_exit(void)
1035{
1036	pci_unregister_driver(&ath11k_pci_driver);
1037}
1038
1039module_exit(ath11k_pci_exit);
1040
1041MODULE_DESCRIPTION("Driver support for Qualcomm Technologies PCIe 802.11ax WLAN devices");
1042MODULE_LICENSE("Dual BSD/GPL");
1043
1044/* firmware files */
1045MODULE_FIRMWARE(ATH11K_FW_DIR "/QCA6390/hw2.0/*");
1046MODULE_FIRMWARE(ATH11K_FW_DIR "/QCN9074/hw1.0/*");
1047MODULE_FIRMWARE(ATH11K_FW_DIR "/WCN6855/hw2.0/*");
1048MODULE_FIRMWARE(ATH11K_FW_DIR "/WCN6855/hw2.1/*");
v6.2
   1// SPDX-License-Identifier: BSD-3-Clause-Clear
   2/*
   3 * Copyright (c) 2019-2020 The Linux Foundation. All rights reserved.
   4 * Copyright (c) 2021-2022, Qualcomm Innovation Center, Inc. All rights reserved.
   5 */
   6
   7#include <linux/module.h>
   8#include <linux/msi.h>
   9#include <linux/pci.h>
  10#include <linux/of.h>
  11
  12#include "pci.h"
  13#include "core.h"
  14#include "hif.h"
  15#include "mhi.h"
  16#include "debug.h"
  17#include "pcic.h"
 
  18
  19#define ATH11K_PCI_BAR_NUM		0
  20#define ATH11K_PCI_DMA_MASK		32
  21
  22#define TCSR_SOC_HW_VERSION		0x0224
  23#define TCSR_SOC_HW_VERSION_MAJOR_MASK	GENMASK(11, 8)
  24#define TCSR_SOC_HW_VERSION_MINOR_MASK	GENMASK(7, 0)
  25
  26#define QCA6390_DEVICE_ID		0x1101
  27#define QCN9074_DEVICE_ID		0x1104
  28#define WCN6855_DEVICE_ID		0x1103
  29
  30static const struct pci_device_id ath11k_pci_id_table[] = {
  31	{ PCI_VDEVICE(QCOM, QCA6390_DEVICE_ID) },
  32	{ PCI_VDEVICE(QCOM, WCN6855_DEVICE_ID) },
  33	{ PCI_VDEVICE(QCOM, QCN9074_DEVICE_ID) },
  34	{0}
  35};
  36
  37MODULE_DEVICE_TABLE(pci, ath11k_pci_id_table);
  38
  39static int ath11k_pci_bus_wake_up(struct ath11k_base *ab)
  40{
  41	struct ath11k_pci *ab_pci = ath11k_pci_priv(ab);
  42
  43	return mhi_device_get_sync(ab_pci->mhi_ctrl->mhi_dev);
  44}
  45
  46static void ath11k_pci_bus_release(struct ath11k_base *ab)
  47{
  48	struct ath11k_pci *ab_pci = ath11k_pci_priv(ab);
  49
  50	mhi_device_put(ab_pci->mhi_ctrl->mhi_dev);
  51}
  52
  53static u32 ath11k_pci_get_window_start(struct ath11k_base *ab, u32 offset)
  54{
  55	if (!ab->hw_params.static_window_map)
  56		return ATH11K_PCI_WINDOW_START;
  57
  58	if ((offset ^ HAL_SEQ_WCSS_UMAC_OFFSET) < ATH11K_PCI_WINDOW_RANGE_MASK)
  59		/* if offset lies within DP register range, use 3rd window */
  60		return 3 * ATH11K_PCI_WINDOW_START;
  61	else if ((offset ^ HAL_SEQ_WCSS_UMAC_CE0_SRC_REG(ab)) <
  62		 ATH11K_PCI_WINDOW_RANGE_MASK)
  63		 /* if offset lies within CE register range, use 2nd window */
  64		return 2 * ATH11K_PCI_WINDOW_START;
  65	else
  66		return ATH11K_PCI_WINDOW_START;
  67}
  68
  69static inline void ath11k_pci_select_window(struct ath11k_pci *ab_pci, u32 offset)
  70{
  71	struct ath11k_base *ab = ab_pci->ab;
  72
  73	u32 window = FIELD_GET(ATH11K_PCI_WINDOW_VALUE_MASK, offset);
  74
  75	lockdep_assert_held(&ab_pci->window_lock);
  76
  77	if (window != ab_pci->register_window) {
  78		iowrite32(ATH11K_PCI_WINDOW_ENABLE_BIT | window,
  79			  ab->mem + ATH11K_PCI_WINDOW_REG_ADDRESS);
  80		ioread32(ab->mem + ATH11K_PCI_WINDOW_REG_ADDRESS);
  81		ab_pci->register_window = window;
  82	}
  83}
  84
  85static void
  86ath11k_pci_window_write32(struct ath11k_base *ab, u32 offset, u32 value)
  87{
  88	struct ath11k_pci *ab_pci = ath11k_pci_priv(ab);
  89	u32 window_start;
  90
  91	window_start = ath11k_pci_get_window_start(ab, offset);
  92
  93	if (window_start == ATH11K_PCI_WINDOW_START) {
  94		spin_lock_bh(&ab_pci->window_lock);
  95		ath11k_pci_select_window(ab_pci, offset);
  96		iowrite32(value, ab->mem + window_start +
  97			  (offset & ATH11K_PCI_WINDOW_RANGE_MASK));
  98		spin_unlock_bh(&ab_pci->window_lock);
  99	} else {
 100		iowrite32(value, ab->mem + window_start +
 101			  (offset & ATH11K_PCI_WINDOW_RANGE_MASK));
 102	}
 103}
 104
 105static u32 ath11k_pci_window_read32(struct ath11k_base *ab, u32 offset)
 106{
 107	struct ath11k_pci *ab_pci = ath11k_pci_priv(ab);
 108	u32 window_start, val;
 109
 110	window_start = ath11k_pci_get_window_start(ab, offset);
 111
 112	if (window_start == ATH11K_PCI_WINDOW_START) {
 113		spin_lock_bh(&ab_pci->window_lock);
 114		ath11k_pci_select_window(ab_pci, offset);
 115		val = ioread32(ab->mem + window_start +
 116			       (offset & ATH11K_PCI_WINDOW_RANGE_MASK));
 117		spin_unlock_bh(&ab_pci->window_lock);
 118	} else {
 119		val = ioread32(ab->mem + window_start +
 120			       (offset & ATH11K_PCI_WINDOW_RANGE_MASK));
 121	}
 122
 123	return val;
 124}
 125
 126int ath11k_pci_get_msi_irq(struct ath11k_base *ab, unsigned int vector)
 127{
 128	struct pci_dev *pci_dev = to_pci_dev(ab->dev);
 129
 130	return pci_irq_vector(pci_dev, vector);
 131}
 132
 133static const struct ath11k_pci_ops ath11k_pci_ops_qca6390 = {
 134	.wakeup = ath11k_pci_bus_wake_up,
 135	.release = ath11k_pci_bus_release,
 136	.get_msi_irq = ath11k_pci_get_msi_irq,
 137	.window_write32 = ath11k_pci_window_write32,
 138	.window_read32 = ath11k_pci_window_read32,
 139};
 140
 141static const struct ath11k_pci_ops ath11k_pci_ops_qcn9074 = {
 142	.wakeup = NULL,
 143	.release = NULL,
 144	.get_msi_irq = ath11k_pci_get_msi_irq,
 145	.window_write32 = ath11k_pci_window_write32,
 146	.window_read32 = ath11k_pci_window_read32,
 147};
 148
 149static const struct ath11k_msi_config msi_config_one_msi = {
 150	.total_vectors = 1,
 151	.total_users = 4,
 152	.users = (struct ath11k_msi_user[]) {
 153		{ .name = "MHI", .num_vectors = 3, .base_vector = 0 },
 154		{ .name = "CE", .num_vectors = 1, .base_vector = 0 },
 155		{ .name = "WAKE", .num_vectors = 1, .base_vector = 0 },
 156		{ .name = "DP", .num_vectors = 1, .base_vector = 0 },
 157	},
 158};
 159
 160static inline void ath11k_pci_select_static_window(struct ath11k_pci *ab_pci)
 161{
 162	u32 umac_window;
 163	u32 ce_window;
 164	u32 window;
 165
 166	umac_window = FIELD_GET(ATH11K_PCI_WINDOW_VALUE_MASK, HAL_SEQ_WCSS_UMAC_OFFSET);
 167	ce_window = FIELD_GET(ATH11K_PCI_WINDOW_VALUE_MASK, HAL_CE_WFSS_CE_REG_BASE);
 168	window = (umac_window << 12) | (ce_window << 6);
 169
 170	iowrite32(ATH11K_PCI_WINDOW_ENABLE_BIT | window,
 171		  ab_pci->ab->mem + ATH11K_PCI_WINDOW_REG_ADDRESS);
 172}
 173
 174static void ath11k_pci_soc_global_reset(struct ath11k_base *ab)
 175{
 176	u32 val, delay;
 177
 178	val = ath11k_pcic_read32(ab, PCIE_SOC_GLOBAL_RESET);
 179
 180	val |= PCIE_SOC_GLOBAL_RESET_V;
 181
 182	ath11k_pcic_write32(ab, PCIE_SOC_GLOBAL_RESET, val);
 183
 184	/* TODO: exact time to sleep is uncertain */
 185	delay = 10;
 186	mdelay(delay);
 187
 188	/* Need to toggle V bit back otherwise stuck in reset status */
 189	val &= ~PCIE_SOC_GLOBAL_RESET_V;
 190
 191	ath11k_pcic_write32(ab, PCIE_SOC_GLOBAL_RESET, val);
 192
 193	mdelay(delay);
 194
 195	val = ath11k_pcic_read32(ab, PCIE_SOC_GLOBAL_RESET);
 196	if (val == 0xffffffff)
 197		ath11k_warn(ab, "link down error during global reset\n");
 198}
 199
 200static void ath11k_pci_clear_dbg_registers(struct ath11k_base *ab)
 201{
 202	u32 val;
 203
 204	/* read cookie */
 205	val = ath11k_pcic_read32(ab, PCIE_Q6_COOKIE_ADDR);
 206	ath11k_dbg(ab, ATH11K_DBG_PCI, "cookie:0x%x\n", val);
 207
 208	val = ath11k_pcic_read32(ab, WLAON_WARM_SW_ENTRY);
 209	ath11k_dbg(ab, ATH11K_DBG_PCI, "WLAON_WARM_SW_ENTRY 0x%x\n", val);
 210
 211	/* TODO: exact time to sleep is uncertain */
 212	mdelay(10);
 213
 214	/* write 0 to WLAON_WARM_SW_ENTRY to prevent Q6 from
 215	 * continuing warm path and entering dead loop.
 216	 */
 217	ath11k_pcic_write32(ab, WLAON_WARM_SW_ENTRY, 0);
 218	mdelay(10);
 219
 220	val = ath11k_pcic_read32(ab, WLAON_WARM_SW_ENTRY);
 221	ath11k_dbg(ab, ATH11K_DBG_PCI, "WLAON_WARM_SW_ENTRY 0x%x\n", val);
 222
 223	/* A read clear register. clear the register to prevent
 224	 * Q6 from entering wrong code path.
 225	 */
 226	val = ath11k_pcic_read32(ab, WLAON_SOC_RESET_CAUSE_REG);
 227	ath11k_dbg(ab, ATH11K_DBG_PCI, "soc reset cause:%d\n", val);
 228}
 229
 230static int ath11k_pci_set_link_reg(struct ath11k_base *ab,
 231				   u32 offset, u32 value, u32 mask)
 232{
 233	u32 v;
 234	int i;
 235
 236	v = ath11k_pcic_read32(ab, offset);
 237	if ((v & mask) == value)
 238		return 0;
 239
 240	for (i = 0; i < 10; i++) {
 241		ath11k_pcic_write32(ab, offset, (v & ~mask) | value);
 242
 243		v = ath11k_pcic_read32(ab, offset);
 244		if ((v & mask) == value)
 245			return 0;
 246
 247		mdelay(2);
 248	}
 249
 250	ath11k_warn(ab, "failed to set pcie link register 0x%08x: 0x%08x != 0x%08x\n",
 251		    offset, v & mask, value);
 252
 253	return -ETIMEDOUT;
 254}
 255
 256static int ath11k_pci_fix_l1ss(struct ath11k_base *ab)
 257{
 258	int ret;
 259
 260	ret = ath11k_pci_set_link_reg(ab,
 261				      PCIE_QSERDES_COM_SYSCLK_EN_SEL_REG(ab),
 262				      PCIE_QSERDES_COM_SYSCLK_EN_SEL_VAL,
 263				      PCIE_QSERDES_COM_SYSCLK_EN_SEL_MSK);
 264	if (ret) {
 265		ath11k_warn(ab, "failed to set sysclk: %d\n", ret);
 266		return ret;
 267	}
 268
 269	ret = ath11k_pci_set_link_reg(ab,
 270				      PCIE_PCS_OSC_DTCT_CONFIG1_REG(ab),
 271				      PCIE_PCS_OSC_DTCT_CONFIG1_VAL,
 272				      PCIE_PCS_OSC_DTCT_CONFIG_MSK);
 273	if (ret) {
 274		ath11k_warn(ab, "failed to set dtct config1 error: %d\n", ret);
 275		return ret;
 276	}
 277
 278	ret = ath11k_pci_set_link_reg(ab,
 279				      PCIE_PCS_OSC_DTCT_CONFIG2_REG(ab),
 280				      PCIE_PCS_OSC_DTCT_CONFIG2_VAL,
 281				      PCIE_PCS_OSC_DTCT_CONFIG_MSK);
 282	if (ret) {
 283		ath11k_warn(ab, "failed to set dtct config2: %d\n", ret);
 284		return ret;
 285	}
 286
 287	ret = ath11k_pci_set_link_reg(ab,
 288				      PCIE_PCS_OSC_DTCT_CONFIG4_REG(ab),
 289				      PCIE_PCS_OSC_DTCT_CONFIG4_VAL,
 290				      PCIE_PCS_OSC_DTCT_CONFIG_MSK);
 291	if (ret) {
 292		ath11k_warn(ab, "failed to set dtct config4: %d\n", ret);
 293		return ret;
 294	}
 295
 296	return 0;
 297}
 298
 299static void ath11k_pci_enable_ltssm(struct ath11k_base *ab)
 300{
 301	u32 val;
 302	int i;
 303
 304	val = ath11k_pcic_read32(ab, PCIE_PCIE_PARF_LTSSM);
 305
 306	/* PCIE link seems very unstable after the Hot Reset*/
 307	for (i = 0; val != PARM_LTSSM_VALUE && i < 5; i++) {
 308		if (val == 0xffffffff)
 309			mdelay(5);
 310
 311		ath11k_pcic_write32(ab, PCIE_PCIE_PARF_LTSSM, PARM_LTSSM_VALUE);
 312		val = ath11k_pcic_read32(ab, PCIE_PCIE_PARF_LTSSM);
 313	}
 314
 315	ath11k_dbg(ab, ATH11K_DBG_PCI, "pci ltssm 0x%x\n", val);
 316
 317	val = ath11k_pcic_read32(ab, GCC_GCC_PCIE_HOT_RST);
 318	val |= GCC_GCC_PCIE_HOT_RST_VAL;
 319	ath11k_pcic_write32(ab, GCC_GCC_PCIE_HOT_RST, val);
 320	val = ath11k_pcic_read32(ab, GCC_GCC_PCIE_HOT_RST);
 321
 322	ath11k_dbg(ab, ATH11K_DBG_PCI, "pci pcie_hot_rst 0x%x\n", val);
 323
 324	mdelay(5);
 325}
 326
 327static void ath11k_pci_clear_all_intrs(struct ath11k_base *ab)
 328{
 329	/* This is a WAR for PCIE Hotreset.
 330	 * When target receive Hotreset, but will set the interrupt.
 331	 * So when download SBL again, SBL will open Interrupt and
 332	 * receive it, and crash immediately.
 333	 */
 334	ath11k_pcic_write32(ab, PCIE_PCIE_INT_ALL_CLEAR, PCIE_INT_CLEAR_ALL);
 335}
 336
 337static void ath11k_pci_set_wlaon_pwr_ctrl(struct ath11k_base *ab)
 338{
 339	u32 val;
 340
 341	val = ath11k_pcic_read32(ab, WLAON_QFPROM_PWR_CTRL_REG);
 342	val &= ~QFPROM_PWR_CTRL_VDD4BLOW_MASK;
 343	ath11k_pcic_write32(ab, WLAON_QFPROM_PWR_CTRL_REG, val);
 344}
 345
 346static void ath11k_pci_force_wake(struct ath11k_base *ab)
 347{
 348	ath11k_pcic_write32(ab, PCIE_SOC_WAKE_PCIE_LOCAL_REG, 1);
 349	mdelay(5);
 350}
 351
 352static void ath11k_pci_sw_reset(struct ath11k_base *ab, bool power_on)
 353{
 354	mdelay(100);
 355
 356	if (power_on) {
 357		ath11k_pci_enable_ltssm(ab);
 358		ath11k_pci_clear_all_intrs(ab);
 359		ath11k_pci_set_wlaon_pwr_ctrl(ab);
 360		if (ab->hw_params.fix_l1ss)
 361			ath11k_pci_fix_l1ss(ab);
 362	}
 363
 364	ath11k_mhi_clear_vector(ab);
 365	ath11k_pci_clear_dbg_registers(ab);
 366	ath11k_pci_soc_global_reset(ab);
 367	ath11k_mhi_set_mhictrl_reset(ab);
 368}
 369
 370static void ath11k_pci_init_qmi_ce_config(struct ath11k_base *ab)
 371{
 372	struct ath11k_qmi_ce_cfg *cfg = &ab->qmi.ce_cfg;
 373
 374	cfg->tgt_ce = ab->hw_params.target_ce_config;
 375	cfg->tgt_ce_len = ab->hw_params.target_ce_count;
 376
 377	cfg->svc_to_ce_map = ab->hw_params.svc_to_ce_map;
 378	cfg->svc_to_ce_map_len = ab->hw_params.svc_to_ce_map_len;
 379	ab->qmi.service_ins_id = ab->hw_params.qmi_service_ins_id;
 380
 381	ath11k_ce_get_shadow_config(ab, &cfg->shadow_reg_v2,
 382				    &cfg->shadow_reg_v2_len);
 383}
 384
 385static void ath11k_pci_msi_config(struct ath11k_pci *ab_pci, bool enable)
 386{
 387	struct pci_dev *dev = ab_pci->pdev;
 388	u16 control;
 389
 390	pci_read_config_word(dev, dev->msi_cap + PCI_MSI_FLAGS, &control);
 391
 392	if (enable)
 393		control |= PCI_MSI_FLAGS_ENABLE;
 394	else
 395		control &= ~PCI_MSI_FLAGS_ENABLE;
 396
 397	pci_write_config_word(dev, dev->msi_cap + PCI_MSI_FLAGS, control);
 398}
 399
 400static void ath11k_pci_msi_enable(struct ath11k_pci *ab_pci)
 401{
 402	ath11k_pci_msi_config(ab_pci, true);
 403}
 404
 405static void ath11k_pci_msi_disable(struct ath11k_pci *ab_pci)
 406{
 407	ath11k_pci_msi_config(ab_pci, false);
 408}
 409
 410static int ath11k_pci_alloc_msi(struct ath11k_pci *ab_pci)
 411{
 412	struct ath11k_base *ab = ab_pci->ab;
 413	const struct ath11k_msi_config *msi_config = ab->pci.msi.config;
 414	struct pci_dev *pci_dev = ab_pci->pdev;
 415	struct msi_desc *msi_desc;
 416	int num_vectors;
 417	int ret;
 418
 419	num_vectors = pci_alloc_irq_vectors(pci_dev,
 420					    msi_config->total_vectors,
 421					    msi_config->total_vectors,
 422					    PCI_IRQ_MSI);
 423	if (num_vectors == msi_config->total_vectors) {
 424		set_bit(ATH11K_FLAG_MULTI_MSI_VECTORS, &ab->dev_flags);
 425	} else {
 426		num_vectors = pci_alloc_irq_vectors(ab_pci->pdev,
 427						    1,
 428						    1,
 429						    PCI_IRQ_MSI);
 430		if (num_vectors < 0) {
 431			ret = -EINVAL;
 432			goto reset_msi_config;
 433		}
 434		clear_bit(ATH11K_FLAG_MULTI_MSI_VECTORS, &ab->dev_flags);
 435		ab->pci.msi.config = &msi_config_one_msi;
 436		ath11k_dbg(ab, ATH11K_DBG_PCI, "request MSI one vector\n");
 437	}
 438	ath11k_info(ab, "MSI vectors: %d\n", num_vectors);
 439
 440	ath11k_pci_msi_disable(ab_pci);
 441
 442	msi_desc = irq_get_msi_desc(ab_pci->pdev->irq);
 443	if (!msi_desc) {
 444		ath11k_err(ab, "msi_desc is NULL!\n");
 445		ret = -EINVAL;
 446		goto free_msi_vector;
 447	}
 448
 449	ab->pci.msi.ep_base_data = msi_desc->msg.data;
 450
 451	pci_read_config_dword(pci_dev, pci_dev->msi_cap + PCI_MSI_ADDRESS_LO,
 452			      &ab->pci.msi.addr_lo);
 453
 454	if (msi_desc->pci.msi_attrib.is_64) {
 455		pci_read_config_dword(pci_dev, pci_dev->msi_cap + PCI_MSI_ADDRESS_HI,
 456				      &ab->pci.msi.addr_hi);
 457	} else {
 458		ab->pci.msi.addr_hi = 0;
 459	}
 460
 461	ath11k_dbg(ab, ATH11K_DBG_PCI, "msi base data is %d\n", ab->pci.msi.ep_base_data);
 462
 463	return 0;
 464
 465free_msi_vector:
 466	pci_free_irq_vectors(ab_pci->pdev);
 467
 468reset_msi_config:
 469	return ret;
 470}
 471
 472static void ath11k_pci_free_msi(struct ath11k_pci *ab_pci)
 473{
 474	pci_free_irq_vectors(ab_pci->pdev);
 475}
 476
 477static int ath11k_pci_config_msi_data(struct ath11k_pci *ab_pci)
 478{
 479	struct msi_desc *msi_desc;
 480
 481	msi_desc = irq_get_msi_desc(ab_pci->pdev->irq);
 482	if (!msi_desc) {
 483		ath11k_err(ab_pci->ab, "msi_desc is NULL!\n");
 484		pci_free_irq_vectors(ab_pci->pdev);
 485		return -EINVAL;
 486	}
 487
 488	ab_pci->ab->pci.msi.ep_base_data = msi_desc->msg.data;
 489
 490	ath11k_dbg(ab_pci->ab, ATH11K_DBG_PCI, "pci after request_irq msi_ep_base_data %d\n",
 491		   ab_pci->ab->pci.msi.ep_base_data);
 492
 493	return 0;
 494}
 495
 496static int ath11k_pci_claim(struct ath11k_pci *ab_pci, struct pci_dev *pdev)
 497{
 498	struct ath11k_base *ab = ab_pci->ab;
 499	u16 device_id;
 500	int ret = 0;
 501
 502	pci_read_config_word(pdev, PCI_DEVICE_ID, &device_id);
 503	if (device_id != ab_pci->dev_id)  {
 504		ath11k_err(ab, "pci device id mismatch: 0x%x 0x%x\n",
 505			   device_id, ab_pci->dev_id);
 506		ret = -EIO;
 507		goto out;
 508	}
 509
 510	ret = pci_assign_resource(pdev, ATH11K_PCI_BAR_NUM);
 511	if (ret) {
 512		ath11k_err(ab, "failed to assign pci resource: %d\n", ret);
 513		goto out;
 514	}
 515
 516	ret = pci_enable_device(pdev);
 517	if (ret) {
 518		ath11k_err(ab, "failed to enable pci device: %d\n", ret);
 519		goto out;
 520	}
 521
 522	ret = pci_request_region(pdev, ATH11K_PCI_BAR_NUM, "ath11k_pci");
 523	if (ret) {
 524		ath11k_err(ab, "failed to request pci region: %d\n", ret);
 525		goto disable_device;
 526	}
 527
 528	ret = dma_set_mask_and_coherent(&pdev->dev,
 529					DMA_BIT_MASK(ATH11K_PCI_DMA_MASK));
 530	if (ret) {
 531		ath11k_err(ab, "failed to set pci dma mask to %d: %d\n",
 532			   ATH11K_PCI_DMA_MASK, ret);
 533		goto release_region;
 534	}
 535
 536	pci_set_master(pdev);
 537
 538	ab->mem_len = pci_resource_len(pdev, ATH11K_PCI_BAR_NUM);
 539	ab->mem = pci_iomap(pdev, ATH11K_PCI_BAR_NUM, 0);
 540	if (!ab->mem) {
 541		ath11k_err(ab, "failed to map pci bar %d\n", ATH11K_PCI_BAR_NUM);
 542		ret = -EIO;
 543		goto clear_master;
 544	}
 545
 546	ath11k_dbg(ab, ATH11K_DBG_BOOT, "boot pci_mem 0x%pK\n", ab->mem);
 
 
 547	return 0;
 548
 549clear_master:
 550	pci_clear_master(pdev);
 551release_region:
 552	pci_release_region(pdev, ATH11K_PCI_BAR_NUM);
 553disable_device:
 554	pci_disable_device(pdev);
 555out:
 556	return ret;
 557}
 558
 559static void ath11k_pci_free_region(struct ath11k_pci *ab_pci)
 560{
 561	struct ath11k_base *ab = ab_pci->ab;
 562	struct pci_dev *pci_dev = ab_pci->pdev;
 563
 564	pci_iounmap(pci_dev, ab->mem);
 565	ab->mem = NULL;
 566	pci_clear_master(pci_dev);
 567	pci_release_region(pci_dev, ATH11K_PCI_BAR_NUM);
 568	if (pci_is_enabled(pci_dev))
 569		pci_disable_device(pci_dev);
 570}
 571
 572static void ath11k_pci_aspm_disable(struct ath11k_pci *ab_pci)
 573{
 574	struct ath11k_base *ab = ab_pci->ab;
 575
 576	pcie_capability_read_word(ab_pci->pdev, PCI_EXP_LNKCTL,
 577				  &ab_pci->link_ctl);
 578
 579	ath11k_dbg(ab, ATH11K_DBG_PCI, "pci link_ctl 0x%04x L0s %d L1 %d\n",
 580		   ab_pci->link_ctl,
 581		   u16_get_bits(ab_pci->link_ctl, PCI_EXP_LNKCTL_ASPM_L0S),
 582		   u16_get_bits(ab_pci->link_ctl, PCI_EXP_LNKCTL_ASPM_L1));
 583
 584	/* disable L0s and L1 */
 585	pcie_capability_write_word(ab_pci->pdev, PCI_EXP_LNKCTL,
 586				   ab_pci->link_ctl & ~PCI_EXP_LNKCTL_ASPMC);
 587
 588	set_bit(ATH11K_PCI_ASPM_RESTORE, &ab_pci->flags);
 589}
 590
 591static void ath11k_pci_aspm_restore(struct ath11k_pci *ab_pci)
 592{
 593	if (test_and_clear_bit(ATH11K_PCI_ASPM_RESTORE, &ab_pci->flags))
 594		pcie_capability_write_word(ab_pci->pdev, PCI_EXP_LNKCTL,
 595					   ab_pci->link_ctl);
 
 
 596}
 597
 598static int ath11k_pci_power_up(struct ath11k_base *ab)
 599{
 600	struct ath11k_pci *ab_pci = ath11k_pci_priv(ab);
 601	int ret;
 602
 603	ab_pci->register_window = 0;
 604	clear_bit(ATH11K_FLAG_DEVICE_INIT_DONE, &ab->dev_flags);
 605	ath11k_pci_sw_reset(ab_pci->ab, true);
 606
 607	/* Disable ASPM during firmware download due to problems switching
 608	 * to AMSS state.
 609	 */
 610	ath11k_pci_aspm_disable(ab_pci);
 611
 612	ath11k_pci_msi_enable(ab_pci);
 613
 614	ret = ath11k_mhi_start(ab_pci);
 615	if (ret) {
 616		ath11k_err(ab, "failed to start mhi: %d\n", ret);
 617		return ret;
 618	}
 619
 620	if (ab->hw_params.static_window_map)
 621		ath11k_pci_select_static_window(ab_pci);
 622
 623	return 0;
 624}
 625
 626static void ath11k_pci_power_down(struct ath11k_base *ab)
 627{
 628	struct ath11k_pci *ab_pci = ath11k_pci_priv(ab);
 629
 630	/* restore aspm in case firmware bootup fails */
 631	ath11k_pci_aspm_restore(ab_pci);
 632
 633	ath11k_pci_force_wake(ab_pci->ab);
 634
 635	ath11k_pci_msi_disable(ab_pci);
 636
 637	ath11k_mhi_stop(ab_pci);
 638	clear_bit(ATH11K_FLAG_DEVICE_INIT_DONE, &ab->dev_flags);
 639	ath11k_pci_sw_reset(ab_pci->ab, false);
 640}
 641
 642static int ath11k_pci_hif_suspend(struct ath11k_base *ab)
 643{
 644	struct ath11k_pci *ar_pci = ath11k_pci_priv(ab);
 645
 646	return ath11k_mhi_suspend(ar_pci);
 647}
 648
 649static int ath11k_pci_hif_resume(struct ath11k_base *ab)
 650{
 651	struct ath11k_pci *ar_pci = ath11k_pci_priv(ab);
 652
 653	return ath11k_mhi_resume(ar_pci);
 654}
 655
 656static void ath11k_pci_hif_ce_irq_enable(struct ath11k_base *ab)
 657{
 658	ath11k_pcic_ce_irqs_enable(ab);
 659}
 660
 661static void ath11k_pci_hif_ce_irq_disable(struct ath11k_base *ab)
 662{
 663	ath11k_pcic_ce_irq_disable_sync(ab);
 664}
 665
 666static int ath11k_pci_start(struct ath11k_base *ab)
 667{
 668	struct ath11k_pci *ab_pci = ath11k_pci_priv(ab);
 669
 670	/* TODO: for now don't restore ASPM in case of single MSI
 671	 * vector as MHI register reading in M2 causes system hang.
 672	 */
 673	if (test_bit(ATH11K_FLAG_MULTI_MSI_VECTORS, &ab->dev_flags))
 674		ath11k_pci_aspm_restore(ab_pci);
 675	else
 676		ath11k_info(ab, "leaving PCI ASPM disabled to avoid MHI M2 problems\n");
 677
 678	ath11k_pcic_start(ab);
 679
 680	return 0;
 681}
 682
 683static const struct ath11k_hif_ops ath11k_pci_hif_ops = {
 684	.start = ath11k_pci_start,
 685	.stop = ath11k_pcic_stop,
 686	.read32 = ath11k_pcic_read32,
 687	.write32 = ath11k_pcic_write32,
 688	.read = ath11k_pcic_read,
 689	.power_down = ath11k_pci_power_down,
 690	.power_up = ath11k_pci_power_up,
 691	.suspend = ath11k_pci_hif_suspend,
 692	.resume = ath11k_pci_hif_resume,
 693	.irq_enable = ath11k_pcic_ext_irq_enable,
 694	.irq_disable = ath11k_pcic_ext_irq_disable,
 695	.get_msi_address =  ath11k_pcic_get_msi_address,
 696	.get_user_msi_vector = ath11k_pcic_get_user_msi_assignment,
 697	.map_service_to_pipe = ath11k_pcic_map_service_to_pipe,
 698	.ce_irq_enable = ath11k_pci_hif_ce_irq_enable,
 699	.ce_irq_disable = ath11k_pci_hif_ce_irq_disable,
 700	.get_ce_msi_idx = ath11k_pcic_get_ce_msi_idx,
 701};
 702
 703static void ath11k_pci_read_hw_version(struct ath11k_base *ab, u32 *major, u32 *minor)
 704{
 705	u32 soc_hw_version;
 706
 707	soc_hw_version = ath11k_pcic_read32(ab, TCSR_SOC_HW_VERSION);
 708	*major = FIELD_GET(TCSR_SOC_HW_VERSION_MAJOR_MASK,
 709			   soc_hw_version);
 710	*minor = FIELD_GET(TCSR_SOC_HW_VERSION_MINOR_MASK,
 711			   soc_hw_version);
 712
 713	ath11k_dbg(ab, ATH11K_DBG_PCI, "pci tcsr_soc_hw_version major %d minor %d\n",
 714		   *major, *minor);
 715}
 716
 717static int ath11k_pci_set_irq_affinity_hint(struct ath11k_pci *ab_pci,
 718					    const struct cpumask *m)
 719{
 720	if (test_bit(ATH11K_FLAG_MULTI_MSI_VECTORS, &ab_pci->ab->dev_flags))
 721		return 0;
 722
 723	return irq_set_affinity_hint(ab_pci->pdev->irq, m);
 724}
 725
 726static int ath11k_pci_probe(struct pci_dev *pdev,
 727			    const struct pci_device_id *pci_dev)
 728{
 729	struct ath11k_base *ab;
 730	struct ath11k_pci *ab_pci;
 731	u32 soc_hw_version_major, soc_hw_version_minor, addr;
 732	const struct ath11k_pci_ops *pci_ops;
 733	int ret;
 734
 735	ab = ath11k_core_alloc(&pdev->dev, sizeof(*ab_pci), ATH11K_BUS_PCI);
 736
 737	if (!ab) {
 738		dev_err(&pdev->dev, "failed to allocate ath11k base\n");
 739		return -ENOMEM;
 740	}
 741
 742	ab->dev = &pdev->dev;
 743	pci_set_drvdata(pdev, ab);
 744	ab_pci = ath11k_pci_priv(ab);
 745	ab_pci->dev_id = pci_dev->device;
 746	ab_pci->ab = ab;
 747	ab_pci->pdev = pdev;
 748	ab->hif.ops = &ath11k_pci_hif_ops;
 
 749	pci_set_drvdata(pdev, ab);
 750	spin_lock_init(&ab_pci->window_lock);
 751
 752	/* Set fixed_mem_region to true for platforms support reserved memory
 753	 * from DT. If memory is reserved from DT for FW, ath11k driver need not
 754	 * allocate memory.
 755	 */
 756	ret = of_property_read_u32(ab->dev->of_node, "memory-region", &addr);
 757	if (!ret)
 758		set_bit(ATH11K_FLAG_FIXED_MEM_RGN, &ab->dev_flags);
 759
 760	ret = ath11k_pci_claim(ab_pci, pdev);
 761	if (ret) {
 762		ath11k_err(ab, "failed to claim device: %d\n", ret);
 763		goto err_free_core;
 764	}
 765
 766	ath11k_dbg(ab, ATH11K_DBG_BOOT, "pci probe %04x:%04x %04x:%04x\n",
 767		   pdev->vendor, pdev->device,
 768		   pdev->subsystem_vendor, pdev->subsystem_device);
 769
 770	ab->id.vendor = pdev->vendor;
 771	ab->id.device = pdev->device;
 772	ab->id.subsystem_vendor = pdev->subsystem_vendor;
 773	ab->id.subsystem_device = pdev->subsystem_device;
 774
 775	switch (pci_dev->device) {
 776	case QCA6390_DEVICE_ID:
 777		ath11k_pci_read_hw_version(ab, &soc_hw_version_major,
 778					   &soc_hw_version_minor);
 779		switch (soc_hw_version_major) {
 780		case 2:
 781			ab->hw_rev = ATH11K_HW_QCA6390_HW20;
 782			break;
 783		default:
 784			dev_err(&pdev->dev, "Unsupported QCA6390 SOC hardware version: %d %d\n",
 785				soc_hw_version_major, soc_hw_version_minor);
 786			ret = -EOPNOTSUPP;
 787			goto err_pci_free_region;
 788		}
 789
 790		pci_ops = &ath11k_pci_ops_qca6390;
 791		break;
 792	case QCN9074_DEVICE_ID:
 793		pci_ops = &ath11k_pci_ops_qcn9074;
 794		ab->hw_rev = ATH11K_HW_QCN9074_HW10;
 795		break;
 796	case WCN6855_DEVICE_ID:
 797		ab->id.bdf_search = ATH11K_BDF_SEARCH_BUS_AND_BOARD;
 798		ath11k_pci_read_hw_version(ab, &soc_hw_version_major,
 799					   &soc_hw_version_minor);
 800		switch (soc_hw_version_major) {
 801		case 2:
 802			switch (soc_hw_version_minor) {
 803			case 0x00:
 804			case 0x01:
 805				ab->hw_rev = ATH11K_HW_WCN6855_HW20;
 806				break;
 807			case 0x10:
 808			case 0x11:
 809				ab->hw_rev = ATH11K_HW_WCN6855_HW21;
 810				break;
 811			default:
 812				goto unsupported_wcn6855_soc;
 813			}
 814			break;
 815		default:
 816unsupported_wcn6855_soc:
 817			dev_err(&pdev->dev, "Unsupported WCN6855 SOC hardware version: %d %d\n",
 818				soc_hw_version_major, soc_hw_version_minor);
 819			ret = -EOPNOTSUPP;
 820			goto err_pci_free_region;
 821		}
 822
 823		pci_ops = &ath11k_pci_ops_qca6390;
 824		break;
 825	default:
 826		dev_err(&pdev->dev, "Unknown PCI device found: 0x%x\n",
 827			pci_dev->device);
 828		ret = -EOPNOTSUPP;
 829		goto err_pci_free_region;
 830	}
 831
 832	ret = ath11k_pcic_register_pci_ops(ab, pci_ops);
 833	if (ret) {
 834		ath11k_err(ab, "failed to register PCI ops: %d\n", ret);
 835		goto err_pci_free_region;
 836	}
 837
 838	ret = ath11k_pcic_init_msi_config(ab);
 839	if (ret) {
 840		ath11k_err(ab, "failed to init msi config: %d\n", ret);
 841		goto err_pci_free_region;
 842	}
 843
 844	ret = ath11k_pci_alloc_msi(ab_pci);
 845	if (ret) {
 846		ath11k_err(ab, "failed to enable msi: %d\n", ret);
 847		goto err_pci_free_region;
 848	}
 849
 850	ret = ath11k_core_pre_init(ab);
 851	if (ret)
 852		goto err_pci_disable_msi;
 853
 
 
 
 
 
 
 854	ret = ath11k_mhi_register(ab_pci);
 855	if (ret) {
 856		ath11k_err(ab, "failed to register mhi: %d\n", ret);
 857		goto err_pci_disable_msi;
 858	}
 859
 860	ret = ath11k_hal_srng_init(ab);
 861	if (ret)
 862		goto err_mhi_unregister;
 863
 864	ret = ath11k_ce_alloc_pipes(ab);
 865	if (ret) {
 866		ath11k_err(ab, "failed to allocate ce pipes: %d\n", ret);
 867		goto err_hal_srng_deinit;
 868	}
 869
 870	ath11k_pci_init_qmi_ce_config(ab);
 871
 872	ret = ath11k_pcic_config_irq(ab);
 873	if (ret) {
 874		ath11k_err(ab, "failed to config irq: %d\n", ret);
 875		goto err_ce_free;
 876	}
 877
 878	ret = ath11k_pci_set_irq_affinity_hint(ab_pci, cpumask_of(0));
 879	if (ret) {
 880		ath11k_err(ab, "failed to set irq affinity %d\n", ret);
 881		goto err_free_irq;
 882	}
 883
 884	/* kernel may allocate a dummy vector before request_irq and
 885	 * then allocate a real vector when request_irq is called.
 886	 * So get msi_data here again to avoid spurious interrupt
 887	 * as msi_data will configured to srngs.
 888	 */
 889	ret = ath11k_pci_config_msi_data(ab_pci);
 890	if (ret) {
 891		ath11k_err(ab, "failed to config msi_data: %d\n", ret);
 892		goto err_irq_affinity_cleanup;
 893	}
 894
 895	ret = ath11k_core_init(ab);
 896	if (ret) {
 897		ath11k_err(ab, "failed to init core: %d\n", ret);
 898		goto err_irq_affinity_cleanup;
 899	}
 
 900	return 0;
 901
 902err_irq_affinity_cleanup:
 903	ath11k_pci_set_irq_affinity_hint(ab_pci, NULL);
 904
 905err_free_irq:
 906	ath11k_pcic_free_irq(ab);
 907
 908err_ce_free:
 909	ath11k_ce_free_pipes(ab);
 910
 911err_hal_srng_deinit:
 912	ath11k_hal_srng_deinit(ab);
 913
 914err_mhi_unregister:
 915	ath11k_mhi_unregister(ab_pci);
 916
 
 
 
 917err_pci_disable_msi:
 918	ath11k_pci_free_msi(ab_pci);
 919
 920err_pci_free_region:
 921	ath11k_pci_free_region(ab_pci);
 922
 923err_free_core:
 924	ath11k_core_free(ab);
 925
 926	return ret;
 927}
 928
 929static void ath11k_pci_remove(struct pci_dev *pdev)
 930{
 931	struct ath11k_base *ab = pci_get_drvdata(pdev);
 932	struct ath11k_pci *ab_pci = ath11k_pci_priv(ab);
 933
 934	ath11k_pci_set_irq_affinity_hint(ab_pci, NULL);
 935
 936	if (test_bit(ATH11K_FLAG_QMI_FAIL, &ab->dev_flags)) {
 937		ath11k_pci_power_down(ab);
 938		ath11k_debugfs_soc_destroy(ab);
 939		ath11k_qmi_deinit_service(ab);
 940		goto qmi_fail;
 941	}
 942
 943	set_bit(ATH11K_FLAG_UNREGISTERING, &ab->dev_flags);
 944
 945	ath11k_core_deinit(ab);
 946
 947qmi_fail:
 948	ath11k_mhi_unregister(ab_pci);
 949
 950	ath11k_pcic_free_irq(ab);
 951	ath11k_pci_free_msi(ab_pci);
 952	ath11k_pci_free_region(ab_pci);
 953
 954	ath11k_hal_srng_deinit(ab);
 955	ath11k_ce_free_pipes(ab);
 956	ath11k_core_free(ab);
 957}
 958
 959static void ath11k_pci_shutdown(struct pci_dev *pdev)
 960{
 961	struct ath11k_base *ab = pci_get_drvdata(pdev);
 962	struct ath11k_pci *ab_pci = ath11k_pci_priv(ab);
 963
 964	ath11k_pci_set_irq_affinity_hint(ab_pci, NULL);
 965	ath11k_pci_power_down(ab);
 966}
 967
 968static __maybe_unused int ath11k_pci_pm_suspend(struct device *dev)
 969{
 970	struct ath11k_base *ab = dev_get_drvdata(dev);
 971	int ret;
 972
 973	if (test_bit(ATH11K_FLAG_QMI_FAIL, &ab->dev_flags)) {
 974		ath11k_dbg(ab, ATH11K_DBG_BOOT, "boot skipping pci suspend as qmi is not initialised\n");
 975		return 0;
 976	}
 977
 978	ret = ath11k_core_suspend(ab);
 979	if (ret)
 980		ath11k_warn(ab, "failed to suspend core: %d\n", ret);
 981
 982	return ret;
 983}
 984
 985static __maybe_unused int ath11k_pci_pm_resume(struct device *dev)
 986{
 987	struct ath11k_base *ab = dev_get_drvdata(dev);
 988	int ret;
 989
 990	if (test_bit(ATH11K_FLAG_QMI_FAIL, &ab->dev_flags)) {
 991		ath11k_dbg(ab, ATH11K_DBG_BOOT, "boot skipping pci resume as qmi is not initialised\n");
 992		return 0;
 993	}
 994
 995	ret = ath11k_core_resume(ab);
 996	if (ret)
 997		ath11k_warn(ab, "failed to resume core: %d\n", ret);
 998
 999	return ret;
1000}
1001
1002static SIMPLE_DEV_PM_OPS(ath11k_pci_pm_ops,
1003			 ath11k_pci_pm_suspend,
1004			 ath11k_pci_pm_resume);
1005
1006static struct pci_driver ath11k_pci_driver = {
1007	.name = "ath11k_pci",
1008	.id_table = ath11k_pci_id_table,
1009	.probe = ath11k_pci_probe,
1010	.remove = ath11k_pci_remove,
1011	.shutdown = ath11k_pci_shutdown,
1012#ifdef CONFIG_PM
1013	.driver.pm = &ath11k_pci_pm_ops,
1014#endif
1015};
1016
1017static int ath11k_pci_init(void)
1018{
1019	int ret;
1020
1021	ret = pci_register_driver(&ath11k_pci_driver);
1022	if (ret)
1023		pr_err("failed to register ath11k pci driver: %d\n",
1024		       ret);
1025
1026	return ret;
1027}
1028module_init(ath11k_pci_init);
1029
1030static void ath11k_pci_exit(void)
1031{
1032	pci_unregister_driver(&ath11k_pci_driver);
1033}
1034
1035module_exit(ath11k_pci_exit);
1036
1037MODULE_DESCRIPTION("Driver support for Qualcomm Technologies 802.11ax WLAN PCIe devices");
1038MODULE_LICENSE("Dual BSD/GPL");
1039
1040/* QCA639x 2.0 firmware files */
1041MODULE_FIRMWARE(ATH11K_FW_DIR "/QCA6390/hw2.0/" ATH11K_BOARD_API2_FILE);
1042MODULE_FIRMWARE(ATH11K_FW_DIR "/QCA6390/hw2.0/" ATH11K_AMSS_FILE);
1043MODULE_FIRMWARE(ATH11K_FW_DIR "/QCA6390/hw2.0/" ATH11K_M3_FILE);